U
    9%e
                     @   sF   d Z ddlmZmZmZ eej  p0e Ze	edddZ
dS )z:Contains utilities to handle datetimes in Huggingface Hub.    )datetime	timedeltatimezone)date_stringreturnc              
   C   s\   z"t | d}|t7 }|tjW S  tk
rV } ztd|  d|W 5 d}~X Y nX dS )a  
    Parses a date_string returned from the server to a datetime object.

    This parser is a weak-parser is the sense that it handles only a single format of
    date_string. It is expected that the server format will never change. The
    implementation depends only on the standard lib to avoid an external dependency
    (python-dateutil). See full discussion about this decision on PR:
    https://github.com/huggingface/huggingface_hub/pull/999.

    Example:
        ```py
        > parse_datetime('2022-08-19T07:19:38.123Z')
        datetime.datetime(2022, 8, 19, 7, 19, 38, 123000, tzinfo=timezone.utc)
        ```

    Args:
        date_string (`str`):
            A string representing a datetime returned by the Hub server.
            String is expected to follow '%Y-%m-%dT%H:%M:%S.%fZ' pattern.

    Returns:
        A python datetime object.

    Raises:
        :class:`ValueError`:
            If `date_string` cannot be parsed.
    z%Y-%m-%dT%H:%M:%S.%fZzCannot parse 'zS' as a datetime. Date string is expected to follow '%Y-%m-%dT%H:%M:%S.%fZ' pattern.N)r   strptime
UTC_OFFSET
astimezoner   utc
ValueError)r   dte r   ^/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/huggingface_hub/utils/_datetime.pyparse_datetime   s    
r   N)__doc__r   r   r   nowr
   r	   	utcoffsetr   strr   r   r   r   r   <module>   s   