o
    7?eɍ                     @   s   d Z dZddlZddlmZ ddlZddlZddlmZ ddl	Z	ddl
Z
ddlmZ ddlmZ ddlmZ dd	lmZ d
ZeejjejjejjejjgZeejjejjgZeejjejjgZdZdZdZe	 dZ!e	 dZ"G dd de#Z$G dd de$Z%G dd de$Z&								dAddZ'					dBddZ(dd Z)G dd  d e*Z+d!d" Z,d#d$ Z-d%d& Z.			'dCd(d)Z/			'dCd*d+Z0e1e2fZ3G d,d- d-e*Z4dDd.d/Z5d0d1 Z6d2d3 Z7d4d5 Z8d6d7gd8d9gd8d9gd:d;gd<d=gd8d9gd>d?gd@Z9dS )Eat  Contains routines for printing protocol messages in JSON format.

Simple usage example:

  # Create a proto object and serialize it to a json format string.
  message = my_proto_pb2.MyMessage(foo='bar')
  json_string = json_format.MessageToJson(message)

  # Parse a json format string to proto object.
  message = json_format.Parse(json_string, my_proto_pb2.MyMessage())
zjieluo@google.com (Jie Luo)    N)OrderedDict)methodcaller)type_checkers)
descriptor)message_factory)symbol_databasez%Y-%m-%dT%H:%M:%SInfinityz	-InfinityNaNu.   [-](?![-])|(?<![-])[-]z\[[a-zA-Z0-9\._]*\]$c                   @      e Zd ZdZdS )Errorz'Top-level module error for json_format.N__name__
__module____qualname____doc__ r   r   \/home/www/facesmatcher.com/pyenv/lib/python3.10/site-packages/google/protobuf/json_format.pyr   O       r   c                   @   r
   )SerializeToJsonErrorz&Thrown if serialization to JSON fails.Nr   r   r   r   r   r   S   r   r   c                   @   r
   )
ParseErrorz Thrown in case of parsing error.Nr   r   r   r   r   r   W   r   r   F   Tc	           
      C   s"   t |||||d}	|	| |||S )a  Converts protobuf message to JSON format.

  Args:
    message: The protocol buffers message instance to serialize.
    including_default_value_fields: If True, singular primitive fields,
        repeated fields, and map fields will always be serialized.  If
        False, only serialize non-empty fields.  Singular message fields
        and oneof fields are not affected by this option.
    preserving_proto_field_name: If True, use the original proto field
        names as defined in the .proto file. If False, convert the field
        names to lowerCamelCase.
    indent: The JSON object will be pretty-printed with this indent level.
        An indent level of 0 or negative will only insert newlines. If the
        indent level is None, no newlines will be inserted.
    sort_keys: If True, then the output will be sorted by field names.
    use_integers_for_enums: If true, print integers instead of enum names.
    descriptor_pool: A Descriptor Pool for resolving types. If None use the
        default.
    float_precision: If set, use this to specify float field valid digits.
    ensure_ascii: If True, strings with non-ASCII characters are escaped.
        If False, Unicode strings are returned unchanged.

  Returns:
    A string containing the JSON formatted protocol buffer message.
  float_precision)_PrinterToJsonString)
messageincluding_default_value_fieldspreserving_proto_field_nameindent	sort_keysuse_integers_for_enumsdescriptor_poolr   ensure_asciiprinterr   r   r   MessageToJson[   s   #r$   c                 C   s   t |||||d}|| S )a  Converts protobuf message to a dictionary.

  When the dictionary is encoded to JSON, it conforms to proto3 JSON spec.

  Args:
    message: The protocol buffers message instance to serialize.
    including_default_value_fields: If True, singular primitive fields,
        repeated fields, and map fields will always be serialized.  If
        False, only serialize non-empty fields.  Singular message fields
        and oneof fields are not affected by this option.
    preserving_proto_field_name: If True, use the original proto field
        names as defined in the .proto file. If False, convert the field
        names to lowerCamelCase.
    use_integers_for_enums: If true, print integers instead of enum names.
    descriptor_pool: A Descriptor Pool for resolving types. If None use the
        default.
    float_precision: If set, use this to specify float field valid digits.

  Returns:
    A dict representation of the protocol buffer message.
  r   )r   _MessageToJsonObject)r   r   r   r    r!   r   r#   r   r   r   MessageToDict   s   
r&   c                 C   s"   | j tjjko| jjo| j jS N)typer   FieldDescriptorZTYPE_MESSAGEmessage_typeZhas_optionsZ
GetOptionsZ	map_entry)fieldr   r   r   _IsMapEntry   s
   
r,   c                   @   st   e Zd ZdZ					dddZdd Zdd	 Zd
d Zdd Zdd Z	dd Z
dd Zdd Zdd Zdd ZdS )r   z)JSON format printer for protocol message.FNc                 C   s6   || _ || _|| _|| _|rd|| _d S d | _d S )Nz.{}g)r   r   r    r!   formatfloat_format)selfr   r   r    r!   r   r   r   r   __init__   s   
z_Printer.__init__c                 C   s   |  |}tj||||dS )N)r   r   r"   )r%   jsondumps)r/   r   r   r   r"   jsr   r   r   r      s   
z_Printer.ToJsonStringc                 C   sL   |j }|j}t|r| |S |tv rtt| d || S i }| ||S )zEConverts message to an object according to Proto3 JSON Specification.r   )
DESCRIPTOR	full_name_IsWrapperMessage_WrapperMessageToJsonObject_WKTJSONMETHODSr   _RegularMessageToJsonObject)r/   r   message_descriptorr5   r3   r   r   r   r%      s   
z_Printer._MessageToJsonObjectc              
      s  |  }z|D ]l\ }jr j}n j}t rF jjd }i }|D ]}t|tr2|r/d}	q6d}	nt	|}	
||| ||	< q#|||< q jtjjkrZ fdd|D ||< q jrkd j }
 |||< q
 |||< qjr|j}
|
jD ]D  jtjjkr jtjjks jrq}jr j}n j}||v rq}t ri ||< q} jtjjkrg ||< q}
  j||< q}W |S W |S  ty } z
td j||d}~ww )	z?Converts normal message according to Proto3 JSON Specification.valuetruefalsec                    s   g | ]}  |qS r   )_FieldToJsonObject).0kr+   r/   r   r   
<listcomp>   s    z8_Printer._RegularMessageToJsonObject.<locals>.<listcomp>z[%s]z#Failed to serialize {0} field: {1}.N)
ListFieldsr   name	json_namer,   r*   fields_by_name
isinstanceboolstrr>   labelr   r)   LABEL_REPEATEDis_extensionr5   r   r4   fieldscpp_typeCPPTYPE_MESSAGEcontaining_oneofdefault_value
ValueErrorr   r-   )r/   r   r3   rM   r;   rD   Zv_fieldZjs_mapkeyZrecorded_keyr:   er   rA   r   r9      st   






z$_Printer._RegularMessageToJsonObjectc                 C   s.  |j tjjkr| |S |j tjjkr9| jr|S |jjdkr dS |jj	
|d}|dur/|jS |jjr7td|S |j tjjkrQ|jtjjkrOt|dS |S |j tjjkr\t|S |j tv ret|S |j tv rt|rw|dk rutS tS t|r~tS |j tjjkr| j rt!t"|| j S t#$|S |S )z<Converts field value according to Proto3 JSON Specification.google.protobuf.NullValueNzKEnum field contains an integer value which can not mapped to an enum value.utf-8g        )%rN   r   r)   rO   r%   CPPTYPE_ENUMr    	enum_typer5   values_by_numbergetrD   	is_closedr   CPPTYPE_STRINGr(   
TYPE_BYTESbase64	b64encodedecodeCPPTYPE_BOOLrH   _INT64_TYPESrI   _FLOAT_TYPESmathisinf_NEG_INFINITY	_INFINITYisnan_NANCPPTYPE_FLOATr.   floatr-   r   ZToShortestFloat)r/   r+   r;   
enum_valuer   r   r   r>     sB   





z_Printer._FieldToJsonObjectc                 C   s   |  si S t }|j}||d< t|| j}||j |j}|j}t	|r/| 
||d< |S |tv rBtt| d || |d< |S | ||S )z<Converts Any message according to Proto3 JSON Specification.@typer;   r   )rC   r   type_url_CreateMessageFromTypeUrlr!   ZParseFromStringr;   r4   r5   r6   r7   r8   r   r9   )r/   r   r3   rn   sub_messager:   r5   r   r   r   _AnyMessageToJsonObjectB  s(   z _Printer._AnyMessageToJsonObjectc                 C   s   |  S )z8Converts message according to Proto3 JSON Specification.)r   r/   r   r   r   r   _GenericMessageToJsonObjectW  s   z$_Printer._GenericMessageToJsonObjectc                 C   s   | d}|du s|dkrdS |dkr| |jS |dkr3|j}t|r)tdt|r2tdnt||}|j	j
| }| ||S )z>Converts Value message according to Proto3 JSON Specification.kindN
null_value
list_valuenumber_valuezTFail to serialize Infinity for Value.number_value, which would parse as string_valuezOFail to serialize NaN for Value.number_value, which would parse as string_value)Z
WhichOneof_ListValueMessageToJsonObjectrv   rw   rd   re   rR   rh   getattrr4   rF   r>   )r/   r   whichr;   Zoneof_descriptorr   r   r   _ValueMessageToJsonObject]  s   



z"_Printer._ValueMessageToJsonObjectc                    s    fdd|j D S )zBConverts ListValue message according to Proto3 JSON Specification.c                    s   g | ]}  |qS r   )r{   )r?   r;   r/   r   r   rB   u  s    z:_Printer._ListValueMessageToJsonObject.<locals>.<listcomp>)valuesrr   r   r|   r   rx   s  s   
z&_Printer._ListValueMessageToJsonObjectc                 C   s*   |j }i }|D ]}| || ||< q|S )z?Converts Struct message according to Proto3 JSON Specification.)rM   r{   )r/   r   rM   retrS   r   r   r   _StructMessageToJsonObjectx  s
   z#_Printer._StructMessageToJsonObjectc                 C   s   |  |jjd |jS )Nr;   )r>   r4   rF   r;   rr   r   r   r   r7     s   z$_Printer._WrapperMessageToJsonObjectFFFNN)r   r   r   r   r0   r   r%   r9   r>   rq   rs   r{   rx   r   r7   r   r   r   r   r      s$    
@,r   c                 C   s   | j jdkS )Nzgoogle/protobuf/wrappers.proto)filerD   )r:   r   r   r   r6     s   r6   c                 C   s4   i }| D ]\}}||v rt d||||< q|S )Nz'Failed to load JSON: duplicate key {0}.)r   r-   )r3   resultrD   r;   r   r   r   _DuplicateChecker  s   
r   c              
   C   sp   t  }|du r|jn|}| dd }z||}W n ty/ } ztd| |d}~ww t	|}| S )z"Creates a message from a type URL.N/z0Can not find message descriptor by type_url: {0})
r   ZDefaultpoolsplitZFindMessageTypeByNameKeyError	TypeErrorr-   r   ZGetMessageClass)rn   r!   dbr   	type_namer:   rT   Zmessage_classr   r   r   ro     s   
ro   d   c              
   C   sd   t | ts
| d} z	tj| td}W n ty) } z
tdt||d}~ww t	|||||S )al  Parses a JSON representation of a protocol message into a message.

  Args:
    text: Message JSON representation.
    message: A protocol buffer message to merge into.
    ignore_unknown_fields: If True, do not raise errors for unknown fields.
    descriptor_pool: A Descriptor Pool for resolving types. If None use the
      default.
    max_recursion_depth: max recursion depth of JSON message to be
      deserialized. JSON messages over this depth will fail to be
      deserialized. Default value is 100.

  Returns:
    The same message passed as argument.

  Raises::
    ParseError: On JSON parsing problems.
  rV   )object_pairs_hookzFailed to load JSON: {0}.N)
rG   rI   r`   r1   loadsr   rR   r   r-   	ParseDict)textr   ignore_unknown_fieldsr!   max_recursion_depthr3   rT   r   r   r   Parse  s   


r   c                 C   s   t |||}|| |d |S )a8  Parses a JSON dictionary representation into a message.

  Args:
    js_dict: Dict representation of a JSON message.
    message: A protocol buffer message to merge into.
    ignore_unknown_fields: If True, do not raise errors for unknown fields.
    descriptor_pool: A Descriptor Pool for resolving types. If None use the
      default.
    max_recursion_depth: max recursion depth of JSON message to be
      deserialized. JSON messages over this depth will fail to be
      deserialized. Default value is 100.

  Returns:
    The same message passed as argument.
   )_ParserConvertMessage)Zjs_dictr   r   r!   r   parserr   r   r   r     s   r   c                   @   s`   e Zd ZdZdd Zdd Zdd Zdd	 Zd
d Zdd Z	dd Z
dd Zdd Zdd ZdS )r   z(JSON format parser for protocol message.c                 C   s   || _ || _|| _d| _d S )Nr   )r   r!   r   recursion_depth)r/   r   r!   r   r   r   r   r0     s   
z_Parser.__init__c                 C   s   |  j d7  _ | j | jkrtd| j|j}|j}|s |j}t|r,| ||| n|t	v r>t
t	| d ||||  n| ||| |  j d8  _ dS )a  Convert a JSON object into a message.

    Args:
      value: A JSON object.
      message: A WKT or regular protocol message to record the data.
      path: parent path to log parse error info.

    Raises:
      ParseError: In case of convert problems.
       z,Message too deep. Max recursion depth is {0}N)r   r   r   r-   r4   r5   rD   r6   _ConvertWrapperMessager8   r   _ConvertFieldValuePair)r/   r;   r   pathr:   r5   r   r   r   r     s   z_Parser.ConvertMessagec                 C   s4  g }|j }tdd |jD }|D ]}z||d}|s%|j|d}|sXt|rX|js8td	|j
||dd }	|j|	}|sXd|	ddd }	|j|	}|sp| jr_W qtd	|j
||d	d
 |jD ||v rtd	|j j
|||| || }
|jdur|
dur|jj}||v rtd	|j j
|||| |
du r|jtjjkr|jj
dkrt||j}d|_n|jtjjkr|jj
dkrt||jd n||j W qt|r||j | |
||d	|| n|j tjj!kr}||j t"|
t#std	||
||jtjjkrRt$|
D ].\}}t||j% }|du rB|j j
dkrBtd	|||| &||d	||| q!qt$|
D ]%\}}|du rhtd	|||t||jt'||d	||| qVnI|jtjjkr|j(r|j| }nt||j}|)  | &|
|d	|| n!|j(rt'|
|d	|||j|< nt||jt'|
|d	|| W q ty } z|r|jdu rtd	|||tt*||d}~w t+y } z	td	|||d}~w t,y } z	td	|||d}~ww dS )a'  Convert field value pairs into regular message.

    Args:
      js: A JSON object to convert the field value pairs.
      message: A regular protocol message to record the data.
      path: parent path to log parse error info.

    Raises:
      ParseError: In case of problems converting.
    c                 s   s    | ]}|j |fV  qd S r'   rE   r?   fr   r   r   	<genexpr>  s    z1_Parser._ConvertFieldValuePair.<locals>.<genexpr>Nz0Message type {0} does not have extensions at {1}r   r   .zaMessage type "{0}" has no field named "{1}" at "{2}".
 Available Fields(except extensions): "{3}"c                 S   s   g | ]}|j qS r   r   r   r   r   r   rB   .  s    z2_Parser._ConvertFieldValuePair.<locals>.<listcomp>zBMessage type "{0}" should not have multiple "{1}" fields at "{2}".zHMessage type "{0}" should not have multiple "{1}" oneof fields at "{2}".google.protobuf.Valuer   rU   {0}.{1}z4repeated field {0} must be in [] which is {1} at {2}zPnull is not allowed to be used as an element in a repeated field at {0}.{1}[{2}]z{0}.{1}[{2}]zFailed to parse {0} field: {1}.)-r4   dictrM   rZ   rF   _VALID_EXTENSION_NAMEmatchZis_extendabler   r-   r5   Z
ExtensionsZ_FindExtensionByNamejoinr   r   appendrP   rD   rN   r   r)   rO   r*   ry   ru   rW   rX   setattr
ClearFieldr,   _ConvertMapFieldValuerJ   rK   rG   list	enumerateaddr   _ConvertScalarFieldValuerL   ZSetInParentrI   rR   r   )r/   r3   r   r   namesr:   Zfields_by_json_namerD   r+   
identifierr;   Z
oneof_namerp   indexitemrT   r   r   r   r     s  















z_Parser._ConvertFieldValuePairc           	   
   C   s  t |tr	|s	dS z|d }W n ty# } ztd||d}~ww zt|| j}W n tyA } z	td|||d}~ww |j}|j	}t
|rY| |d |d| n%|tv rptt| d |d |d||  n|d= | ||| ||d< | |_||_dS )z/Convert a JSON representation into Any message.Nrm   z0@type is missing when parsing any message at {0}
{0} at {1}r;   	{0}.valuer   )rG   r   r   r   r-   ro   r!   r   r4   r5   r6   r   r8   r   r   ZSerializeToStringr;   rn   )	r/   r;   r   r   rn   rT   rp   r:   r5   r   r   r   _ConvertAnyMessage  sF   

z_Parser._ConvertAnyMessagec              
   C   s<   z| | W dS  ty } z	td|||d}~ww )z?Convert a JSON representation into message with FromJsonString.r   N)ZFromJsonStringrR   r   r-   )r/   r;   r   r   rT   r   r   r   _ConvertGenericMessage  s   z_Parser._ConvertGenericMessagec                 C   s   t |tr| ||j| dS t |tr| ||j| dS |du r'd|_dS t |tr1||_	dS t |t
r;||_dS t |trE||_dS td|t||)z1Convert a JSON representation into Value message.Nr   z(Value {0} has unexpected type {1} at {2})rG   r   _ConvertStructMessageZstruct_valuer   _ConvertListValueMessagerv   ru   rH   Z
bool_valuerI   Zstring_value_INT_OR_FLOATrw   r   r-   r(   )r/   r;   r   r   r   r   r   _ConvertValueMessage  s   









z_Parser._ConvertValueMessagec              	   C   sV   t |tstd|||d t|D ]\}}| ||j d|| qdS )z5Convert a JSON representation into ListValue message.z+ListValue must be in [] which is {0} at {1}r}   {0}[{1}]N)	rG   r   r   r-   r   r   r   r}   r   )r/   r;   r   r   r   r   r   r   r   r     s   


z _Parser._ConvertListValueMessagec              	   C   sP   t |tstd|||  |D ]}| || |j| d|| qdS )z2Convert a JSON representation into Struct message.z,Struct must be in a dict which is {0} at {1}r   N)rG   r   r   r-   ZClearr   rM   )r/   r;   r   r   rS   r   r   r   r     s   

z_Parser._ConvertStructMessagec              	   C   s,   |j jd }t|dt||d|d dS )z3Convert a JSON representation into Wrapper message.r;   r   r   N)r4   rF   r   r   r-   )r/   r;   r   r   r+   r   r   r   r     s
   z_Parser._ConvertWrapperMessagec           	   	   C   s   t |tstd|j|||jjd }|jjd }|D ]:}t||d|d}|jt	j
jkrD| || t||j| d|| qt|| |d||dt||j|< qdS )	af  Convert map field value for a message map field.

    Args:
      value: A JSON object to convert the map field value.
      message: A protocol message to record the converted data.
      field: The descriptor of the map field to be converted.
      path: parent path to log parse error info.

    Raises:
      ParseError: In case of convert problems.
    z3Map field {0} must be in a dict which is {1} at {2}rS   r;   z{0}.keyTr   r   N)rG   r   r   r-   rD   r*   rF   r   rN   r   r)   rO   r   ry   )	r/   r;   r   r+   r   Z	key_fieldZvalue_fieldrS   	key_valuer   r   r   r     s*   



z_Parser._ConvertMapFieldValueN)r   r   r   r   r0   r   r   r   r   r   r   r   r   r   r   r   r   r   r     s     	 	
r   c           	   
   C   s  z|j tv rt| W S |j tv rt| |W S |j tjjkr#t| |W S |j tjj	kr\|j
tjjkrPt| tr<| d}n| }|ddt|d    }t|W S t| rYtd| W S |j tjjkr|jj| d}|du rzt| }|jj|d}W n ty } ztd| |jj|d}~ww |du r|jjrtd| |jj|W S |jW S W dS  ty } z	td|||d}~ww )aq  Convert a single scalar field value.

  Args:
    value: A scalar value to convert the scalar field value.
    field: The descriptor of the field to convert.
    path: parent path to log parse error info.
    require_str: If True, the field value must be a str.

  Returns:
    The converted scalar field value

  Raises:
    ParseError: In case of convert problems.
  rV      =   zUnpaired surrogateNz(Invalid enum value {0} for enum type {1}r   ) rN   
_INT_TYPES_ConvertIntegerrc   _ConvertFloatr   r)   ra   _ConvertBoolr\   r(   r]   rG   rI   encodelenr^   urlsafe_b64decode_UNPAIRED_SURROGATE_PATTERNsearchr   rW   rX   Zvalues_by_namerZ   intrY   rR   r-   r5   r[   number)	r;   r+   r   require_strencodedZpadded_valuerl   r   rT   r   r   r   r     sV   




r   c                 C   sf   t | tr|  std| t | tr#| ddkr#td| t | tr/td| t| S )zConvert an integer.

  Args:
    value: A scalar value to convert.

  Returns:
    The integer value.

  Raises:
    ParseError: If an integer couldn't be consumed.
  zCouldn't parse integer: {0} r   zCouldn't parse integer: "{0}"z2Bool value {0} is not acceptable for integer field)	rG   rk   
is_integerr   r-   rI   findrH   r   )r;   r   r   r   r   <  s   
r   c              
   C   s  t | tr8t| rtdt| r| dkrtdtd|jtjj	kr8| t
jkr/td| t
jk r8td| dkr@tdzt| W S  ty } z2| tkr[td	W  Y d
}~S | tkritdW  Y d
}~S | tkrwtdW  Y d
}~S td| |d
}~ww )z!Convert an floating point number.z,Couldn't parse NaN, use quoted "NaN" insteadr   zICouldn't parse Infinity or value too large, use quoted "Infinity" insteadzKCouldn't parse -Infinity or value too small, use quoted "-Infinity" insteadzFloat value too largezFloat value too smallnanz-Couldn't parse float "nan", use "NaN" insteadz-infNinfzCouldn't parse float: {0})rG   rk   rd   rh   r   re   rN   r   r)   rj   r   Z
_FLOAT_MAXZ
_FLOAT_MINrR   rf   rg   ri   r-   )r;   r+   rT   r   r   r   r   U  s4   





r   c                 C   s@   |r| dkrdS | dkrdS t d| t| tst d| S )zConvert a boolean value.

  Args:
    value: A scalar value to convert.
    require_str: If True, value must be a str.

  Returns:
    The bool parsed.

  Raises:
    ParseError: If a boolean value couldn't be consumed.
  r<   Tr=   Fz#Expected "true" or "false", not {0}z%Expected true or false without quotes)r   r-   rG   rH   )r;   r   r   r   r   r   y  s   
r   rq   r   rs   r   rx   r   r   r   r{   r   )zgoogle.protobuf.Anyzgoogle.protobuf.Durationzgoogle.protobuf.FieldMaskzgoogle.protobuf.ListValuezgoogle.protobuf.Structzgoogle.protobuf.Timestampr   )FFr   FFNNTr   )FNr   )F):r   
__author__r^   collectionsr   r1   rd   operatorr   resysZgoogle.protobuf.internalr   Zgoogle.protobufr   r   r   Z_TIMESTAMPFOMAT	frozensetr)   ZCPPTYPE_INT32ZCPPTYPE_UINT32ZCPPTYPE_INT64ZCPPTYPE_UINT64r   rb   rj   ZCPPTYPE_DOUBLErc   rg   rf   ri   compiler   r   	Exceptionr   r   r   r$   r&   r,   objectr   r6   r   ro   r   r   r   rk   r   r   r   r   r   r   r8   r   r   r   r   <module>   s   

.
& S	
#
  
&:$
