o
    Mf{#                     @   st   U d Z ddlmZ ddlmZ ddlmZ dZi Zee	e
f ed< efddZdd
dZdd ZG dd deZd	S )z=Wrap long-running operations returned from Google Cloud APIs.    )Dict)operations_pb2)json_formatztype.googleapis.com_TYPE_URL_MAPc                 C   s   | j j}d||f S )a   Compute a type URL for a klass.

    :type klass: type
    :param klass: class to be used as a factory for the given type

    :type prefix: str
    :param prefix: URL prefix for the type

    :rtype: str
    :returns: the URL, prefixed as appropriate
    z%s/%s)
DESCRIPTOR	full_name)klassprefixname r   a/var/www/html/analyze/labelStudio/lib/python3.10/site-packages/google/cloud/operation/__init__.py_compute_type_url   s   r   Nc                 C   sB   |du rt | }|tv rt| | urtdt| f | t|< dS )a  Register a klass as the factory for a given type URL.

    :type klass: :class:`type`
    :param klass: class to be used as a factory for the given type

    :type type_url: str
    :param type_url: (Optional) URL naming the type. If not provided,
                     infers the URL from the type descriptor.

    :raises ValueError: if a registration already exists for the URL.
    NzConflict: %s)r   r   
ValueError)r   type_urlr   r   r   register_type,   s   r   c                 C   s   t | j }|| jS )a  Convert an ``Any`` protobuf into the actual class.

    Uses the type URL to do the conversion.

    .. note::

        This assumes that the type URL is already registered.

    :type any_pb: :class:`google.protobuf.any_pb2.Any`
    :param any_pb: An any object to be converted.

    :rtype: object
    :returns: The instance (of the correct type) stored in the any
              instance.
    )r   r   
FromStringvalue)any_pbr   r   r   r   	_from_anyA   s   
r   c                   @   s   e Zd ZdZdZ	 dZ	 dZ	 dZ	 dZdd Z	e
dd Ze
dd	 Zed
d Zdd Zdd Zdd Zdd Zdd ZdS )	Operationa  Representation of a Google API Long-Running Operation.

    .. _protobuf: https://github.com/googleapis/googleapis/blob/                  050400df0fdb16f63b63e9dee53819044bffc857/                  google/longrunning/operations.proto#L80
    .. _service: https://github.com/googleapis/googleapis/blob/                 050400df0fdb16f63b63e9dee53819044bffc857/                 google/longrunning/operations.proto#L38
    .. _JSON: https://cloud.google.com/speech/reference/rest/              v1beta1/operations#Operation

    This wraps an operation `protobuf`_ object and attempts to
    interact with the long-running operations `service`_ (specific
    to a given API). (Some services also offer a `JSON`_
    API that maps the same underlying data type.)

    :type name: str
    :param name: The fully-qualified path naming the operation.

    :type client: :class:`~google.cloud.client.Client`
    :param client: The client used to poll for the status of the operation.
                   If the operation was created via JSON/HTTP, the client
                   must own a :class:`~google.cloud._http.Connection`
                   to send polling requests. If created via protobuf, the
                   client must have a gRPC stub in the ``_operations_stub``
                   attribute.

    :type caller_metadata: dict
    :param caller_metadata: caller-assigned metadata about the operation
    NTc                 K   s    || _ || _| | _d| _d S )NF)r
   clientcopycaller_metadata	_complete)selfr
   r   r   r   r   r   __init__   s   

zOperation.__init__c                 K   s(   | |j |fi |}|| d|_|S )aD  Factory:  construct an instance from a protobuf.

        :type operation_pb:
            :class:`~google.longrunning.operations_pb2.Operation`
        :param operation_pb: Protobuf to be parsed.

        :type client: object: must provide ``_operations_stub`` accessor.
        :param client: The client used to poll for the status of the operation.

        :type caller_metadata: dict
        :param caller_metadata: caller-assigned metadata about the operation

        :rtype: :class:`Operation`
        :returns: new instance, with attributes based on the protobuf.
        T)r
   _update_state
_from_grpc)clsoperation_pbr   r   resultr   r   r   from_pb   s   
zOperation.from_pbc                 K   s8   t |t }| |j|fi |}|| d|_|S )a  Factory: construct an instance from a dictionary.

        :type operation: dict
        :param operation: Operation as a JSON object.

        :type client: :class:`~google.cloud.client.Client`
        :param client: The client used to poll for the status of the operation.

        :type caller_metadata: dict
        :param caller_metadata: caller-assigned metadata about the operation

        :rtype: :class:`Operation`
        :returns: new instance, with attributes based on the protobuf.
        F)r   	ParseDictr   r   r
   r   r   )r   	operationr   r   r   r    r   r   r   	from_dict   s
   
zOperation.from_dictc                 C   s   | j S )z|Has the operation already completed?

        :rtype: bool
        :returns: True if already completed, else false.
        )r   r   r   r   r   complete   s   zOperation.completec                 C   s   t j| jd}| jj|S )zPolls the status of the current operation.

        Uses gRPC request to check.

        :rtype: :class:`~google.longrunning.operations_pb2.Operation`
        :returns: The latest status of the current operation.
        )r
   )r   GetOperationRequestr
   r   _operations_stubGetOperation)r   
request_pbr   r   r   _get_operation_rpc   s   zOperation._get_operation_rpcc                 C   s.   d| j f }| jjjd|d}t|t S )zChecks the status of the current operation.

        Uses HTTP request to check.

        :rtype: :class:`~google.longrunning.operations_pb2.Operation`
        :returns: The latest status of the current operation.
        zoperations/%sGET)methodpath)r
   r   _connectionapi_requestr   r"   r   r   )r   r.   api_responser   r   r   _get_operation_http   s   zOperation._get_operation_httpc                 C   s   | j r|  S |  S )zChecks the status of the current operation.

        :rtype: :class:`~google.longrunning.operations_pb2.Operation`
        :returns: The latest status of the current operation.
        )r   r+   r2   r%   r   r   r   _get_operation   s   zOperation._get_operationc                 C   s\   |j rd| _|drt|j| _|d}|dkr |j| _dS |dkr,t|j| _dS dS )zUpdate the state of the current object based on operation.

        :type operation_pb:
            :class:`~google.longrunning.operations_pb2.Operation`
        :param operation_pb: Protobuf to be parsed.
        Tmetadatar    errorresponseN)doner   HasFieldr   r4   
WhichOneofr5   r6   )r   r   result_typer   r   r   r      s   

zOperation._update_statec                 C   s&   | j rtd|  }| | | j S )zCheck if the operation has finished.

        :rtype: bool
        :returns: A boolean indicating if the current operation has completed.
        :raises ValueError: if the operation
                 has already completed.
        zThe operation has completed.)r&   r   r3   r   )r   r   r   r   r   poll   s
   
zOperation.poll)__name__
__module____qualname____doc__targetr6   r5   r4   r   r   classmethodr!   r$   propertyr&   r+   r2   r3   r   r;   r   r   r   r   r   U   s.    


r   )N)r?   typingr   google.longrunningr   google.protobufr   _GOOGLE_APIS_PREFIXr   strtype__annotations__r   r   r   objectr   r   r   r   r   <module>   s   
