o
    ɶdl                     @   s8   d dl mZmZmZ d dlmZ eG dd deZdS )    )formatted_flat_dictNONE_SENTINEL#value_allowed_none_or_none_sentinel)init_model_state_from_kwargsc                   @   sR  e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdd Zedd Zejdd Zedd Zejdd Zedd Zejdd Zedd Zejdd Zedd Zejdd Zed d! Zejd"d! Zed#d$ Zejd%d$ Zed&d' Zejd(d' Zed)d* Zejd+d* Zed,d- Zejd.d- Zed/d0 Zejd1d0 Zed2d3 Zejd4d3 Zed5d6 Z e jd7d6 Z ed8d9 Z!e!jd:d9 Z!ed;d< Z"e"jd=d< Z"ed>d? Z#e#jd@d? Z#edAdB Z$e$jdCdB Z$edDdE Z%e%jdFdE Z%edGdH Z&e&jdIdH Z&dJdK Z'dLdM Z(dNdO Z)dPS )QAuthenticationProviderz3
    Settings for the Authentication Provider.
    CLIENT_CREDENTIALSAUTHORIZATION_CODEGENERICOAMGOOGLE	MICROSOFTCREATINGUPDATINGACTIVEINACTIVEDELETINGDELETEDFAILEDc                 K   sb  i ddddddddddddddd	dd
dddddddddddddddddddd| _ i ddddddddddddddd	dd
ddddd dd!dd"dd#dd$dd%dd&d'd(d| _d)| _d)| _d)| _d)| _d)| _d)| _d)| _d)| _	d)| _
d)| _d)| _d)| _d)| _d)| _d)| _d)| _d)| _d)| _d)| _d)S )*a  
        Initializes a new AuthenticationProvider object with values from keyword arguments.
        The following keyword arguments are supported (corresponding to the getters/setters of this class):

        :param id:
            The value to assign to the id property of this AuthenticationProvider.
        :type id: str

        :param grant_type:
            The value to assign to the grant_type property of this AuthenticationProvider.
            Allowed values for this property are: "CLIENT_CREDENTIALS", "AUTHORIZATION_CODE", 'UNKNOWN_ENUM_VALUE'.
            Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
        :type grant_type: str

        :param identity_provider:
            The value to assign to the identity_provider property of this AuthenticationProvider.
            Allowed values for this property are: "GENERIC", "OAM", "GOOGLE", "MICROSOFT", 'UNKNOWN_ENUM_VALUE'.
            Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
        :type identity_provider: str

        :param name:
            The value to assign to the name property of this AuthenticationProvider.
        :type name: str

        :param token_endpoint_url:
            The value to assign to the token_endpoint_url property of this AuthenticationProvider.
        :type token_endpoint_url: str

        :param authorization_endpoint_url:
            The value to assign to the authorization_endpoint_url property of this AuthenticationProvider.
        :type authorization_endpoint_url: str

        :param short_authorization_code_request_url:
            The value to assign to the short_authorization_code_request_url property of this AuthenticationProvider.
        :type short_authorization_code_request_url: str

        :param revoke_token_endpoint_url:
            The value to assign to the revoke_token_endpoint_url property of this AuthenticationProvider.
        :type revoke_token_endpoint_url: str

        :param client_id:
            The value to assign to the client_id property of this AuthenticationProvider.
        :type client_id: str

        :param scopes:
            The value to assign to the scopes property of this AuthenticationProvider.
        :type scopes: str

        :param subject_claim:
            The value to assign to the subject_claim property of this AuthenticationProvider.
        :type subject_claim: str

        :param refresh_token_retention_period_in_days:
            The value to assign to the refresh_token_retention_period_in_days property of this AuthenticationProvider.
        :type refresh_token_retention_period_in_days: int

        :param redirect_url:
            The value to assign to the redirect_url property of this AuthenticationProvider.
        :type redirect_url: str

        :param is_visible:
            The value to assign to the is_visible property of this AuthenticationProvider.
        :type is_visible: bool

        :param lifecycle_state:
            The value to assign to the lifecycle_state property of this AuthenticationProvider.
            Allowed values for this property are: "CREATING", "UPDATING", "ACTIVE", "INACTIVE", "DELETING", "DELETED", "FAILED", 'UNKNOWN_ENUM_VALUE'.
            Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.
        :type lifecycle_state: str

        :param time_created:
            The value to assign to the time_created property of this AuthenticationProvider.
        :type time_created: datetime

        :param time_updated:
            The value to assign to the time_updated property of this AuthenticationProvider.
        :type time_updated: datetime

        :param freeform_tags:
            The value to assign to the freeform_tags property of this AuthenticationProvider.
        :type freeform_tags: dict(str, str)

        :param defined_tags:
            The value to assign to the defined_tags property of this AuthenticationProvider.
        :type defined_tags: dict(str, dict(str, object))

        idstr
grant_typeidentity_providernametoken_endpoint_urlauthorization_endpoint_url$short_authorization_code_request_urlrevoke_token_endpoint_url	client_idscopessubject_claim&refresh_token_retention_period_in_daysintredirect_url
is_visibleboollifecycle_statetime_createddatetimetime_updatedzdict(str, str)zdict(str, dict(str, object)))freeform_tagsdefined_tagsZ	grantTypeZidentityProviderZtokenEndpointUrlZauthorizationEndpointUrlZ shortAuthorizationCodeRequestUrlZrevokeTokenEndpointUrlZclientIdZsubjectClaimZ!refreshTokenRetentionPeriodInDaysZredirectUrlZ	isVisibleZlifecycleStateZtimeCreatedZtimeUpdatedZfreeformTagsZdefinedTagsN)Zswagger_typesZattribute_map_id_grant_type_identity_provider_name_token_endpoint_url_authorization_endpoint_url%_short_authorization_code_request_url_revoke_token_endpoint_url
_client_id_scopes_subject_claim'_refresh_token_retention_period_in_days_redirect_url_is_visible_lifecycle_state_time_created_time_updated_freeform_tags_defined_tags)selfkwargs r@   Jusr/lib/python3.10/site-packages/oci/oda/models/authentication_provider.py__init__F   s   X	

	


zAuthenticationProvider.__init__c                 C      | j S )z
        **[Required]** Gets the id of this AuthenticationProvider.
        Unique immutable identifier that was assigned when the Authentication Provider was created.


        :return: The id of this AuthenticationProvider.
        :rtype: str
        r+   r>   r@   r@   rA   r         
zAuthenticationProvider.idc                 C   
   || _ dS )z
        Sets the id of this AuthenticationProvider.
        Unique immutable identifier that was assigned when the Authentication Provider was created.


        :param id: The id of this AuthenticationProvider.
        :type: str
        NrD   )r>   r   r@   r@   rA   r         

c                 C   rC   )a  
        **[Required]** Gets the grant_type of this AuthenticationProvider.
        The grant type for the Authentication Provider.

        Allowed values for this property are: "CLIENT_CREDENTIALS", "AUTHORIZATION_CODE", 'UNKNOWN_ENUM_VALUE'.
        Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.


        :return: The grant_type of this AuthenticationProvider.
        :rtype: str
        )r,   rE   r@   r@   rA   r         z!AuthenticationProvider.grant_typec                 C   s    ddg}t ||sd}|| _dS )z
        Sets the grant_type of this AuthenticationProvider.
        The grant type for the Authentication Provider.


        :param grant_type: The grant_type of this AuthenticationProvider.
        :type: str
        r   r   UNKNOWN_ENUM_VALUEN)r   r,   )r>   r   allowed_valuesr@   r@   rA   r        


c                 C   rC   )a  
        **[Required]** Gets the identity_provider of this AuthenticationProvider.
        Which type of Identity Provider (IDP) you are using.

        Allowed values for this property are: "GENERIC", "OAM", "GOOGLE", "MICROSOFT", 'UNKNOWN_ENUM_VALUE'.
        Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.


        :return: The identity_provider of this AuthenticationProvider.
        :rtype: str
        )r-   rE   r@   r@   rA   r     rI   z(AuthenticationProvider.identity_providerc                 C       g d}t ||sd}|| _dS )z
        Sets the identity_provider of this AuthenticationProvider.
        Which type of Identity Provider (IDP) you are using.


        :param identity_provider: The identity_provider of this AuthenticationProvider.
        :type: str
        )r	   r
   r   r   rJ   N)r   r-   )r>   r   rK   r@   r@   rA   r   #  rL   c                 C   rC   )z
        **[Required]** Gets the name of this AuthenticationProvider.
        A name to identify the Authentication Provider.


        :return: The name of this AuthenticationProvider.
        :rtype: str
        r.   rE   r@   r@   rA   r   2  rF   zAuthenticationProvider.namec                 C   rG   )z
        Sets the name of this AuthenticationProvider.
        A name to identify the Authentication Provider.


        :param name: The name of this AuthenticationProvider.
        :type: str
        NrN   )r>   r   r@   r@   rA   r   >  rH   c                 C   rC   )z
        **[Required]** Gets the token_endpoint_url of this AuthenticationProvider.
        The IDPs URL for requesting access tokens.


        :return: The token_endpoint_url of this AuthenticationProvider.
        :rtype: str
        r/   rE   r@   r@   rA   r   J  rF   z)AuthenticationProvider.token_endpoint_urlc                 C   rG   )z
        Sets the token_endpoint_url of this AuthenticationProvider.
        The IDPs URL for requesting access tokens.


        :param token_endpoint_url: The token_endpoint_url of this AuthenticationProvider.
        :type: str
        NrO   )r>   r   r@   r@   rA   r   V  rH   c                 C   rC   )a"  
        Gets the authorization_endpoint_url of this AuthenticationProvider.
        The IDPs URL for the page that users authenticate with by entering the user name and password.


        :return: The authorization_endpoint_url of this AuthenticationProvider.
        :rtype: str
        r0   rE   r@   r@   rA   r   b  rF   z1AuthenticationProvider.authorization_endpoint_urlc                 C   rG   )a;  
        Sets the authorization_endpoint_url of this AuthenticationProvider.
        The IDPs URL for the page that users authenticate with by entering the user name and password.


        :param authorization_endpoint_url: The authorization_endpoint_url of this AuthenticationProvider.
        :type: str
        NrP   )r>   r   r@   r@   rA   r   n  rH   c                 C   rC   )a  
        Gets the short_authorization_code_request_url of this AuthenticationProvider.
        A shortened version of the authorization URL, which you can get from a URL shortener service (one that allows
        you to send query parameters).  You might need this because the generated authorization-code-request URL
        could be too long for SMS and older smart phones.


        :return: The short_authorization_code_request_url of this AuthenticationProvider.
        :rtype: str
        r1   rE   r@   r@   rA   r   z     z;AuthenticationProvider.short_authorization_code_request_urlc                 C   rG   )a  
        Sets the short_authorization_code_request_url of this AuthenticationProvider.
        A shortened version of the authorization URL, which you can get from a URL shortener service (one that allows
        you to send query parameters).  You might need this because the generated authorization-code-request URL
        could be too long for SMS and older smart phones.


        :param short_authorization_code_request_url: The short_authorization_code_request_url of this AuthenticationProvider.
        :type: str
        NrQ   )r>   r   r@   r@   rA   r        
c                 C   rC   )a  
        Gets the revoke_token_endpoint_url of this AuthenticationProvider.
        If you want to revoke all the refresh tokens and access tokens of the logged-in user from a dialog flow, then
        you need the IDP's revoke refresh token URL. If you provide this URL, then you can use the System.OAuth2ResetTokens
        component to revoke the user's tokens for this service.


        :return: The revoke_token_endpoint_url of this AuthenticationProvider.
        :rtype: str
        r2   rE   r@   r@   rA   r     rR   z0AuthenticationProvider.revoke_token_endpoint_urlc                 C   rG   )a  
        Sets the revoke_token_endpoint_url of this AuthenticationProvider.
        If you want to revoke all the refresh tokens and access tokens of the logged-in user from a dialog flow, then
        you need the IDP's revoke refresh token URL. If you provide this URL, then you can use the System.OAuth2ResetTokens
        component to revoke the user's tokens for this service.


        :param revoke_token_endpoint_url: The revoke_token_endpoint_url of this AuthenticationProvider.
        :type: str
        NrT   )r>   r   r@   r@   rA   r     rS   c                 C   rC   )ak  
        **[Required]** Gets the client_id of this AuthenticationProvider.
        The client ID for the IDP application (OAuth Client) that was registered as described in Identity Provider Registration.
        With Microsoft identity platform, use the application ID.


        :return: The client_id of this AuthenticationProvider.
        :rtype: str
        r3   rE   r@   r@   rA   r        z AuthenticationProvider.client_idc                 C   rG   )ad  
        Sets the client_id of this AuthenticationProvider.
        The client ID for the IDP application (OAuth Client) that was registered as described in Identity Provider Registration.
        With Microsoft identity platform, use the application ID.


        :param client_id: The client_id of this AuthenticationProvider.
        :type: str
        NrU   )r>   r   r@   r@   rA   r        
c                 C   rC   )u  
        **[Required]** Gets the scopes of this AuthenticationProvider.
        A space-separated list of the scopes that must be included when Digital Assistant requests an access token from
        the provider. Include all the scopes that are required to access the resources. If refresh tokens are enabled,
        include the scope that’s necessary to get the refresh token (typically offline_access).


        :return: The scopes of this AuthenticationProvider.
        :rtype: str
        r4   rE   r@   r@   rA   r     rR   zAuthenticationProvider.scopesc                 C   rG   )u  
        Sets the scopes of this AuthenticationProvider.
        A space-separated list of the scopes that must be included when Digital Assistant requests an access token from
        the provider. Include all the scopes that are required to access the resources. If refresh tokens are enabled,
        include the scope that’s necessary to get the refresh token (typically offline_access).


        :param scopes: The scopes of this AuthenticationProvider.
        :type: str
        NrX   )r>   r   r@   r@   rA   r     rS   c                 C   rC   )z
        Gets the subject_claim of this AuthenticationProvider.
        The access-token profile claim to use to identify the user.


        :return: The subject_claim of this AuthenticationProvider.
        :rtype: str
        r5   rE   r@   r@   rA   r     rF   z$AuthenticationProvider.subject_claimc                 C   rG   )z
        Sets the subject_claim of this AuthenticationProvider.
        The access-token profile claim to use to identify the user.


        :param subject_claim: The subject_claim of this AuthenticationProvider.
        :type: str
        NrY   )r>   r   r@   r@   rA   r     rH   c                 C   rC   )a(  
        Gets the refresh_token_retention_period_in_days of this AuthenticationProvider.
        The number of days to keep the refresh token in the Digital Assistant cache.


        :return: The refresh_token_retention_period_in_days of this AuthenticationProvider.
        :rtype: int
        r6   rE   r@   r@   rA   r       rF   z=AuthenticationProvider.refresh_token_retention_period_in_daysc                 C   rG   )aM  
        Sets the refresh_token_retention_period_in_days of this AuthenticationProvider.
        The number of days to keep the refresh token in the Digital Assistant cache.


        :param refresh_token_retention_period_in_days: The refresh_token_retention_period_in_days of this AuthenticationProvider.
        :type: int
        NrZ   )r>   r    r@   r@   rA   r      rH   c                 C   rC   )z
        Gets the redirect_url of this AuthenticationProvider.
        The OAuth Redirect URL.


        :return: The redirect_url of this AuthenticationProvider.
        :rtype: str
        r7   rE   r@   r@   rA   r"     rF   z#AuthenticationProvider.redirect_urlc                 C   rG   )z
        Sets the redirect_url of this AuthenticationProvider.
        The OAuth Redirect URL.


        :param redirect_url: The redirect_url of this AuthenticationProvider.
        :type: str
        Nr[   )r>   r"   r@   r@   rA   r"   $  rH   c                 C   rC   )z
        **[Required]** Gets the is_visible of this AuthenticationProvider.
        Whether this Authentication Provider is visible in the ODA UI.


        :return: The is_visible of this AuthenticationProvider.
        :rtype: bool
        r8   rE   r@   r@   rA   r#   0  rF   z!AuthenticationProvider.is_visiblec                 C   rG   )z
        Sets the is_visible of this AuthenticationProvider.
        Whether this Authentication Provider is visible in the ODA UI.


        :param is_visible: The is_visible of this AuthenticationProvider.
        :type: bool
        Nr\   )r>   r#   r@   r@   rA   r#   <  rH   c                 C   rC   )a  
        **[Required]** Gets the lifecycle_state of this AuthenticationProvider.
        The Authentication Provider's current state.

        Allowed values for this property are: "CREATING", "UPDATING", "ACTIVE", "INACTIVE", "DELETING", "DELETED", "FAILED", 'UNKNOWN_ENUM_VALUE'.
        Any unrecognized values returned by a service will be mapped to 'UNKNOWN_ENUM_VALUE'.


        :return: The lifecycle_state of this AuthenticationProvider.
        :rtype: str
        )r9   rE   r@   r@   rA   r%   H  rI   z&AuthenticationProvider.lifecycle_statec                 C   rM   )z
        Sets the lifecycle_state of this AuthenticationProvider.
        The Authentication Provider's current state.


        :param lifecycle_state: The lifecycle_state of this AuthenticationProvider.
        :type: str
        )r   r   r   r   r   r   r   rJ   N)r   r9   )r>   r%   rK   r@   r@   rA   r%   W  rL   c                 C   rC   )aI  
        **[Required]** Gets the time_created of this AuthenticationProvider.
        When the resource was created. A date-time string as described in `RFC 3339`__, section 14.29.

        __ https://tools.ietf.org/rfc/rfc3339


        :return: The time_created of this AuthenticationProvider.
        :rtype: datetime
        r:   rE   r@   r@   rA   r&   f  rR   z#AuthenticationProvider.time_createdc                 C   rG   )aE  
        Sets the time_created of this AuthenticationProvider.
        When the resource was created. A date-time string as described in `RFC 3339`__, section 14.29.

        __ https://tools.ietf.org/rfc/rfc3339


        :param time_created: The time_created of this AuthenticationProvider.
        :type: datetime
        Nr]   )r>   r&   r@   r@   rA   r&   t  rS   c                 C   rC   )aN  
        **[Required]** Gets the time_updated of this AuthenticationProvider.
        When the resource was last updated. A date-time string as described in `RFC 3339`__, section 14.29.

        __ https://tools.ietf.org/rfc/rfc3339


        :return: The time_updated of this AuthenticationProvider.
        :rtype: datetime
        r;   rE   r@   r@   rA   r(     rR   z#AuthenticationProvider.time_updatedc                 C   rG   )aJ  
        Sets the time_updated of this AuthenticationProvider.
        When the resource was last updated. A date-time string as described in `RFC 3339`__, section 14.29.

        __ https://tools.ietf.org/rfc/rfc3339


        :param time_updated: The time_updated of this AuthenticationProvider.
        :type: datetime
        Nr^   )r>   r(   r@   r@   rA   r(     rS   c                 C   rC   )a/  
        Gets the freeform_tags of this AuthenticationProvider.
        Simple key-value pair that is applied without any predefined name, type, or scope.
        Example: `{"bar-key": "value"}`


        :return: The freeform_tags of this AuthenticationProvider.
        :rtype: dict(str, str)
        r<   rE   r@   r@   rA   r)     rV   z$AuthenticationProvider.freeform_tagsc                 C   rG   )a;  
        Sets the freeform_tags of this AuthenticationProvider.
        Simple key-value pair that is applied without any predefined name, type, or scope.
        Example: `{"bar-key": "value"}`


        :param freeform_tags: The freeform_tags of this AuthenticationProvider.
        :type: dict(str, str)
        Nr_   )r>   r)   r@   r@   rA   r)     rW   c                 C   rC   )aI  
        Gets the defined_tags of this AuthenticationProvider.
        Usage of predefined tag keys. These predefined keys are scoped to namespaces.
        Example: `{"foo-namespace": {"bar-key": "value"}}`


        :return: The defined_tags of this AuthenticationProvider.
        :rtype: dict(str, dict(str, object))
        r=   rE   r@   r@   rA   r*     rV   z#AuthenticationProvider.defined_tagsc                 C   rG   )aT  
        Sets the defined_tags of this AuthenticationProvider.
        Usage of predefined tag keys. These predefined keys are scoped to namespaces.
        Example: `{"foo-namespace": {"bar-key": "value"}}`


        :param defined_tags: The defined_tags of this AuthenticationProvider.
        :type: dict(str, dict(str, object))
        Nr`   )r>   r*   r@   r@   rA   r*     rW   c                 C   s   t | S N)r   rE   r@   r@   rA   __repr__  s   zAuthenticationProvider.__repr__c                 C   s   |d u rdS | j |j kS )NF)__dict__r>   otherr@   r@   rA   __eq__  s   zAuthenticationProvider.__eq__c                 C   s
   | |k S ra   r@   rd   r@   r@   rA   __ne__  s   
zAuthenticationProvider.__ne__N)*__name__
__module____qualname____doc__ZGRANT_TYPE_CLIENT_CREDENTIALSZGRANT_TYPE_AUTHORIZATION_CODEZIDENTITY_PROVIDER_GENERICZIDENTITY_PROVIDER_OAMZIDENTITY_PROVIDER_GOOGLEZIDENTITY_PROVIDER_MICROSOFTZLIFECYCLE_STATE_CREATINGZLIFECYCLE_STATE_UPDATINGZLIFECYCLE_STATE_ACTIVEZLIFECYCLE_STATE_INACTIVEZLIFECYCLE_STATE_DELETINGZLIFECYCLE_STATE_DELETEDZLIFECYCLE_STATE_FAILEDrB   propertyr   setterr   r   r   r   r   r   r   r   r   r   r    r"   r#   r%   r&   r(   r)   r*   rb   rf   rg   r@   r@   r@   rA   r      s     





































r   N)Zoci.utilr   r   r   Zoci.decoratorsr   objectr   r@   r@   r@   rA   <module>   s   