Bd\Rc@sddlmZmZddlZddlTdddddd gZddd YZdefd YZdefd YZdefd YZ defdYZ d efdYZ dZ dS(i(t long_to_bytest bytes_to_longN(t*t DerObjectt DerIntegertDerOctetStringtDerNullt DerSequencet DerObjectIdcBseZdZidd6dd6dd6dd6d d 6d d 6Zded dZdZdZdZ dZ ddZ RS(sBase class for defining a single DER object. Instantiate this class ONLY when you have to decode a DER element. i0tSEQUENCEis BIT STRINGitINTEGERis OCTET STRINGitNULLisOBJECT IDENTIFIERtcCsjt|s|dkr$||_n9t|dkrHt||_n|jj||_||_dS(sInitialize the DER object according to a specific type. The ASN.1 type is either specified as the ASN.1 string (e.g. 'SEQUENCE'), directly with its numerical tag or with no tag at all (None).iN(tisInttNonettypeTagtlentordttypeTagstgettpayload(tselftASN1TypeR((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyt__init__'s  cCs|j||jkS(N(RR(RR((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pytisType6scCs:|dkr0t|}tt|d|St|S(sReturn a byte string that encodes the given payload length (in bytes) in a format suitable for a DER length tag (L). ii(RtbchrR(Rt payloadLentencoding((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyt _lengthOctets9s  cCs*t|j|jt|j|jS(s6Return a complete DER element, fully encoded as a TLV.(RRRRR(R((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pytencodeBscCs~t||}|dkr*||dfSt||d|d|d@!}|dkrhtdn||d|d@fS(sGiven a (part of a) DER element, and an index to the first byte of a DER length tag (L), return a tuple with the payload size, and the index of the first byte of the such payload (V). Raises a ValueError exception if the DER length is invalid. Raises an IndexError exception if the DER element is too short. iisNot a DER length tag.(tbordRt ValueError(Rtidxtdertlengtht payloadLength((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyt _decodeLenFs # icCsyt|d|_|jd@dkr8tdn|jd|\}}|r{t|||kr{tdn||||!|_Wntk rtdnX||S(sDecode a complete DER element, and re-initializes this object with it. @param derEle A complete DER element. It must start with a DER T tag. @param noLeftOvers Indicate whether it is acceptable to complete the parsing of the DER element and find that not all bytes in derEle have been used. @return Index of the first unused byte in the given DER element. Raises a ValueError exception in case of parsing errors. Raises an IndexError exception if the DER element is too short. iisUnsupported DER tagisNot a DER structuresNot a valid DER SEQUENCE.(RRRR$RRt IndexError(RtderElet noLeftOversR"R ((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pytdecodeVs N( t__name__t __module__t__doc__RRtbRRRRR$R((((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRs   cBs)eZddZdZddZRS(icCstj|d||_dS(s|Class to model an INTEGER DER element. Limitation: only non-negative values are supported. R N(RRtvalue(RR-((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRqscCsQt|j|_t|jddkrDtd|j|_ntj|S(s>Return a complete INTEGER DER element, fully encoded as a TLV.ii(RR-RRRRR(R((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRyscCsxtj|||}|j|jdkr:tdnt|jddkrbtdnt|j|_|S(sDecode a complete INTEGER DER element, and re-initializes this object with it. @param derEle A complete INTEGER DER element. It must start with a DER INTEGER tag. @param noLeftOvers Indicate whether it is acceptable to complete the parsing of the DER element and find that not all bytes in derEle have been used. @return Index of the first unused byte in the given DER element. Raises a ValueError exception if the DER element is not a valid non-negative INTEGER. Raises an IndexError exception if the DER element is too short. R sNot a DER INTEGER.iisNegative INTEGER.( RR(RRRRRRR-(RR&R't tlvLength((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyR(s(R)R*RRR((((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRps  cBseZdZddZdZdZdZdZdZ dZ dZ d Z d Z d Zd Zd dZRS(sClass to model a SEQUENCE DER element. This object behave like a dynamic Python sequence. Sub-elements that are INTEGERs, look like Python integers. Any other sub-element is a binary string encoded as the complete DER sub-element (TLV). cCs5tj|d|dkr(g|_n ||_dS(sKInitialize the SEQUENCE DER object. Always empty initially.R N(RRRt_seq(RtstartSeq((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRs  cCs|j|=dS(N(R/(Rtn((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyt __delitem__scCs |j|S(N(R/(RR1((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyt __getitem__scCs||j|scCsttt|jS(s=Return the number of items in this sequence that are numbers.(RtfilterR R/(R((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pythasIntsscCs"|jo!|jt|jkS(s6Return True if all items in this sequence are numbers.(R/RAR(R((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyt hasOnlyIntsscCstd|_xc|jD]X}y|j|7_Wqy|jt|j7_WqqtdqqXqXqWtj|S(s;Return the DER encoding for the ASN.1 SEQUENCE, containing the non-negative integers and longs added to this object. Limitation: Raises a ValueError exception if it some elements in the sequence are neither Python integers nor complete DER INTEGERs. R s&Trying to DER encode an unknown object(R,RR/RRRR(RR?((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRsic Cs3g|_ytj|||}|j|jdkrFtdnd}x|t|jkr t|j|}||jdkrt }||j|j|7}|jj |j qO|j |d|j\}}|jj |j|||!||}qOWWnt k r.tdnX|S(sDecode a complete SEQUENCE DER element, and re-initializes this object with it. @param derEle A complete SEQUENCE DER element. It must start with a DER SEQUENCE tag. @param noLeftOvers Indicate whether it is acceptable to complete the parsing of the DER element and find that not all bytes in derEle have been used. @return Index of the first unused byte in the given DER element. DER INTEGERs are decoded into Python integers. Any other DER element is not decoded. Its validity is not checked. Raises a ValueError exception if the DER element is not a valid DER SEQUENCE. Raises an IndexError exception if the DER element is too short. R sNot a DER SEQUENCE.iR isNot a valid DER SEQUENCE.(R/RR(RRRRRRRR>R-R$R%( RR&R'R.R Rt newIntegertitemLentitemIdx((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyR(s$   N(R)R*R+RRR2R3R5R9R:R<R=R>RARBRR((((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRs           cBs&eZeddZddZRS(R cCstj|d||_dS(Ns OCTET STRING(RRR(RR-((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRsicCs4tj||}|jds0tdn|S(Ns OCTET STRINGsNot a valid OCTET STRING.(RR(RR(RR&R'tp((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyR(s(R)R*R,RR((((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRscBseZdZRS(cCstj|ddS(NR (RR(R((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyR s(R)R*R(((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyR scBseZdZddZRS(cCstj|ddS(NsOBJECT IDENTIFIER(RR(R((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyRsicCs4tj||}|jds0tdn|S(NsOBJECT IDENTIFIERsNot a valid OBJECT IDENTIFIER.(RR(RR(RR&R'RF((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyR(s(R)R*RR((((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyR s cCs-d}y||7}Wntk r(dSXdS(Nii(t TypeError(txttest((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyR s  (( tCrypto.Util.numberRRtsystCrypto.Util.py3compatt__all__RRRRRRR (((s6/usr/lib64/python2.7/site-packages/Crypto/Util/asn1.pyts  S'g