o
     
j/                     @   s   d dl mZ d dlmZ d dlmZ d dlmZ d dlmZ G dd de	eZ
G dd	 d	e	eZG d
d de	eZeG dd dZeG dd dZeG dd dZeG dd dZeG dd dZeG dd dZdS )    )	dataclass)datetime)Enum)Literal)parse_datetimec                   @   s@   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdS )
SpaceStagea  
    Enumeration of possible stage of a Space on the Hub.

    Value can be compared to a string:
    ```py
    assert SpaceStage.BUILDING == "BUILDING"
    ```

    Taken from https://github.com/huggingface/moon-landing/blob/main/server/repo_types/SpaceInfo.ts#L61 (private url).
    NO_APP_FILECONFIG_ERRORBUILDINGBUILD_ERRORRUNNINGRUNNING_BUILDINGRUNTIME_ERRORDELETINGSTOPPEDPAUSEDAPP_STARTINGRUNNING_APP_STARTINGN)__name__
__module____qualname____doc__r   r	   r
   r   r   r   r   r   r   r   r   r    r   r   M/home/kuhnn/.local/lib/python3.10/site-packages/huggingface_hub/_space_api.pyr      s    r   c                   @   st   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdZdS )SpaceHardwarea=  
    Enumeration of hardwares available to run your Space on the Hub.

    Value can be compared to a string:
    ```py
    assert SpaceHardware.CPU_BASIC == "cpu-basic"
    ```

    Taken from https://github.com/huggingface-internal/moon-landing/blob/main/server/repo_types/SpaceHardwareFlavor.ts (private url).
    z	cpu-basiczcpu-upgradezcpu-performancezcpu-xlsprx8z	zero-a10gzt4-smallz	t4-mediuml4x1l4x4l40sx1l40sx4l40sx8z
a10g-smallz
a10g-largeza10g-largex2za10g-largex4z
a100-largea100x4a100x8h200h200x2h200x4h200x8inf2x6N)r   r   r   r   	CPU_BASICCPU_UPGRADECPU_PERFORMANCECPU_XLSPRX8	ZERO_A10GT4_SMALL	T4_MEDIUML4X1L4X4L40SX1L40SX4L40SX8
A10G_SMALL
A10G_LARGEA10G_LARGEX2A10G_LARGEX4
A100_LARGEA100X4A100X8H200H200X2H200X4H200X8INF2X6r   r   r   r   r   1   s6    r   c                   @   s   e Zd ZdZdZdZdZdS )SpaceStoragea5  
    Enumeration of persistent storage available for your Space on the Hub.

    Value can be compared to a string:
    ```py
    assert SpaceStorage.SMALL == "small"
    ```

    Taken from https://github.com/huggingface/moon-landing/blob/main/server/repo_types/SpaceHardwareFlavor.ts#L24 (private url).
    smallmediumlargeN)r   r   r   r   SMALLMEDIUMLARGEr   r   r   r   rA   _   s
    rA   c                   @   s   e Zd ZU dZed ed< eed< eed< dZedB ed< dZe	dB ed< dZ
edB ed	< dddZd
efddZd
efddZdS )Volumea  
    Describes a volume to mount in a Space or Job container.

    Args:
        type (`str`):
            Type of volume: `"bucket"`, `"model"`, `"dataset"`, or `"space"`.
        source (`str`):
            Source identifier, e.g. `"username/my-bucket"` or `"username/my-model"`.
        mount_path (`str`):
            Mount path inside the container, e.g. `"/data"`. Must start with `/`.
        revision (`str` or `None`):
            Git revision (only for repos, defaults to `"main"`).
        read_only (`bool` or `None`):
            Read-only mount. Forced `True` for repos, defaults to `False` for buckets.
        path (`str` or `None`):
            Subfolder prefix inside the bucket/repo to mount, e.g. `"path/to/dir"`.
    )bucketmodeldatasetspacetypesource
mount_pathNrevision	read_onlypathreturnc                 K   sv   | dd| _|d | _| d}|d ur|n|d | _| d| _| d}|d ur-|n| d| _| d	| _d S )
NrM   rJ   rN   	mountPathrO   rP   readOnlyrQ   rR   )getrM   rN   rO   rP   rQ   rR   )selfkwargsrO   rQ   r   r   r   __init__   s   


zVolume.__init__c                 C   sR   | j | j| jd}| jdur| j|d< | jdur| j|d< | jdur'| j|d< |S )z6Serialize to the JSON payload expected by the Hub API.)rM   rN   rT   NrP   rU   rR   )rM   rN   rO   rP   rQ   rR   rW   datar   r   r   to_dict   s   





zVolume.to_dictc              	   C   sj   | j r	d| j  nd}| jrd| j nd}dddd| jd}d| j d| j | | d	| j | 	S )
zDReturn the volume as an HF handle in the format expected by the CLI./ @z:roz:rw)TFNzhf://zs/:)rR   rP   rV   rQ   rM   rN   rO   )rW   rR   rP   ror   r   r   to_hf_handle   s   (zVolume.to_hf_handle)rS   N)r   r   r   r   r   __annotations__strrP   rQ   boolrR   rY   dictr\   rb   r   r   r   r   rH   p   s   
 

rH   c                   @   sL   e Zd ZU ed ed< eeeedB f  ed< eed< deddfdd	Z	dS )
SpaceHotReloading)createdcanceledstatusNreplica_statusesrawr[   rS   c                 C   s   |d | _ |d | _|| _d S )Nrj   replicaStatuses)rj   rk   rl   rZ   r   r   r   rY      s   


zSpaceHotReloading.__init__)
r   r   r   r   rc   listtuplerd   rf   rY   r   r   r   r   rg      s
   
 rg   c                   @   s   e Zd ZU dZeed< edB ed< edB ed< edB ed< edB ed< e	dB ed< e
e dB ed	< eed
< deddfddZdS )SpaceRuntimea  
    Contains information about the current runtime of a Space.

    Args:
        stage (`str`):
            Current stage of the space. Example: RUNNING.
        hardware (`str` or `None`):
            Current hardware of the space. Example: "cpu-basic". Can be `None` if Space
            is `BUILDING` for the first time.
        requested_hardware (`str` or `None`):
            Requested hardware. Can be different from `hardware` especially if the request
            has just been made. Example: "t4-medium". Can be `None` if no hardware has
            been requested yet.
        sleep_time (`int` or `None`):
            Number of seconds the Space will be kept alive after the last request. By default (if value is `None`), the
            Space will never go to sleep if it's running on an upgraded hardware, while it will go to sleep after 48
            hours on a free 'cpu-basic' hardware. For more details, see https://huggingface.co/docs/hub/spaces-gpus#sleep-time.
        volumes (`list[Volume]` or `None`):
            List of volumes mounted in the Space. Each volume is a [`Volume`] object describing its type, source,
            mount path, and optional settings. `None` if no volumes are attached.
        raw (`dict`):
            Raw response from the server. Contains more information about the Space
            runtime like number of replicas, number of cpu, memory size,...
    stageNhardwarerequested_hardware
sleep_timestoragehot_reloadingvolumesrl   r[   rS   c                 C   s   |d | _ |di d| _|di d| _|d| _|d| _|d }d ur2t|nd | _|d}|d urEd	d
 |D nd | _|| _	d S )Nrq   rr   current	requested	gcTimeoutru   hotReloadingrw   c                 S   s   g | ]	}t d i |qS )r   )rH   ).0vr   r   r   
<listcomp>   s    z)SpaceRuntime.__init__.<locals>.<listcomp>)
rq   rV   rr   rs   rt   ru   rg   rv   rw   rl   )rW   r[   raw_hrraw_volumesr   r   r   rY      s   
 

zSpaceRuntime.__init__)r   r   r   r   r   rc   r   intrA   rg   rn   rH   rf   rY   r   r   r   r   rp      s   
 rp   c                   @   sH   e Zd ZU dZeed< edB ed< edB ed< dededdfdd	ZdS )
SpaceSecreta&  
    Contains information about a secret of a Space.

    Secret values are write-only and cannot be read back. Only the key, description,
    and last update time are returned by the API.

    Args:
        key (`str`):
            Secret key. Example: `"GITHUB_API_KEY"`
        description (`str` or None):
            Description of the secret. Example: `"Github API key to access the Github API"`.
        updated_at (`datetime` or None):
            datetime of the last update of the secret (if the secret has been updated at least once).
    keyNdescription
updated_atvaluesrS   c                 C   s<   || _ |d| _|d}|d urt|| _d S d | _d S )Nr   	updatedAt)r   rV   r   r   r   rW   r   r   r   r   r   r   rY      s   
 zSpaceSecret.__init__	r   r   r   r   rd   rc   r   rf   rY   r   r   r   r   r      s   
 r   c                   @   sP   e Zd ZU dZeed< eed< edB ed< edB ed< dededdfd	d
ZdS )SpaceVariablea  
    Contains information about the current variables of a Space.

    Args:
        key (`str`):
            Variable key. Example: `"MODEL_REPO_ID"`
        value (`str`):
            Variable value. Example: `"the_model_repo_id"`.
        description (`str` or None):
            Description of the variable. Example: `"Model Repo ID of the implemented model"`.
        updatedAt (`datetime` or None):
            datetime of the last update of the variable (if the variable has been updated at least once).
    r   valueNr   r   r   rS   c                 C   sF   || _ |d | _|d| _|d}|d urt|| _d S d | _d S )Nr   r   r   )r   r   rV   r   r   r   r   r   r   r   rY     s
   

 zSpaceVariable.__init__r   r   r   r   r   r     s   
 r   c                   @   s   e Zd ZU dZeed< eed< eed< edB ed< edB ed< eed< eed	< ee dB ed
< e	dB ed< edB ed< edB ed< e
dB ed< edB ed< deddfddZdS )SpaceSearchResulta  A single result from the Spaces semantic search API.

    Returned by [`HfApi.search_spaces`].

    Attributes:
        id (`str`):
            ID of the Space (e.g. `"username/repo-name"`).
        author (`str`):
            Author of the Space.
        title (`str`):
            Display title of the Space.
        emoji (`str` or `None`):
            Emoji icon of the Space.
        sdk (`str` or `None`):
            SDK used by the Space (e.g. `"gradio"`, `"docker"`, `"static"`).
        likes (`int`):
            Number of likes.
        private (`bool`):
            Whether the Space is private.
        tags (`list[str]` or `None`):
            List of tags.
        runtime ([`SpaceRuntime`] or `None`):
            Runtime information (stage, hardware, etc.).
        ai_short_description (`str` or `None`):
            AI-generated short description.
        ai_category (`str` or `None`):
            AI-generated category (e.g. `"Image Generation"`).
        semantic_relevancy_score (`float` or `None`):
            Semantic relevancy score (0-1) relative to the search query.
        trending_score (`int` or `None`):
            Trending score.
    idauthortitleNemojisdklikesprivatetagsruntimeai_short_descriptionai_categorysemantic_relevancy_scoretrending_scorer[   rS   c                 C   s   | d}|d | _| dd| _| dd| _| d| _| d| _| dd	| _| d
d| _| d| _|r>t	|nd | _
| d| _| d| _| d| _| d| _d S )Nr   r   r   r^   r   r   r   r   r   r   Fr   r   r   semanticRelevancyScoretrendingScore)rV   r   r   r   r   r   r   r   r   rp   r   r   r   r   r   )rW   r[   r   r   r   r   rY   R  s   

zSpaceSearchResult.__init__)r   r   r   r   rd   rc   r   re   rn   rp   floatrf   rY   r   r   r   r   r   !  s    
 !r   N)dataclassesr   r   enumr   typingr   huggingface_hub.utilsr   rd   r   r   rA   rH   rg   rp   r   r   r   r   r   r   r   <module>   s(   .;/