o
    ëÉ¶díb  ã                   @   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                   @   s  e 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'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
d0d1„ ƒZejd2d1„ ƒZe
d3d4„ ƒZejd5d4„ ƒZe
d6d7„ ƒZejd8d7„ ƒZe
d9d:„ ƒZejd;d:„ ƒZe
d<d=„ ƒZejd>d=„ ƒZd?d@„ ZdAdB„ ZdCdD„ Z dES )FÚUsera¬  
    An individual employee or system that needs to manage or use your company's Oracle Cloud Infrastructure
    resources. Users might need to launch instances, manage remote disks, work with your cloud network, etc. Users
    have one or more IAM Service credentials (:class:`ApiKey`,
    :class:`UIPassword`, :class:`SwiftPassword` and
    :class:`AuthToken`).
    For more information, see `User Credentials`__). End users of your
    application are not typically IAM Service users, but for tenancies that have identity domains, they might be.
    For conceptual information about users and other IAM Service components, see `Overview of IAM`__.

    These users are created directly within the Oracle Cloud Infrastructure system, via the IAM service.
    They are different from *federated users*, who authenticate themselves to the Oracle Cloud Infrastructure
    Console via an identity provider. For more information, see
    `Identity Providers and Federation`__.

    To use any of the API operations, you must be authorized in an IAM policy. If you're not authorized,
    talk to an administrator. If you're an administrator who needs to write policies to give users access,
    see `Get Started with Policies`__.

    **Warning:** Oracle recommends that you avoid using any confidential information when you supply string values
    using the API.

    __ https://docs.cloud.oracle.com/Content/Identity/usercred/usercredentials.htm
    __ https://docs.cloud.oracle.com/Content/Identity/getstarted/identity-domains.htm
    __ https://docs.cloud.oracle.com/Content/Identity/Concepts/federation.htm
    __ https://docs.cloud.oracle.com/Content/Identity/policiesgs/get-started-with-policies.htm
    ÚCREATINGÚACTIVEÚINACTIVEÚDELETINGÚDELETEDc                 K   sX  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i¥| _ 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&i¥| _d'| _d'| _d'| _d'| _d'| _d'| _d'| _d'| _	d'| _
d'| _d'| _d'| _d'| _d'| _d'| _d'| _d'| _d'| _d'S )(a  
        Initializes a new User 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 User.
        :type id: str

        :param compartment_id:
            The value to assign to the compartment_id property of this User.
        :type compartment_id: str

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

        :param description:
            The value to assign to the description property of this User.
        :type description: str

        :param email:
            The value to assign to the email property of this User.
        :type email: str

        :param email_verified:
            The value to assign to the email_verified property of this User.
        :type email_verified: bool

        :param db_user_name:
            The value to assign to the db_user_name property of this User.
        :type db_user_name: str

        :param identity_provider_id:
            The value to assign to the identity_provider_id property of this User.
        :type identity_provider_id: str

        :param external_identifier:
            The value to assign to the external_identifier property of this User.
        :type external_identifier: str

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

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

        :param inactive_status:
            The value to assign to the inactive_status property of this User.
        :type inactive_status: int

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

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

        :param capabilities:
            The value to assign to the capabilities property of this User.
        :type capabilities: oci.identity.models.UserCapabilities

        :param is_mfa_activated:
            The value to assign to the is_mfa_activated property of this User.
        :type is_mfa_activated: bool

        :param last_successful_login_time:
            The value to assign to the last_successful_login_time property of this User.
        :type last_successful_login_time: datetime

        :param previous_successful_login_time:
            The value to assign to the previous_successful_login_time property of this User.
        :type previous_successful_login_time: datetime

        ÚidÚstrÚcompartment_idÚnameÚdescriptionÚemailÚemail_verifiedÚboolÚdb_user_nameÚidentity_provider_idÚexternal_identifierÚtime_createdÚdatetimeÚlifecycle_stateÚinactive_statusÚintÚfreeform_tagszdict(str, str)Údefined_tagszdict(str, dict(str, object))ÚcapabilitiesZUserCapabilitiesÚis_mfa_activatedÚlast_successful_login_timeÚprevious_successful_login_timeZcompartmentIdZemailVerifiedZ
dbUserNameZidentityProviderIdZexternalIdentifierZtimeCreatedZlifecycleStateZinactiveStatusZfreeformTagsZdefinedTagsZisMfaActivatedZlastSuccessfulLoginTimeZpreviousSuccessfulLoginTimeN)Zswagger_typesZattribute_mapÚ_idÚ_compartment_idÚ_nameÚ_descriptionÚ_emailÚ_email_verifiedÚ_db_user_nameÚ_identity_provider_idÚ_external_identifierÚ_time_createdÚ_lifecycle_stateÚ_inactive_statusÚ_freeform_tagsÚ_defined_tagsÚ_capabilitiesÚ_is_mfa_activatedÚ_last_successful_login_timeÚ_previous_successful_login_time)ÚselfÚkwargs© r6   ú<usr/lib/python3.10/site-packages/oci/identity/models/user.pyÚ__init__>   s¸   Pÿþýüûúùø	÷
öõôóòñðïîÿþýüûúùø	÷
öõôóòñðïî
zUser.__init__c                 C   ó   | j S )z”
        **[Required]** Gets the id of this User.
        The OCID of the user.


        :return: The id of this User.
        :rtype: str
        ©r"   ©r4   r6   r6   r7   r   Ë   ó   
zUser.idc                 C   ó
   || _ dS )z†
        Sets the id of this User.
        The OCID of the user.


        :param id: The id of this User.
        :type: str
        Nr:   )r4   r   r6   r6   r7   r   ×   ó   

c                 C   r9   )zÃ
        **[Required]** Gets the compartment_id of this User.
        The OCID of the tenancy containing the user.


        :return: The compartment_id of this User.
        :rtype: str
        ©r#   r;   r6   r6   r7   r   ã   r<   zUser.compartment_idc                 C   r=   )zÁ
        Sets the compartment_id of this User.
        The OCID of the tenancy containing the user.


        :param compartment_id: The compartment_id of this User.
        :type: str
        Nr?   )r4   r   r6   r6   r7   r   ï   r>   c                 C   r9   )a4  
        **[Required]** Gets the name of this User.
        The name you assign to the user during creation. This is the user's login for the Console.
        The name must be unique across all users in the tenancy and cannot be changed.


        :return: The name of this User.
        :rtype: str
        ©r$   r;   r6   r6   r7   r   û   s   z	User.namec                 C   r=   )a(  
        Sets the name of this User.
        The name you assign to the user during creation. This is the user's login for the Console.
        The name must be unique across all users in the tenancy and cannot be changed.


        :param name: The name of this User.
        :type: str
        Nr@   )r4   r   r6   r6   r7   r     s   
c                 C   r9   )aC  
        **[Required]** Gets the description of this User.
        The description you assign to the user. Does not have to be unique, and it's changeable.

        (For tenancies that support identity domains) You can have an empty description.


        :return: The description of this User.
        :rtype: str
        ©r%   r;   r6   r6   r7   r     ó   zUser.descriptionc                 C   r=   )a>  
        Sets the description of this User.
        The description you assign to the user. Does not have to be unique, and it's changeable.

        (For tenancies that support identity domains) You can have an empty description.


        :param description: The description of this User.
        :type: str
        NrA   )r4   r   r6   r6   r7   r   #  ó   
c                 C   r9   )aw  
        Gets the email of this User.
        The email address you assign to the user.
        The email address must be unique across all users in the tenancy.

        (For tenancies that support identity domains) The email address is required unless the requirement is disabled at the tenancy level.


        :return: The email of this User.
        :rtype: str
        ©r&   r;   r6   r6   r7   r   1  s   z
User.emailc                 C   r=   )a{  
        Sets the email of this User.
        The email address you assign to the user.
        The email address must be unique across all users in the tenancy.

        (For tenancies that support identity domains) The email address is required unless the requirement is disabled at the tenancy level.


        :param email: The email of this User.
        :type: str
        NrD   )r4   r   r6   r6   r7   r   @  s   
c                 C   r9   )z¶
        Gets the email_verified of this User.
        Whether the email address has been validated.


        :return: The email_verified of this User.
        :rtype: bool
        ©r'   r;   r6   r6   r7   r   O  r<   zUser.email_verifiedc                 C   r=   )zÃ
        Sets the email_verified of this User.
        Whether the email address has been validated.


        :param email_verified: The email_verified of this User.
        :type: bool
        NrE   )r4   r   r6   r6   r7   r   [  r>   c                 C   r9   )zÊ
        Gets the db_user_name of this User.
        DB username of the DB credential. Has to be unique across the tenancy.


        :return: The db_user_name of this User.
        :rtype: str
        ©r(   r;   r6   r6   r7   r   g  r<   zUser.db_user_namec                 C   r=   )zÕ
        Sets the db_user_name of this User.
        DB username of the DB credential. Has to be unique across the tenancy.


        :param db_user_name: The db_user_name of this User.
        :type: str
        NrF   )r4   r   r6   r6   r7   r   s  r>   c                 C   r9   )zÌ
        Gets the identity_provider_id of this User.
        The OCID of the `IdentityProvider` this user belongs to.


        :return: The identity_provider_id of this User.
        :rtype: str
        ©r)   r;   r6   r6   r7   r     r<   zUser.identity_provider_idc                 C   r=   )zß
        Sets the identity_provider_id of this User.
        The OCID of the `IdentityProvider` this user belongs to.


        :param identity_provider_id: The identity_provider_id of this User.
        :type: str
        NrG   )r4   r   r6   r6   r7   r   ‹  r>   c                 C   r9   )zÁ
        Gets the external_identifier of this User.
        Identifier of the user in the identity provider


        :return: The external_identifier of this User.
        :rtype: str
        ©r*   r;   r6   r6   r7   r   —  r<   zUser.external_identifierc                 C   r=   )zÓ
        Sets the external_identifier of this User.
        Identifier of the user in the identity provider


        :param external_identifier: The external_identifier of this User.
        :type: str
        NrH   )r4   r   r6   r6   r7   r   £  r>   c                 C   r9   )a
  
        **[Required]** Gets the time_created of this User.
        Date and time the user was created, in the format defined by RFC3339.

        Example: `2016-08-25T21:10:29.600Z`


        :return: The time_created of this User.
        :rtype: datetime
        ©r+   r;   r6   r6   r7   r   ¯  rB   zUser.time_createdc                 C   r=   )a  
        Sets the time_created of this User.
        Date and time the user was created, in the format defined by RFC3339.

        Example: `2016-08-25T21:10:29.600Z`


        :param time_created: The time_created of this User.
        :type: datetime
        NrI   )r4   r   r6   r6   r7   r   ½  rC   c                 C   r9   )aý  
        **[Required]** Gets the lifecycle_state of this User.
        The user's current state. After creating a user, make sure its `lifecycleState` changes from CREATING to
        ACTIVE before using it.

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


        :return: The lifecycle_state of this User.
        :rtype: str
        )r,   r;   r6   r6   r7   r   Ë  ó   zUser.lifecycle_statec                 C   s    g d¢}t ||ƒsd}|| _dS )a   
        Sets the lifecycle_state of this User.
        The user's current state. After creating a user, make sure its `lifecycleState` changes from CREATING to
        ACTIVE before using it.


        :param lifecycle_state: The lifecycle_state of this User.
        :type: str
        )r   r   r	   r
   r   ZUNKNOWN_ENUM_VALUEN)r   r,   )r4   r   Zallowed_valuesr6   r6   r7   r   Û  s   

c                 C   r9   )aÞ  
        Gets the inactive_status of this User.
        Returned only if the user's `lifecycleState` is INACTIVE. A 16-bit value showing the reason why the user
        is inactive:

        - bit 0: SUSPENDED (reserved for future use)
        - bit 1: DISABLED (reserved for future use)
        - bit 2: BLOCKED (the user has exceeded the maximum number of failed login attempts for the Console)


        :return: The inactive_status of this User.
        :rtype: int
        ©r-   r;   r6   r6   r7   r   ë  ó   zUser.inactive_statusc                 C   r=   )aì  
        Sets the inactive_status of this User.
        Returned only if the user's `lifecycleState` is INACTIVE. A 16-bit value showing the reason why the user
        is inactive:

        - bit 0: SUSPENDED (reserved for future use)
        - bit 1: DISABLED (reserved for future use)
        - bit 2: BLOCKED (the user has exceeded the maximum number of failed login attempts for the Console)


        :param inactive_status: The inactive_status of this User.
        :type: int
        NrK   )r4   r   r6   r6   r7   r   ü  ó   
c                 C   r9   )aº  
        Gets the freeform_tags of this User.
        Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace.
        For more information, see `Resource Tags`__.

        Example: `{"Department": "Finance"}`

        __ https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm


        :return: The freeform_tags of this User.
        :rtype: dict(str, str)
        ©r.   r;   r6   r6   r7   r     rL   zUser.freeform_tagsc                 C   r=   )aÆ  
        Sets the freeform_tags of this User.
        Free-form tags for this resource. Each tag is a simple key-value pair with no predefined name, type, or namespace.
        For more information, see `Resource Tags`__.

        Example: `{"Department": "Finance"}`

        __ https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm


        :param freeform_tags: The freeform_tags of this User.
        :type: dict(str, str)
        NrN   )r4   r   r6   r6   r7   r     rM   c                 C   r9   )a¯  
        Gets the defined_tags of this User.
        Defined tags for this resource. Each key is predefined and scoped to a namespace.
        For more information, see `Resource Tags`__.
        Example: `{"Operations": {"CostCenter": "42"}}`

        __ https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm


        :return: The defined_tags of this User.
        :rtype: dict(str, dict(str, object))
        ©r/   r;   r6   r6   r7   r   /  rJ   zUser.defined_tagsc                 C   r=   )aº  
        Sets the defined_tags of this User.
        Defined tags for this resource. Each key is predefined and scoped to a namespace.
        For more information, see `Resource Tags`__.
        Example: `{"Operations": {"CostCenter": "42"}}`

        __ https://docs.cloud.oracle.com/Content/General/Concepts/resourcetags.htm


        :param defined_tags: The defined_tags of this User.
        :type: dict(str, dict(str, object))
        NrO   )r4   r   r6   r6   r7   r   ?  s   
c                 C   r9   )z›
        Gets the capabilities of this User.

        :return: The capabilities of this User.
        :rtype: oci.identity.models.UserCapabilities
        ©r0   r;   r6   r6   r7   r   O  s   zUser.capabilitiesc                 C   r=   )z¦
        Sets the capabilities of this User.

        :param capabilities: The capabilities of this User.
        :type: oci.identity.models.UserCapabilities
        NrP   )r4   r   r6   r6   r7   r   Y  s   
c                 C   r9   )zÒ
        **[Required]** Gets the is_mfa_activated of this User.
        Flag indicates if MFA has been activated for the user.


        :return: The is_mfa_activated of this User.
        :rtype: bool
        ©r1   r;   r6   r6   r7   r   c  r<   zUser.is_mfa_activatedc                 C   r=   )zÒ
        Sets the is_mfa_activated of this User.
        Flag indicates if MFA has been activated for the user.


        :param is_mfa_activated: The is_mfa_activated of this User.
        :type: bool
        NrQ   )r4   r   r6   r6   r7   r   o  r>   c                 C   r9   )aÈ  
        Gets the last_successful_login_time of this User.
        The date and time of when the user most recently logged in the
        format defined by RFC3339 (ex. `2016-08-25T21:10:29.600Z`).
        If there is no login history, this field is null.

        For illustrative purposes, suppose we have a user who has logged in
        at July 1st, 2020 at 1200 PST and logged out 30 minutes later.
        They then login again on July 2nd, 2020 at 1500 PST.

        Their previousSuccessfulLoginTime would be `2020-07-01:19:00.000Z`.

        Their lastSuccessfulLoginTime would be `2020-07-02:22:00.000Z`.


        :return: The last_successful_login_time of this User.
        :rtype: datetime
        ©r2   r;   r6   r6   r7   r    {  ó   zUser.last_successful_login_timec                 C   r=   )aá  
        Sets the last_successful_login_time of this User.
        The date and time of when the user most recently logged in the
        format defined by RFC3339 (ex. `2016-08-25T21:10:29.600Z`).
        If there is no login history, this field is null.

        For illustrative purposes, suppose we have a user who has logged in
        at July 1st, 2020 at 1200 PST and logged out 30 minutes later.
        They then login again on July 2nd, 2020 at 1500 PST.

        Their previousSuccessfulLoginTime would be `2020-07-01:19:00.000Z`.

        Their lastSuccessfulLoginTime would be `2020-07-02:22:00.000Z`.


        :param last_successful_login_time: The last_successful_login_time of this User.
        :type: datetime
        NrR   )r4   r    r6   r6   r7   r    ‘  ó   
c                 C   r9   )aÐ  
        Gets the previous_successful_login_time of this User.
        The date and time of when the user most recently logged in the
        format defined by RFC3339 (ex. `2016-08-25T21:10:29.600Z`).
        If there is no login history, this field is null.

        For illustrative purposes, suppose we have a user who has logged in
        at July 1st, 2020 at 1200 PST and logged out 30 minutes later.
        They then login again on July 2nd, 2020 at 1500 PST.

        Their previousSuccessfulLoginTime would be `2020-07-01:19:00.000Z`.

        Their lastSuccessfulLoginTime would be `2020-07-02:22:00.000Z`.


        :return: The previous_successful_login_time of this User.
        :rtype: datetime
        ©r3   r;   r6   r6   r7   r!   §  rS   z#User.previous_successful_login_timec                 C   r=   )aí  
        Sets the previous_successful_login_time of this User.
        The date and time of when the user most recently logged in the
        format defined by RFC3339 (ex. `2016-08-25T21:10:29.600Z`).
        If there is no login history, this field is null.

        For illustrative purposes, suppose we have a user who has logged in
        at July 1st, 2020 at 1200 PST and logged out 30 minutes later.
        They then login again on July 2nd, 2020 at 1500 PST.

        Their previousSuccessfulLoginTime would be `2020-07-01:19:00.000Z`.

        Their lastSuccessfulLoginTime would be `2020-07-02:22:00.000Z`.


        :param previous_successful_login_time: The previous_successful_login_time of this User.
        :type: datetime
        NrU   )r4   r!   r6   r6   r7   r!   ½  rT   c                 C   s   t | ƒS ©N)r   r;   r6   r6   r7   Ú__repr__Ó  s   zUser.__repr__c                 C   s   |d u rdS | j |j kS )NF)Ú__dict__©r4   Úotherr6   r6   r7   Ú__eq__Ö  s   zUser.__eq__c                 C   s
   | |k S rV   r6   rY   r6   r6   r7   Ú__ne__Ü  s   
zUser.__ne__N)!Ú__name__Ú
__module__Ú__qualname__Ú__doc__ZLIFECYCLE_STATE_CREATINGZLIFECYCLE_STATE_ACTIVEZLIFECYCLE_STATE_INACTIVEZLIFECYCLE_STATE_DELETINGZLIFECYCLE_STATE_DELETEDr8   Úpropertyr   Úsetterr   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r    r!   rW   r[   r\   r6   r6   r6   r7   r      s¨     




























	
	





r   N)Zoci.utilr   r   r   Zoci.decoratorsr   Úobjectr   r6   r6   r6   r7   Ú<module>   s   