HEX
Server: LiteSpeed
System: Linux shams.tasjeel.ae 5.14.0-611.5.1.el9_7.x86_64 #1 SMP PREEMPT_DYNAMIC Tue Nov 11 08:09:09 EST 2025 x86_64
User: infowars (1469)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: //lib64/python3.9/site-packages/gssapi/__pycache__/creds.cpython-39.pyc
a

��_�@�@sjddlmZddlmZddlmZmZddlm	Z	ed�Z
ed�Zed�Zed�Z
Gd	d
�d
ej�ZdS)�)�creds)�named_tuples)�import_gssapi_extension�_encode_dict)�namesZcred_imp_expZs4uZ
cred_storeZrfc5588cs�eZdZdZdZd"�fdd�	Zedd��Zed	d
��Zedd��Z	ed
d��Z
ed#dd��Zd$dd�Z
d%dd�Zd&dd�Zd'dd�Zd(dd�Zdd�Zd d!�Z�ZS))�Credentialsa<GSSAPI Credentials

    This class represents a set of GSSAPI credentials which may
    be used with and/or returned by other GSSAPI methods.

    It inherits from the low-level GSSAPI :class:`~gssapi.raw.creds.Creds`
    class, and thus may used with both low-level and high-level API methods.

    If your implementation of GSSAPI supports the credentials import-export
    extension, you may pickle and unpickle this object.

    The constructor either acquires or imports a set of GSSAPI
    credentials.

    If the `base` argument is used, an existing
    :class:`~gssapi.raw.creds.Cred` object from the low-level API is
    converted into a high-level object.

    If the `token` argument is used, the credentials
    are imported using the token, if the credentials import-export
    extension is supported (:requires-ext:`cred_imp_exp`).

    Otherwise, the credentials are acquired as per the
    :meth:`acquire` method.

    Raises:
        BadMechanismError
        BadNameTypeError
        BadNameError
        ExpiredCredentialsError
        MissingCredentialsError
    �N�bothc
s^|dur|}n>|dur2tdur&td��t�|�}n|j|||||d�}	|	j}tt|��||�S)N�WYour GSSAPI implementation does not have support for importing and exporting creditials)�store)�
rcred_imp_exp�NotImplementedErrorZimport_cred�acquirer�superr�__new__)
�cls�base�token�name�lifetime�mechs�usagerZ
base_creds�res��	__class__r�2/usr/lib64/python3.9/site-packages/gssapi/creds.pyr1s�zCredentials.__new__cCs|jddddd�jS)z.Get the name associated with these credentialsTF�rrrr)�inquirer��selfrrrrEs�zCredentials.namecCs|jddddd�jS)z/Get the remaining lifetime of these credentialsFTr)rrrrrrrKs�zCredentials.lifetimecCs|jddddd�jS)z(Get the mechanisms for these credentialsFTr)rrrrrrrQs�zCredentials.mechscCs|jddddd�jS)z>Get the usage (initiate, accept, or both) of these credentialsFTr)rrrrrrrWs�zCredentials.usagecCs^|durt�||||�}n*tdur*td��t|�}t�|||||�}t�||jd�|j	|j
�S)aAcquire GSSAPI credentials

        This method acquires credentials.  If the `store` argument is
        used, the credentials will be acquired from the given
        credential store (if supported).  Otherwise, the credentials are
        acquired from the default store.

        The credential store information is a dictionary containing
        mechanisms-specific keys and values pointing to a credential store
        or stores.

        Using a non-default store requires support for the credentials store
        extension.

        Args:
            name (Name): the name associated with the credentials,
                or None for the default name
            lifetime (int): the desired lifetime of the credentials, or None
                for indefinite
            mechs (list): the desired :class:`MechType` OIDs to be used
                with the credentials, or None for the default set
            usage (str): the usage for the credentials -- either 'both',
                'initiate', or 'accept'
            store (dict): the credential store information pointing to the
                credential store from which to acquire the credentials,
                or None for the default store (:requires-ext:`cred_store`)

        Returns:
            AcquireCredResult: the acquired credentials and information about
                them

        Raises:
            BadMechanismError
            BadNameTypeError
            BadNameError
            ExpiredCredentialsError
            MissingCredentialsError
        N�SYour GSSAPI implementation does not have support for manipulating credential stores�r)�rcredsZacquire_cred�rcred_cred_storer
rZacquire_cred_from�tuplesZAcquireCredResultrrr)rrrrrrrrrrr]s*���zCredentials.acquireFcCsZ|dur*tdurtd��t�|||||�Stdur:td��t|�}t�||||||�SdS)a�Store these credentials into the given store

        This method stores the current credentials into the specified
        credentials store.  If the default store is used, support for
        :rfc:`5588` is required.  Otherwise, support for the credentials
        store extension is required.

        :requires-ext:`rfc5588` or :requires-ext:`cred_store`

        Args:
            store (dict): the store into which to store the credentials,
                or None for the default store.
            usage (str): the usage to store the credentials with -- either
                'both', 'initiate', or 'accept'
            mech (OID): the :class:`MechType` to associate with the
                stored credentials
            overwrite (bool): whether or not to overwrite existing credentials
                stored with the same name, etc
            set_default (bool): whether or not to set these credentials as
                the default credentials for the given store.

        Returns:
            StoreCredResult: the results of the credential storing operation

        Raises:
            GSSError
            ExpiredCredentialsError
            MissingCredentialsError
            OperationUnavailableError
            DuplicateCredentialsElementError
        Nz=Your GSSAPI implementation does not have support for RFC 5588z\Your GSSAPI implementation does not have support for manipulating credential stores directly)�
rcred_rfc5588r
Z
store_credr#rZstore_cred_into)rrr�mechZ	overwriteZset_defaultrrrr�s"
��zCredentials.store�initiatecCs2tdurtd��t�|||||�}t|�|jd�S)a�Impersonate a name using the current credentials

        This method acquires credentials by impersonating another
        name using the current credentials.

        :requires-ext:`s4u`

        Args:
            name (Name): the name to impersonate
            lifetime (int): the desired lifetime of the new credentials,
                or None for indefinite
            mechs (list): the desired :class:`MechType` OIDs for the new
                credentials
            usage (str): the desired usage for the new credentials -- either
                'both', 'initiate', or 'accept'.  Note that some mechanisms
                may only support 'initiate'.

        Returns:
            Credentials: the new credentials impersonating the given name
        N�8Your GSSAPI implementation does not have support for S4Ur!)�	rcred_s4ur
Zacquire_cred_impersonate_name�typer)rrrrrrrrr�impersonate�s�zCredentials.impersonateTcCsDt�|||||�}|jdur*t�|j�}nd}t�||j|j|j	�S)a�Inspect these credentials for information

        This method inspects these credentials for information about them.

        Args:
            name (bool): get the name associated with the credentials
            lifetime (bool): get the remaining lifetime for the credentials
            usage (bool): get the usage for the credentials
            mechs (bool): get the mechanisms associated with the credentials

        Returns:
            InquireCredResult: the information about the credentials,
                with None used when the corresponding argument was False

        Raises:
            MissingCredentialsError
            InvalidCredentialsError
            ExpiredCredentialsError
        N)
r"Zinquire_credrr�Namer$ZInquireCredResultrrr)rrrrrr�res_namerrrr�s

�zCredentials.inquirecCsFt�||||||�}|jdur,t�|j�}nd}t�||j|j|j	�S)a�Inspect these credentials for per-mechanism information

        This method inspects these credentials for per-mechanism information
        about them.

        Args:
            mech (OID): the mechanism for which to retrive the information
            name (bool): get the name associated with the credentials
            init_lifetime (bool): get the remaining initiate lifetime for
                the credentials
            accept_lifetime (bool): get the remaining accept lifetime for
                the credentials
            usage (bool): get the usage for the credentials

        Returns:
            InquireCredByMechResult: the information about the credentials,
                with None used when the corresponding argument was False
        N)
r"Zinquire_cred_by_mechrrr,r$ZInquireCredByMechResult�
init_lifetime�accept_lifetimer)rr&rr.r/rrr-rrr�inquire_by_mech
s�
�zCredentials.inquire_by_mechc		Cs�|dur|durtd��|durPtdur0td��t|�}t�|||||||�}nD|dur�tdurhtd��t�|||||||�}nt�||||||�}t	|j
�S)a	Acquire more credentials to add to the current set

        This method works like :meth:`acquire`, except that it adds the
        acquired credentials for a single mechanism to a copy of the current
        set, instead of creating a new set for multiple mechanisms.
        Unlike :meth:`acquire`, you cannot pass None desired name or
        mechanism.

        If the `impersonator` argument is used, the credentials will
        impersonate the given name using the impersonator credentials
        (:requires-ext:`s4u`).

        If the `store` argument is used, the credentials will be acquired
        from the given credential store (:requires-ext:`cred_store`).
        Otherwise, the credentials are acquired from the default store.

        The credential store information is a dictionary containing
        mechanisms-specific keys and values pointing to a credential store
        or stores.

        Note that the `store` argument is not compatible with the
        `impersonator` argument.

        Args:
            name (Name): the name associated with the
                credentials
            mech (OID): the desired :class:`MechType` to be used with the
                credentials
            usage (str): the usage for the credentials -- either 'both',
                'initiate', or 'accept'
            init_lifetime (int): the desired initiate lifetime of the
                credentials, or None for indefinite
            accept_lifetime (int): the desired accept lifetime of the
                credentials, or None for indefinite
            impersonator (Credentials): the credentials to use to impersonate
                the given name, or None to not acquire normally
                (:requires-ext:`s4u`)
            store (dict): the credential store information pointing to the
                credential store from which to acquire the credentials,
                or None for the default store (:requires-ext:`cred_store`)

        Returns:
            Credentials: the credentials set containing the current credentials
                and the newly acquired ones.

        Raises:
            BadMechanismError
            BadNameTypeError
            BadNameError
            DuplicateCredentialsElementError
            ExpiredCredentialsError
            MissingCredentialsError
        NzMYou cannot use both the `impersonator` and `store` arguments at the same timer r()�
ValueErrorr#r
rZ
add_cred_fromr)Zadd_cred_impersonate_namer"Zadd_credrr)	rrr&rr.r/Zimpersonatorrrrrr�add/s,9���zCredentials.addcCstdurtd��t�|�S)ayExport these credentials into a token

        This method exports the current credentials to a token that can
        then be imported by passing the `token` argument to the constructor.

        This is often used to pass credentials between processes.

        :requires-ext:`cred_imp_exp`

        Returns:
            bytes: the exported credentials in token form
        Nr
)rr
Zexport_credrrrr�export�szCredentials.exportcCst|�d|��ffS)N)r*r3rrrr�
__reduce__�szCredentials.__reduce__)NNNNNr	N)NNNr	N)Nr	NFF)NNNr')TTTT)TTTT)r	NNNN)�__name__�
__module__�__qualname__�__doc__�	__slots__r�propertyrrrr�classmethodrrr+rr0r2r3r4�
__classcell__rrrrr
sB!�



�;�
4�
!
�
"�
UrN)Z
gssapi.rawrr"rr$Z
gssapi._utilsrrZgssapirrr)r#r%ZCredsrrrrr�<module>s