a
    OfX                     @  s6  U d Z ddlmZ ddlZddlZddlmZ ddl	m
Z
mZmZmZmZmZ ddlmZmZ ddlmZmZmZmZ ddlmZmZmZ d	d
lmZmZmZ d	dl m!Z! d	dl"m#Z# d	dl$m%Z% erddl&a&dZ'de(d< nda&g dZ)ej*G dd dej+Z,eZ-eee,ddgdf Z.eee,dddgdf Z/eee,ddgdf Z0eee,dddgdf Z1eee,dgdf Z2eee,dgdf Z3eee,dg ddf Z4eee,dg d df Z5eee,d!d"gdf Z6eee,d#d$gd%d&d'd(f Z7eee,d)d*gd+d,f Z8eee,d-gd%d.d/f Z9eee,g d0d%d1d/f Z:eee,g d2d3d,f Z;eee,g d4d3d,f Z<eee,d5d6gd%d7d/f Z=d8d9d:d;Z>eree?d<f Z@nG d=d> d>Z@G d?d@ d@ejAZBG dAdB dBZCG dCdD dDZDdEZEde(dF< ereEZFnG dGdH dHZFdId9dJdKZGeG ZHdLZIdMdNdOdPdQZJe!eKZLdS )RzEThe networks module contains types for common network-related fields.    )annotationsN)version)IPv4AddressIPv4InterfaceIPv4NetworkIPv6AddressIPv6InterfaceIPv6Network)TYPE_CHECKINGAny)MultiHostUrlPydanticCustomErrorUrlcore_schema)	AnnotatedSelf	TypeAlias   )_fields_repr_schema_generation_shared)getattr_migration)GetCoreSchemaHandler)JsonSchemaValuez7str | bytes | int | tuple[str | bytes | int, str | int]r   NetworkType)AnyUrl
AnyHttpUrlFileUrlFtpUrlHttpUrlWebsocketUrlAnyWebsocketUrlUrlConstraintsEmailStr	NameEmailIPvAnyAddressIPvAnyInterfaceIPvAnyNetworkPostgresDsnCockroachDsnAmqpDsnRedisDsnMongoDsnKafkaDsnNatsDsnvalidate_emailMySQLDsn
MariaDBDsnClickHouseDsnc                   @  sh   e Zd ZU dZdZded< dZded< dZded< dZd	ed
< dZ	ded< dZ
d	ed< ddddZdS )r"   a  Url constraints.

    Attributes:
        max_length: The maximum length of the url. Defaults to `None`.
        allowed_schemes: The allowed schemes. Defaults to `None`.
        host_required: Whether the host is required. Defaults to `None`.
        default_host: The default host. Defaults to `None`.
        default_port: The default port. Defaults to `None`.
        default_path: The default path. Defaults to `None`.
    Nz
int | None
max_lengthzlist[str] | Noneallowed_schemeszbool | Nonehost_requiredz
str | Nonedefault_hostdefault_portdefault_pathintreturnc                 C  s2   t | j| jd urt| jnd | j| j| j| jfS N)hashr3   r4   tupler5   r6   r7   r8   self rA   J/var/www/ai-form-bot/venv/lib/python3.9/site-packages/pydantic/networks.py__hash__L   s    zUrlConstraints.__hash__)__name__
__module____qualname____doc__r3   __annotations__r4   r5   r6   r7   r8   rC   rA   rA   rA   rB   r"   8   s   
r"   httphttps)r4   i#  )r3   r4   wswssfileftpT)	postgres
postgresqlzpostgresql+asyncpgzpostgresql+pg8000zpostgresql+psycopgzpostgresql+psycopg2zpostgresql+psycopg2cffizpostgresql+py-postgresqlzpostgresql+pygresql)r5   r4   )Zcockroachdbzcockroachdb+psycopg2zcockroachdb+asyncpgZamqpZamqpsZredisZrediss	localhosti  z/0)r4   r6   r7   r8   Zmongodbzmongodb+srvii  )r4   r7   Zkafkai#  )r4   r6   r7   )ZnatstlsrK   i~  )mysqlzmysql+mysqlconnectorzmysql+aiomysqlzmysql+asyncmyzmysql+mysqldbzmysql+pymysqlzmysql+cymysqlzmysql+pyodbci  )Zmariadbzmariadb+mariadbconnectorzmariadb+pymysqlzclickhouse+nativezclickhouse+asynchi(#  Noner:   c               
   C  s^   zdd l a W n. ty: }  ztd| W Y d } ~ n
d } ~ 0 0 tddd dksZtdd S )Nr   zCemail-validator is not installed, run `pip install pydantic[email]`zemail-validator.2zKemail-validator version >= 2.0 required, run pip install -U email-validator)email_validatorImportErrorr   	partition)erA   rA   rB   import_email_validator  s     r[   .c                   @  sP   e Zd ZdZeddddddZeddd	d
ddZedddddZdS )r#   a   
        Info:
            To use this type, you need to install the optional
            [`email-validator`](https://github.com/JoshData/python-email-validator) package:

            ```bash
            pip install email-validator
            ```

        Validate email addresses.

        ```py
        from pydantic import BaseModel, EmailStr

        class Model(BaseModel):
            email: EmailStr

        print(Model(email='contact@mail.com'))
        #> email='contact@mail.com'
        ```
        	type[Any]r   core_schema.CoreSchema_source_handlerr;   c                 C  s   t   t| jt S r<   )r[   r    no_info_after_validator_function	_validate
str_schemaclsr_   r`   rA   rA   rB   __get_pydantic_core_schema__  s    z%EmailStr.__get_pydantic_core_schema__._schema_generation_shared.GetJsonSchemaHandlerr   r   handlerr;   c                 C  s   ||}|j ddd |S )Nstringemailtypeformatupdatere   r   ri   Zfield_schemarA   rA   rB   __get_pydantic_json_schema__  s    z%EmailStr.__get_pydantic_json_schema__strinput_valuer;   c                C  s   t |d S )Nr   )r/   re   ru   rA   rA   rB   rb     s    zEmailStr._validateN)rD   rE   rF   rG   classmethodrf   rr   rb   rA   rA   rA   rB   r#     s   r#   c                   @  s   e Zd ZdZdZdddddZdddd	d
ZeddddddZeddddddZ	edddddZ
ddddZdS )r$   a  
    Info:
        To use this type, you need to install the optional
        [`email-validator`](https://github.com/JoshData/python-email-validator) package:

        ```bash
        pip install email-validator
        ```

    Validate a name and email address combination, as specified by
    [RFC 5322](https://datatracker.ietf.org/doc/html/rfc5322#section-3.4).

    The `NameEmail` has two properties: `name` and `email`.
    In case the `name` is not provided, it's inferred from the email address.

    ```py
    from pydantic import BaseModel, NameEmail

    class User(BaseModel):
        email: NameEmail

    user = User(email='Fred Bloggs <fred.bloggs@example.com>')
    print(user.email)
    #> Fred Bloggs <fred.bloggs@example.com>
    print(user.email.name)
    #> Fred Bloggs

    user = User(email='fred.bloggs@example.com')
    print(user.email)
    #> fred.bloggs <fred.bloggs@example.com>
    print(user.email.name)
    #> fred.bloggs
    ```
    namerk   rs   c                 C  s   || _ || _d S r<   rx   )r@   ry   rk   rA   rA   rB   __init__  s    zNameEmail.__init__r   bool)otherr;   c                 C  s"   t |to | j| jf|j|jfkS r<   )
isinstancer$   ry   rk   )r@   r|   rA   rA   rB   __eq__  s    zNameEmail.__eq__r]   rg   r   rh   c                 C  s   ||}|j ddd |S )Nrj   z
name-emailrl   ro   rq   rA   rA   rB   rr     s    z&NameEmail.__get_pydantic_json_schema__r\   r   r^   c              
   C  sB   t   t| jtjt tjt| t gdddt dS )NZname_email_typezInput is not a valid NameEmail)Zcustom_error_typeZcustom_error_message)json_schemaZpython_schemaserialization)	r[   r   ra   rb   Zjson_or_python_schemarc   Zunion_schemaZis_instance_schemato_string_ser_schemard   rA   rA   rB   rf     s    z&NameEmail.__get_pydantic_core_schema__z
Self | strr   rt   c                C  s(   t |tr t|\}}| ||S |S d S r<   )r}   rs   r/   )re   ru   ry   rk   rA   rA   rB   rb     s    

zNameEmail._validater:   c                 C  s4   d| j v r d| j  d| j dS | j  d| j dS )N@"z" <>z <rx   r?   rA   rA   rB   __str__  s    
zNameEmail.__str__N)rD   rE   rF   rG   	__slots__rz   r~   rw   rr   rf   rb   r   rA   rA   rA   rB   r$     s   #r$   c                   @  sd   e Zd ZdZdZdddddZedd	d
dddZeddddddZedddddZ	dS )r%   a  Validate an IPv4 or IPv6 address.

    ```py
    from pydantic import BaseModel
    from pydantic.networks import IPvAnyAddress

    class IpModel(BaseModel):
        ip: IPvAnyAddress

    print(IpModel(ip='127.0.0.1'))
    #> ip=IPv4Address('127.0.0.1')

    try:
        IpModel(ip='http://www.example.com')
    except ValueError as e:
        print(e.errors())
        '''
        [
            {
                'type': 'ip_any_address',
                'loc': ('ip',),
                'msg': 'value is not a valid IPv4 or IPv6 address',
                'input': 'http://www.example.com',
            }
        ]
        '''
    ```
    rA   r   zIPv4Address | IPv6Addressvaluer;   c                 C  sJ   z
t |W S  ty   Y n0 z
t|W S  tyD   tddY n0 dS )z!Validate an IPv4 or IPv6 address.Zip_any_addressz)value is not a valid IPv4 or IPv6 addressN)r   
ValueErrorr   r   re   r   rA   rA   rB   __new__E  s    

zIPvAnyAddress.__new__r]   rg   r   rh   c                 C  s   i }|j ddd |S )Nrj   Zipvanyaddressrl   ro   rq   rA   rA   rB   rr   Q  s    z*IPvAnyAddress.__get_pydantic_json_schema__r\   r   r^   c                 C  s   t j| jt  dS N)r   r   Z no_info_plain_validator_functionrb   r   rd   rA   rA   rB   rf   Y  s    
z*IPvAnyAddress.__get_pydantic_core_schema__rt   c                C  s   | |S r<   rA   rv   rA   rA   rB   rb   c  s    zIPvAnyAddress._validateN
rD   rE   rF   rG   r   r   rw   rr   rf   rb   rA   rA   rA   rB   r%   %  s   	r%   c                   @  sd   e Zd ZdZdZdddddZedd	d
dddZeddddddZedddddZ	dS )r&   #Validate an IPv4 or IPv6 interface.rA   r   zIPv4Interface | IPv6Interfacer   c                 C  sJ   z
t |W S  ty   Y n0 z
t|W S  tyD   tddY n0 dS )r   Zip_any_interfacez+value is not a valid IPv4 or IPv6 interfaceN)r   r   r   r   r   rA   rA   rB   r   m  s    

zIPvAnyInterface.__new__r]   rg   r   rh   c                 C  s   i }|j ddd |S )Nrj   Zipvanyinterfacerl   ro   rq   rA   rA   rB   rr   y  s    z,IPvAnyInterface.__get_pydantic_json_schema__r\   r   r^   c                 C  s   t j| jt  dS r   r   rd   rA   rA   rB   rf     s    
z,IPvAnyInterface.__get_pydantic_core_schema__rt   c                C  s   | |S r<   rA   rv   rA   rA   rB   rb     s    zIPvAnyInterface._validateNr   rA   rA   rA   rB   r&   h  s   	r&   zIPv4Network | IPv6NetworkIPvAnyNetworkTypec                   @  sd   e Zd ZdZdZdddddZedd	d
dddZeddddddZedddddZ	dS )r'   !Validate an IPv4 or IPv6 network.rA   r   r   r   c                 C  sJ   z
t |W S  ty   Y n0 z
t|W S  tyD   tddY n0 dS )r   Zip_any_networkz)value is not a valid IPv4 or IPv6 networkN)r   r   r	   r   r   rA   rA   rB   r     s    

zIPvAnyNetwork.__new__r]   rg   r   rh   c                 C  s   i }|j ddd |S )Nrj   Zipvanynetworkrl   ro   rq   rA   rA   rB   rr     s    z*IPvAnyNetwork.__get_pydantic_json_schema__r\   r   r^   c                 C  s   t j| jt  dS r   r   rd   rA   rA   rB   rf     s    
z*IPvAnyNetwork.__get_pydantic_core_schema__rt   c                C  s   | |S r<   rA   rv   rA   rA   rB   rb     s    zIPvAnyNetwork._validateNr   rA   rA   rA   rB   r'     s   	r'   zre.Pattern[str]c               	   C  s<   d} d|  d|  d}d}d}t d| d| d	| d
S )Nz[\w!#$%&\'*+\-/=?^_`{|}~]z((?:z+\s+)*z+)z"((?:[^"]|\")+)"z<\s*(.+)\s*>z\s*(?:|z)?\s*z\s*)recompile)Z
name_charsZunquoted_name_groupZquoted_name_groupZemail_grouprA   rA   rB   _build_pretty_email_regex  s
    r   i   rs   ztuple[str, str]r   c              
   C  s   t du rt  t| tkr2tddddt dit| }d}|rZ| \}}} |pX|}|  }zt j	|dd}W nB t j
y } z(tdddt|jd	 i|W Y d}~n
d}~0 0 |j}|dusJ |p|j}||fS )
a|  Email address validation using [email-validator](https://pypi.org/project/email-validator/).

    Note:
        Note that:

        * Raw IP address (literal) domain parts are not allowed.
        * `"John Doe <local_part@domain.com>"` style "pretty" email addresses are processed.
        * Spaces are striped from the beginning and end of addresses, but no error is raised.
    NZvalue_errorz,value is not a valid email address: {reason}reasonzLength must not exceed z charactersF)Zcheck_deliverabilityr   )rW   r[   lenMAX_EMAIL_LENGTHr   pretty_email_regex	fullmatchgroupsstripr/   ZEmailNotValidErrorrs   args
normalizedZ
local_part)r   mry   Zunquoted_nameZquoted_namerk   partsrZ   rA   rA   rB   r/     s4    


r/   )MrG   
__future__r   Z_annotationsdataclassesZ_dataclassesr   importlib.metadatar   	ipaddressr   r   r   r   r   r	   typingr
   r   Zpydantic_corer   r   r   r   typing_extensionsr   r   r   	_internalr   r   r   Z
_migrationr   Zannotated_handlersr   r   r   rW   r   rH   __all__	dataclassZPydanticMetadatar"   r   r   r   r!   r    r   r   r(   r)   r*   r+   r,   r-   r.   r0   r1   r2   r[   rs   r#   ZRepresentationr$   r%   r&   r   r'   r   r   r   r/   rD   __getattr__rA   rA   rA   rB   <module>   s     ML



-YC(*)