U kg @sfdZddlZddlZddlZddlmZddlmZddlZddl Z ddl m Z ddl Z ddlmZz ddlZWnek rdZYnXddZd ejdd Zd Zd Zd ZdZdZdZdZd ZdZdZdZdZ dZ!dZ"Gddde#Z$Gddde$Z%Gddde$Z&Gddde$Z'e(Z)Z*edddZ+e+,d d!krJd"d#Z-n"e+,d$d!krdd%d#Z-nd&d#Z-[+d'd(Z.Gd)d*d*Z/d+d,Z0d-d.Z1Gd/d0d0Z2d1d2Z3e/e2fZ4Gd3d4d4Z5Gd5d6d6Z6Gd7d8d8Z7Gd9d:d:Z8Gd;d<d<Z9Gd=d>d>Z:dZ;ZdZdBdCZ?d[dDdEZ@dFdGZAd\dIdJZBGdKdLdLerXejCneDZEGdMdNdNZFGdOdPdPZGGdQdRdReGZHGdSdTdTZIeIZJeKdUkrbeIdVZLzeMeLjNOWn.e$k rZPzeMdWePW5dZP[PXYnXe:eLZQeQReQSd dXeQTdd zeQD]ZUeMeUq Wn.e$k r`ZPzeMdWePW5dZP[PXYnXdS)]a An XML-RPC client interface for Python. The marshalling and response parser code can also be used to implement XML-RPC servers. Exported exceptions: Error Base class for client errors ProtocolError Indicates an HTTP protocol error ResponseError Indicates a broken response package Fault Indicates an XML-RPC fault package Exported classes: ServerProxy Represents a logical connection to an XML-RPC server MultiCall Executor of boxcared xmlrpc requests DateTime dateTime wrapper for an ISO 8601 string or time tuple or localtime integer value to generate a "dateTime.iso8601" XML-RPC value Binary binary data wrapper Marshaller Generate an XML-RPC params chunk from a Python data structure Unmarshaller Unmarshal an XML-RPC response from incoming XML event message Transport Handles an HTTP transaction to an XML-RPC server SafeTransport Handles an HTTPS transaction to an XML-RPC server Exported constants: (none) Exported functions: getparser Create instance of the fastest available parser & attach to an unmarshalling object dumps Convert an argument tuple or a Fault instance to an XML-RPC request (or response, if the methodresponse option is used). loads Convert an XML-RPC packet to unmarshalled data plus a method name (None if not present). N)datetime)Decimal)expat)BytesIOcCs$|dd}|dd}|ddS)N&z&z>)replace)sr #/usr/lib/python3.8/xmlrpc/client.pyescapes  r z%d.%diiiDii ipiԁiCiBiiic@seZdZdZejZdS)ErrorzBase class for client errors.N)__name__ __module__ __qualname____doc__object__str__r r r r rsrc@s eZdZdZddZddZdS) ProtocolErrorz!Indicates an HTTP protocol error.cCs&t|||_||_||_||_dSN)r__init__urlerrcodeerrmsgheaders)selfrrrrr r r rs  zProtocolError.__init__cCsd|jj|j|j|jfS)Nz<%s for %s: %s %s>) __class__rrrrrr r r __repr__szProtocolError.__repr__Nrrrrrr r r r r rsrc@seZdZdZdS) ResponseErrorz$Indicates a broken response package.N)rrrrr r r r r"sr"c@s eZdZdZddZddZdS)Faultz#Indicates an XML-RPC fault package.cKst|||_||_dSr)rr faultCode faultString)rr$r%Zextrar r r rs zFault.__init__cCsd|jj|j|jfS)Nz <%s %s: %r>)rrr$r%rr r r r szFault.__repr__Nr!r r r r r#sr#z%YZ0001cCs |dSN%Y%m%dT%H:%M:%Sstrftimevaluer r r _iso8601_format sr-z%4YcCs |dS)Nz%4Y%m%dT%H:%M:%Sr)r+r r r r-scCs|ddS)Nr()r*zfillr+r r r r-scCsLt|trt|St|ttjfs<|dkr2t}t|}d|ddS)Nrz%04d%02d%02dT%02d:%02d:%02d) isinstancerr-tupletime struct_time localtimer+r r r _strftimes  r6c@sreZdZdZdddZddZddZd d Zd d Zd dZ ddZ ddZ ddZ ddZ ddZddZdS)DateTimezDateTime wrapper for an ISO 8601 string or time tuple or localtime integer value to generate 'dateTime.iso8601' XML-RPC value. rcCs t|tr||_n t||_dSr)r1strr,r6)rr,r r r r(s zDateTime.__init__cCst|tr|j}|j}nzt|tr2|j}t|}n`t|trH|j}|}nJt|drd|}|}n.t|drv|jj p|t |}t d|jj |f||fS)N timetuplerzCan't compare %s and %s) r1r7r,rr-r8hasattrr9rrtype TypeError)rotherr oZotyper r r make_comparable.s*        zDateTime.make_comparablecCs||\}}||kSrr?rr=r r>r r r __lt__CszDateTime.__lt__cCs||\}}||kSrr@rAr r r __le__GszDateTime.__le__cCs||\}}||kSrr@rAr r r __gt__KszDateTime.__gt__cCs||\}}||kSrr@rAr r r __ge__OszDateTime.__ge__cCs||\}}||kSrr@rAr r r __eq__SszDateTime.__eq__cCst|jdSr')r3strptimer,rr r r r9WszDateTime.timetuplecCs|jSrr+rr r r r_szDateTime.__str__cCsd|jj|jt|fS)Nz<%s %r at %#x>)rrr,idrr r r r bszDateTime.__repr__cCst||_dSr)r8stripr,rdatar r r decodeeszDateTime.decodecCs$|d||j|ddSNzz )writer,)routr r r encodehs  zDateTime.encodeN)r)rrrrrr?rBrCrDrErFr9rr rLrPr r r r r7"s r7cCst}|||Sr)r7rLrKr,r r r _datetimems rRcCs t|dSr')rrG)rKr r r _datetime_typessrSc@s:eZdZdZd ddZddZddZd d Zd d ZdS)BinaryzWrapper for binary data.NcCs>|dkrd}n&t|ttfs,td|jjt|}||_dS)Nz#expected bytes or bytearray, not %s)r1bytes bytearrayr<rrrKrJr r r rszBinary.__init__cCs t|jdS)Nzlatin-1)r8rKrr r r rszBinary.__str__cCst|tr|j}|j|kSr)r1rTrK)rr=r r r rFs z Binary.__eq__cCst||_dSr)base64 decodebytesrKrJr r r rLsz Binary.decodecCs4|dt|j}||d|ddSNz asciiz )rNrX encodebytesrKrL)rrOencodedr r r rPs  z Binary.encode)N) rrrrrrrFrLrPr r r r rT|s  rTcCst}|||Sr)rTrLrQr r r _binarys r^c@s$eZdZddZddZddZdS) ExpatParsercCsDtdd|_}||_|j|_|j|_|j|_ d}| |ddSr) rZ ParserCreate_parser_targetstartZStartElementHandlerendZEndElementHandlerrKZCharacterDataHandlerxml)rtargetparserencodingr r r rszExpatParser.__init__cCs|j|ddSNr)r`ParserJr r r feedszExpatParser.feedcCs8z |j}Wntk rYnX|`|`|dddS)NrUT)r`AttributeErrorrari)rrfr r r closes  zExpatParser.closeN)rrrrrjrlr r r r r_s r_c@seZdZdZdddZiZddZdd Zd d Zeee d<d d Z e ee <ddZ e ee <e ZddZeee<efddZeee<ddZeee<eee<ddZeee<eee<efddZeee<ddZeee<ddZeee<eee <eed<dS) MarshalleravGenerate an XML-RPC params chunk from a Python data structure. Create a Marshaller instance for each set of parameters, and use the "dumps" method to convert your data (represented as a tuple) to an XML-RPC params chunk. To write a fault response, pass a Fault instance instead. You may prefer to use the "dumps" module function for this purpose. NFcCsi|_d|_||_||_dSr)memorKrg allow_none)rrgror r r rszMarshaller.__init__cCsg}|j}|j}t|tr@|d||j|jd||dn4|d|D]}|d||||dqL|dd|}|S) Nz )r$r%z z z z z )append_Marshaller__dumpr1r#r$r%join)rvaluesrOrNdumpvresultr r r dumpss&     zMarshaller.dumpscCsz|jt|}Wnftk rxt|ds)ror<rr,rNr r r dump_nil szMarshaller.dump_nilcCs$|d||rdpd|ddS)Nz10z r rr r r dump_boolszMarshaller.dump_boolcCs<|tks|tkrtd|d|tt||ddS)Nzint exceeds XML-RPC limitsz z )MAXINTMININT OverflowErrorr8intrr r r dump_longs zMarshaller.dump_longcCs |d|t||ddS)Nzz )reprrr r r dump_double$s zMarshaller.dump_doublecCs |d||||ddS)Nzz r )rr,rNr r r r dump_unicode*s zMarshaller.dump_unicodecCs,|dt|}||d|ddSrZ)rXr\rL)rr,rNr]r r r dump_bytes0s zMarshaller.dump_bytescCsZt|}||jkrtdd|j|<|j}|d|D]}|||q6|d|j|=dS)Nz"cannot marshal recursive sequencesz z )rHrnr<rr)rr,rNirurvr r r dump_array8s   zMarshaller.dump_arraycCst|}||jkrtdd|j|<|j}|d|D]D\}}|dt|ts\td|d||||||dq:|d|j|=dS)Nz%cannot marshal recursive dictionariesz z zdictionary key must be stringz%s z z )rHrnr<rritemsr1r8)rr,rNr rrukrvr r r dump_structFs     zMarshaller.dump_structcCs |d|t||ddSrM)r6rr r r dump_datetimeXs zMarshaller.dump_datetimecCs2|jtkr ||_|||`n||j|dSr)rWRAPPERSrNrPrryrr r r dump_instance^s   zMarshaller.dump_instancerz)NF)!rrrrrr{rxrrrr;rboolrrZdump_intrfloatr rr8rrVrWrr2listrdictrrrr7rTr r r r rms<      rmc@sneZdZdZdEddZddZddZd d Zd d Zd dZ ddZ ddZ iZ ddZ e e d<ddZee d<ddZee d<ee d<ee d<ee d<ee d<ee d <d!d"Zee d#<ee d$<d%d&Zee d'<d(d)Zee d*<ee d+<d,d-Zee d.<d/d0Zee d1<d2d3Zee d4<d5d6Zee d7<d8d9Zee d:<d;d<Zee d=<d>d?Zee d@<dAdBZee dC<dDS)F UnmarshalleraUnmarshal an XML-RPC response, based on incoming XML event messages (start, data, end). Call close() to get the resulting data structure. Note that this reader is fairly tolerant, and gladly accepts bogus XML-RPC data without complaining (but not bogus XML). FcCsHd|_g|_g|_g|_d|_d|_d|_|jj|_|p:||_||_ dS)NFutf-8) _type_stack_marks_data_value _methodname _encodingrq _use_datetime _use_bytes)r use_datetimeuse_builtin_typesr r r r~s  zUnmarshaller.__init__cCs:|jdks|jrt|jdkr0tf|jdt|jS)Nfaultr)rrr"r#rr2rr r r rls  zUnmarshaller.closecCs|jSr)rrr r r getmethodnameszUnmarshaller.getmethodnamecCs ||_dSr)r)rrgZ standaloner r r rdszUnmarshaller.xmlcCshd|kr|dd}|dks&|dkr8|jt|jg|_|jrZ||jkrZtd||dk|_dS)N:arraystructzunknown tag %rr,) splitrrqlenrrrr{r")rtagZattrsr r r rbs zUnmarshaller.startcCs|j|dSr)rrq)rtextr r r rKszUnmarshaller.datac Csvz|j|}WnTtk rbd|kr,YdSz|j|dd}Wntk r\YYdSXYnX||d|jS)Nrrrp)r{r|rrsr)rrrr r r rcszUnmarshaller.endc Csnz|j|}WnTtk rbd|kr,YdSz|j|dd}Wntk r\YYdSXYnX|||S)Nrr)r{r|r)rrrKrr r r end_dispatchszUnmarshaller.end_dispatchcCs|dd|_dSrh)rqrrJr r r end_nils zUnmarshaller.end_nilZnilcCs:|dkr|dn|dkr(|dntdd|_dS)NrFrTzbad boolean valuer)rqr<rrJr r r end_booleans   zUnmarshaller.end_booleanbooleancCs|t|d|_dSrh)rqrrrJr r r end_intszUnmarshaller.end_intZi1Zi2Zi4Zi8rZ bigintegercCs|t|d|_dSrh)rqrrrJr r r end_doubleszUnmarshaller.end_doubleZdoublercCs|t|d|_dSrh)rqrrrJr r r end_bigdecimalszUnmarshaller.end_bigdecimalZ bigdecimalcCs&|jr||j}||d|_dSrh)rrLrqrrJr r r end_strings  zUnmarshaller.end_stringstringnamecCs.|j}|j|dg|j|d<d|_dSrh)rpoprr)rrKmarkr r r end_arrays zUnmarshaller.end_arrayrcCs`|j}i}|j|d}tdt|dD]}||d|||<q,|g|j|d<d|_dS)Nrrr&)rrrrangerr)rrKrrrrr r r end_structs zUnmarshaller.end_structrcCs6t}||d|jr"|j}||d|_dS)Nr[r)rTrLrPrrKrqrrrKr,r r r end_base64 s  zUnmarshaller.end_base64rXcCs,t}|||jrt|}||dSr)r7rLrrSrqrr r r end_dateTimes  zUnmarshaller.end_dateTimezdateTime.iso8601cCs|jr||dSr)rrrJr r r end_valueszUnmarshaller.end_valuer,cCs d|_dS)NparamsrrJr r r end_params"szUnmarshaller.end_paramsrcCs d|_dS)NrrrJr r r end_fault&szUnmarshaller.end_faultrcCs"|jr||j}||_d|_dS)N methodName)rrLrrrJr r r end_methodName*s zUnmarshaller.end_methodNamerN)FF)rrrrrrlrrdrbrKrcrr{rrrrrrrrrrrrrrr r r r rrsZ   rc@s$eZdZddZddZddZdS)_MultiCallMethodcCs||_||_dSr)_MultiCallMethod__call_list_MultiCallMethod__name)rZ call_listrr r r r7sz_MultiCallMethod.__init__cCst|jd|j|fSNz%s.%s)rrrrrr r r __getattr__:sz_MultiCallMethod.__getattr__cGs|j|j|fdSr)rrqrrargsr r r __call__<sz_MultiCallMethod.__call__Nrrrrrrr r r r r4src@s eZdZdZddZddZdS)MultiCallIteratorzaIterates over the results of a multicall. Exceptions are raised in response to xmlrpc faults.cCs ||_dSr)results)rrr r r rCszMultiCallIterator.__init__cCsR|j|}t|tikr.t|d|dn t|tgkrF|dStddS)Nr$r%rz#unexpected type in multicall result)rr;r# ValueError)rritemr r r __getitem__Fs  zMultiCallIterator.__getitem__N)rrrrrrr r r r r?src@s0eZdZdZddZddZddZdd Zd S) MultiCalla~server -> an object used to boxcar method calls server should be a ServerProxy object. Methods can be added to the MultiCall using normal method call syntax e.g.: multicall = MultiCall(server_proxy) multicall.add(2,3) multicall.get_address("Guido") To execute the multicall, call the MultiCall object e.g.: add_result, address = multicall() cCs||_g|_dSr)_MultiCall__server_MultiCall__call_list)rserverr r r r`szMultiCall.__init__cCsd|jjt|fS)Nz <%s at %#x>)rrrHrr r r r dszMultiCall.__repr__cCs t|j|Sr)rrrr r r rgszMultiCall.__getattr__cCs6g}|jD]\}}|||dq t|jj|S)N)rr)rrqrrsystemZ multicall)rZmarshalled_listrrr r r rjszMultiCall.__call__N)rrrrrr rrr r r r rOs rFcCsrtrHtrH|rt}tj}n|r&t}t}nt}t}tdd||t}t|}n"t||d}trbt|}nt |}||fS)zgetparser() -> parser, unmarshaller Create an instance of the fastest available parser, and attach it to an unmarshalling object. Return both objects. TFrr) FastParserFastUnmarshallerrSrXrYr^rRr#rr_)rrZ mkdatetimeZmkbytesrerfr r r getparser|s    rcCst|ttfstdt|tr&d}n"|rHt|trHt|dksHtd|sPd}tr^t|}n t||}||}|dkrdt|}nd}|r|d|d|d f}n|r|d |d f}n|Sd |S) adata [,options] -> marshalled data Convert an argument tuple or a Fault instance to an XML-RPC request (or response, if the methodresponse option is used). In addition to the data object, the following options can be given as keyword arguments: methodname: the method name for a methodCall packet methodresponse: true to create a methodResponse packet. If this option is used with a tuple, the tuple must be a singleton (i.e. it can contain only one element). encoding: the packet encoding (default is UTF-8) All byte strings in the data structure are assumed to use the packet encoding. Unicode strings are automatically converted, where necessary. z(argument must be tuple or Fault instancer&z"response tuple must be a singletonrz$ z z z z z z rp) r1r2r#AssertionErrorrFastMarshallerrmrxr8rs)r methodnameZmethodresponsergromrKZ xmlheaderr r r rxs<    rxcCs2t||d\}}|||||fS)zdata -> unmarshalled data, method name Convert an XML-RPC packet to unmarshalled data plus a method name (None if not present). If the XML-RPC packet represents a fault condition, this function raises a Fault exception. r)rrjrlr)rKrrpur r r loadss  rc Cs<tstt}tjd|dd}||W5QRX|S)zhdata -> gzip encoded data Encode data using the gzip content encoding as described in RFC 1952 wbr&)modefileobjZ compresslevel)gzipNotImplementedErrorrGzipFilerNgetvalue)rKrgzfr r r gzip_encodes r@c Cststtjdt|dH}z$|dkr0|}n||d}Wntk r\tdYnXW5QRX|dkrt||krtd|S)zrgzip encoded data -> unencoded data Decode data using the gzip content encoding as described in RFC 1952 rbrrrr&z invalid dataz#max gzipped payload length exceeded)rrrrreadOSErrorrr)rKZ max_decoderZdecodedr r r gzip_decodes rc@s eZdZdZddZddZdS)GzipDecodedResponsezha file-like object to decode a response encoded with the gzip method, as described in RFC 1952. cCs.tstt||_tjj|d|jddS)Nrr)rrrriorr)rresponser r r r:szGzipDecodedResponse.__init__cCs"ztj|W5|jXdSr)rrlrrrr r r rlBszGzipDecodedResponse.closeN)rrrrrrlr r r r r6src@s$eZdZddZddZddZdS)_MethodcCs||_||_dSr _Method__send _Method__name)rsendrr r r rOsz_Method.__init__cCst|jd|j|fSr)rrrrr r r rRsz_Method.__getattr__cGs||j|Srrrr r r rTsz_Method.__call__Nrr r r r rLsrc@seZdZdZdeZdZdZddddd Zdd d Z d d d Z ddZ ddZ ddZ ddZddZddZddZddZdS)! Transportz1Handles an HTTP transaction to an XML-RPC server.zPython-xmlrpc/%sTNFr )rcCs&||_||_d|_t||_g|_dSN)NN)r_use_builtin_types _connectionr_headers_extra_headers)rrrrr r r rks  zTransport.__init__c CsdD]v}z|||||WStjjk r<|r8Yqtk rx}z |sf|jtjtjtjfkrhW5d}~XYqXqdS)N)rr&) single_requesthttpclientZRemoteDisconnectedrerrnoZ ECONNRESETZ ECONNABORTEDZEPIPE)rhosthandler request_bodyverboserer r r request}szTransport.requestcCsz8|||||}|}|jdkr6||_||WSWn2tk rNYntk rj|YnX|ddr| t |||j|j t | dS)Nzcontent-lengthrp) send_requestZ getresponseZstatusr parse_responser# Exceptionrl getheaderrrreasonrZ getheaders)rr r r r Z http_connZrespr r r rs&   zTransport.single_requestcCst|j|jdS)Nr)rrrrr r r rszTransport.getparsercCsri}t|tr|\}}tj|\}}|rdtj|}t|d}d | }dd|fg}ng}|||fS)NrrpZ AuthorizationzBasic ) r1r2urllibparseZ _splituserZunquote_to_bytesrXr\rLrsr)rr x509ZauthZ extra_headersr r r get_host_infos   zTransport.get_host_infocCsL|jr||jdkr|jdS||\}|_}|tj|f|_|jdS)Nrr&)rrrrrZHTTPConnectionrr Zchostrr r r make_connections  zTransport.make_connectioncCs |j\}}|rd|_|dSr)rrl)rr  connectionr r r rls zTransport.closecCs||}|j|j}|r$|d|jrJtrJ|jd|dd|dn |d||d|d|jf| ||| |||S)Nr&ZPOSTT)Zskip_accept_encoding)zAccept-Encodingr)z Content-Typeztext/xmlz User-Agent) rrrZset_debuglevelaccept_gzip_encodingrZ putrequestrq user_agent send_headers send_content)rr r r debugrrr r r rs         zTransport.send_requestcCs|D]\}}|||qdSr) putheader)rrrkeyvalr r r rs zTransport.send_headerscCsR|jdk r0|jt|kr0tr0|ddt|}|dtt|||dS)NContent-EncodingrzContent-Length)encode_thresholdrrr"rr8Z endheaders)rrr r r r r s   zTransport.send_contentcCst|dr*|dddkr$t|}q.|}n|}|\}}|d}|sJqj|jr^tdt|||q:||k rz| | | S)Nrr%rprizbody:) r:rrrrr printrrjrl)rrstreamrrrKr r r r$s      zTransport.parse_response)FF)F)F)rrrr __version__rrr&rrrrrrrlrrr rr r r r r]s"  ! rcs2eZdZdZd dddfdd Zdd ZZS) SafeTransportz2Handles an HTTPS transaction to an XML-RPC server.Fr Nrcontextcstj|||d||_dS)Nrrr)superrr,)rrrrr,rr r rEs zSafeTransport.__init__cCst|jr||jdkr|jdSttjds2td||\}|_}|tjj|dfd|ji|p`if|_|jdS)Nrr&HTTPSConnectionz1your version of http.client doesn't support HTTPSr,) rr:rrrrrr0r,rr r r rNs    zSafeTransport.make_connection)FF)rrrrrr __classcell__r r r/r r*Bs  r*c@sZeZdZdZddddddZdd Zd d Zd d ZddZddZ ddZ ddZ dS) ServerProxyauri [,options] -> a logical connection to an XML-RPC server uri is the connection point on the server, given as scheme://host/target. The standard implementation always supports the "http" scheme. If SSL socket support is available (Python 2.0), it also supports "https". If the target part and the slash preceding it are both omitted, "/RPC2" is assumed. The following options can be given as keyword arguments: transport: a transport factory encoding: the request encoding (default is UTF-8) All 8-bit strings passed to the server proxy are assumed to use the given encoding. NFr r+c Cstj|\} }| dkr tdtj|\|_|_|js@d|_|dkr|| dkr^t} d| i} nt} i} | f|||d| }||_ |pd|_ ||_ ||_ dS)N)rhttpszunsupported XML-RPC protocolz/RPC2r3r,r-r) rrZ _splittyperZ _splithost_ServerProxy__host_ServerProxy__handlerr*r_ServerProxy__transport_ServerProxy__encoding_ServerProxy__verbose_ServerProxy__allow_none) rZuri transportrgr rorrrr,r;r Z extra_kwargsr r r rs,  zServerProxy.__init__cCs|jdSr)r6rlrr r r Z__closeszServerProxy.__closecCsPt|||j|jd|jd}|jj|j|j||jd}t |dkrL|d}|S)N)rgroxmlcharrefreplace)r r&r) rxr7r9rPr6rr4r5r8r)rrrrrr r r Z __requests  zServerProxy.__requestcCsd|jj|j|jfS)Nz <%s for %s%s>)rrr4r5rr r r r szServerProxy.__repr__cCs t|j|Sr)r_ServerProxy__requestrr r r rszServerProxy.__getattr__cCs.|dkr|jS|dkr|jStd|fdS)z|A workaround to get special attributes on the ServerProxy without interfering with the magic __getattr__ rlr:zAttribute %r not foundN)_ServerProxy__closer6rk)rattrr r r rs zServerProxy.__call__cCs|Srr rr r r __enter__szServerProxy.__enter__cGs |dSr)r=rr r r __exit__szServerProxy.__exit__)NNFFFF) rrrrrr=r<r rrr?r@r r r r r2ms   r2__main__zhttp://localhost:8000ZERROR )FF)NNNF)FF)r)VrrXsysr3rZdecimalrZ http.clientrZ urllib.parserZ xml.parsersrr rrr ImportErrorr version_infor)rrZ PARSE_ERRORZ SERVER_ERRORZAPPLICATION_ERRORZ SYSTEM_ERRORZTRANSPORT_ERRORZNOT_WELLFORMED_ERRORZUNSUPPORTED_ENCODINGZINVALID_ENCODING_CHARZINVALID_XMLRPCZMETHOD_NOT_FOUNDZINVALID_METHOD_PARAMSZINTERNAL_ERRORrrrr"r#rrZBooleanZ_day0r*r-r6r7rRrSrTr^rr_rmrrrrrrrrrxrrrrrrrrr*r2ZServerrrr'Z currentTimeZgetCurrentTimervZmultiZgetDatapowaddrr r r r Ys*           K #!(C %  ' K  f+h