
    i8                        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 d dl	m
Z
mZ d dlmZ  G d d	ee          Ze G d
 d                      Ze G d d                      Ze G d d                      Ze G d d                      Ze G d d                      Ze G d d                      Ze G d d                      Ze G d d                      Ze G d d                      Zddddedee         d eeef         dz  d!eeef         dz  d"e
dz  d#eez  ez  dz  d$eeef         dz  d%ee         dz  d&eeef         fd'ZdS )(    )	dataclass)datetime)Enum)Any)	constants)SpaceHardwareVolume)parse_datetimec                   &    e Zd ZdZdZdZdZdZdZdS )JobStageah  
    Enumeration of possible stage of a Job on the Hub.

    Value can be compared to a string:
    ```py
    assert JobStage.COMPLETED == "COMPLETED"
    ```
    Possible values are: `COMPLETED`, `CANCELED`, `ERROR`, `DELETED`, `RUNNING`.
    Taken from https://github.com/huggingface/moon-landing/blob/main/server/job_types/JobInfo.ts#L61 (private url).
    	COMPLETEDCANCELEDERRORDELETEDRUNNINGN)	__name__
__module____qualname____doc__r   r   r   r   r        Z/usr/local/lib/hermes-agent/venv/lib/python3.11/site-packages/huggingface_hub/_jobs_api.pyr   r      s3        	 	 IHEGGGGr   r   c                   *    e Zd ZU eed<   edz  ed<   dS )	JobStatusstageNmessage)r   r   r   r   __annotations__strr   r   r   r   r   ,   s+         OOO4Zr   r   c                   .    e Zd ZU eed<   eed<   eed<   dS )JobOwneridnametypeN)r   r   r   r   r   r   r   r   r    r    2   s+         GGG
III
IIIIIr   r    c                   B   e Zd ZU dZeed<   edz  ed<   edz  ed<   edz  ed<   ee         dz  ed<   ee         dz  ed<   eee	f         dz  ed	<   eee	f         dz  ed
<   e
dz  ed<   eeef         dz  ed<   ee         dz  ed<   eed<   eed<   eed<   eed<   ddZdS )JobInfoa
  
    Contains information about a Job.

    Args:
        id (`str`):
            Job ID.
        created_at (`datetime` or `None`):
            When the Job was created.
        docker_image (`str` or `None`):
            The Docker image from Docker Hub used for the Job.
            Can be None if space_id is present instead.
        space_id (`str` or `None`):
            The Docker image from Hugging Face Spaces used for the Job.
            Can be None if docker_image is present instead.
        command (`list[str]` or `None`):
            Command of the Job, e.g. `["python", "-c", "print('hello world')"]`
        arguments (`list[str]` or `None`):
            Arguments passed to the command
        environment (`dict[str]` or `None`):
            Environment variables of the Job as a dictionary.
        secrets (`dict[str]` or `None`):
            Secret environment variables of the Job (encrypted).
        flavor (`str` or `None`):
            Flavor for the hardware, as in Hugging Face Spaces. See [`SpaceHardware`] for possible values.
            E.g. `"cpu-basic"`.
        labels (`dict[str, str]` or `None`):
            Labels to attach to the job (key-value pairs).
        volumes (`list[Volume]` or `None`):
            Volumes mounted in the job container (buckets, models, datasets, spaces).
        status: (`JobStatus` or `None`):
            Status of the Job, e.g. `JobStatus(stage="RUNNING", message=None)`
            See [`JobStage`] for possible stage values.
        owner: (`JobOwner` or `None`):
            Owner of the Job, e.g. `JobOwner(id="5e9ecfc04957053f60648a3e", name="lhoestq", type="user")`

    Example:

    ```python
    >>> from huggingface_hub import run_job
    >>> job = run_job(
    ...     image="python:3.12",
    ...     command=["python", "-c", "print('Hello from the cloud!')"]
    ... )
    >>> job
    JobInfo(id='687fb701029421ae5549d998', created_at=datetime.datetime(2025, 7, 22, 16, 6, 25, 79000, tzinfo=datetime.timezone.utc), docker_image='python:3.12', space_id=None, command=['python', '-c', "print('Hello from the cloud!')"], arguments=[], environment={}, secrets={}, flavor='cpu-basic', labels=None, status=JobStatus(stage='RUNNING', message=None), owner=JobOwner(id='5e9ecfc04957053f60648a3e', name='lhoestq', type='user'), endpoint='https://huggingface.co', url='https://huggingface.co/jobs/lhoestq/687fb701029421ae5549d998')
    >>> job.id
    '687fb701029421ae5549d998'
    >>> job.url
    'https://huggingface.co/jobs/lhoestq/687fb701029421ae5549d998'
    >>> job.status.stage
    'RUNNING'
    ```
    r!   N
created_atdocker_imagespace_idcommand	argumentsenvironmentsecretsflavorlabelsvolumesstatusownerendpointurlreturnc                    |d         | _         |                    d          p|                    d          }|rt          |          nd | _        |                    d          p|                    d          | _        |                    d          p|                    d          | _        |                    di           }t          |d         |d	         |d
                   | _        |                    d          | _        |                    d          | _	        |                    d          | _
        |                    d          | _        |                    d          | _        |                    d          | _        |                    d          }|rd |D             nd | _        |                    di           }t          |d         |                    d                    | _        |                    dt"          j                  | _        | j         d| j        j         d| j          | _        d S )Nr!   	createdAtr&   dockerImager'   spaceIdr(   r1   r"   r#   r!   r"   r#   r)   r*   r+   r,   r-   r.   r/   c                 &    g | ]}t          d i |S r   r	   .0vs     r   
<listcomp>z$JobInfo.__init__.<locals>.<listcomp>   "    555555r   r0   r   r   )r   r   r2   z/jobs//)r!   getr
   r&   r'   r(   r    r1   r)   r*   r+   r,   r-   r.   r/   r   r0   r   ENDPOINTr2   r"   r3   )selfkwargsr&   r1   r/   r0   s         r   __init__zJobInfo.__init__   s   ,ZZ,,H

<0H0H
8BL.444"JJ}55SN9S9S

9--GJ1G1G

7B''t5=uV}UUU
zz),,K00!::m44zz),,jj**jj****Y''9@J55W5555dHb))fWovzz)?T?TUUU 

:y/ABBmFF4:?FFTWFFr   r4   N)r   r   r   r   r   r   r   listdictr   r   r	   r   r    rG   r   r   r   r%   r%   9   s:        4 4l 	GGG4*Dj#YCy4c3h$&&&&#s(^d""""D    cNT!!!!&\D    OOO MMM	HHHG G G G G Gr   r%   c                   8   e Zd ZU edz  ed<   edz  ed<   ee         dz  ed<   ee         dz  ed<   eeef         dz  ed<   eeef         dz  ed<   edz  ed<   e	dz  ed	<   ee         dz  ed
<   edz  ed<   eeef         dz  ed<   ee
         dz  ed<   ddZdS )JobSpecNr'   r(   r)   r*   r+   r,   r-   timeouttagsarchr.   r/   r4   c                    |                     d          p|                     d          | _        |                     d          p|                     d          | _        |                     d          | _        |                     d          | _        |                     d          | _        |                     d          | _        |                     d	          | _        |                     d
          | _        |                     d          | _	        |                     d          | _
        |                     d          | _        |                     d          }|rd |D             nd | _        d S )Nr7   r'   r8   r(   r)   r*   r+   r,   r-   rM   rN   rO   r.   r/   c                 &    g | ]}t          d i |S r;   r<   r=   s     r   r@   z$JobSpec.__init__.<locals>.<listcomp>   rA   r   )rC   r'   r(   r)   r*   r+   r,   r-   rM   rN   rO   r.   r/   )rE   rF   r/   s      r   rG   zJobSpec.__init__   s,   "JJ}55SN9S9S

9--GJ1G1Gzz),,K00!::m44zz),,jj**zz),,JJv&&	JJv&&	jj****Y''9@J55W5555dr   rH   )r   r   r   r   r   rI   rJ   r   r   intr	   rG   r   r   r   rL   rL      s         *Dj#YCy4c3h$&&&&#s(^d""""D    4Z
s)d

*cNT!!!!&\D    K K K K K Kr   rL   c                   ,    e Zd ZU eed<   eed<   ddZdS )LastJobInfor!   atr4   Nc                 T    |d         | _         t          |d                   | _        d S )Nr!   rU   )r!   r
   rU   rE   rF   s     r   rG   zLastJobInfo.__init__   s$    , ..r   rH   )r   r   r   r   r   r   rG   r   r   r   rT   rT      s<         GGGLLL/ / / / / /r   rT   c                   8    e Zd ZU edz  ed<   edz  ed<   ddZdS )ScheduledJobStatusNlast_jobnext_job_run_atr4   c                 "   |                     d          p|                     d          }|rt          di |nd | _        |                     d          p|                     d          }|rt          t	          |                    nd | _        d S )NlastJobrZ   nextJobRunAtr[   r   )rC   rT   rZ   r
   r   r[   )rE   rF   rZ   r[   s       r   rG   zScheduledJobStatus.__init__   s    ::i((BFJJz,B,B3;E//h/// **^44U

CT8U8UGV`~c/.B.BCCC\`r   rH   )r   r   r   rT   r   r   rG   r   r   r   rY   rY      sQ         D    _$$$a a a a a ar   rY   c                       e Zd ZU dZeed<   edz  ed<   eed<   edz  ed<   edz  ed<   edz  ed<   e	ed	<   e
ed
<   ddZdS )ScheduledJobInfoa  
    Contains information about a Job.

    Args:
        id (`str`):
            Scheduled Job ID.
        created_at (`datetime` or `None`):
            When the scheduled Job was created.
        tags (`list[str]` or `None`):
            The tags of the scheduled Job.
        schedule (`str` or `None`):
            One of "@annually", "@yearly", "@monthly", "@weekly", "@daily", "@hourly", or a
            CRON schedule expression (e.g., '0 9 * * 1' for 9 AM every Monday).
        suspend (`bool` or `None`):
            Whether the scheduled job is suspended (paused).
        concurrency (`bool` or `None`):
            Whether multiple instances of this Job can run concurrently.
        status (`ScheduledJobStatus` or `None`):
            Status of the scheduled Job.
        owner: (`JobOwner` or `None`):
            Owner of the scheduled Job, e.g. `JobOwner(id="5e9ecfc04957053f60648a3e", name="lhoestq", type="user")`
        job_spec: (`JobSpec` or `None`):
            Specifications of the Job.

    Example:

    ```python
    >>> from huggingface_hub import run_job
    >>> scheduled_job = create_scheduled_job(
    ...     image="python:3.12",
    ...     command=["python", "-c", "print('Hello from the cloud!')"],
    ...     schedule="@hourly",
    ... )
    >>> scheduled_job.id
    '687fb701029421ae5549d999'
    >>> scheduled_job.status.next_job_run_at
    datetime.datetime(2025, 7, 22, 17, 6, 25, 79000, tzinfo=datetime.timezone.utc)
    ```
    r!   Nr&   job_specschedulesuspendconcurrencyr0   r1   r4   c                 *   |d         | _         |                    d          p|                    d          }|rt          |          nd | _        t	          di |                    d          p|                    di           | _        |                    d          | _        |                    d          | _        |                    d          | _        |                    d	i           }t          |                    d
          p|                    d          |                    d          p|                    d                    | _
        |                    di           }t          |d         |d         |d                   | _        d S )Nr!   r6   r&   ra   jobSpecrb   rc   rd   r0   rZ   r]   r[   r^   )rZ   r[   r1   r"   r#   r9   r   )r!   rC   r
   r&   rL   ra   rb   rc   rd   rY   r0   r    r1   )rE   rF   r&   r0   r1   s        r   rG   zScheduledJobInfo.__init__  s\   ,ZZ,,H

<0H0H
8BL.444XX6::j#9#9#VVZZ	SU=V=VXX

:..zz),,!::m44Hb))(ZZ
++Dvzz)/D/D"JJ'899WVZZ=W=W
 
 
 

7B''t5=uV}UUU


r   rH   )r   r   r   r   r   r   r   rL   boolrY   r    rG   r   r   r   r`   r`      s         & &P 	GGG4DjD[OOOV V V V V Vr   r`   c                   N    e Zd ZU dZeed<   eed<   eed<   eed<   eed<   d
d	ZdS )JobAcceleratora  
    Contains information about a Job accelerator (GPU).

    Args:
        type (`str`):
            Type of accelerator, e.g. `"gpu"`.
        model (`str`):
            Model of accelerator, e.g. `"T4"`, `"A10G"`, `"A100"`, `"L4"`, `"L40S"`.
        quantity (`str`):
            Number of accelerators, e.g. `"1"`, `"2"`, `"4"`, `"8"`.
        vram (`str`):
            Total VRAM, e.g. `"16 GB"`, `"24 GB"`.
        manufacturer (`str`):
            Manufacturer of the accelerator, e.g. `"Nvidia"`.
    r#   modelquantityvrammanufacturerr4   Nc                     |d         | _         |d         | _        |d         | _        |d         | _        |d         | _        d S )Nr#   rj   rk   rl   rm   )r#   rj   rk   rl   rm   rW   s     r   rG   zJobAccelerator.__init__,  sB    6N	G_
z*6N	">2r   rH   )r   r   r   r   r   r   rG   r   r   r   ri   ri     sf            IIIJJJMMM
III3 3 3 3 3 3r   ri   c                   r    e Zd ZU dZeed<   eed<   eed<   eed<   edz  ed<   eed<   eed	<   eed
<   ddZ	dS )JobHardwarea  
    Contains information about available Job hardware.

    Args:
        name (`str`):
            Machine identifier, e.g. `"cpu-basic"`, `"a10g-large"`.
        pretty_name (`str`):
            Human-readable name, e.g. `"CPU Basic"`, `"Nvidia A10G - large"`.
        cpu (`str`):
            CPU specification, e.g. `"2 vCPU"`, `"12 vCPU"`.
        ram (`str`):
            RAM specification, e.g. `"16 GB"`, `"46 GB"`.
        accelerator (`JobAccelerator` or `None`):
            GPU/accelerator details if available.
        unit_cost_micro_usd (`int`):
            Cost in micro-dollars per unit, e.g. `167` (= $0.000167).
        unit_cost_usd (`float`):
            Cost in USD per unit, e.g. `0.000167`.
        unit_label (`str`):
            Cost unit period, e.g. `"minute"`.

    Example:

    ```python
    >>> from huggingface_hub import list_jobs_hardware
    >>> hardware_list = list_jobs_hardware()
    >>> hardware_list[0]
    JobHardware(name='cpu-basic', pretty_name='CPU Basic', cpu='2 vCPU', ram='16 GB', accelerator=None, unit_cost_micro_usd=167, unit_cost_usd=0.000167, unit_label='minute')
    >>> hardware_list[0].name
    'cpu-basic'
    ```
    r"   pretty_namecpuramNacceleratorunit_cost_micro_usdunit_cost_usd
unit_labelr4   c                    |d         | _         |d         | _        |d         | _        |d         | _        |                    d          }|rt          d	i |nd | _        |d         | _        |d         | _        |d         | _	        d S )
Nr"   
prettyNamerr   rs   rt   unitCostMicroUSDunitCostUSD	unitLabelr   )
r"   rq   rr   rs   rC   ri   rt   ru   rv   rw   )rE   rF   rt   s      r   rG   zJobHardware.__init__`  s    6N	!,/%=%=jj//<GQ>88K888T#)*<#= #M2 -r   rH   )
r   r   r   r   r   r   ri   rR   floatrG   r   r   r   rp   rp   4  s          B III	HHH	HHH$&&&&OOO	. 	. 	. 	. 	. 	.r   rp   N)r.   r/   imager)   envr,   r-   rM   r.   r/   r4   c                    |g |pi |pt           j        d}|r||d<   |roddddd}	t          |t                    rA|d         |	v r7t	          t          |d d                   |	|d                  z            |d	<   nt	          |          |d	<   |r||d
<   |rd |D             |d<   dD ]3}
|                     |
          r| t          |
          d          |d<    n4| |d<   |S )N)r)   r*   r+   r-   r,      <   i  iQ )smhdtimeoutSecondsr.   c                 6    g | ]}|                                 S r   )to_dict)r>   vols     r   r@   z$_create_job_spec.<locals>.<listcomp>  s     @@@s{{}}@@@r   r/   )zhttps://huggingface.co/spaces/zhttps://hf.co/spaces/zhuggingface.co/spaces/zhf.co/spaces/r8   r7   )r   	CPU_BASIC
isinstancer   rR   r}   
startswithlen)r~   r)   r   r,   r-   rM   r.   r/   ra   time_units_factorsprefixs              r   _create_job_specr   l  sP    yb3M3	   H  &% 6#$2DyIIgs## 	67I(I(I),U73B3<-@-@CUV]^`VaCb-b)c)cH%&&),WH%& $# A@@@@@ 
( 
( F## 	"'F"6HYE	 #(Or   )dataclassesr   r   enumr   typingr   huggingface_hubr   huggingface_hub._space_apir   r	   huggingface_hub.utils._datetimer
   r   r   r   r    r%   rL   rT   rY   r`   ri   rp   rI   rJ   rR   r}   r   r   r   r   <module>r      s   " ! ! ! ! !                   % % % % % % < < < < < < < < : : : : : :    sD   (        
         ^G ^G ^G ^G ^G ^G ^G ^GB K K K K K K K K< / / / / / / / / a a a a a a a a @V @V @V @V @V @V @V @VF 3 3 3 3 3 3 3 3> 4. 4. 4. 4. 4. 4. 4. 4.~ %)#'. . .. #Y. 
c3h$		.
 #s(^d". D . 5[3%. cNT!. &\D . 
#s(^. . . . . .r   