U
    $FZh{#                     @   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)Z
DESCRIPTORZ	full_name)klassprefixname r	   f/home/aprabhat/apps/x.techxrdev.in/venv/lib/python3.8/site-packages/google/cloud/operation/__init__.py_compute_type_url   s    r   Nc                 C   sB   |dkrt | }|tkr6t| | k	r6t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   Z
FromStringvalue)Zany_pbr   r	   r	   r
   	_from_anyA   s    
r   c                   @   sx   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|}|| 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   s4   t |t }| |j|f|}|| 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   Z	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   ZGetOperationRequestr   r   Z_operations_stubZGetOperation)r   Z
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   _connectionZapi_requestr   r   r   r   )r   r%   Zapi_responser	   r	   r
   _get_operation_http   s    zOperation._get_operation_httpc                 C   s   | j r|  S |  S dS )zChecks the status of the current operation.

        :rtype: :class:`~google.longrunning.operations_pb2.Operation`
        :returns: The latest status of the current operation.
        N)r   r"   r'   r    r	   r	   r
   _get_operation   s    zOperation._get_operationc                 C   sV   |j rd| _|dr"t|j| _|d}|dkr>|j| _n|dkrRt|j| _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   ZHasFieldr   r)   Z
WhichOneofr*   r+   )r   r   Z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   r(   r   )r   r   r	   r	   r
   poll   s
    
zOperation.poll)__name__
__module____qualname____doc__targetr+   r*   r)   r   r   classmethodr   r   propertyr!   r"   r'   r(   r   r-   r	   r	   r	   r
   r   U   s$   


r   )N)r1   typingr   Zgoogle.longrunningr   Zgoogle.protobufr   Z_GOOGLE_APIS_PREFIXr   strtype__annotations__r   r   r   objectr   r	   r	   r	   r
   <module>   s   
