HEX
Server: Apache
System: Linux pdx1-shared-a1-38 6.6.104-grsec-jammy+ #3 SMP Tue Sep 16 00:28:11 UTC 2025 x86_64
User: mmickelson (3396398)
PHP: 8.1.31
Disabled: NONE
Upload Files
File: //lib/python3/dist-packages/boto/s3/__pycache__/connection.cpython-310.pyc
o

ckF[�g�@s,ddlZddlZddlmZmZddlZddlmZddl	Z
ddlmZddl
m
Z
ddlmZddlmZddlmZdd	lmZmZd
d�Zdd
�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�ZGdd�de�Z Gdd�de�Z!Gdd�de�Z"dS) �N)�six�urllib)�detect_potential_s3sigv4)�AWSAuthConnection)�handler)�Bucket)�Key)�	ResultSet)�BotoClientError�S3ResponseErrorcCs|d��s
td��dS)aJ
    Bucket names must not contain uppercase characters. We check for
    this by appending a lowercase character and testing with islower().
    Note this also covers cases like numeric bucket names with dashes.

    >>> check_lowercase_bucketname("Aaaa")
    Traceback (most recent call last):
    ...
    BotoClientError: S3Error: Bucket names cannot contain upper-case
    characters when using either the sub-domain or virtual hosting calling
    format.

    >>> check_lowercase_bucketname("1234-5678-9123")
    True
    >>> check_lowercase_bucketname("abcdefg1234")
    True
    �azuBucket names cannot contain upper-case characters when using either the sub-domain or virtual hosting calling format.T)�islowerr
)�n�r�4/usr/lib/python3/dist-packages/boto/s3/connection.py�check_lowercase_bucketname(srcs�fdd�}|S)Ncs(t|�dkr
t|d�r
	�|i|��S)N��)�lenr)�args�kwargs��frr�wrapperBsz(assert_case_insensitive.<locals>.wrapperr)rrrrr�assert_case_insensitiveAsrc@s:eZdZdd�Zd
dd�Zdd�Zd
dd	�Zd
d
d�ZdS)�_CallingFormatcCsdS�N�r��self�server�bucketrrr�get_bucket_serverK�z _CallingFormat.get_bucket_serverrcCs2d|}||�||�7}||�|�||��7}|S)Nz%s://��
build_host�get_path�build_path_base�r�
connection�protocolr r!�key�url_baserrr�build_url_baseNsz_CallingFormat.build_url_basecCs|dkr|S|�||�Sr)r"rrrrr%Tsz_CallingFormat.build_hostcCs4tj�|�}d}|dkrd|}|dtj�|�S)Nr�/�/%s��boto�utils�get_utf8_valuer�parse�quote)rr!r+�pathrrr�build_auth_pathZs
z_CallingFormat.build_auth_pathcCstj�|�}dtj�|�S)Nr/r0)rr!r+rrrr'asz_CallingFormat.build_path_baseN�r)�__name__�
__module__�__qualname__r"r-r%r7r'rrrrrIs

rc@�eZdZedd��ZdS)�SubdomainCallingFormatcCsd||fS)Nz%s.%srrrrrr"hsz(SubdomainCallingFormat.get_bucket_serverN�r9r:r;rr"rrrrr=f�r=c@r<)�VHostCallingFormatcCs|S�Nrrrrrr"osz$VHostCallingFormat.get_bucket_serverNr>rrrrr@mr?r@c@seZdZdd�Zddd�ZdS)�OrdinaryCallingFormatcCs|SrArrrrrr"vr#z'OrdinaryCallingFormat.get_bucket_serverrcCs0tj�|�}d}|r|d|7}|tj�|�S)Nr.z%s/r0)rr!r+�	path_baserrrr'ys
z%OrdinaryCallingFormat.build_path_baseNr8)r9r:r;r"r'rrrrrBtsrBc@seZdZddd�ZdS)�(ProtocolIndependentOrdinaryCallingFormatrcCs.d}||�||�7}||�|�||��7}|S)Nz//r$r(rrrr-�sz7ProtocolIndependentOrdinaryCallingFormat.build_url_baseNr8)r9r:r;r-rrrrrD�srDc@s4eZdZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdS)�Locationr�EUzeu-central-1z	us-west-1z	us-west-2z	sa-east-1zap-northeast-1zap-southeast-1zap-southeast-2z
cn-north-1N)
r9r:r;�DEFAULTrF�
EUCentral1�USWest�USWest2�SAEast�APNortheast�APSoutheast�APSoutheast2�CNNorth1rrrrrE�srEc@�eZdZdS)�NoHostProvidedN�r9r:r;rrrrrQ�srQc@rP)�HostRequiredErrorNrRrrrrrS�srScs$eZdZdZej�ddd�ZdZdddddddde	dded	d
e
dddddf�fdd
�	Zedd��Z
dd�Zdd�Zdd�Zdd�Z						d2dd�Z				d3dd�Z			d4d d!�Zd5d"d#�Zd5d$d%�Zd6d&d'�Zd5d(d)�Zd6d*d+�Zdejdfd,d-�Zd5d.d/�Z			d7�fd0d1�	Z�ZS)8�S3Connectionzs3.amazonaws.com�s3�calling_formatz)boto.s3.connection.SubdomainCallingFormatz)Signature=%s&Expires=%d&AWSAccessKeyId=%sNTrr.�awsFcs�d}|	turtj�dd�}	|	dur|j}	d}t|tj�r#tj�	|��}||_
||_||_t
t|�j|	|||||||||
||
|||||d�|rQd|��vrStd��dSdS)NFrU�hostT)�debug�https_connection_factoryr6�provider�security_token�suppress_consec_slashes�validate_certs�profile_name�
hmac-v4-s3z6When using SigV4, you must specify a 'host' parameter.)rQr1�config�get�DefaultHost�
isinstancer�string_typesr2�
find_classrV�bucket_class�anon�superrT�__init__�_required_auth_capabilityrS)r�aws_access_key_id�aws_secret_access_key�	is_secure�port�proxy�
proxy_port�
proxy_user�
proxy_passrXrYrZrVr6r[rgr\r]rhr^r_�no_host_provided��	__class__rrrj�s4�	��zS3Connection.__init__cCs|jrdgSdgS)NrhrU)rh)rrrrrk�sz&S3Connection._required_auth_capabilityccs�|��D]}|VqdSrA)�get_all_buckets)rr!rrr�__iter__�s��zS3Connection.__iter__cCs|�|�duSrA)�lookup)r�bucket_namerrr�__contains__�szS3Connection.__contains__cCs
||_dS)aX
        Set the Bucket class associated with this bucket.  By default, this
        would be the boto.s3.key.Bucket class but if you want to subclass that
        for some reason this allows you to associate your new class.

        :type bucket_class: class
        :param bucket_class: A subclass of Bucket that can be more specific
        N)rg)rrgrrr�set_bucket_class�s
	zS3Connection.set_bucket_classcCs2t|tj�s
Jd��dt�tjj|�d�|�fS)zX
        Taken from the AWS book Python examples and modified for use with boto
        z;Policy document must include a valid expiration Time objectz({"expiration": "%s",
"conditions": [%s]}�,)rd�time�struct_time�strftimer1r2�ISO8601�join)r�expiration_time�
conditionsrrr�build_post_policy�s��zS3Connection.build_post_policy�p�http�STANDARDcCs�|durg}|	durg}	t�tt��|��}|	�d|�|�d�r2|	�d|dtd���n|	�d|�|rJ|	�d|�|�d|d��|r[|	�d	|�|�d
|d��|rd|	�d|�|jjr{|�d|jjd��|	�d
|jj�|
r�|�d|
d��|	�d|
�|r�|�d|d��|	�d|�|�||	�}
t	�
|
�}|�d|d��|�d|jd��|j�
|�}|�d|d��|�d|d��d||j�|��|�f}||d�S)a�
        Taken from the AWS book Python examples and modified for use with boto
        This only returns the arguments required for the post form, not the
        actual form.  This does not return the file input field which also
        needs to be added

        :type bucket_name: string
        :param bucket_name: Bucket to submit to

        :type key: string
        :param key:  Key name, optionally add ${filename} to the end to
            attach the submitted filename

        :type expires_in: integer
        :param expires_in: Time (in seconds) before this expires, defaults
            to 6000

        :type acl: string
        :param acl: A canned ACL.  One of:
            * private
            * public-read
            * public-read-write
            * authenticated-read
            * bucket-owner-read
            * bucket-owner-full-control

        :type success_action_redirect: string
        :param success_action_redirect: URL to redirect to on success

        :type max_content_length: integer
        :param max_content_length: Maximum size for this file

        :type http_method: string
        :param http_method:  HTTP Method to use, "http" or "https"

        :type storage_class: string
        :param storage_class: Storage class to use for storing the object.
            Valid values: STANDARD | REDUCED_REDUNDANCY

        :type server_side_encryption: string
        :param server_side_encryption: Specifies server-side encryption
            algorithm to use when Amazon S3 creates an object.
            Valid values: None | AES256

        :rtype: dict
        :return: A dictionary containing field names/values as well as
            a url to POST to

            .. code-block:: python


        Nz{"bucket": "%s"}z${filename}z["starts-with", "$key", "%s"]z
{"key": "%s"}z
{"acl": "%s"}�acl)�name�valuez!{"success_action_redirect": "%s"}�success_action_redirectz["content-length-range", 0, %i]�x-amz-security-tokenz{"x-amz-security-token": "%s"}zx-amz-storage-classz{"x-amz-storage-class": "%s"}zx-amz-server-side-encryptionz&{"x-amz-server-side-encryption": "%s"}�policy�AWSAccessKeyId�	signaturer+z%s://%s/)�action�fields)r~�gmtime�int�append�endswithrr[r\r��base64�	b64encoderl�
_auth_handler�sign_stringrVr%�server_name)rrzr+�
expires_inr�r��max_content_length�http_methodr�r��
storage_class�server_side_encryption�
expirationr��
policy_b64r��urlrrr�build_post_form_args�s^:
���
���
z!S3Connection.build_post_form_argsrc
Cs�|j�||�}
|j�||�}|j�|��|�}|�d�r"|dd�}i}
|dur,||
d<|dur5|
�|�|j||
||||
d�}|jj	|||	d�S)Nz:443����	VersionId)�headersrX�params)�iso_date)
rVr'r7r%r�r��update�build_base_http_requestr��presign)rr��methodr!r+r��
force_http�response_headers�
version_idr�r6�	auth_pathrXr��http_requestrrr�generate_url_sigv4es"


�
�zS3Connection.generate_url_sigv4c
Cs�|jjddkr|r|j||||||||
d�S|pi}|	r"t|�}ntt��|�}|j�||�}|�|�}g}
|
durC|
�d|
�|r[|�	�D]\}}|
�d|t
j�|�f�qI|j
jre|j
j|d<|
rxd|vrmdnd}||d�|
�7}|j�||�|r�|js�tj�|||||j
�}|j�|�}t
jj|d	d
�}d|j|||jf}nd	}|r�|j
j}|�	�D]\}}|�|�r�|
�d|t
j�|�f�q�|
r�|s�dnd}||d�|
�7}|r�d}d}n|j}|j}|j�|||�|�||�|S)
Nrr`)r!r+r�r�r�r�zversionId=%sz%s=%sr��?�&r)�safer��P)r��
capabilityr�r�r~rVr7r&r��itemsrr4r5r[r\r�r'rhr1r2�canonical_stringr��QueryStringrl�
header_prefix�
startswithr*ror-r�)rr�r�r!r+r��
query_authr�r��expires_in_absoluter��expiresr��extra_qp�k�v�	delimiter�c_string�b64_hmac�encoded_canonical�
query_part�
hdr_prefixr*rorrr�generate_urlsj
�


�

�
�
��zS3Connection.generate_urlcCsv|jd|d�}|��}|jdkr|j�|j|j|��td|jfg�}t�	||�}t
|t�s2|�d�}t
j�||�|S)N�GET�r�i,rzutf-8)�make_request�read�statusr[�storage_response_error�reasonr	rgr�
XmlHandlerrd�bytes�encode�xml�sax�parseString)rr��response�body�rs�hrrrrw�s

�

zS3Connection.get_all_bucketscCs|j|d�}|jjS)a
        Convenience method that returns the "CanonicalUserID" of the
        user who's credentials are associated with the connection.
        The only way to get this value is to do a GET request on the
        service which returns all buckets associated with the account.
        As part of that response, the canonical userid is returned.
        This method simply does all of that and then returns just the
        user id.

        :rtype: string
        :return: A string containing the canonical user id.
        r�)rw�owner�id)rr�r�rrr�get_canonical_user_id�s
z"S3Connection.get_canonical_user_idcCs|r	|j||d�S|�||�S)a�
        Retrieves a bucket by name.

        If the bucket does not exist, an ``S3ResponseError`` will be raised. If
        you are unsure if the bucket exists or not, you can use the
        ``S3Connection.lookup`` method, which will either return a valid bucket
        or ``None``.

        If ``validate=False`` is passed, no request is made to the service (no
        charge/communication delay). This is only safe to do if you are **sure**
        the bucket exists.

        If the default ``validate=True`` is passed, a request is made to the
        service to ensure the bucket exists. Prior to Boto v2.25.0, this fetched
        a list of keys (but with a max limit set to ``0``, always returning an empty
        list) in the bucket (& included better error messages), at an
        increased expense. As of Boto v2.25.0, this now performs a HEAD request
        (less expensive but worse error messages).

        If you were relying on parsing the error message before, you should call
        something like::

            bucket = conn.get_bucket('<bucket_name>', validate=False)
            bucket.get_all_keys(maxkeys=0)

        :type bucket_name: string
        :param bucket_name: The name of the bucket

        :type headers: dict
        :param headers: Additional headers to pass along with the request to
            AWS.

        :type validate: boolean
        :param validate: If ``True``, it will try to verify the bucket exists
            on the service-side. (Default: ``True``)
        r�)�head_bucketrg)rrz�validater�rrr�
get_bucket�s%zS3Connection.get_bucketcCs�|jd||d�}|��}|jdkr|�||�S|jdkr.|j�|j|j|�}d|_d|_|�|jdkrE|j�|j|j|�}d|_d	|_|�|j�|j|j|��)
a|
        Determines if a bucket exists by name.

        If the bucket does not exist, an ``S3ResponseError`` will be raised.

        :type bucket_name: string
        :param bucket_name: The name of the bucket

        :type headers: dict
        :param headers: Additional headers to pass along with the request to
            AWS.

        :returns: A <Bucket> object
        �HEADr���i��AccessDeniedz
Access Deniedi��NoSuchBucketz#The specified bucket does not exist)	r�r�r�rgr[r�r��
error_code�
error_message)rrzr�r�r��errrrrr�s2

�
�
�zS3Connection.head_bucketcCs(z|j|||d�}W|Sd}Y|S)aR
        Attempts to get a bucket from S3.

        Works identically to ``S3Connection.get_bucket``, save for that it
        will return ``None`` if the bucket does not exist instead of throwing
        an exception.

        :type bucket_name: string
        :param bucket_name: The name of the bucket

        :type headers: dict
        :param headers: Additional headers to pass along with the request to
            AWS.

        :type validate: boolean
        :param validate: If ``True``, it will try to fetch all keys within the
            given bucket. (Default: ``True``)
        r�N)r�)rrzr�r�r!rrrry.s�zS3Connection.lookupcCs�t|�|r|r|||jj<n|jj|i}|tjkrd}nd|d}|jd|||d�}|��}|jdkr?|j�|j|j	|��|jdkrJ|�
||�S|j�|j|j	|��)a
        Creates a new located bucket. By default it's in the USA. You can pass
        Location.EU to create a European bucket (S3) or European Union bucket
        (GCS).

        :type bucket_name: string
        :param bucket_name: The name of the new bucket

        :type headers: dict
        :param headers: Additional headers to pass along with the request to AWS.

        :type location: str
        :param location: The location of the new bucket.  You can use one of the
            constants in :class:`boto.s3.connection.Location` (e.g. Location.EU,
            Location.USWest, etc.).

        :type policy: :class:`boto.s3.acl.CannedACLStrings`
        :param policy: A canned ACL policy that will be applied to the
            new key in S3.

        rz/<CreateBucketConfiguration><LocationConstraint>z1</LocationConstraint></CreateBucketConfiguration>�PUT)r��datai�r�)rr[�
acl_headerrErGr�r�r��storage_create_errorr�rgr�)rrzr��locationr�r�r�r�rrr�
create_bucketGs2
��
�

�

�zS3Connection.create_bucketcCs:|jd||d�}|��}|jdkr|j�|j|j|��dS)a�
        Removes an S3 bucket.

        In order to remove the bucket, it must first be empty. If the bucket is
        not empty, an ``S3ResponseError`` will be raised.

        :type bucket_name: string
        :param bucket_name: The name of the bucket

        :type headers: dict
        :param headers: Additional headers to pass along with the request to
            AWS.
        �DELETEr���N)r�r�r�r[r�r�)rr!r�r�r�rrr�
delete_bucketvs

��zS3Connection.delete_bucketc

s�t||j�r	|j}t|t�r|j}|j�||�}
tj�d|
�|j�	||�}tj�d|�|j�
|��|�}|rV|
d|7}
tj�d|
�|d|7}tj�d|�tt
|�j||
|||||||	d�	S)Nzpath=%szauth_path=%sr�)�override_num_retries�
retry_handler)rdrgr�rrVr'r1�logrYr7r%r�rirTr�)
rr�r!r+r�r��
query_args�senderr�r�r6r�rXrurrr��s(

�zS3Connection.make_request)	r�NNNr�NNr�N)rrNFNNN)rrNTFNFNrA)TN)rrNrNNNN) r9r:r;rcr1rarb�DefaultCallingFormatr�rQrrjrrkrxr{r|r�r�r�r�rwr�r�r�ryrErGr�r�r��
__classcell__rrrurrT�s`�#

�u
�
�
;


*
-
�
/�rT)#�xml.saxr�r��boto.compatrrr~�	boto.authr�
boto.utilsr1�boto.connectionrr�boto.s3.bucketr�boto.s3.keyr�boto.resultsetr	�boto.exceptionr
rrr�objectrr=r@rBrDrErQrSrTrrrr�<module>s.