1 line
2.2 MiB
1 line
2.2 MiB
{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./node_modules/node-forge/lib/forge.js","webpack:///./node_modules/node-forge/lib/util.js","webpack:///./node_modules/node-forge/lib/asn1.js","webpack:///./node_modules/node-forge/lib/random.js","webpack:///./node_modules/node-forge/lib/md.js","webpack:///./node_modules/jquery/dist/jquery.js","webpack:///./node_modules/node-forge/lib/aes.js","webpack:///./node_modules/node-forge/lib/oids.js","webpack:///./node_modules/node-forge/lib/pem.js","webpack:///(webpack)/buildin/global.js","webpack:///./node_modules/node-forge/lib/hmac.js","webpack:///./node_modules/node-forge/lib/sha1.js","webpack:///./node_modules/buffer/index.js","webpack:///./node_modules/node-forge/lib/des.js","webpack:///./node_modules/node-forge/lib/rsa.js","webpack:///./node_modules/node-forge/lib/jsbn.js","webpack:///./node_modules/node-forge/lib/cipher.js","webpack:///./node_modules/process/browser.js","webpack:///./node_modules/node-forge/lib/md5.js","webpack:///./node_modules/node-forge/lib/pki.js","webpack:///./node_modules/node-forge/lib/pbkdf2.js","webpack:///./node_modules/node-forge/lib/pkcs12.js","webpack:///./node_modules/node-forge/lib/x509.js","webpack:///./node_modules/node-forge/lib/pss.js","webpack:///./browser_app/confirm-modal.js","webpack:///./node_modules/node-forge/lib/cipherModes.js","webpack:///./node_modules/node-forge/lib/tls.js","webpack:///./node_modules/node-forge/lib/pbe.js","webpack:///./node_modules/node-forge/lib/sha256.js","webpack:///./node_modules/node-forge/lib/prng.js","webpack:///./node_modules/node-forge/lib/rc2.js","webpack:///./node_modules/node-forge/lib/pkcs1.js","webpack:///./node_modules/node-forge/lib/prime.js","webpack:///./node_modules/node-forge/lib/pkcs7asn1.js","webpack:///./node_modules/node-forge/lib/mgf1.js","webpack:///./node_modules/node-forge/lib/debug.js","webpack:///./node_modules/node-forge/lib/sha512.js","webpack:///./node_modules/node-forge/lib/log.js","webpack:///./node_modules/simple-form-submit/dist/index.js","webpack:///./browser_app/index.js","webpack:///./node_modules/bootstrap/dist/js/bootstrap.js","webpack:///./node_modules/popper.js/dist/esm/popper.js","webpack:///./node_modules/jquery-form/dist/jquery.form.min.js","webpack:///./node_modules/node-forge/lib/index.js","webpack:///./node_modules/timers-browserify/main.js","webpack:///./node_modules/setimmediate/setImmediate.js","webpack:///./node_modules/base64-js/index.js","webpack:///./node_modules/ieee754/index.js","webpack:///./node_modules/isarray/index.js","webpack:///./node_modules/node-forge/lib/baseN.js","webpack:///./node_modules/node-forge/lib/aesCipherSuites.js","webpack:///./node_modules/node-forge/lib/mgf.js","webpack:///./node_modules/node-forge/lib/ed25519.js","webpack:///./node_modules/node-forge/lib/asn1-validator.js","webpack:///./node_modules/node-forge/lib/kem.js","webpack:///./node_modules/node-forge/lib/md.all.js","webpack:///./node_modules/node-forge/lib/pkcs7.js","webpack:///./node_modules/node-forge/lib/ssh.js","webpack:///./node_modules/node-forge/lib/task.js","webpack:///./node_modules/qrcode-svg/lib/qrcode.js","webpack:///./node_modules/form-data/lib/browser.js"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","options","usePureJavaScript","forge","baseN","util","_checkBitsParam","Error","ByteStringBuffer","b","this","data","read","isArrayBuffer","isArrayBufferView","Buffer","toString","arr","Uint8Array","String","fromCharCode","apply","e","length","putByte","_constructedStringLength","process","nextTick","browser","setImmediate","undefined","arguments","callback","setTimeout","window","postMessage","msg","callbacks","push","addEventListener","event","source","stopPropagation","copy","slice","forEach","MutationObserver","now","Date","attr","div","document","createElement","observe","attributes","oldSetImmediate","setAttribute","isNodejs","versions","node","globalScope","global","self","isArray","Array","x","ArrayBuffer","buffer","byteLength","ByteBuffer","_optimizeConstructedString","substr","isEmpty","putBytes","fillWithByte","bytes","putString","str","encodeUtf8","putInt16","putInt24","putInt32","putInt16Le","putInt24Le","putInt32Le","putInt","putSignedInt","putBuffer","getBytes","getByte","charCodeAt","getInt16","rval","getInt24","getInt32","getInt16Le","getInt24Le","getInt32Le","getInt","getSignedInt","max","count","Math","min","clear","at","setAt","last","createBuffer","compact","truncate","len","toHex","decodeUtf8","DataBuffer","readOffset","growSize","DataView","byteOffset","write","writeOffset","accommodate","amount","src","dst","set","setUint8","encoding","view","ceil","binary","hex","decode","base64","raw","Uint16Array","text","utf16","encode","setInt16","setInt8","setInt32","getInt8","getUint8","utf8","input","fillString","xorBytes","s1","s2","s3","hexToBytes","parseInt","bytesToHex","int32ToBytes","_base64","_base64Idx","_base58","encode64","maxline","chr1","chr2","chr3","line","output","charAt","isNaN","decode64","replace","enc1","enc2","enc3","enc4","unescape","encodeURIComponent","decodeURIComponent","escape","base58","offset","out","j","subarray","k","deflate","api","start","substring","inflate","_setStorageObject","id","obj","removeItem","JSON","stringify","setItem","error","message","_getStorageObject","getItem","init","parse","_setItem","_getItem","_removeItem","empty","prop","_clearItems","_callStorageFunction","func","args","location","type","done","exception","idx","localStorage","ex","clearItems","parseUrl","regex","lastIndex","exec","url","full","scheme","host","port","path","fullHost","_queryVariables","getQueryVariables","query","q","kvpairs","split","val","pos","indexOf","search","parseFragment","fragment","fp","fq","shift","pathString","queryString","makeRequest","reqString","frag","req","getPath","getQuery","getQueryLast","_default","vals","makeLink","jQuery","join","qstr","param","setPath","keys","next","hasNext","deletePath","format","match","part","re","argi","parts","code","formatNumber","number","decimals","dec_point","thousands_sep","abs","toFixed","formatSize","size","bytesFromIP","ip","bytesFromIPv4","bytesFromIPv6","num","blanks","zeros","filter","bytesToIP","bytesToIPv4","bytesToIPv6","zeroGroups","zeroMaxGroup","end","group","splice","unshift","estimateCores","update","cores","navigator","hardwareConcurrency","Worker","Blob","blobUrl","URL","createObjectURL","st","et","sample","samples","numWorkers","avg","floor","reduce","revokeObjectURL","workers","results","worker","terminate","map","err","overlaps","r1","overlap","r2","asn1","_checkBufferLength","remaining","available","requested","Class","UNIVERSAL","APPLICATION","CONTEXT_SPECIFIC","PRIVATE","Type","NONE","BOOLEAN","INTEGER","BITSTRING","OCTETSTRING","NULL","OID","ODESC","EXTERNAL","REAL","ENUMERATED","EMBEDDED","UTF8","ROID","SEQUENCE","SET","PRINTABLESTRING","IA5STRING","UTCTIME","GENERALIZEDTIME","BMPSTRING","tagClass","constructed","tmp","composed","bitStringContents","original","excludeBitStringContents","equals","obj1","obj2","equal","includeBitStringContents","getBerValueLength","b2","fromDer","strict","decodeBitStrings","_fromDer","depth","b1","longFormBytes","_getValueLength","savedRead","savedRemaining","unused","subOptions","verbose","used","tc","asn1Options","toDer","useBitStringContents","lenBytes","oidToDer","oid","valueBytes","values","derToOid","utcTimeToDate","utc","date","year","MM","DD","hh","mm","ss","setUTCFullYear","setUTCHours","setTime","generalizedTimeToDate","gentime","YYYY","fff","isUTC","parseFloat","setFullYear","setHours","dateToUtcTime","getUTCFullYear","getUTCMonth","getUTCDate","getUTCHours","getUTCMinutes","getUTCSeconds","dateToGeneralizedTime","integerToDer","integer","derToInteger","validate","v","capture","errors","optional","captureAsn1","captureBitStringContents","captureBitStringValue","_nonLatinRegex","prettyPrint","level","indentation","indent","IA5String","subvalues","sub","pki","oids","test","random","prng_aes","_prng_aes_output","_prng_aes_buffer","spawnPrng","ctx","prng","generate","getBytesSync","formatKey","aes","_expandKey","formatSeed","seed","cipher","_updateBlock","increment","md","sha256","_ctx","getRandomValues","_crypto","crypto","msCrypto","collectInt","_navBytes","collect","mousemove","clientX","clientY","keypress","charCode","createInstance","algorithms","factory","w","noGlobal","getProto","getPrototypeOf","flat","array","concat","class2type","hasOwn","fnToString","ObjectFunctionString","support","isFunction","nodeType","isWindow","preservedScriptAttributes","nonce","noModule","DOMEval","doc","script","getAttribute","head","appendChild","parentNode","removeChild","toType","selector","context","fn","isArrayLike","jquery","constructor","toArray","pushStack","elems","ret","merge","prevObject","each","elem","first","eq","even","grep","_elem","odd","sort","extend","copyIsArray","clone","target","deep","isPlainObject","expando","isReady","noop","proto","Ctor","isEmptyObject","globalEval","makeArray","inArray","second","invert","matches","callbackExpect","arg","guid","iterator","_i","toLowerCase","Sizzle","Expr","getText","isXML","tokenize","compile","select","outermostContext","sortInput","hasDuplicate","setDocument","docElem","documentIsHTML","rbuggyQSA","rbuggyMatches","contains","preferredDoc","dirruns","classCache","createCache","tokenCache","compilerCache","nonnativeSelectorCache","sortOrder","a","pop","pushNative","list","booleans","whitespace","identifier","pseudos","rwhitespace","RegExp","rtrim","rcomma","rcombinators","rdescend","rpseudo","ridentifier","matchExpr","rhtml","rinputs","rheader","rnative","rquickExpr","rsibling","runescape","funescape","nonHex","high","rcssescape","fcssescape","ch","asCodePoint","unloadHandler","inDisabledFieldset","addCombinator","disabled","nodeName","dir","childNodes","els","nid","groups","newSelector","newContext","ownerDocument","getElementById","getElementsByTagName","getElementsByClassName","qsa","testContext","scope","toSelector","querySelectorAll","qsaError","removeAttribute","cache","cacheLength","markFunction","assert","el","addHandle","attrs","handler","attrHandle","siblingCheck","cur","diff","sourceIndex","nextSibling","createInputPseudo","createButtonPseudo","createDisabledPseudo","isDisabled","createPositionalPseudo","argument","matchIndexes","namespace","namespaceURI","documentElement","hasCompare","subWindow","defaultView","top","attachEvent","className","createComment","getById","getElementsByName","attrId","find","getAttributeNode","tag","innerHTML","matchesSelector","webkitMatchesSelector","mozMatchesSelector","oMatchesSelector","msMatchesSelector","disconnectedMatch","compareDocumentPosition","adown","bup","compare","sortDetached","aup","ap","bp","expr","elements","specified","sel","uniqueSort","duplicates","detectDuplicates","sortStable","textContent","firstChild","nodeValue","selectors","createPseudo","relative","preFilter","excess","unquoted","nodeNameSelector","pattern","operator","check","result","what","_argument","simple","forward","ofType","_context","xml","uniqueCache","outerCache","nodeIndex","parent","useCache","lastChild","uniqueID","pseudo","setFilters","matched","matcher","unmatched","lang","elemLang","hash","activeElement","hasFocus","href","tabIndex","checked","selected","selectedIndex","_matchIndexes","radio","checkbox","file","password","image","submit","reset","tokens","combinator","base","skip","checkNonElements","doneName","oldCache","newCache","elementMatcher","matchers","condense","newUnmatched","mapped","setMatcher","postFilter","postFinder","postSelector","temp","preMap","postMap","preexisting","contexts","multipleContexts","matcherIn","matcherOut","matcherFromTokens","checkContext","leadingRelative","implicitRelative","matchContext","matchAnyContext","filters","parseOnly","soFar","preFilters","cached","setMatchers","elementMatchers","bySet","byElement","superMatcher","outermost","matchedCount","setMatched","contextBackup","dirrunsUnique","matcherFromGroupMatchers","token","compiled","_name","defaultValue","unique","isXMLDoc","escapeSelector","until","is","siblings","rneedsContext","needsContext","rsingleTag","winnow","qualifier","not","rootjQuery","root","parseHTML","ready","rparentsprev","guaranteedUnique","children","contents","prev","sibling","has","targets","closest","index","prevAll","add","addBack","parents","parentsUntil","nextAll","nextUntil","prevUntil","contentDocument","content","reverse","rnothtmlwhite","Identity","Thrower","adoptValue","resolve","reject","noValue","method","promise","fail","then","Callbacks","_","flag","createOptions","firing","memory","fired","locked","queue","firingIndex","fire","once","stopOnFalse","remove","disable","lock","fireWith","Deferred","tuples","state","always","deferred","pipe","fns","newDefer","tuple","returned","progress","notify","onFulfilled","onRejected","onProgress","maxDepth","special","that","mightThrow","TypeError","notifyWith","resolveWith","exceptionHook","stackTrace","rejectWith","getStackHook","stateString","when","singleValue","resolveContexts","resolveValues","master","updateFunc","rerrorNames","stack","console","warn","readyException","readyList","completed","removeEventListener","catch","readyWait","wait","readyState","doScroll","access","chainable","emptyGet","bulk","_key","rmsPrefix","rdashAlpha","fcamelCase","_all","letter","toUpperCase","camelCase","string","acceptData","owner","Data","uid","configurable","hasData","dataPriv","dataUser","rbrace","rmultiDash","dataAttr","getData","removeData","_data","_removeData","dequeue","startLength","hooks","_queueHooks","stop","setter","clearQueue","defer","pnum","rcssNum","cssExpand","isAttached","getRootNode","isHiddenWithinTree","style","display","css","adjustCSS","valueParts","tween","adjusted","scale","maxIterations","currentValue","initial","unit","cssNumber","initialInUnit","defaultDisplayMap","getDefaultDisplay","body","showHide","show","hide","toggle","rcheckableType","rtagName","rscriptType","createDocumentFragment","checkClone","cloneNode","noCloneChecked","option","wrapMap","thead","col","tr","td","getAll","setGlobalEval","refElements","tbody","tfoot","colgroup","caption","th","optgroup","buildFragment","scripts","selection","ignored","wrap","attached","nodes","htmlPrefilter","createTextNode","rkeyEvent","rmouseEvent","rtypenamespace","returnTrue","returnFalse","expectSync","safeActiveElement","on","types","one","origFn","off","leverageNative","notAsync","saved","isTrigger","delegateType","stopImmediatePropagation","preventDefault","trigger","Event","handleObjIn","eventHandle","events","handleObj","handlers","namespaces","origType","elemData","handle","triggered","dispatch","bindType","delegateCount","setup","mappedTypes","origCount","teardown","removeEvent","nativeEvent","handlerQueue","fix","delegateTarget","preDispatch","isPropagationStopped","currentTarget","isImmediatePropagationStopped","rnamespace","postDispatch","matchedHandlers","matchedSelectors","button","addProp","hook","originalEvent","writable","load","noBubble","click","beforeunload","returnValue","props","isDefaultPrevented","defaultPrevented","relatedTarget","timeStamp","isSimulated","altKey","bubbles","cancelable","changedTouches","ctrlKey","detail","eventPhase","metaKey","pageX","pageY","shiftKey","keyCode","buttons","offsetX","offsetY","pointerId","pointerType","screenX","screenY","targetTouches","toElement","touches","which","focus","blur","mouseenter","mouseleave","pointerenter","pointerleave","orig","related","rnoInnerhtml","rchecked","rcleanScript","manipulationTarget","disableScript","restoreScript","cloneCopyEvent","dest","udataOld","udataCur","fixInput","domManip","collection","hasScripts","iNoClone","valueIsFunction","html","_evalUrl","keepData","cleanData","dataAndEvents","deepDataAndEvents","srcElements","destElements","inPage","detach","append","prepend","insertBefore","before","after","replaceWith","replaceChild","appendTo","prependTo","insertAfter","replaceAll","insert","rnumnonpx","getStyles","opener","getComputedStyle","swap","old","rboxStyle","curCSS","computed","width","minWidth","maxWidth","getPropertyValue","pixelBoxStyles","addGetHookIf","conditionFn","hookFn","computeStyleTests","container","cssText","divStyle","pixelPositionVal","reliableMarginLeftVal","roundPixelMeasures","marginLeft","right","pixelBoxStylesVal","boxSizingReliableVal","position","scrollboxSizeVal","offsetWidth","measure","round","reliableTrDimensionsVal","backgroundClip","clearCloneStyle","boxSizingReliable","pixelPosition","reliableMarginLeft","scrollboxSize","reliableTrDimensions","table","trChild","trStyle","height","cssPrefixes","emptyStyle","vendorProps","finalPropName","final","cssProps","capName","vendorPropName","rdisplayswap","rcustomProp","cssShow","visibility","cssNormalTransform","letterSpacing","fontWeight","setPositiveNumber","subtract","boxModelAdjustment","dimension","box","isBorderBox","styles","computedVal","extra","delta","getWidthOrHeight","valueIsBorderBox","offsetProp","getClientRects","Tween","easing","cssHooks","opacity","origName","isCustomProp","setProperty","isFinite","getBoundingClientRect","scrollboxSizeBuggy","left","margin","padding","border","prefix","suffix","expand","expanded","propHooks","run","percent","eased","duration","step","fx","scrollTop","scrollLeft","linear","swing","cos","PI","fxNow","inProgress","rfxtypes","rrun","schedule","hidden","requestAnimationFrame","interval","tick","createFxNow","genFx","includeWidth","createTween","animation","Animation","tweeners","properties","stopped","prefilters","currentTime","startTime","tweens","opts","specialEasing","originalProperties","originalOptions","gotoEnd","propFilter","complete","timer","anim","tweener","oldfire","propTween","restoreDisplay","isBox","dataShow","unqueued","overflow","overflowX","overflowY","prefilter","speed","opt","speeds","fadeTo","to","animate","optall","doAnimation","finish","stopQueue","timers","cssFn","slideDown","slideUp","slideToggle","fadeIn","fadeOut","fadeToggle","slow","fast","delay","time","timeout","clearTimeout","checkOn","optSelected","radioValue","boolHook","removeAttr","nType","attrHooks","bool","attrNames","lowercaseName","rfocusable","rclickable","stripAndCollapse","getClass","classesToArray","removeProp","propFix","tabindex","addClass","classes","curValue","clazz","finalValue","removeClass","toggleClass","stateVal","isValidValue","classNames","hasClass","rreturn","valHooks","optionSet","focusin","rfocusMorph","stopPropagationCallback","onlyHandlers","bubbleType","ontype","lastElement","eventPath","parentWindow","simulate","triggerHandler","attaches","rquery","parseXML","DOMParser","parseFromString","rbracket","rCRLF","rsubmitterTypes","rsubmittable","buildParams","traditional","valueOrFunction","serialize","serializeArray","r20","rhash","rantiCache","rheaders","rnoContent","rprotocol","transports","allTypes","originAnchor","addToPrefiltersOrTransports","structure","dataTypeExpression","dataType","dataTypes","inspectPrefiltersOrTransports","jqXHR","inspected","seekingTransport","inspect","prefilterOrFactory","dataTypeOrTransport","ajaxExtend","flatOptions","ajaxSettings","active","lastModified","etag","isLocal","protocol","processData","async","contentType","accepts","json","responseFields","converters","ajaxSetup","settings","ajaxPrefilter","ajaxTransport","ajax","transport","cacheURL","responseHeadersString","responseHeaders","timeoutTimer","urlAnchor","fireGlobals","uncached","callbackContext","globalEventContext","completeDeferred","statusCode","requestHeaders","requestHeadersNames","strAbort","getResponseHeader","getAllResponseHeaders","setRequestHeader","overrideMimeType","mimeType","status","abort","statusText","finalText","crossDomain","hasContent","ifModified","headers","beforeSend","success","send","nativeStatusText","responses","isSuccess","response","modified","ct","finalDataType","firstDataType","ajaxHandleResponses","conv2","current","conv","dataFilter","throws","ajaxConvert","getJSON","getScript","wrapAll","firstElementChild","wrapInner","htmlIsFunction","unwrap","visible","offsetHeight","xhr","XMLHttpRequest","xhrSuccessStatus","0","1223","xhrSupported","cors","errorCallback","open","username","xhrFields","onload","onerror","onabort","ontimeout","onreadystatechange","responseType","responseText","scriptAttrs","charset","scriptCharset","evt","oldCallbacks","rjsonp","jsonp","jsonpCallback","originalSettings","callbackName","overwritten","responseContainer","jsonProp","createHTMLDocument","implementation","keepScripts","parsed","params","animated","setOffset","curPosition","curLeft","curCSSTop","curTop","curOffset","curCSSLeft","curElem","using","rect","win","pageYOffset","pageXOffset","offsetParent","parentOffset","scrollTo","Height","Width","defaultExtra","funcName","unbind","delegate","undelegate","hover","fnOver","fnOut","proxy","holdReady","hold","parseJSON","isNumeric","trim","_jQuery","_$","$","noConflict","registerAlgorithm","Algorithm","startEncrypting","iv","_createCipher","decrypt","createEncryptionCipher","startDecrypting","createDecryptionCipher","initialize","blockSize","encrypt","inBlock","outBlock","_w","_init","encryptOp","modes","ecb","cbc","cfb","ofb","ctr","gcm","sbox","isbox","rcon","mix","imix","xtime","e2","e4","e8","sx","sx2","me","ime","ei","iNk","Nk","m0","m1","m2","m3","wnew","wi","a2","c2","Nr","algorithm","createDecipher","createCipher","_IN","_I_","pem","foldHeader","header","insertSpace","$1","candidate","ltrim","procType","version","contentDomain","dekInfo","parameters","rMessage","rHeader","lines","li","nl","vi","g","Function","hmac","_md","_ipadding","_opadding","keylen","blockLength","digest","inner","getMac","sha1","_initialized","_padding","_state","_input","digestLength","messageLength","fullMessageLength","messageLengthSize","messageLength64","int32s","h0","h1","h2","h3","h4","_update","finalBlock","bits","ieee754","kMaxLength","TYPED_ARRAY_SUPPORT","RangeError","__proto__","encodingOrOffset","allocUnsafe","from","fromArrayLike","fromArrayBuffer","isEncoding","actual","fromString","isBuffer","fromObject","assertSize","isView","loweredCase","utf8ToBytes","base64ToBytes","slowToString","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","bidirectionalIndexOf","arrayIndexOf","lastIndexOf","indexSize","arrLength","valLength","buf","readUInt16BE","foundIndex","found","hexWrite","Number","strLen","utf8Write","blitBuffer","asciiWrite","byteArray","asciiToBytes","latin1Write","base64Write","ucs2Write","units","hi","lo","utf16leToBytes","fromByteArray","res","secondByte","thirdByte","fourthByte","tempCodePoint","firstByte","codePoint","bytesPerSequence","codePoints","decodeCodePointsArray","SlowBuffer","alloc","INSPECT_MAX_BYTES","foo","typedArraySupport","poolSize","_augment","species","fill","allocUnsafeSlow","_isBuffer","y","swap16","swap32","swap64","thisStart","thisEnd","thisCopy","targetCopy","includes","toJSON","_arr","checkOffset","ext","checkInt","objectWriteUInt16","littleEndian","objectWriteUInt32","checkIEEE754","writeFloat","noAssert","writeDouble","newBuf","sliceLen","readUIntLE","mul","readUIntBE","readUInt8","readUInt16LE","readUInt32LE","readUInt32BE","readIntLE","pow","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readFloatLE","readFloatBE","readDoubleLE","readDoubleBE","writeUIntLE","writeUIntBE","writeUInt8","writeUInt16LE","writeUInt16BE","writeUInt32LE","writeUInt32BE","writeIntLE","limit","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeFloatLE","writeFloatBE","writeDoubleLE","writeDoubleBE","targetStart","INVALID_BASE64_RE","Infinity","leadSurrogate","toByteArray","stringtrim","base64clean","des","_keys","pc2bytes0","pc2bytes1","pc2bytes2","pc2bytes3","pc2bytes4","pc2bytes5","pc2bytes6","pc2bytes7","pc2bytes8","pc2bytes9","pc2bytes10","pc2bytes11","pc2bytes12","pc2bytes13","iterations","shifts","lefttmp","righttmp","_createKeys","spfunction1","spfunction2","spfunction3","spfunction4","spfunction5","spfunction6","spfunction7","spfunction8","looping","endloop","loopinc","right1","right2","BigInteger","jsbn","rsa","GCD_30_DELTA","privateKeyValidator","rsaPrivateKeyValidator","rsaPublicKeyValidator","publicKeyValidator","emsaPkcs1v15encode","oidBytes","digestInfo","digestAlgorithm","_modPow","pub","modPow","dP","mod","ONE","dQ","qInv","modInverse","bitLength","compareTo","gcd","xp","multiply","xq","_encodePkcs1_v1_5","bt","eb","padByte","padNum","numZeros","padBytes","_decodePkcs1_v1_5","em","ml","_generateKeyPair","workLoad","workerScript","getPrime","pBits","qBits","prime","generateProbablePrime","p1","q1","phi","privateKey","setPrivateKey","publicKey","setPublicKey","_bnToBytes","_getMillerRabinTests","_detectNodeCrypto","_detectSubtleCrypto","subtle","_detectSubtleMsCrypto","_intToUint8Array","yhex","ed","expected","xhex","createKeyPairGenerationState","rng","nextBytes","eInt","pqState","fromInt","stepKeyPairGenerationState","THIRTY","t2","deltaIdx","op_or","t1","total","bits1","testBit","bitwiseTo","shiftLeft","dAddOffset","byteValue","isProbablePrime","generateKeyPair","modulusLength","publicExponent","publicKeyEncoding","privateKeyEncoding","priv","privateKeyFromPem","publicKeyFromPem","generateKey","pair","exportKey","pkcs8","privateKeyFromAsn1","setRsaPublicKey","genOp","oncomplete","exportOp","keypair","generateKeyPairSync","schemeOptions","pkcs1","encode_rsa_oaep","signature","verify","setRsaPrivateKey","decode_rsa_oaep","wrapRsaPrivateKey","rsaKey","rsaEncryption","privateKeyModulus","privateKeyPublicExponent","privateKeyPrivateExponent","privateKeyPrime1","privateKeyPrime2","privateKeyExponent1","privateKeyExponent2","privateKeyCoefficient","privateKeyToAsn1","privateKeyToRSAPrivateKey","publicKeyFromAsn1","publicKeyOid","rsaPublicKey","publicKeyModulus","publicKeyExponent","publicKeyToAsn1","publicKeyToSubjectPublicKeyInfo","publicKeyToRSAPublicKey","dbits","fromNumber","nbi","am3","xl","xh","h","am","appName","DB","DM","DV","FV","F1","F2","rr","vv","BI_RC","int2char","intAt","nbv","nbits","Classic","Montgomery","mp","invDigit","mpl","mph","um","mt2","op_and","op_xor","op_andnot","lbit","cbit","NullExp","nNop","Barrett","q3","dlShiftTo","mu","divide","convert","revert","divRemTo","mulTo","multiplyTo","sqrTo","squareTo","ZERO","subTo","copyTo","u0","clamp","drShiftTo","fromRadix","mi","sh","lShiftTo","bs","cbs","bm","ds","rShiftTo","pm","pt","ts","ms","nsh","ys","y0","yt","d1","d2","qd","isEven","exp","z","negate","toRadix","km","modPowInt","multiplyUpperTo","multiplyLowerTo","lowprimes","lplim","chunkSize","LN2","log","signum","cs","intValue","dMultiply","op","f","changeBit","addTo","modInt","millerRabin","n1","getLowestSetBit","shiftRight","shortValue","and","or","xor","andNot","bitCount","setBit","clearBit","flipBit","remainder","divideAndRemainder","k1","g2","is1","ac","u","getAlgorithm","BlockCipher","_finish","_op","_decrypt","pad","unpad","afterFinish","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","currentQueue","draining","queueIndex","cleanUpNextTick","drainQueue","marker","runClearTimeout","Item","title","env","argv","addListener","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","binding","cwd","chdir","umask","md5","_g","_r","_k","sin","carry","pemToDer","headerType","privateKeyToPem","privateKeyInfoToPem","pkcs5","pbkdf2","dkLen","pbkdf2Sync","hLen","prf","u_c","u_c1","dk","outer","p12","pkcs12","contentInfoValidator","pfxValidator","safeBagValidator","attributeValidator","certBagValidator","_getBagsByAttribute","safeContents","attrName","attrValue","bagType","safeBags","bag","_decodePkcs7Data","_decryptSafeContents","pkcs7","encryptedDataValidator","encAlgorithm","pbe","getCipher","encParameter","encryptedContentAsn1","encrypted","_decodeSafeContents","safeBag","validator","decoder","bagId","_decodeBagAttributes","bagAttributes","bagAsn1","bagValue","pkcs8ShroudedKeyBag","decryptPrivateKeyInfo","keyBag","certBag","certId","x509Certificate","certAsn1","cert","certificateFromAsn1","decodedAttrs","pkcs12FromAsn1","pfx","getBags","localKeyId","localKeyIdHex","friendlyName","getBagsByFriendlyName","getBagsByLocalKeyId","mac","macKeyBytes","macAlgorithm","sha384","sha512","macSalt","macIterations","macKey","macDigest","authSafe","contentInfo","encryptedData","_decodeAuthenticatedSafe","toPkcs12Asn1","saltSize","useMac","generateLocalKeyId","bagAttrs","pairedCert","certificateFromPem","certificateToAsn1","chain","certSafeBags","certBagAttrs","certSafeBag","certSafeContents","certCI","pkAsn1","encryptPrivateKeyInfo","keySafeContents","keyCI","macData","safe","macValue","generatePkcs12Key","_shortNames","x509CertificateValidator","rsassaPssParameterValidator","certificationRequestInfoValidator","certificationRequestValidator","_getAttribute","shortName","RDNAttributesAsArray","rdn","si","valueTagClass","CRIAttributesAsArray","seq","extensionRequest","extensions","certificateExtensionFromAsn1","_readSignatureParameters","fillDefaults","algorithmOid","mgf","saltLength","hashOid","maskGenOid","maskGenHashOid","_dnToAsn1","_fillMissingFields","attribute","valueConstructed","certificateExtensionToAsn1","_fillMissingExtensionFields","extension","b3","digitalSignature","nonRepudiation","keyEncipherment","dataEncipherment","keyAgreement","keyCertSign","cRLSign","encipherOnly","decipherOnly","cA","pathLenConstraint","client","server","email","objsign","reserved","sslCA","emailCA","objCA","altNames","altName","comment","ski","generateSubjectKeyIdentifier","subjectKeyIdentifier","keyIdentifier","authorityCertIssuer","issuer","serialNumber","subSeq","fullNameGeneralNames","_signatureParametersToAsn1","_CRIAttributesToAsn1","csr","computeHash","certificateToPem","publicKeyToPem","publicKeyToRSAPublicKeyPem","getPublicKeyFingerprint","delimiter","certificationRequestFromPem","certificationRequestFromAsn1","certificationRequestToPem","certificationRequestToAsn1","createCertificate","siginfo","validity","notBefore","notAfter","getField","sn","addField","subject","setSubject","uniqueId","setIssuer","setExtensions","exts","getExtension","sign","signatureOid","tbsCertificate","getTBSCertificate","child","issued","expectedIssuer","actualIssuer","sha1WithRSAEncryption","signatureParameters","pss","isIssuer","iattr","sattr","verifySubjectKeyIdentifier","certVersion","serial","certSerialNumber","certSignatureOid","certSignatureParams","certinfoSignatureOid","certinfoSignatureParams","certSignature","certValidity1UTCTime","certValidity2GeneralizedTime","certValidity3UTCTime","certValidity4GeneralizedTime","imd","certIssuer","certIssuerUniqueId","smd","certSubject","certSubjectUniqueId","certExtensions","certificateExtensionsFromAsn1","subjectPublicKeyInfo","extseq","critical","ev","gn","createCertificationRequest","csrVersion","csrSignatureOid","csrSignatureParams","csrSignature","certificationRequestInfo","certificationRequestInfoSubject","addAttribute","certificationRequestInfoAttributes","setAttributes","getCertificationRequestInfo","cri","jan_1_1950","jan_1_2050","_dateToAsn1","tbs","certificateExtensionsToAsn1","distinguishedNameToAsn1","dn","createCaStore","certs","caStore","getBySubject","ensureSubjectHasHash","getIssuer","addCertificate","hasCertificate","der1","listAllCertificates","certList","removeCertificate","certificateError","bad_certificate","unsupported_certificate","certificate_revoked","certificate_expired","certificate_unknown","unknown_ca","verifyCertificateChain","validityCheckDate","selfSigned","verified","se","keyUsage","basicConstraints","bcExt","keyUsageExt","vfd","sLen","salt_","salt","pssobj","modBits","emBits","emLen","mHash","m_","ps","db","maskLen","dbMask","maskedDB","mask","checkLen","querySelector","ConfirmDialog","_div","_promise","Promise","_resolve","_reject","onclick","cancel","_close","transformIV","ints","blocks","inc32","block","from64To32","_ints","_inBlock","_outBlock","_prev","_iv","_partialBlock","_partialOutput","_partialBytes","inputLength","partialBytes","_R","additionalData","_cipherLength","_tagLength","tagLength","_tag","_hashBlock","_hashSubkey","componentBits","_m","generateHashTable","ivLength","_j0","ghash","_aDataLength","_s","lengths","z_i","v_i","lsb","tableMultiply","x_i","ah","multiplier","perInt","shft","generateSubHashTable","mid","half","m_i","m_j","prf_TLS1","secret","label","slen","ai","md5itr","sha1itr","md5bytes","sha1bytes","record","readVector","writeVector","tls","TLS_1_0","major","minor","TLS_1_1","TLS_1_2","SupportedVersions","Versions","Version","MaxFragment","ConnectionEnd","PRFAlgorithm","tls_prf_sha256","BulkCipherAlgorithm","none","rc4","des3","CipherType","stream","aead","MACAlgorithm","hmac_md5","hmac_sha1","hmac_sha256","hmac_sha384","hmac_sha512","CompressionMethod","ContentType","change_cipher_spec","alert","handshake","application_data","heartbeat","HandshakeType","hello_request","client_hello","server_hello","certificate","server_key_exchange","certificate_request","server_hello_done","certificate_verify","client_key_exchange","finished","Alert","Level","warning","fatal","Description","close_notify","unexpected_message","bad_record_mac","decryption_failed","record_overflow","decompression_failure","handshake_failure","illegal_parameter","access_denied","decode_error","decrypt_error","export_restriction","protocol_version","insufficient_security","internal_error","user_canceled","no_renegotiation","HeartbeatMessageType","heartbeat_request","heartbeat_response","CipherSuites","getCipherSuite","twoBytes","handleUnexpected","entity","description","handleHelloRequest","handshaking","handshakes","createAlert","flush","parseHelloMessage","session_id","cipher_suite","compression_method","cipher_suites","compression_methods","snl","session","server_name","serverNameList","cipherSuite","compressionMethod","createSecurityParameters","msgRandom","cRandom","sp","client_random","sRandom","createRandom","prf_algorithm","bulk_cipher_algorithm","cipher_type","enc_key_length","block_length","fixed_iv_length","record_iv_length","mac_algorithm","mac_length","mac_key_length","compression_algorithm","pre_master_secret","master_secret","server_random","handleServerHello","sessionId","expect","SCC","resuming","SCE","handleClientHello","sessionCache","getSession","clientHelloVersion","CCC","verifyClient","CCE","CKE","createRecord","createServerHello","createChangeCipherSpec","pending","createConnectionState","createFinished","createServerKeyExchange","createCertificateRequest","createServerHelloDone","handleCertificate","certificate_list","cause","SKE","serverCertificate","clientCertificate","handleServerKeyExchange","SCR","handleClientKeyExchange","enc_pre_master_secret","getPrivateKey","CCV","handleCertificateRequest","certificate_types","certificate_authorities","certificateRequest","SHD","handleCertificateVerify","msgBytes","handleServerHelloDone","createClientKeyExchange","SER","createCertificateVerify","getClientSignature","handleChangeCipherSpec","SFI","CFI","handleFinished","vd","SAD","CAD","peerCertificate","isConnected","connected","handleAlert","close","origin","handleHandshake","fragmented","hsTable","handleApplicationData","dataReady","handleHeartbeat","payload","createHeartbeat","expectedHeartbeatPayload","heartbeatReceived","__","R0","R1","R2","R3","R4","ctTable","H0","H1","H2","H3","H4","H5","H6","H7","H8","H9","generateKeys","tls10","client_write_MAC_key","server_write_MAC_key","client_write_key","server_write_key","client_write_IV","server_write_IV","createMode","sequenceNumber","macLength","macFunction","cipherState","cipherFunction","compressionState","compressFunction","updateSequenceNumber","initSecurityParameters","initConnectionState","getTimezoneOffset","createClientHello","cipherSuites","cSuites","compressionMethods","cMethods","virtualHost","serverName","snList","extLength","hint","getCertificate","der","certBuffer","getSignature","certTypes","cAs","byteBuffer","payloadLength","plaintextLength","paddingLength","records","rec","tlsData","tlsDataReady","_certErrorToAlertDesc","verifyOptions","desc","_alertDescToCertError","createSessionCache","capacity","setSession","order","createConnection","cn","dpth","cts","closed","clearFail","compatibleVersion","_readRecordHeader","_readRecord","aligned","prepare","prepareHeartbeatRequest","prf_tls1","seqNum","encryptedPrivateKeyValidator","PBES2AlgorithmsValidator","pkcs12PbeParamsValidator","prfOidToMessageDigest","prfOid","prfAlgorithm","supported","prfAlgorithmToMessageDigest","encryptionAlgorithm","countBytes","ivLen","encOid","cipherFn","createPbkdf2Params","saltBytes","encryptionOid","encryptionParams","encryptedPrivateKeyToPem","epki","encryptedPrivateKeyFromPem","encryptRsaPrivateKey","legacy","opensslDeriveBytes","decryptRsaPrivateKey","rc2","iter","passBuf","D","Slen","S","Plen","P","I","B","Inew","chunk","getCipherForPBES2","getCipherForPKCS12PBE","supportedOids","kdfOid","kdfSalt","kdfIterationCount","encIv","dIvLen","digests","h5","h6","h7","s0","maj","plugin","reseeds","generated","keyBytes","pools","_reseedSync","_seed","needed","seedFileSync","_2powK","seedBytes","defaultSeedFile","entropy","Uint32Array","QuotaExceededError","pool","generateSync","seedFile","_reseed","randomBytes","registerWorker","listener","piTable","rol","word","ror","expandKey","effKeyBits","L","T","T1","T8","TM","mixRound","mashRound","_output","K","R","runPlan","plan","ptr","rsa_mgf1","maskLength","mgf1Md","mgf1","keyLength","maxLength","lHash","PS","PS_length","seedLength","seedMask","maskedSeed","expectedLength","lHashPrime","in_ps","is_0","error_mask","primeincFindPrimeWithoutWorkers","generateRandom","range","workerMessage","primeincFindPrimeWithWorkers","primeincFindPrime","mrTests","getMillerRabinTests","millerRabinTests","maxBlockTime","_primeinc","p7v","pkcs7asn1","encryptedContentInfoValidator","envelopedDataValidator","signerValidator","signedDataValidator","recipientInfoValidator","debug","storage","cat","sha224","_states","_h","messageLength128","hlen","t1_hi","t1_lo","t2_hi","t2_lo","s0_hi","s0_lo","s1_hi","ch_hi","maj_hi","maj_lo","a_hi","a_lo","b_hi","b_lo","c_hi","c_lo","d_hi","d_lo","e_hi","e_lo","f_hi","f_lo","g_hi","g_lo","h_hi","h_lo","w2","w7","w15","w16","levels","sLevelInfo","sLoggers","sConsoleLogger","LEVEL_LOCKED","NO_LEVEL_CHECK","INTERPOLATE","logMessage","messageLevelIndex","logger","flags","prepareStandard","standard","category","prepareFull","prepareStandardFull","standardFull","timestamp","makeLogger","logFunction","setLevel","addLogger","info","levelHandlers","consoleLogger","__assign","assign","__importDefault","form_data_1","submitFormData","formActionUrl","formData","fetchRequestInit","mergedFetchRequestInit","fetch","submitForm","form","default","QRCode","classList","totp","init_list","init_new","alphabet","randBase32","input_secret","generate_qrcode","svg_container","svg","fido2","client_cert","generate_private_key","key_size","valid_time","form_sign_key","action","p12Asn1","ca_cert","p12Der","p12b64","revoke_certificate","Popper","_defineProperties","descriptor","_createClass","Constructor","protoProps","staticProps","_defineProperty","ownKeys","enumerableOnly","getOwnPropertySymbols","symbols","sym","getOwnPropertyDescriptor","_objectSpread2","getOwnPropertyDescriptors","defineProperties","transitionEndEmulator","_this","called","Util","TRANSITION_END","triggerTransitionEnd","getUID","getSelectorFromElement","element","hrefAttr","getTransitionDurationFromElement","transitionDuration","transitionDelay","floatTransitionDuration","floatTransitionDelay","reflow","supportsTransitionEnd","Boolean","isElement","typeCheckConfig","componentName","config","configTypes","expectedTypes","valueType","findShadowRoot","attachShadow","ShadowRoot","jQueryDetection","emulateTransitionEnd","NAME","JQUERY_NO_CONFLICT","CLOSE","CLOSED","CLICK_DATA_API","ClassName","_element","_proto","rootElement","_getRootElement","_triggerCloseEvent","_removeElement","dispose","closeEvent","_destroyElement","_jQueryInterface","$element","_handleDismiss","alertInstance","JQUERY_NO_CONFLICT$1","ClassName$1","Selector$1","Event$1","FOCUS_BLUR_DATA_API","LOAD_DATA_API","Button","triggerChangeEvent","addAriaPressed","tagName","hasAttribute","inputBtn","_len","_button","NAME$2","EVENT_KEY$2","JQUERY_NO_CONFLICT$2","Default","keyboard","slide","pause","touch","DefaultType","Direction","Event$2","SLIDE","SLID","KEYDOWN","MOUSEENTER","MOUSELEAVE","TOUCHSTART","TOUCHMOVE","TOUCHEND","POINTERDOWN","POINTERUP","DRAG_START","ClassName$2","Selector$2","PointerType","TOUCH","PEN","Carousel","_items","_interval","_activeElement","_isPaused","_isSliding","touchTimeout","touchStartX","touchDeltaX","_config","_getConfig","_indicatorsElement","_touchSupported","maxTouchPoints","_pointerEvent","PointerEvent","MSPointerEvent","_addEventListeners","_slide","nextWhenVisible","cycle","clearInterval","setInterval","visibilityState","activeIndex","_getItemIndex","direction","_handleSwipe","absDeltax","_this2","_keydown","_addTouchEventListeners","_this3","move","_getItemByDirection","isNextDirection","isPrevDirection","lastItemIndex","itemIndex","_triggerSlideEvent","eventDirectionName","targetIndex","fromIndex","slideEvent","_setActiveIndicatorElement","indicators","nextIndicator","directionalClassName","orderClassName","_this4","activeElementIndex","nextElement","nextElementIndex","isCycling","slidEvent","nextElementInterval","defaultInterval","ride","_dataApiClickHandler","slideIndex","carousels","$carousel","NAME$3","JQUERY_NO_CONFLICT$3","Default$1","DefaultType$1","Event$3","SHOW","SHOWN","HIDE","HIDDEN","ClassName$3","Dimension","Selector$3","Collapse","_isTransitioning","_triggerArray","toggleList","filterElement","foundElem","_selector","_parent","_getParent","_addAriaAndCollapsedClass","actives","activesData","startEvent","_getDimension","setTransitioning","scrollSize","triggerArrayLength","isTransitioning","_getTargetFromElement","triggerArray","isOpen","$this","$trigger","$target","NAME$4","JQUERY_NO_CONFLICT$4","REGEXP_KEYDOWN","ARROW_UP_KEYCODE","Event$4","CLICK","KEYDOWN_DATA_API","KEYUP_DATA_API","ClassName$4","Selector$4","AttachmentMap","Default$2","flip","boundary","reference","popperConfig","DefaultType$2","Dropdown","_popper","_menu","_getMenuElement","_inNavbar","_detectNavbar","isActive","_clearMenus","usePopper","showEvent","_getParentFromElement","referenceElement","_getPopperConfig","hideEvent","destroy","scheduleUpdate","_getPlacement","$parentDropdown","placement","_getOffset","offsets","modifiers","enabled","preventOverflow","boundariesElement","applyStyle","toggles","clickEvent","dropdownMenu","_dataApiKeydownHandler","items","item","JQUERY_NO_CONFLICT$5","Default$3","backdrop","DefaultType$3","Event$5","HIDE_PREVENTED","FOCUSIN","RESIZE","CLICK_DISMISS","KEYDOWN_DISMISS","MOUSEUP_DISMISS","MOUSEDOWN_DISMISS","ClassName$5","Selector$5","Modal","_dialog","_backdrop","_isShown","_isBodyOverflowing","_ignoreBackdropClick","_scrollbarWidth","_checkScrollbar","_setScrollbar","_adjustDialog","_setEscapeEvent","_setResizeEvent","_showBackdrop","_showElement","transition","_hideModal","htmlElement","handleUpdate","_triggerBackdropTransition","hideEventPrevented","modalTransitionDuration","modalBody","Node","ELEMENT_NODE","_enforceFocus","shownEvent","transitionComplete","_this5","_this6","_this7","_this8","_resetAdjustments","_resetScrollbar","_removeBackdrop","_this9","backdropTransitionDuration","callbackRemove","_backdropTransitionDuration","isModalOverflowing","scrollHeight","clientHeight","paddingLeft","paddingRight","innerWidth","_getScrollbarWidth","_this10","fixedContent","stickyContent","actualPadding","calculatedPadding","actualMargin","marginRight","calculatedMargin","scrollDiv","scrollbarWidth","clientWidth","_this11","uriAttrs","DefaultWhitelist","area","br","hr","img","ol","pre","small","span","sup","strong","ul","SAFE_URL_PATTERN","DATA_URL_PATTERN","sanitizeHtml","unsafeHtml","whiteList","sanitizeFn","createdDocument","whitelistKeys","_loop","elName","attributeList","whitelistedAttributes","allowedAttributeList","regExp","attrRegex","allowedAttribute","NAME$6","JQUERY_NO_CONFLICT$6","BSCLS_PREFIX_REGEX","DISALLOWED_ATTRIBUTES","DefaultType$4","template","fallbackPlacement","sanitize","AttachmentMap$1","AUTO","TOP","RIGHT","BOTTOM","LEFT","Default$4","HoverState","Event$6","INSERTED","FOCUSOUT","ClassName$6","Selector$6","Trigger","Tooltip","_isEnabled","_timeout","_hoverState","_activeTrigger","tip","_setListeners","enable","toggleEnabled","dataKey","DATA_KEY","_getDelegateConfig","_isWithActiveTrigger","_enter","_leave","getTipElement","EVENT_KEY","_hideModalHandler","isWithContent","shadowRoot","isInTheDom","tipId","setContent","attachment","_getAttachment","addAttachmentClass","_getContainer","_fixTransition","prevHoverState","_cleanTipClass","getTitle","CLASS_PREFIX","setElementContent","behavior","arrow","onCreate","originalPlacement","_handlePopperPlacementChange","onUpdate","eventIn","eventOut","_fixTitle","titleType","dataAttributes","$tip","tabClass","popperData","popperInstance","instance","popper","initConfigAnimation","NAME$7","JQUERY_NO_CONFLICT$7","BSCLS_PREFIX_REGEX$1","Default$5","DefaultType$5","ClassName$7","Selector$7","Event$7","Popover","_Tooltip","subClass","superClass","_getContent","CLASS_PREFIX$1","NAME$8","JQUERY_NO_CONFLICT$8","Default$6","DefaultType$6","Event$8","ACTIVATE","SCROLL","ClassName$8","Selector$8","OffsetMethod","ScrollSpy","_scrollElement","_offsets","_targets","_activeTarget","_scrollHeight","_process","refresh","autoMethod","offsetMethod","offsetBase","_getScrollTop","_getScrollHeight","targetSelector","targetBCR","_getOffsetHeight","innerHeight","maxScroll","_activate","_clear","queries","$link","scrollSpys","$spy","JQUERY_NO_CONFLICT$9","Event$9","ClassName$9","Selector$9","Tab","previous","listElement","itemSelector","hiddenEvent","_transitionComplete","dropdownChild","dropdownElement","dropdownToggleList","JQUERY_NO_CONFLICT$a","Event$a","ClassName$a","DefaultType$7","autohide","Default$7","Selector$a","Toast","Scrollspy","isBrowser","timeoutDuration","longerTimeoutBrowsers","userAgent","debounce","scheduled","functionToCheck","getStyleComputedProperty","getParentNode","getScrollParent","_getStyleComputedProp","getReferenceNode","referenceNode","isIE11","MSInputMethodContext","documentMode","isIE10","isIE","getOffsetParent","noOffsetParent","nextElementSibling","getRoot","findCommonOffsetParent","element1","element2","DOCUMENT_POSITION_FOLLOWING","createRange","setStart","setEnd","commonAncestorContainer","element1root","getScroll","side","upperSide","scrollingElement","includeScroll","modifier","bottom","getBordersSize","axis","sideA","sideB","getSize","computedStyle","getWindowSizes","classCallCheck","createClass","_extends","getClientRect","sizes","horizScrollbar","vertScrollbar","getOffsetRectRelativeToArbitraryNode","fixedPosition","isHTML","childrenRect","parentRect","scrollParent","borderTopWidth","borderLeftWidth","marginTop","getViewportOffsetRectRelativeToArtbitraryNode","excludeScroll","relativeOffset","isFixed","getFixedPositionOffsetParent","parentElement","getBoundaries","boundaries","boundariesNode","_getWindowSizes","isPaddingNumber","getArea","_ref","computeAutoPlacement","refRect","rects","sortedAreas","filteredAreas","_ref2","computedPlacement","variation","getReferenceOffsets","commonOffsetParent","getOuterSizes","marginBottom","getOppositePlacement","getPopperOffsets","referenceOffsets","popperRect","popperOffsets","isHoriz","mainSide","secondarySide","measurement","secondaryMeasurement","runModifiers","ends","findIndex","isDestroyed","arrowStyles","flipped","positionFixed","isCreated","isModifierEnabled","modifierName","some","getSupportedPropertyName","prefixes","upperProp","toCheck","willChange","disableEventListeners","removeOnDestroy","getWindow","setupEventListeners","updateBound","passive","scrollElement","attachToScrollParents","scrollParents","isBody","eventsEnabled","enableEventListeners","cancelAnimationFrame","setStyles","isFirefox","isModifierRequired","requestingName","requestedName","requesting","isRequired","_requesting","placements","validPlacements","clockwise","counter","BEHAVIORS","parseOffset","basePlacement","useHeight","fragments","divider","splitRegex","ops","mergeWithPrevious","toValue","index2","Defaults","shiftvariation","_data$offsets","isVertical","shiftOffsets","transformProp","popperStyles","transform","priority","primary","escapeWithReference","secondary","keepTogether","opSide","_data$offsets$arrow","arrowElement","sideCapitalized","altSide","arrowElementSize","center","popperMarginSide","popperBorderSide","sideValue","placementOpposite","flipOrder","refOffsets","overlapsRef","overflowsLeft","overflowsRight","overflowsTop","overflowsBottom","overflowsBoundaries","flippedVariationByRef","flipVariations","flippedVariationByContent","flipVariationsByContent","flippedVariation","getOppositeVariation","subtractLength","bound","computeStyle","legacyGpuAccelerationOption","gpuAcceleration","offsetParentRect","shouldRound","noRound","referenceWidth","popperWidth","isVariation","horizontalToInteger","verticalToInteger","getRoundedOffsets","devicePixelRatio","prefixedProperty","invertTop","invertLeft","onLoad","modifierOptions","Utils","PopperUtils","ajaxSubmit","clk","clk_x","clk_y","offsetLeft","offsetTop","opera","postError","fileapi","files","formdata","FormData","attr2","contentWindow","skipEncodingOverride","enctype","A","extraData","iframeTarget","aborted","X","O","iframeSrc","detachEvent","XMLDocument","C","responseXML","textarea","innerText","M","N","getTime","execCommand","F","E","forceSync","ActiveXObject","loadXML","eval","veto","beforeSerialize","formToArray","semantic","filtering","beforeSubmit","resetForm","clearForm","includeHidden","replaceTarget","iframe","closeKeepAlive","uploadProgress","upload","loaded","lengthComputable","ajaxForm","delegation","ajaxFormUnbind","fieldValue","required","formSerialize","fieldSerialize","clearFields","clearInputs","defaultChecked","multiple","defaultSelected","Timeout","clearFn","_id","_clearFn","unref","ref","enroll","msecs","_idleTimeoutId","_idleTimeout","unenroll","_unrefActive","_onTimeout","clearImmediate","registerImmediate","channel","messagePrefix","onGlobalMessage","nextHandle","tasksByHandle","currentlyRunningATask","attachTo","runIfPresent","importScripts","postMessageIsAsynchronous","oldOnMessage","onmessage","canUsePostMessage","MessageChannel","port1","port2","task","b64","lens","getLens","validLen","placeHoldersLen","Arr","_byteLength","curByte","revLookup","uint8","extraBytes","len2","encodeChunk","lookup","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","NaN","rt","_reverseAlphabets","digits","_encodeWithByteBuffer","decrypt_aes_cbc_sha1","encrypt_aes_cbc_sha1","encrypt_aes_cbc_sha1_padding","decrypt_aes_cbc_sha1_padding","macLen","mac2","mac1","compareMacs","asn1Validator","NativeBuffer","ed25519","messageToNativeBuffer","constants","PUBLIC_KEY_BYTE_LENGTH","PRIVATE_KEY_BYTE_LENGTH","SEED_BYTE_LENGTH","SIGN_BYTE_LENGTH","HASH_BYTE_LENGTH","pk","sk","gf","scalarbase","pack","crypto_sign_keypair","privateKeyOid","ed25519Oid","EdDSA25519","privateKeyBytes","publicKeyBytes","ed25519PublicKey","publicKeyFromPrivateKey","signedMsg","sm","Float64Array","smlen","modL","crypto_sign","sig","chk","den","den2","den4","den6","set25519","gf1","unpack25519","Z","pow2523","neq25519","par25519","gf0","unpackneg","scalarmult","crypto_verify_32","crypto_sign_open","D2","Y","msgLen","cswap","sel25519","tx","ty","zi","inv25519","pack25519","car25519","xi","yi","vn","t0","t3","t4","t5","t6","t7","t8","t9","t10","t11","t12","t13","t14","t15","t16","t17","t18","t19","t20","t21","t22","t23","t24","t25","t26","t27","t28","t29","t30","b0","b4","b5","b6","b7","b8","b9","b10","b11","b12","b13","b14","b15","kem","_createKDF","kdf","counterStart","encapsulation","kdf1","kdf2","p7","_recipientFromAsn1","encryptedContent","parameter","encKey","_recipientsToAsn1","recipients","_signerToAsn1","authenticatedAttributesAsn1","signatureAlgorithm","unauthenticatedAttributes","attrsAsn1","_attributeToAsn1","messageDigest","signingTime","_fromAsn1","rawCapture","_decryptContent","ciph","messageFromPem","messageFromAsn1","messageToPem","pemObj","toAsn1","envelopedData","createEnvelopedData","createEncryptedData","signedData","createSignedData","fromAsn1","certificates","crls","signers","digestAlgorithmIdentifiers","signerInfos","addSigner","signer","authenticatedAttributes","detached","detachedContent","mds","_signersToAsn1","addSignerInfos","addDigestAlgorithmIds","addCertificateRevokationList","crl","infos","_recipientsFromAsn1","recipientInfos","ec","findRecipient","sAttr","rAttr","recipient","privKey","desCBC","addRecipient","keyLen","ciphFn","ssh","_addBigIntegerToBuffer","hexVal","_addStringToBuffer","_sha1","sha","privateKeyToPutty","passphrase","ppk","pubbuffer","privbuffer","encLen","aeskey","mackey","macbuffer","publicKeyToOpenSSH","privateKeyToOpenSSH","sTasks","sNextTaskId","sTaskQueues","READY","RUNNING","BLOCKED","SLEEPING","DONE","ERROR","STOP","START","sStateTable","Task","subtasks","timeoutId","swapTime","userData","subrun","subtask","successCallback","failureCallback","parallel","ptask","startParallelTask","pname","pi","unblock","failure","runNext","sleep","cond","wakeup","cancelTimeout","permitsNeeded","recurse","doNext","suppressCallbacks","createCondition","tasks","QR8bitByte","QRMode","MODE_8BIT_BYTE","parsedData","QRCodeModel","typeNumber","errorCorrectLevel","moduleCount","dataCache","dataList","getLength","put","addData","newData","isDark","row","getModuleCount","make","makeImpl","getBestMaskPattern","maskPattern","setupPositionProbePattern","setupPositionAdjustPattern","setupTimingPattern","setupTypeInfo","setupTypeNumber","createData","mapData","minLostPoint","lostPoint","QRUtil","getLostPoint","createMovieClip","target_mc","instance_name","qr_mc","createEmptyMovieClip","beginFill","moveTo","lineTo","endFill","getPatternPosition","getBCHTypeNumber","getBCHTypeInfo","inc","bitIndex","byteIndex","dark","getMask","PAD0","PAD1","rsBlocks","QRRSBlock","getRSBlocks","QRBitBuffer","getLengthInBits","totalDataCount","dataCount","putBit","createBytes","maxDcCount","maxEcCount","dcdata","ecdata","dcCount","ecCount","totalCount","rsPoly","getErrorCorrectPolynomial","modPoly","QRPolynomial","modIndex","totalCodeCount","MODE_NUMBER","MODE_ALPHA_NUM","MODE_KANJI","QRErrorCorrectLevel","QRMaskPattern","PATTERN_POSITION_TABLE","G15","G18","G15_MASK","getBCHDigit","digit","errorCorrectLength","QRMath","gexp","qrCode","sameCount","darkCount","glog","LOG_TABLE","EXP_TABLE","ratio","RS_BLOCK_TABLE","rsBlock","getRsBlockTable","bufIndex","bit","QRCodeLimitLength","color","background","ecl","encodeURI","_getUTF8Length","_getTypeNumber","_getErrorCorrectLevel","qrcode","pretty","EOL","xsize","ysize","xmlDeclaration","predefined","defs","bgrect","modrect","pathdata","px","py","isInteger","save","writeFile"],"mappings":"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,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,GAAG,EAAE,IAAI,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,GAAG,EAAE,IAAI,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,GAAG,EAAE,IAAI,IAAI,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,GAAG,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,GAAG,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,EAAE,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,GAAG,IAAI,KAAK,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,EAAE,IAAI,IAAI,GAAG,IAAI,KAAK,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE,IAAI,KAAK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","file":"main.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 40);\n","/**\n * Node.js module for Forge.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2016 Digital Bazaar, Inc.\n */\nmodule.exports = {\n // default options\n options: {\n usePureJavaScript: false\n }\n};\n","/**\n * Utility functions for web applications.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2018 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nvar baseN = require('./baseN');\n\n/* Utilities API */\nvar util = module.exports = forge.util = forge.util || {};\n\n// define setImmediate and nextTick\n(function() {\n // use native nextTick (unless we're in webpack)\n // webpack (or better node-libs-browser polyfill) sets process.browser.\n // this way we can detect webpack properly\n if(typeof process !== 'undefined' && process.nextTick && !process.browser) {\n util.nextTick = process.nextTick;\n if(typeof setImmediate === 'function') {\n util.setImmediate = setImmediate;\n } else {\n // polyfill setImmediate with nextTick, older versions of node\n // (those w/o setImmediate) won't totally starve IO\n util.setImmediate = util.nextTick;\n }\n return;\n }\n\n // polyfill nextTick with native setImmediate\n if(typeof setImmediate === 'function') {\n util.setImmediate = function() { return setImmediate.apply(undefined, arguments); };\n util.nextTick = function(callback) {\n return setImmediate(callback);\n };\n return;\n }\n\n /* Note: A polyfill upgrade pattern is used here to allow combining\n polyfills. For example, MutationObserver is fast, but blocks UI updates,\n so it needs to allow UI updates periodically, so it falls back on\n postMessage or setTimeout. */\n\n // polyfill with setTimeout\n util.setImmediate = function(callback) {\n setTimeout(callback, 0);\n };\n\n // upgrade polyfill to use postMessage\n if(typeof window !== 'undefined' &&\n typeof window.postMessage === 'function') {\n var msg = 'forge.setImmediate';\n var callbacks = [];\n util.setImmediate = function(callback) {\n callbacks.push(callback);\n // only send message when one hasn't been sent in\n // the current turn of the event loop\n if(callbacks.length === 1) {\n window.postMessage(msg, '*');\n }\n };\n function handler(event) {\n if(event.source === window && event.data === msg) {\n event.stopPropagation();\n var copy = callbacks.slice();\n callbacks.length = 0;\n copy.forEach(function(callback) {\n callback();\n });\n }\n }\n window.addEventListener('message', handler, true);\n }\n\n // upgrade polyfill to use MutationObserver\n if(typeof MutationObserver !== 'undefined') {\n // polyfill with MutationObserver\n var now = Date.now();\n var attr = true;\n var div = document.createElement('div');\n var callbacks = [];\n new MutationObserver(function() {\n var copy = callbacks.slice();\n callbacks.length = 0;\n copy.forEach(function(callback) {\n callback();\n });\n }).observe(div, {attributes: true});\n var oldSetImmediate = util.setImmediate;\n util.setImmediate = function(callback) {\n if(Date.now() - now > 15) {\n now = Date.now();\n oldSetImmediate(callback);\n } else {\n callbacks.push(callback);\n // only trigger observer when it hasn't been triggered in\n // the current turn of the event loop\n if(callbacks.length === 1) {\n div.setAttribute('a', attr = !attr);\n }\n }\n };\n }\n\n util.nextTick = util.setImmediate;\n})();\n\n// check if running under Node.js\nutil.isNodejs =\n typeof process !== 'undefined' && process.versions && process.versions.node;\n\n\n// 'self' will also work in Web Workers (instance of WorkerGlobalScope) while\n// it will point to `window` in the main thread.\n// To remain compatible with older browsers, we fall back to 'window' if 'self'\n// is not available.\nutil.globalScope = (function() {\n if(util.isNodejs) {\n return global;\n }\n\n return typeof self === 'undefined' ? window : self;\n})();\n\n// define isArray\nutil.isArray = Array.isArray || function(x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n};\n\n// define isArrayBuffer\nutil.isArrayBuffer = function(x) {\n return typeof ArrayBuffer !== 'undefined' && x instanceof ArrayBuffer;\n};\n\n// define isArrayBufferView\nutil.isArrayBufferView = function(x) {\n return x && util.isArrayBuffer(x.buffer) && x.byteLength !== undefined;\n};\n\n/**\n * Ensure a bits param is 8, 16, 24, or 32. Used to validate input for\n * algorithms where bit manipulation, JavaScript limitations, and/or algorithm\n * design only allow for byte operations of a limited size.\n *\n * @param n number of bits.\n *\n * Throw Error if n invalid.\n */\nfunction _checkBitsParam(n) {\n if(!(n === 8 || n === 16 || n === 24 || n === 32)) {\n throw new Error('Only 8, 16, 24, or 32 bits supported: ' + n);\n }\n}\n\n// TODO: set ByteBuffer to best available backing\nutil.ByteBuffer = ByteStringBuffer;\n\n/** Buffer w/BinaryString backing */\n\n/**\n * Constructor for a binary string backed byte buffer.\n *\n * @param [b] the bytes to wrap (either encoded as string, one byte per\n * character, or as an ArrayBuffer or Typed Array).\n */\nfunction ByteStringBuffer(b) {\n // TODO: update to match DataBuffer API\n\n // the data in this buffer\n this.data = '';\n // the pointer for reading from this buffer\n this.read = 0;\n\n if(typeof b === 'string') {\n this.data = b;\n } else if(util.isArrayBuffer(b) || util.isArrayBufferView(b)) {\n if(typeof Buffer !== 'undefined' && b instanceof Buffer) {\n this.data = b.toString('binary');\n } else {\n // convert native buffer to forge buffer\n // FIXME: support native buffers internally instead\n var arr = new Uint8Array(b);\n try {\n this.data = String.fromCharCode.apply(null, arr);\n } catch(e) {\n for(var i = 0; i < arr.length; ++i) {\n this.putByte(arr[i]);\n }\n }\n }\n } else if(b instanceof ByteStringBuffer ||\n (typeof b === 'object' && typeof b.data === 'string' &&\n typeof b.read === 'number')) {\n // copy existing buffer\n this.data = b.data;\n this.read = b.read;\n }\n\n // used for v8 optimization\n this._constructedStringLength = 0;\n}\nutil.ByteStringBuffer = ByteStringBuffer;\n\n/* Note: This is an optimization for V8-based browsers. When V8 concatenates\n a string, the strings are only joined logically using a \"cons string\" or\n \"constructed/concatenated string\". These containers keep references to one\n another and can result in very large memory usage. For example, if a 2MB\n string is constructed by concatenating 4 bytes together at a time, the\n memory usage will be ~44MB; so ~22x increase. The strings are only joined\n together when an operation requiring their joining takes place, such as\n substr(). This function is called when adding data to this buffer to ensure\n these types of strings are periodically joined to reduce the memory\n footprint. */\nvar _MAX_CONSTRUCTED_STRING_LENGTH = 4096;\nutil.ByteStringBuffer.prototype._optimizeConstructedString = function(x) {\n this._constructedStringLength += x;\n if(this._constructedStringLength > _MAX_CONSTRUCTED_STRING_LENGTH) {\n // this substr() should cause the constructed string to join\n this.data.substr(0, 1);\n this._constructedStringLength = 0;\n }\n};\n\n/**\n * Gets the number of bytes in this buffer.\n *\n * @return the number of bytes in this buffer.\n */\nutil.ByteStringBuffer.prototype.length = function() {\n return this.data.length - this.read;\n};\n\n/**\n * Gets whether or not this buffer is empty.\n *\n * @return true if this buffer is empty, false if not.\n */\nutil.ByteStringBuffer.prototype.isEmpty = function() {\n return this.length() <= 0;\n};\n\n/**\n * Puts a byte in this buffer.\n *\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putByte = function(b) {\n return this.putBytes(String.fromCharCode(b));\n};\n\n/**\n * Puts a byte in this buffer N times.\n *\n * @param b the byte to put.\n * @param n the number of bytes of value b to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.fillWithByte = function(b, n) {\n b = String.fromCharCode(b);\n var d = this.data;\n while(n > 0) {\n if(n & 1) {\n d += b;\n }\n n >>>= 1;\n if(n > 0) {\n b += b;\n }\n }\n this.data = d;\n this._optimizeConstructedString(n);\n return this;\n};\n\n/**\n * Puts bytes in this buffer.\n *\n * @param bytes the bytes (as a binary encoded string) to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putBytes = function(bytes) {\n this.data += bytes;\n this._optimizeConstructedString(bytes.length);\n return this;\n};\n\n/**\n * Puts a UTF-16 encoded string into this buffer.\n *\n * @param str the string to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putString = function(str) {\n return this.putBytes(util.encodeUtf8(str));\n};\n\n/**\n * Puts a 16-bit integer in this buffer in big-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt16 = function(i) {\n return this.putBytes(\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n/**\n * Puts a 24-bit integer in this buffer in big-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt24 = function(i) {\n return this.putBytes(\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n/**\n * Puts a 32-bit integer in this buffer in big-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt32 = function(i) {\n return this.putBytes(\n String.fromCharCode(i >> 24 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n/**\n * Puts a 16-bit integer in this buffer in little-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt16Le = function(i) {\n return this.putBytes(\n String.fromCharCode(i & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF));\n};\n\n/**\n * Puts a 24-bit integer in this buffer in little-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt24Le = function(i) {\n return this.putBytes(\n String.fromCharCode(i & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF));\n};\n\n/**\n * Puts a 32-bit integer in this buffer in little-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt32Le = function(i) {\n return this.putBytes(\n String.fromCharCode(i & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 24 & 0xFF));\n};\n\n/**\n * Puts an n-bit integer in this buffer in big-endian order.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putInt = function(i, n) {\n _checkBitsParam(n);\n var bytes = '';\n do {\n n -= 8;\n bytes += String.fromCharCode((i >> n) & 0xFF);\n } while(n > 0);\n return this.putBytes(bytes);\n};\n\n/**\n * Puts a signed n-bit integer in this buffer in big-endian order. Two's\n * complement representation is used.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putSignedInt = function(i, n) {\n // putInt checks n\n if(i < 0) {\n i += 2 << (n - 1);\n }\n return this.putInt(i, n);\n};\n\n/**\n * Puts the given buffer into this buffer.\n *\n * @param buffer the buffer to put into this one.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.putBuffer = function(buffer) {\n return this.putBytes(buffer.getBytes());\n};\n\n/**\n * Gets a byte from this buffer and advances the read pointer by 1.\n *\n * @return the byte.\n */\nutil.ByteStringBuffer.prototype.getByte = function() {\n return this.data.charCodeAt(this.read++);\n};\n\n/**\n * Gets a uint16 from this buffer in big-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.ByteStringBuffer.prototype.getInt16 = function() {\n var rval = (\n this.data.charCodeAt(this.read) << 8 ^\n this.data.charCodeAt(this.read + 1));\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in big-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.ByteStringBuffer.prototype.getInt24 = function() {\n var rval = (\n this.data.charCodeAt(this.read) << 16 ^\n this.data.charCodeAt(this.read + 1) << 8 ^\n this.data.charCodeAt(this.read + 2));\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in big-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.ByteStringBuffer.prototype.getInt32 = function() {\n var rval = (\n this.data.charCodeAt(this.read) << 24 ^\n this.data.charCodeAt(this.read + 1) << 16 ^\n this.data.charCodeAt(this.read + 2) << 8 ^\n this.data.charCodeAt(this.read + 3));\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets a uint16 from this buffer in little-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.ByteStringBuffer.prototype.getInt16Le = function() {\n var rval = (\n this.data.charCodeAt(this.read) ^\n this.data.charCodeAt(this.read + 1) << 8);\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in little-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.ByteStringBuffer.prototype.getInt24Le = function() {\n var rval = (\n this.data.charCodeAt(this.read) ^\n this.data.charCodeAt(this.read + 1) << 8 ^\n this.data.charCodeAt(this.read + 2) << 16);\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in little-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.ByteStringBuffer.prototype.getInt32Le = function() {\n var rval = (\n this.data.charCodeAt(this.read) ^\n this.data.charCodeAt(this.read + 1) << 8 ^\n this.data.charCodeAt(this.read + 2) << 16 ^\n this.data.charCodeAt(this.read + 3) << 24);\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets an n-bit integer from this buffer in big-endian order and advances the\n * read pointer by ceil(n/8).\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.ByteStringBuffer.prototype.getInt = function(n) {\n _checkBitsParam(n);\n var rval = 0;\n do {\n // TODO: Use (rval * 0x100) if adding support for 33 to 53 bits.\n rval = (rval << 8) + this.data.charCodeAt(this.read++);\n n -= 8;\n } while(n > 0);\n return rval;\n};\n\n/**\n * Gets a signed n-bit integer from this buffer in big-endian order, using\n * two's complement, and advances the read pointer by n/8.\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.ByteStringBuffer.prototype.getSignedInt = function(n) {\n // getInt checks n\n var x = this.getInt(n);\n var max = 2 << (n - 2);\n if(x >= max) {\n x -= max << 1;\n }\n return x;\n};\n\n/**\n * Reads bytes out as a binary encoded string and clears them from the\n * buffer. Note that the resulting string is binary encoded (in node.js this\n * encoding is referred to as `binary`, it is *not* `utf8`).\n *\n * @param count the number of bytes to read, undefined or null for all.\n *\n * @return a binary encoded string of bytes.\n */\nutil.ByteStringBuffer.prototype.getBytes = function(count) {\n var rval;\n if(count) {\n // read count bytes\n count = Math.min(this.length(), count);\n rval = this.data.slice(this.read, this.read + count);\n this.read += count;\n } else if(count === 0) {\n rval = '';\n } else {\n // read all bytes, optimize to only copy when needed\n rval = (this.read === 0) ? this.data : this.data.slice(this.read);\n this.clear();\n }\n return rval;\n};\n\n/**\n * Gets a binary encoded string of the bytes from this buffer without\n * modifying the read pointer.\n *\n * @param count the number of bytes to get, omit to get all.\n *\n * @return a string full of binary encoded characters.\n */\nutil.ByteStringBuffer.prototype.bytes = function(count) {\n return (typeof(count) === 'undefined' ?\n this.data.slice(this.read) :\n this.data.slice(this.read, this.read + count));\n};\n\n/**\n * Gets a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n *\n * @return the byte.\n */\nutil.ByteStringBuffer.prototype.at = function(i) {\n return this.data.charCodeAt(this.read + i);\n};\n\n/**\n * Puts a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.setAt = function(i, b) {\n this.data = this.data.substr(0, this.read + i) +\n String.fromCharCode(b) +\n this.data.substr(this.read + i + 1);\n return this;\n};\n\n/**\n * Gets the last byte without modifying the read pointer.\n *\n * @return the last byte.\n */\nutil.ByteStringBuffer.prototype.last = function() {\n return this.data.charCodeAt(this.data.length - 1);\n};\n\n/**\n * Creates a copy of this buffer.\n *\n * @return the copy.\n */\nutil.ByteStringBuffer.prototype.copy = function() {\n var c = util.createBuffer(this.data);\n c.read = this.read;\n return c;\n};\n\n/**\n * Compacts this buffer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.compact = function() {\n if(this.read > 0) {\n this.data = this.data.slice(this.read);\n this.read = 0;\n }\n return this;\n};\n\n/**\n * Clears this buffer.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.clear = function() {\n this.data = '';\n this.read = 0;\n return this;\n};\n\n/**\n * Shortens this buffer by triming bytes off of the end of this buffer.\n *\n * @param count the number of bytes to trim off.\n *\n * @return this buffer.\n */\nutil.ByteStringBuffer.prototype.truncate = function(count) {\n var len = Math.max(0, this.length() - count);\n this.data = this.data.substr(this.read, len);\n this.read = 0;\n return this;\n};\n\n/**\n * Converts this buffer to a hexadecimal string.\n *\n * @return a hexadecimal string.\n */\nutil.ByteStringBuffer.prototype.toHex = function() {\n var rval = '';\n for(var i = this.read; i < this.data.length; ++i) {\n var b = this.data.charCodeAt(i);\n if(b < 16) {\n rval += '0';\n }\n rval += b.toString(16);\n }\n return rval;\n};\n\n/**\n * Converts this buffer to a UTF-16 string (standard JavaScript string).\n *\n * @return a UTF-16 string.\n */\nutil.ByteStringBuffer.prototype.toString = function() {\n return util.decodeUtf8(this.bytes());\n};\n\n/** End Buffer w/BinaryString backing */\n\n/** Buffer w/UInt8Array backing */\n\n/**\n * FIXME: Experimental. Do not use yet.\n *\n * Constructor for an ArrayBuffer-backed byte buffer.\n *\n * The buffer may be constructed from a string, an ArrayBuffer, DataView, or a\n * TypedArray.\n *\n * If a string is given, its encoding should be provided as an option,\n * otherwise it will default to 'binary'. A 'binary' string is encoded such\n * that each character is one byte in length and size.\n *\n * If an ArrayBuffer, DataView, or TypedArray is given, it will be used\n * *directly* without any copying. Note that, if a write to the buffer requires\n * more space, the buffer will allocate a new backing ArrayBuffer to\n * accommodate. The starting read and write offsets for the buffer may be\n * given as options.\n *\n * @param [b] the initial bytes for this buffer.\n * @param options the options to use:\n * [readOffset] the starting read offset to use (default: 0).\n * [writeOffset] the starting write offset to use (default: the\n * length of the first parameter).\n * [growSize] the minimum amount, in bytes, to grow the buffer by to\n * accommodate writes (default: 1024).\n * [encoding] the encoding ('binary', 'utf8', 'utf16', 'hex') for the\n * first parameter, if it is a string (default: 'binary').\n */\nfunction DataBuffer(b, options) {\n // default options\n options = options || {};\n\n // pointers for read from/write to buffer\n this.read = options.readOffset || 0;\n this.growSize = options.growSize || 1024;\n\n var isArrayBuffer = util.isArrayBuffer(b);\n var isArrayBufferView = util.isArrayBufferView(b);\n if(isArrayBuffer || isArrayBufferView) {\n // use ArrayBuffer directly\n if(isArrayBuffer) {\n this.data = new DataView(b);\n } else {\n // TODO: adjust read/write offset based on the type of view\n // or specify that this must be done in the options ... that the\n // offsets are byte-based\n this.data = new DataView(b.buffer, b.byteOffset, b.byteLength);\n }\n this.write = ('writeOffset' in options ?\n options.writeOffset : this.data.byteLength);\n return;\n }\n\n // initialize to empty array buffer and add any given bytes using putBytes\n this.data = new DataView(new ArrayBuffer(0));\n this.write = 0;\n\n if(b !== null && b !== undefined) {\n this.putBytes(b);\n }\n\n if('writeOffset' in options) {\n this.write = options.writeOffset;\n }\n}\nutil.DataBuffer = DataBuffer;\n\n/**\n * Gets the number of bytes in this buffer.\n *\n * @return the number of bytes in this buffer.\n */\nutil.DataBuffer.prototype.length = function() {\n return this.write - this.read;\n};\n\n/**\n * Gets whether or not this buffer is empty.\n *\n * @return true if this buffer is empty, false if not.\n */\nutil.DataBuffer.prototype.isEmpty = function() {\n return this.length() <= 0;\n};\n\n/**\n * Ensures this buffer has enough empty space to accommodate the given number\n * of bytes. An optional parameter may be given that indicates a minimum\n * amount to grow the buffer if necessary. If the parameter is not given,\n * the buffer will be grown by some previously-specified default amount\n * or heuristic.\n *\n * @param amount the number of bytes to accommodate.\n * @param [growSize] the minimum amount, in bytes, to grow the buffer by if\n * necessary.\n */\nutil.DataBuffer.prototype.accommodate = function(amount, growSize) {\n if(this.length() >= amount) {\n return this;\n }\n growSize = Math.max(growSize || this.growSize, amount);\n\n // grow buffer\n var src = new Uint8Array(\n this.data.buffer, this.data.byteOffset, this.data.byteLength);\n var dst = new Uint8Array(this.length() + growSize);\n dst.set(src);\n this.data = new DataView(dst.buffer);\n\n return this;\n};\n\n/**\n * Puts a byte in this buffer.\n *\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putByte = function(b) {\n this.accommodate(1);\n this.data.setUint8(this.write++, b);\n return this;\n};\n\n/**\n * Puts a byte in this buffer N times.\n *\n * @param b the byte to put.\n * @param n the number of bytes of value b to put.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.fillWithByte = function(b, n) {\n this.accommodate(n);\n for(var i = 0; i < n; ++i) {\n this.data.setUint8(b);\n }\n return this;\n};\n\n/**\n * Puts bytes in this buffer. The bytes may be given as a string, an\n * ArrayBuffer, a DataView, or a TypedArray.\n *\n * @param bytes the bytes to put.\n * @param [encoding] the encoding for the first parameter ('binary', 'utf8',\n * 'utf16', 'hex'), if it is a string (default: 'binary').\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putBytes = function(bytes, encoding) {\n if(util.isArrayBufferView(bytes)) {\n var src = new Uint8Array(bytes.buffer, bytes.byteOffset, bytes.byteLength);\n var len = src.byteLength - src.byteOffset;\n this.accommodate(len);\n var dst = new Uint8Array(this.data.buffer, this.write);\n dst.set(src);\n this.write += len;\n return this;\n }\n\n if(util.isArrayBuffer(bytes)) {\n var src = new Uint8Array(bytes);\n this.accommodate(src.byteLength);\n var dst = new Uint8Array(this.data.buffer);\n dst.set(src, this.write);\n this.write += src.byteLength;\n return this;\n }\n\n // bytes is a util.DataBuffer or equivalent\n if(bytes instanceof util.DataBuffer ||\n (typeof bytes === 'object' &&\n typeof bytes.read === 'number' && typeof bytes.write === 'number' &&\n util.isArrayBufferView(bytes.data))) {\n var src = new Uint8Array(bytes.data.byteLength, bytes.read, bytes.length());\n this.accommodate(src.byteLength);\n var dst = new Uint8Array(bytes.data.byteLength, this.write);\n dst.set(src);\n this.write += src.byteLength;\n return this;\n }\n\n if(bytes instanceof util.ByteStringBuffer) {\n // copy binary string and process as the same as a string parameter below\n bytes = bytes.data;\n encoding = 'binary';\n }\n\n // string conversion\n encoding = encoding || 'binary';\n if(typeof bytes === 'string') {\n var view;\n\n // decode from string\n if(encoding === 'hex') {\n this.accommodate(Math.ceil(bytes.length / 2));\n view = new Uint8Array(this.data.buffer, this.write);\n this.write += util.binary.hex.decode(bytes, view, this.write);\n return this;\n }\n if(encoding === 'base64') {\n this.accommodate(Math.ceil(bytes.length / 4) * 3);\n view = new Uint8Array(this.data.buffer, this.write);\n this.write += util.binary.base64.decode(bytes, view, this.write);\n return this;\n }\n\n // encode text as UTF-8 bytes\n if(encoding === 'utf8') {\n // encode as UTF-8 then decode string as raw binary\n bytes = util.encodeUtf8(bytes);\n encoding = 'binary';\n }\n\n // decode string as raw binary\n if(encoding === 'binary' || encoding === 'raw') {\n // one byte per character\n this.accommodate(bytes.length);\n view = new Uint8Array(this.data.buffer, this.write);\n this.write += util.binary.raw.decode(view);\n return this;\n }\n\n // encode text as UTF-16 bytes\n if(encoding === 'utf16') {\n // two bytes per character\n this.accommodate(bytes.length * 2);\n view = new Uint16Array(this.data.buffer, this.write);\n this.write += util.text.utf16.encode(view);\n return this;\n }\n\n throw new Error('Invalid encoding: ' + encoding);\n }\n\n throw Error('Invalid parameter: ' + bytes);\n};\n\n/**\n * Puts the given buffer into this buffer.\n *\n * @param buffer the buffer to put into this one.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putBuffer = function(buffer) {\n this.putBytes(buffer);\n buffer.clear();\n return this;\n};\n\n/**\n * Puts a string into this buffer.\n *\n * @param str the string to put.\n * @param [encoding] the encoding for the string (default: 'utf16').\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putString = function(str) {\n return this.putBytes(str, 'utf16');\n};\n\n/**\n * Puts a 16-bit integer in this buffer in big-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt16 = function(i) {\n this.accommodate(2);\n this.data.setInt16(this.write, i);\n this.write += 2;\n return this;\n};\n\n/**\n * Puts a 24-bit integer in this buffer in big-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt24 = function(i) {\n this.accommodate(3);\n this.data.setInt16(this.write, i >> 8 & 0xFFFF);\n this.data.setInt8(this.write, i >> 16 & 0xFF);\n this.write += 3;\n return this;\n};\n\n/**\n * Puts a 32-bit integer in this buffer in big-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt32 = function(i) {\n this.accommodate(4);\n this.data.setInt32(this.write, i);\n this.write += 4;\n return this;\n};\n\n/**\n * Puts a 16-bit integer in this buffer in little-endian order.\n *\n * @param i the 16-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt16Le = function(i) {\n this.accommodate(2);\n this.data.setInt16(this.write, i, true);\n this.write += 2;\n return this;\n};\n\n/**\n * Puts a 24-bit integer in this buffer in little-endian order.\n *\n * @param i the 24-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt24Le = function(i) {\n this.accommodate(3);\n this.data.setInt8(this.write, i >> 16 & 0xFF);\n this.data.setInt16(this.write, i >> 8 & 0xFFFF, true);\n this.write += 3;\n return this;\n};\n\n/**\n * Puts a 32-bit integer in this buffer in little-endian order.\n *\n * @param i the 32-bit integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt32Le = function(i) {\n this.accommodate(4);\n this.data.setInt32(this.write, i, true);\n this.write += 4;\n return this;\n};\n\n/**\n * Puts an n-bit integer in this buffer in big-endian order.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putInt = function(i, n) {\n _checkBitsParam(n);\n this.accommodate(n / 8);\n do {\n n -= 8;\n this.data.setInt8(this.write++, (i >> n) & 0xFF);\n } while(n > 0);\n return this;\n};\n\n/**\n * Puts a signed n-bit integer in this buffer in big-endian order. Two's\n * complement representation is used.\n *\n * @param i the n-bit integer.\n * @param n the number of bits in the integer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.putSignedInt = function(i, n) {\n _checkBitsParam(n);\n this.accommodate(n / 8);\n if(i < 0) {\n i += 2 << (n - 1);\n }\n return this.putInt(i, n);\n};\n\n/**\n * Gets a byte from this buffer and advances the read pointer by 1.\n *\n * @return the byte.\n */\nutil.DataBuffer.prototype.getByte = function() {\n return this.data.getInt8(this.read++);\n};\n\n/**\n * Gets a uint16 from this buffer in big-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.DataBuffer.prototype.getInt16 = function() {\n var rval = this.data.getInt16(this.read);\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in big-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.DataBuffer.prototype.getInt24 = function() {\n var rval = (\n this.data.getInt16(this.read) << 8 ^\n this.data.getInt8(this.read + 2));\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in big-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.DataBuffer.prototype.getInt32 = function() {\n var rval = this.data.getInt32(this.read);\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets a uint16 from this buffer in little-endian order and advances the read\n * pointer by 2.\n *\n * @return the uint16.\n */\nutil.DataBuffer.prototype.getInt16Le = function() {\n var rval = this.data.getInt16(this.read, true);\n this.read += 2;\n return rval;\n};\n\n/**\n * Gets a uint24 from this buffer in little-endian order and advances the read\n * pointer by 3.\n *\n * @return the uint24.\n */\nutil.DataBuffer.prototype.getInt24Le = function() {\n var rval = (\n this.data.getInt8(this.read) ^\n this.data.getInt16(this.read + 1, true) << 8);\n this.read += 3;\n return rval;\n};\n\n/**\n * Gets a uint32 from this buffer in little-endian order and advances the read\n * pointer by 4.\n *\n * @return the word.\n */\nutil.DataBuffer.prototype.getInt32Le = function() {\n var rval = this.data.getInt32(this.read, true);\n this.read += 4;\n return rval;\n};\n\n/**\n * Gets an n-bit integer from this buffer in big-endian order and advances the\n * read pointer by n/8.\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.DataBuffer.prototype.getInt = function(n) {\n _checkBitsParam(n);\n var rval = 0;\n do {\n // TODO: Use (rval * 0x100) if adding support for 33 to 53 bits.\n rval = (rval << 8) + this.data.getInt8(this.read++);\n n -= 8;\n } while(n > 0);\n return rval;\n};\n\n/**\n * Gets a signed n-bit integer from this buffer in big-endian order, using\n * two's complement, and advances the read pointer by n/8.\n *\n * @param n the number of bits in the integer (8, 16, 24, or 32).\n *\n * @return the integer.\n */\nutil.DataBuffer.prototype.getSignedInt = function(n) {\n // getInt checks n\n var x = this.getInt(n);\n var max = 2 << (n - 2);\n if(x >= max) {\n x -= max << 1;\n }\n return x;\n};\n\n/**\n * Reads bytes out as a binary encoded string and clears them from the\n * buffer.\n *\n * @param count the number of bytes to read, undefined or null for all.\n *\n * @return a binary encoded string of bytes.\n */\nutil.DataBuffer.prototype.getBytes = function(count) {\n // TODO: deprecate this method, it is poorly named and\n // this.toString('binary') replaces it\n // add a toTypedArray()/toArrayBuffer() function\n var rval;\n if(count) {\n // read count bytes\n count = Math.min(this.length(), count);\n rval = this.data.slice(this.read, this.read + count);\n this.read += count;\n } else if(count === 0) {\n rval = '';\n } else {\n // read all bytes, optimize to only copy when needed\n rval = (this.read === 0) ? this.data : this.data.slice(this.read);\n this.clear();\n }\n return rval;\n};\n\n/**\n * Gets a binary encoded string of the bytes from this buffer without\n * modifying the read pointer.\n *\n * @param count the number of bytes to get, omit to get all.\n *\n * @return a string full of binary encoded characters.\n */\nutil.DataBuffer.prototype.bytes = function(count) {\n // TODO: deprecate this method, it is poorly named, add \"getString()\"\n return (typeof(count) === 'undefined' ?\n this.data.slice(this.read) :\n this.data.slice(this.read, this.read + count));\n};\n\n/**\n * Gets a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n *\n * @return the byte.\n */\nutil.DataBuffer.prototype.at = function(i) {\n return this.data.getUint8(this.read + i);\n};\n\n/**\n * Puts a byte at the given index without modifying the read pointer.\n *\n * @param i the byte index.\n * @param b the byte to put.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.setAt = function(i, b) {\n this.data.setUint8(i, b);\n return this;\n};\n\n/**\n * Gets the last byte without modifying the read pointer.\n *\n * @return the last byte.\n */\nutil.DataBuffer.prototype.last = function() {\n return this.data.getUint8(this.write - 1);\n};\n\n/**\n * Creates a copy of this buffer.\n *\n * @return the copy.\n */\nutil.DataBuffer.prototype.copy = function() {\n return new util.DataBuffer(this);\n};\n\n/**\n * Compacts this buffer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.compact = function() {\n if(this.read > 0) {\n var src = new Uint8Array(this.data.buffer, this.read);\n var dst = new Uint8Array(src.byteLength);\n dst.set(src);\n this.data = new DataView(dst);\n this.write -= this.read;\n this.read = 0;\n }\n return this;\n};\n\n/**\n * Clears this buffer.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.clear = function() {\n this.data = new DataView(new ArrayBuffer(0));\n this.read = this.write = 0;\n return this;\n};\n\n/**\n * Shortens this buffer by triming bytes off of the end of this buffer.\n *\n * @param count the number of bytes to trim off.\n *\n * @return this buffer.\n */\nutil.DataBuffer.prototype.truncate = function(count) {\n this.write = Math.max(0, this.length() - count);\n this.read = Math.min(this.read, this.write);\n return this;\n};\n\n/**\n * Converts this buffer to a hexadecimal string.\n *\n * @return a hexadecimal string.\n */\nutil.DataBuffer.prototype.toHex = function() {\n var rval = '';\n for(var i = this.read; i < this.data.byteLength; ++i) {\n var b = this.data.getUint8(i);\n if(b < 16) {\n rval += '0';\n }\n rval += b.toString(16);\n }\n return rval;\n};\n\n/**\n * Converts this buffer to a string, using the given encoding. If no\n * encoding is given, 'utf8' (UTF-8) is used.\n *\n * @param [encoding] the encoding to use: 'binary', 'utf8', 'utf16', 'hex',\n * 'base64' (default: 'utf8').\n *\n * @return a string representation of the bytes in this buffer.\n */\nutil.DataBuffer.prototype.toString = function(encoding) {\n var view = new Uint8Array(this.data, this.read, this.length());\n encoding = encoding || 'utf8';\n\n // encode to string\n if(encoding === 'binary' || encoding === 'raw') {\n return util.binary.raw.encode(view);\n }\n if(encoding === 'hex') {\n return util.binary.hex.encode(view);\n }\n if(encoding === 'base64') {\n return util.binary.base64.encode(view);\n }\n\n // decode to text\n if(encoding === 'utf8') {\n return util.text.utf8.decode(view);\n }\n if(encoding === 'utf16') {\n return util.text.utf16.decode(view);\n }\n\n throw new Error('Invalid encoding: ' + encoding);\n};\n\n/** End Buffer w/UInt8Array backing */\n\n/**\n * Creates a buffer that stores bytes. A value may be given to populate the\n * buffer with data. This value can either be string of encoded bytes or a\n * regular string of characters. When passing a string of binary encoded\n * bytes, the encoding `raw` should be given. This is also the default. When\n * passing a string of characters, the encoding `utf8` should be given.\n *\n * @param [input] a string with encoded bytes to store in the buffer.\n * @param [encoding] (default: 'raw', other: 'utf8').\n */\nutil.createBuffer = function(input, encoding) {\n // TODO: deprecate, use new ByteBuffer() instead\n encoding = encoding || 'raw';\n if(input !== undefined && encoding === 'utf8') {\n input = util.encodeUtf8(input);\n }\n return new util.ByteBuffer(input);\n};\n\n/**\n * Fills a string with a particular value. If you want the string to be a byte\n * string, pass in String.fromCharCode(theByte).\n *\n * @param c the character to fill the string with, use String.fromCharCode\n * to fill the string with a byte value.\n * @param n the number of characters of value c to fill with.\n *\n * @return the filled string.\n */\nutil.fillString = function(c, n) {\n var s = '';\n while(n > 0) {\n if(n & 1) {\n s += c;\n }\n n >>>= 1;\n if(n > 0) {\n c += c;\n }\n }\n return s;\n};\n\n/**\n * Performs a per byte XOR between two byte strings and returns the result as a\n * string of bytes.\n *\n * @param s1 first string of bytes.\n * @param s2 second string of bytes.\n * @param n the number of bytes to XOR.\n *\n * @return the XOR'd result.\n */\nutil.xorBytes = function(s1, s2, n) {\n var s3 = '';\n var b = '';\n var t = '';\n var i = 0;\n var c = 0;\n for(; n > 0; --n, ++i) {\n b = s1.charCodeAt(i) ^ s2.charCodeAt(i);\n if(c >= 10) {\n s3 += t;\n t = '';\n c = 0;\n }\n t += String.fromCharCode(b);\n ++c;\n }\n s3 += t;\n return s3;\n};\n\n/**\n * Converts a hex string into a 'binary' encoded string of bytes.\n *\n * @param hex the hexadecimal string to convert.\n *\n * @return the binary-encoded string of bytes.\n */\nutil.hexToBytes = function(hex) {\n // TODO: deprecate: \"Deprecated. Use util.binary.hex.decode instead.\"\n var rval = '';\n var i = 0;\n if(hex.length & 1 == 1) {\n // odd number of characters, convert first character alone\n i = 1;\n rval += String.fromCharCode(parseInt(hex[0], 16));\n }\n // convert 2 characters (1 byte) at a time\n for(; i < hex.length; i += 2) {\n rval += String.fromCharCode(parseInt(hex.substr(i, 2), 16));\n }\n return rval;\n};\n\n/**\n * Converts a 'binary' encoded string of bytes to hex.\n *\n * @param bytes the byte string to convert.\n *\n * @return the string of hexadecimal characters.\n */\nutil.bytesToHex = function(bytes) {\n // TODO: deprecate: \"Deprecated. Use util.binary.hex.encode instead.\"\n return util.createBuffer(bytes).toHex();\n};\n\n/**\n * Converts an 32-bit integer to 4-big-endian byte string.\n *\n * @param i the integer.\n *\n * @return the byte string.\n */\nutil.int32ToBytes = function(i) {\n return (\n String.fromCharCode(i >> 24 & 0xFF) +\n String.fromCharCode(i >> 16 & 0xFF) +\n String.fromCharCode(i >> 8 & 0xFF) +\n String.fromCharCode(i & 0xFF));\n};\n\n// base64 characters, reverse mapping\nvar _base64 =\n 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';\nvar _base64Idx = [\n/*43 -43 = 0*/\n/*'+', 1, 2, 3,'/' */\n 62, -1, -1, -1, 63,\n\n/*'0','1','2','3','4','5','6','7','8','9' */\n 52, 53, 54, 55, 56, 57, 58, 59, 60, 61,\n\n/*15, 16, 17,'=', 19, 20, 21 */\n -1, -1, -1, 64, -1, -1, -1,\n\n/*65 - 43 = 22*/\n/*'A','B','C','D','E','F','G','H','I','J','K','L','M', */\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,\n\n/*'N','O','P','Q','R','S','T','U','V','W','X','Y','Z' */\n 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25,\n\n/*91 - 43 = 48 */\n/*48, 49, 50, 51, 52, 53 */\n -1, -1, -1, -1, -1, -1,\n\n/*97 - 43 = 54*/\n/*'a','b','c','d','e','f','g','h','i','j','k','l','m' */\n 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,\n\n/*'n','o','p','q','r','s','t','u','v','w','x','y','z' */\n 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51\n];\n\n// base58 characters (Bitcoin alphabet)\nvar _base58 = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz';\n\n/**\n * Base64 encodes a 'binary' encoded string of bytes.\n *\n * @param input the binary encoded string of bytes to base64-encode.\n * @param maxline the maximum number of encoded characters per line to use,\n * defaults to none.\n *\n * @return the base64-encoded output.\n */\nutil.encode64 = function(input, maxline) {\n // TODO: deprecate: \"Deprecated. Use util.binary.base64.encode instead.\"\n var line = '';\n var output = '';\n var chr1, chr2, chr3;\n var i = 0;\n while(i < input.length) {\n chr1 = input.charCodeAt(i++);\n chr2 = input.charCodeAt(i++);\n chr3 = input.charCodeAt(i++);\n\n // encode 4 character group\n line += _base64.charAt(chr1 >> 2);\n line += _base64.charAt(((chr1 & 3) << 4) | (chr2 >> 4));\n if(isNaN(chr2)) {\n line += '==';\n } else {\n line += _base64.charAt(((chr2 & 15) << 2) | (chr3 >> 6));\n line += isNaN(chr3) ? '=' : _base64.charAt(chr3 & 63);\n }\n\n if(maxline && line.length > maxline) {\n output += line.substr(0, maxline) + '\\r\\n';\n line = line.substr(maxline);\n }\n }\n output += line;\n return output;\n};\n\n/**\n * Base64 decodes a string into a 'binary' encoded string of bytes.\n *\n * @param input the base64-encoded input.\n *\n * @return the binary encoded string.\n */\nutil.decode64 = function(input) {\n // TODO: deprecate: \"Deprecated. Use util.binary.base64.decode instead.\"\n\n // remove all non-base64 characters\n input = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, '');\n\n var output = '';\n var enc1, enc2, enc3, enc4;\n var i = 0;\n\n while(i < input.length) {\n enc1 = _base64Idx[input.charCodeAt(i++) - 43];\n enc2 = _base64Idx[input.charCodeAt(i++) - 43];\n enc3 = _base64Idx[input.charCodeAt(i++) - 43];\n enc4 = _base64Idx[input.charCodeAt(i++) - 43];\n\n output += String.fromCharCode((enc1 << 2) | (enc2 >> 4));\n if(enc3 !== 64) {\n // decoded at least 2 bytes\n output += String.fromCharCode(((enc2 & 15) << 4) | (enc3 >> 2));\n if(enc4 !== 64) {\n // decoded 3 bytes\n output += String.fromCharCode(((enc3 & 3) << 6) | enc4);\n }\n }\n }\n\n return output;\n};\n\n/**\n * Encodes the given string of characters (a standard JavaScript\n * string) as a binary encoded string where the bytes represent\n * a UTF-8 encoded string of characters. Non-ASCII characters will be\n * encoded as multiple bytes according to UTF-8.\n *\n * @param str a standard string of characters to encode.\n *\n * @return the binary encoded string.\n */\nutil.encodeUtf8 = function(str) {\n return unescape(encodeURIComponent(str));\n};\n\n/**\n * Decodes a binary encoded string that contains bytes that\n * represent a UTF-8 encoded string of characters -- into a\n * string of characters (a standard JavaScript string).\n *\n * @param str the binary encoded string to decode.\n *\n * @return the resulting standard string of characters.\n */\nutil.decodeUtf8 = function(str) {\n return decodeURIComponent(escape(str));\n};\n\n// binary encoding/decoding tools\n// FIXME: Experimental. Do not use yet.\nutil.binary = {\n raw: {},\n hex: {},\n base64: {},\n base58: {},\n baseN : {\n encode: baseN.encode,\n decode: baseN.decode\n }\n};\n\n/**\n * Encodes a Uint8Array as a binary-encoded string. This encoding uses\n * a value between 0 and 255 for each character.\n *\n * @param bytes the Uint8Array to encode.\n *\n * @return the binary-encoded string.\n */\nutil.binary.raw.encode = function(bytes) {\n return String.fromCharCode.apply(null, bytes);\n};\n\n/**\n * Decodes a binary-encoded string to a Uint8Array. This encoding uses\n * a value between 0 and 255 for each character.\n *\n * @param str the binary-encoded string to decode.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.binary.raw.decode = function(str, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(str.length);\n }\n offset = offset || 0;\n var j = offset;\n for(var i = 0; i < str.length; ++i) {\n out[j++] = str.charCodeAt(i);\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Encodes a 'binary' string, ArrayBuffer, DataView, TypedArray, or\n * ByteBuffer as a string of hexadecimal characters.\n *\n * @param bytes the bytes to convert.\n *\n * @return the string of hexadecimal characters.\n */\nutil.binary.hex.encode = util.bytesToHex;\n\n/**\n * Decodes a hex-encoded string to a Uint8Array.\n *\n * @param hex the hexadecimal string to convert.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.binary.hex.decode = function(hex, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(Math.ceil(hex.length / 2));\n }\n offset = offset || 0;\n var i = 0, j = offset;\n if(hex.length & 1) {\n // odd number of characters, convert first character alone\n i = 1;\n out[j++] = parseInt(hex[0], 16);\n }\n // convert 2 characters (1 byte) at a time\n for(; i < hex.length; i += 2) {\n out[j++] = parseInt(hex.substr(i, 2), 16);\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Base64-encodes a Uint8Array.\n *\n * @param input the Uint8Array to encode.\n * @param maxline the maximum number of encoded characters per line to use,\n * defaults to none.\n *\n * @return the base64-encoded output string.\n */\nutil.binary.base64.encode = function(input, maxline) {\n var line = '';\n var output = '';\n var chr1, chr2, chr3;\n var i = 0;\n while(i < input.byteLength) {\n chr1 = input[i++];\n chr2 = input[i++];\n chr3 = input[i++];\n\n // encode 4 character group\n line += _base64.charAt(chr1 >> 2);\n line += _base64.charAt(((chr1 & 3) << 4) | (chr2 >> 4));\n if(isNaN(chr2)) {\n line += '==';\n } else {\n line += _base64.charAt(((chr2 & 15) << 2) | (chr3 >> 6));\n line += isNaN(chr3) ? '=' : _base64.charAt(chr3 & 63);\n }\n\n if(maxline && line.length > maxline) {\n output += line.substr(0, maxline) + '\\r\\n';\n line = line.substr(maxline);\n }\n }\n output += line;\n return output;\n};\n\n/**\n * Decodes a base64-encoded string to a Uint8Array.\n *\n * @param input the base64-encoded input string.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.binary.base64.decode = function(input, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(Math.ceil(input.length / 4) * 3);\n }\n\n // remove all non-base64 characters\n input = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, '');\n\n offset = offset || 0;\n var enc1, enc2, enc3, enc4;\n var i = 0, j = offset;\n\n while(i < input.length) {\n enc1 = _base64Idx[input.charCodeAt(i++) - 43];\n enc2 = _base64Idx[input.charCodeAt(i++) - 43];\n enc3 = _base64Idx[input.charCodeAt(i++) - 43];\n enc4 = _base64Idx[input.charCodeAt(i++) - 43];\n\n out[j++] = (enc1 << 2) | (enc2 >> 4);\n if(enc3 !== 64) {\n // decoded at least 2 bytes\n out[j++] = ((enc2 & 15) << 4) | (enc3 >> 2);\n if(enc4 !== 64) {\n // decoded 3 bytes\n out[j++] = ((enc3 & 3) << 6) | enc4;\n }\n }\n }\n\n // make sure result is the exact decoded length\n return output ? (j - offset) : out.subarray(0, j);\n};\n\n// add support for base58 encoding/decoding with Bitcoin alphabet\nutil.binary.base58.encode = function(input, maxline) {\n return util.binary.baseN.encode(input, _base58, maxline);\n};\nutil.binary.base58.decode = function(input, maxline) {\n return util.binary.baseN.decode(input, _base58, maxline);\n};\n\n// text encoding/decoding tools\n// FIXME: Experimental. Do not use yet.\nutil.text = {\n utf8: {},\n utf16: {}\n};\n\n/**\n * Encodes the given string as UTF-8 in a Uint8Array.\n *\n * @param str the string to encode.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.text.utf8.encode = function(str, output, offset) {\n str = util.encodeUtf8(str);\n var out = output;\n if(!out) {\n out = new Uint8Array(str.length);\n }\n offset = offset || 0;\n var j = offset;\n for(var i = 0; i < str.length; ++i) {\n out[j++] = str.charCodeAt(i);\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Decodes the UTF-8 contents from a Uint8Array.\n *\n * @param bytes the Uint8Array to decode.\n *\n * @return the resulting string.\n */\nutil.text.utf8.decode = function(bytes) {\n return util.decodeUtf8(String.fromCharCode.apply(null, bytes));\n};\n\n/**\n * Encodes the given string as UTF-16 in a Uint8Array.\n *\n * @param str the string to encode.\n * @param [output] an optional Uint8Array to write the output to; if it\n * is too small, an exception will be thrown.\n * @param [offset] the start offset for writing to the output (default: 0).\n *\n * @return the Uint8Array or the number of bytes written if output was given.\n */\nutil.text.utf16.encode = function(str, output, offset) {\n var out = output;\n if(!out) {\n out = new Uint8Array(str.length * 2);\n }\n var view = new Uint16Array(out.buffer);\n offset = offset || 0;\n var j = offset;\n var k = offset;\n for(var i = 0; i < str.length; ++i) {\n view[k++] = str.charCodeAt(i);\n j += 2;\n }\n return output ? (j - offset) : out;\n};\n\n/**\n * Decodes the UTF-16 contents from a Uint8Array.\n *\n * @param bytes the Uint8Array to decode.\n *\n * @return the resulting string.\n */\nutil.text.utf16.decode = function(bytes) {\n return String.fromCharCode.apply(null, new Uint16Array(bytes.buffer));\n};\n\n/**\n * Deflates the given data using a flash interface.\n *\n * @param api the flash interface.\n * @param bytes the data.\n * @param raw true to return only raw deflate data, false to include zlib\n * header and trailer.\n *\n * @return the deflated data as a string.\n */\nutil.deflate = function(api, bytes, raw) {\n bytes = util.decode64(api.deflate(util.encode64(bytes)).rval);\n\n // strip zlib header and trailer if necessary\n if(raw) {\n // zlib header is 2 bytes (CMF,FLG) where FLG indicates that\n // there is a 4-byte DICT (alder-32) block before the data if\n // its 5th bit is set\n var start = 2;\n var flg = bytes.charCodeAt(1);\n if(flg & 0x20) {\n start = 6;\n }\n // zlib trailer is 4 bytes of adler-32\n bytes = bytes.substring(start, bytes.length - 4);\n }\n\n return bytes;\n};\n\n/**\n * Inflates the given data using a flash interface.\n *\n * @param api the flash interface.\n * @param bytes the data.\n * @param raw true if the incoming data has no zlib header or trailer and is\n * raw DEFLATE data.\n *\n * @return the inflated data as a string, null on error.\n */\nutil.inflate = function(api, bytes, raw) {\n // TODO: add zlib header and trailer if necessary/possible\n var rval = api.inflate(util.encode64(bytes)).rval;\n return (rval === null) ? null : util.decode64(rval);\n};\n\n/**\n * Sets a storage object.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param obj the storage object, null to remove.\n */\nvar _setStorageObject = function(api, id, obj) {\n if(!api) {\n throw new Error('WebStorage not available.');\n }\n\n var rval;\n if(obj === null) {\n rval = api.removeItem(id);\n } else {\n // json-encode and base64-encode object\n obj = util.encode64(JSON.stringify(obj));\n rval = api.setItem(id, obj);\n }\n\n // handle potential flash error\n if(typeof(rval) !== 'undefined' && rval.rval !== true) {\n var error = new Error(rval.error.message);\n error.id = rval.error.id;\n error.name = rval.error.name;\n throw error;\n }\n};\n\n/**\n * Gets a storage object.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n *\n * @return the storage object entry or null if none exists.\n */\nvar _getStorageObject = function(api, id) {\n if(!api) {\n throw new Error('WebStorage not available.');\n }\n\n // get the existing entry\n var rval = api.getItem(id);\n\n /* Note: We check api.init because we can't do (api == localStorage)\n on IE because of \"Class doesn't support Automation\" exception. Only\n the flash api has an init method so this works too, but we need a\n better solution in the future. */\n\n // flash returns item wrapped in an object, handle special case\n if(api.init) {\n if(rval.rval === null) {\n if(rval.error) {\n var error = new Error(rval.error.message);\n error.id = rval.error.id;\n error.name = rval.error.name;\n throw error;\n }\n // no error, but also no item\n rval = null;\n } else {\n rval = rval.rval;\n }\n }\n\n // handle decoding\n if(rval !== null) {\n // base64-decode and json-decode data\n rval = JSON.parse(util.decode64(rval));\n }\n\n return rval;\n};\n\n/**\n * Stores an item in local storage.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param data the data for the item (any javascript object/primitive).\n */\nvar _setItem = function(api, id, key, data) {\n // get storage object\n var obj = _getStorageObject(api, id);\n if(obj === null) {\n // create a new storage object\n obj = {};\n }\n // update key\n obj[key] = data;\n\n // set storage object\n _setStorageObject(api, id, obj);\n};\n\n/**\n * Gets an item from local storage.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n *\n * @return the item.\n */\nvar _getItem = function(api, id, key) {\n // get storage object\n var rval = _getStorageObject(api, id);\n if(rval !== null) {\n // return data at key\n rval = (key in rval) ? rval[key] : null;\n }\n\n return rval;\n};\n\n/**\n * Removes an item from local storage.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n */\nvar _removeItem = function(api, id, key) {\n // get storage object\n var obj = _getStorageObject(api, id);\n if(obj !== null && key in obj) {\n // remove key\n delete obj[key];\n\n // see if entry has no keys remaining\n var empty = true;\n for(var prop in obj) {\n empty = false;\n break;\n }\n if(empty) {\n // remove entry entirely if no keys are left\n obj = null;\n }\n\n // set storage object\n _setStorageObject(api, id, obj);\n }\n};\n\n/**\n * Clears the local disk storage identified by the given ID.\n *\n * @param api the storage interface.\n * @param id the storage ID to use.\n */\nvar _clearItems = function(api, id) {\n _setStorageObject(api, id, null);\n};\n\n/**\n * Calls a storage function.\n *\n * @param func the function to call.\n * @param args the arguments for the function.\n * @param location the location argument.\n *\n * @return the return value from the function.\n */\nvar _callStorageFunction = function(func, args, location) {\n var rval = null;\n\n // default storage types\n if(typeof(location) === 'undefined') {\n location = ['web', 'flash'];\n }\n\n // apply storage types in order of preference\n var type;\n var done = false;\n var exception = null;\n for(var idx in location) {\n type = location[idx];\n try {\n if(type === 'flash' || type === 'both') {\n if(args[0] === null) {\n throw new Error('Flash local storage not available.');\n }\n rval = func.apply(this, args);\n done = (type === 'flash');\n }\n if(type === 'web' || type === 'both') {\n args[0] = localStorage;\n rval = func.apply(this, args);\n done = true;\n }\n } catch(ex) {\n exception = ex;\n }\n if(done) {\n break;\n }\n }\n\n if(!done) {\n throw exception;\n }\n\n return rval;\n};\n\n/**\n * Stores an item on local disk.\n *\n * The available types of local storage include 'flash', 'web', and 'both'.\n *\n * The type 'flash' refers to flash local storage (SharedObject). In order\n * to use flash local storage, the 'api' parameter must be valid. The type\n * 'web' refers to WebStorage, if supported by the browser. The type 'both'\n * refers to storing using both 'flash' and 'web', not just one or the\n * other.\n *\n * The location array should list the storage types to use in order of\n * preference:\n *\n * ['flash']: flash only storage\n * ['web']: web only storage\n * ['both']: try to store in both\n * ['flash','web']: store in flash first, but if not available, 'web'\n * ['web','flash']: store in web first, but if not available, 'flash'\n *\n * The location array defaults to: ['web', 'flash']\n *\n * @param api the flash interface, null to use only WebStorage.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param data the data for the item (any javascript object/primitive).\n * @param location an array with the preferred types of storage to use.\n */\nutil.setItem = function(api, id, key, data, location) {\n _callStorageFunction(_setItem, arguments, location);\n};\n\n/**\n * Gets an item on local disk.\n *\n * Set setItem() for details on storage types.\n *\n * @param api the flash interface, null to use only WebStorage.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param location an array with the preferred types of storage to use.\n *\n * @return the item.\n */\nutil.getItem = function(api, id, key, location) {\n return _callStorageFunction(_getItem, arguments, location);\n};\n\n/**\n * Removes an item on local disk.\n *\n * Set setItem() for details on storage types.\n *\n * @param api the flash interface.\n * @param id the storage ID to use.\n * @param key the key for the item.\n * @param location an array with the preferred types of storage to use.\n */\nutil.removeItem = function(api, id, key, location) {\n _callStorageFunction(_removeItem, arguments, location);\n};\n\n/**\n * Clears the local disk storage identified by the given ID.\n *\n * Set setItem() for details on storage types.\n *\n * @param api the flash interface if flash is available.\n * @param id the storage ID to use.\n * @param location an array with the preferred types of storage to use.\n */\nutil.clearItems = function(api, id, location) {\n _callStorageFunction(_clearItems, arguments, location);\n};\n\n/**\n * Parses the scheme, host, and port from an http(s) url.\n *\n * @param str the url string.\n *\n * @return the parsed url object or null if the url is invalid.\n */\nutil.parseUrl = function(str) {\n // FIXME: this regex looks a bit broken\n var regex = /^(https?):\\/\\/([^:&^\\/]*):?(\\d*)(.*)$/g;\n regex.lastIndex = 0;\n var m = regex.exec(str);\n var url = (m === null) ? null : {\n full: str,\n scheme: m[1],\n host: m[2],\n port: m[3],\n path: m[4]\n };\n if(url) {\n url.fullHost = url.host;\n if(url.port) {\n if(url.port !== 80 && url.scheme === 'http') {\n url.fullHost += ':' + url.port;\n } else if(url.port !== 443 && url.scheme === 'https') {\n url.fullHost += ':' + url.port;\n }\n } else if(url.scheme === 'http') {\n url.port = 80;\n } else if(url.scheme === 'https') {\n url.port = 443;\n }\n url.full = url.scheme + '://' + url.fullHost;\n }\n return url;\n};\n\n/* Storage for query variables */\nvar _queryVariables = null;\n\n/**\n * Returns the window location query variables. Query is parsed on the first\n * call and the same object is returned on subsequent calls. The mapping\n * is from keys to an array of values. Parameters without values will have\n * an object key set but no value added to the value array. Values are\n * unescaped.\n *\n * ...?k1=v1&k2=v2:\n * {\n * \"k1\": [\"v1\"],\n * \"k2\": [\"v2\"]\n * }\n *\n * ...?k1=v1&k1=v2:\n * {\n * \"k1\": [\"v1\", \"v2\"]\n * }\n *\n * ...?k1=v1&k2:\n * {\n * \"k1\": [\"v1\"],\n * \"k2\": []\n * }\n *\n * ...?k1=v1&k1:\n * {\n * \"k1\": [\"v1\"]\n * }\n *\n * ...?k1&k1:\n * {\n * \"k1\": []\n * }\n *\n * @param query the query string to parse (optional, default to cached\n * results from parsing window location search query).\n *\n * @return object mapping keys to variables.\n */\nutil.getQueryVariables = function(query) {\n var parse = function(q) {\n var rval = {};\n var kvpairs = q.split('&');\n for(var i = 0; i < kvpairs.length; i++) {\n var pos = kvpairs[i].indexOf('=');\n var key;\n var val;\n if(pos > 0) {\n key = kvpairs[i].substring(0, pos);\n val = kvpairs[i].substring(pos + 1);\n } else {\n key = kvpairs[i];\n val = null;\n }\n if(!(key in rval)) {\n rval[key] = [];\n }\n // disallow overriding object prototype keys\n if(!(key in Object.prototype) && val !== null) {\n rval[key].push(unescape(val));\n }\n }\n return rval;\n };\n\n var rval;\n if(typeof(query) === 'undefined') {\n // set cached variables if needed\n if(_queryVariables === null) {\n if(typeof(window) !== 'undefined' && window.location && window.location.search) {\n // parse window search query\n _queryVariables = parse(window.location.search.substring(1));\n } else {\n // no query variables available\n _queryVariables = {};\n }\n }\n rval = _queryVariables;\n } else {\n // parse given query\n rval = parse(query);\n }\n return rval;\n};\n\n/**\n * Parses a fragment into a path and query. This method will take a URI\n * fragment and break it up as if it were the main URI. For example:\n * /bar/baz?a=1&b=2\n * results in:\n * {\n * path: [\"bar\", \"baz\"],\n * query: {\"k1\": [\"v1\"], \"k2\": [\"v2\"]}\n * }\n *\n * @return object with a path array and query object.\n */\nutil.parseFragment = function(fragment) {\n // default to whole fragment\n var fp = fragment;\n var fq = '';\n // split into path and query if possible at the first '?'\n var pos = fragment.indexOf('?');\n if(pos > 0) {\n fp = fragment.substring(0, pos);\n fq = fragment.substring(pos + 1);\n }\n // split path based on '/' and ignore first element if empty\n var path = fp.split('/');\n if(path.length > 0 && path[0] === '') {\n path.shift();\n }\n // convert query into object\n var query = (fq === '') ? {} : util.getQueryVariables(fq);\n\n return {\n pathString: fp,\n queryString: fq,\n path: path,\n query: query\n };\n};\n\n/**\n * Makes a request out of a URI-like request string. This is intended to\n * be used where a fragment id (after a URI '#') is parsed as a URI with\n * path and query parts. The string should have a path beginning and\n * delimited by '/' and optional query parameters following a '?'. The\n * query should be a standard URL set of key value pairs delimited by\n * '&'. For backwards compatibility the initial '/' on the path is not\n * required. The request object has the following API, (fully described\n * in the method code):\n * {\n * path: <the path string part>.\n * query: <the query string part>,\n * getPath(i): get part or all of the split path array,\n * getQuery(k, i): get part or all of a query key array,\n * getQueryLast(k, _default): get last element of a query key array.\n * }\n *\n * @return object with request parameters.\n */\nutil.makeRequest = function(reqString) {\n var frag = util.parseFragment(reqString);\n var req = {\n // full path string\n path: frag.pathString,\n // full query string\n query: frag.queryString,\n /**\n * Get path or element in path.\n *\n * @param i optional path index.\n *\n * @return path or part of path if i provided.\n */\n getPath: function(i) {\n return (typeof(i) === 'undefined') ? frag.path : frag.path[i];\n },\n /**\n * Get query, values for a key, or value for a key index.\n *\n * @param k optional query key.\n * @param i optional query key index.\n *\n * @return query, values for a key, or value for a key index.\n */\n getQuery: function(k, i) {\n var rval;\n if(typeof(k) === 'undefined') {\n rval = frag.query;\n } else {\n rval = frag.query[k];\n if(rval && typeof(i) !== 'undefined') {\n rval = rval[i];\n }\n }\n return rval;\n },\n getQueryLast: function(k, _default) {\n var rval;\n var vals = req.getQuery(k);\n if(vals) {\n rval = vals[vals.length - 1];\n } else {\n rval = _default;\n }\n return rval;\n }\n };\n return req;\n};\n\n/**\n * Makes a URI out of a path, an object with query parameters, and a\n * fragment. Uses jQuery.param() internally for query string creation.\n * If the path is an array, it will be joined with '/'.\n *\n * @param path string path or array of strings.\n * @param query object with query parameters. (optional)\n * @param fragment fragment string. (optional)\n *\n * @return string object with request parameters.\n */\nutil.makeLink = function(path, query, fragment) {\n // join path parts if needed\n path = jQuery.isArray(path) ? path.join('/') : path;\n\n var qstr = jQuery.param(query || {});\n fragment = fragment || '';\n return path +\n ((qstr.length > 0) ? ('?' + qstr) : '') +\n ((fragment.length > 0) ? ('#' + fragment) : '');\n};\n\n/**\n * Follows a path of keys deep into an object hierarchy and set a value.\n * If a key does not exist or it's value is not an object, create an\n * object in it's place. This can be destructive to a object tree if\n * leaf nodes are given as non-final path keys.\n * Used to avoid exceptions from missing parts of the path.\n *\n * @param object the starting object.\n * @param keys an array of string keys.\n * @param value the value to set.\n */\nutil.setPath = function(object, keys, value) {\n // need to start at an object\n if(typeof(object) === 'object' && object !== null) {\n var i = 0;\n var len = keys.length;\n while(i < len) {\n var next = keys[i++];\n if(i == len) {\n // last\n object[next] = value;\n } else {\n // more\n var hasNext = (next in object);\n if(!hasNext ||\n (hasNext && typeof(object[next]) !== 'object') ||\n (hasNext && object[next] === null)) {\n object[next] = {};\n }\n object = object[next];\n }\n }\n }\n};\n\n/**\n * Follows a path of keys deep into an object hierarchy and return a value.\n * If a key does not exist, create an object in it's place.\n * Used to avoid exceptions from missing parts of the path.\n *\n * @param object the starting object.\n * @param keys an array of string keys.\n * @param _default value to return if path not found.\n *\n * @return the value at the path if found, else default if given, else\n * undefined.\n */\nutil.getPath = function(object, keys, _default) {\n var i = 0;\n var len = keys.length;\n var hasNext = true;\n while(hasNext && i < len &&\n typeof(object) === 'object' && object !== null) {\n var next = keys[i++];\n hasNext = next in object;\n if(hasNext) {\n object = object[next];\n }\n }\n return (hasNext ? object : _default);\n};\n\n/**\n * Follow a path of keys deep into an object hierarchy and delete the\n * last one. If a key does not exist, do nothing.\n * Used to avoid exceptions from missing parts of the path.\n *\n * @param object the starting object.\n * @param keys an array of string keys.\n */\nutil.deletePath = function(object, keys) {\n // need to start at an object\n if(typeof(object) === 'object' && object !== null) {\n var i = 0;\n var len = keys.length;\n while(i < len) {\n var next = keys[i++];\n if(i == len) {\n // last\n delete object[next];\n } else {\n // more\n if(!(next in object) ||\n (typeof(object[next]) !== 'object') ||\n (object[next] === null)) {\n break;\n }\n object = object[next];\n }\n }\n }\n};\n\n/**\n * Check if an object is empty.\n *\n * Taken from:\n * http://stackoverflow.com/questions/679915/how-do-i-test-for-an-empty-javascript-object-from-json/679937#679937\n *\n * @param object the object to check.\n */\nutil.isEmpty = function(obj) {\n for(var prop in obj) {\n if(obj.hasOwnProperty(prop)) {\n return false;\n }\n }\n return true;\n};\n\n/**\n * Format with simple printf-style interpolation.\n *\n * %%: literal '%'\n * %s,%o: convert next argument into a string.\n *\n * @param format the string to format.\n * @param ... arguments to interpolate into the format string.\n */\nutil.format = function(format) {\n var re = /%./g;\n // current match\n var match;\n // current part\n var part;\n // current arg index\n var argi = 0;\n // collected parts to recombine later\n var parts = [];\n // last index found\n var last = 0;\n // loop while matches remain\n while((match = re.exec(format))) {\n part = format.substring(last, re.lastIndex - 2);\n // don't add empty strings (ie, parts between %s%s)\n if(part.length > 0) {\n parts.push(part);\n }\n last = re.lastIndex;\n // switch on % code\n var code = match[0][1];\n switch(code) {\n case 's':\n case 'o':\n // check if enough arguments were given\n if(argi < arguments.length) {\n parts.push(arguments[argi++ + 1]);\n } else {\n parts.push('<?>');\n }\n break;\n // FIXME: do proper formating for numbers, etc\n //case 'f':\n //case 'd':\n case '%':\n parts.push('%');\n break;\n default:\n parts.push('<%' + code + '?>');\n }\n }\n // add trailing part of format string\n parts.push(format.substring(last));\n return parts.join('');\n};\n\n/**\n * Formats a number.\n *\n * http://snipplr.com/view/5945/javascript-numberformat--ported-from-php/\n */\nutil.formatNumber = function(number, decimals, dec_point, thousands_sep) {\n // http://kevin.vanzonneveld.net\n // + original by: Jonas Raoni Soares Silva (http://www.jsfromhell.com)\n // + improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)\n // + bugfix by: Michael White (http://crestidg.com)\n // + bugfix by: Benjamin Lupton\n // + bugfix by: Allan Jensen (http://www.winternet.no)\n // + revised by: Jonas Raoni Soares Silva (http://www.jsfromhell.com)\n // * example 1: number_format(1234.5678, 2, '.', '');\n // * returns 1: 1234.57\n\n var n = number, c = isNaN(decimals = Math.abs(decimals)) ? 2 : decimals;\n var d = dec_point === undefined ? ',' : dec_point;\n var t = thousands_sep === undefined ?\n '.' : thousands_sep, s = n < 0 ? '-' : '';\n var i = parseInt((n = Math.abs(+n || 0).toFixed(c)), 10) + '';\n var j = (i.length > 3) ? i.length % 3 : 0;\n return s + (j ? i.substr(0, j) + t : '') +\n i.substr(j).replace(/(\\d{3})(?=\\d)/g, '$1' + t) +\n (c ? d + Math.abs(n - i).toFixed(c).slice(2) : '');\n};\n\n/**\n * Formats a byte size.\n *\n * http://snipplr.com/view/5949/format-humanize-file-byte-size-presentation-in-javascript/\n */\nutil.formatSize = function(size) {\n if(size >= 1073741824) {\n size = util.formatNumber(size / 1073741824, 2, '.', '') + ' GiB';\n } else if(size >= 1048576) {\n size = util.formatNumber(size / 1048576, 2, '.', '') + ' MiB';\n } else if(size >= 1024) {\n size = util.formatNumber(size / 1024, 0) + ' KiB';\n } else {\n size = util.formatNumber(size, 0) + ' bytes';\n }\n return size;\n};\n\n/**\n * Converts an IPv4 or IPv6 string representation into bytes (in network order).\n *\n * @param ip the IPv4 or IPv6 address to convert.\n *\n * @return the 4-byte IPv6 or 16-byte IPv6 address or null if the address can't\n * be parsed.\n */\nutil.bytesFromIP = function(ip) {\n if(ip.indexOf('.') !== -1) {\n return util.bytesFromIPv4(ip);\n }\n if(ip.indexOf(':') !== -1) {\n return util.bytesFromIPv6(ip);\n }\n return null;\n};\n\n/**\n * Converts an IPv4 string representation into bytes (in network order).\n *\n * @param ip the IPv4 address to convert.\n *\n * @return the 4-byte address or null if the address can't be parsed.\n */\nutil.bytesFromIPv4 = function(ip) {\n ip = ip.split('.');\n if(ip.length !== 4) {\n return null;\n }\n var b = util.createBuffer();\n for(var i = 0; i < ip.length; ++i) {\n var num = parseInt(ip[i], 10);\n if(isNaN(num)) {\n return null;\n }\n b.putByte(num);\n }\n return b.getBytes();\n};\n\n/**\n * Converts an IPv6 string representation into bytes (in network order).\n *\n * @param ip the IPv6 address to convert.\n *\n * @return the 16-byte address or null if the address can't be parsed.\n */\nutil.bytesFromIPv6 = function(ip) {\n var blanks = 0;\n ip = ip.split(':').filter(function(e) {\n if(e.length === 0) ++blanks;\n return true;\n });\n var zeros = (8 - ip.length + blanks) * 2;\n var b = util.createBuffer();\n for(var i = 0; i < 8; ++i) {\n if(!ip[i] || ip[i].length === 0) {\n b.fillWithByte(0, zeros);\n zeros = 0;\n continue;\n }\n var bytes = util.hexToBytes(ip[i]);\n if(bytes.length < 2) {\n b.putByte(0);\n }\n b.putBytes(bytes);\n }\n return b.getBytes();\n};\n\n/**\n * Converts 4-bytes into an IPv4 string representation or 16-bytes into\n * an IPv6 string representation. The bytes must be in network order.\n *\n * @param bytes the bytes to convert.\n *\n * @return the IPv4 or IPv6 string representation if 4 or 16 bytes,\n * respectively, are given, otherwise null.\n */\nutil.bytesToIP = function(bytes) {\n if(bytes.length === 4) {\n return util.bytesToIPv4(bytes);\n }\n if(bytes.length === 16) {\n return util.bytesToIPv6(bytes);\n }\n return null;\n};\n\n/**\n * Converts 4-bytes into an IPv4 string representation. The bytes must be\n * in network order.\n *\n * @param bytes the bytes to convert.\n *\n * @return the IPv4 string representation or null for an invalid # of bytes.\n */\nutil.bytesToIPv4 = function(bytes) {\n if(bytes.length !== 4) {\n return null;\n }\n var ip = [];\n for(var i = 0; i < bytes.length; ++i) {\n ip.push(bytes.charCodeAt(i));\n }\n return ip.join('.');\n};\n\n/**\n * Converts 16-bytes into an IPv16 string representation. The bytes must be\n * in network order.\n *\n * @param bytes the bytes to convert.\n *\n * @return the IPv16 string representation or null for an invalid # of bytes.\n */\nutil.bytesToIPv6 = function(bytes) {\n if(bytes.length !== 16) {\n return null;\n }\n var ip = [];\n var zeroGroups = [];\n var zeroMaxGroup = 0;\n for(var i = 0; i < bytes.length; i += 2) {\n var hex = util.bytesToHex(bytes[i] + bytes[i + 1]);\n // canonicalize zero representation\n while(hex[0] === '0' && hex !== '0') {\n hex = hex.substr(1);\n }\n if(hex === '0') {\n var last = zeroGroups[zeroGroups.length - 1];\n var idx = ip.length;\n if(!last || idx !== last.end + 1) {\n zeroGroups.push({start: idx, end: idx});\n } else {\n last.end = idx;\n if((last.end - last.start) >\n (zeroGroups[zeroMaxGroup].end - zeroGroups[zeroMaxGroup].start)) {\n zeroMaxGroup = zeroGroups.length - 1;\n }\n }\n }\n ip.push(hex);\n }\n if(zeroGroups.length > 0) {\n var group = zeroGroups[zeroMaxGroup];\n // only shorten group of length > 0\n if(group.end - group.start > 0) {\n ip.splice(group.start, group.end - group.start + 1, '');\n if(group.start === 0) {\n ip.unshift('');\n }\n if(group.end === 7) {\n ip.push('');\n }\n }\n }\n return ip.join(':');\n};\n\n/**\n * Estimates the number of processes that can be run concurrently. If\n * creating Web Workers, keep in mind that the main JavaScript process needs\n * its own core.\n *\n * @param options the options to use:\n * update true to force an update (not use the cached value).\n * @param callback(err, max) called once the operation completes.\n */\nutil.estimateCores = function(options, callback) {\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n if('cores' in util && !options.update) {\n return callback(null, util.cores);\n }\n if(typeof navigator !== 'undefined' &&\n 'hardwareConcurrency' in navigator &&\n navigator.hardwareConcurrency > 0) {\n util.cores = navigator.hardwareConcurrency;\n return callback(null, util.cores);\n }\n if(typeof Worker === 'undefined') {\n // workers not available\n util.cores = 1;\n return callback(null, util.cores);\n }\n if(typeof Blob === 'undefined') {\n // can't estimate, default to 2\n util.cores = 2;\n return callback(null, util.cores);\n }\n\n // create worker concurrency estimation code as blob\n var blobUrl = URL.createObjectURL(new Blob(['(',\n function() {\n self.addEventListener('message', function(e) {\n // run worker for 4 ms\n var st = Date.now();\n var et = st + 4;\n while(Date.now() < et);\n self.postMessage({st: st, et: et});\n });\n }.toString(),\n ')()'], {type: 'application/javascript'}));\n\n // take 5 samples using 16 workers\n sample([], 5, 16);\n\n function sample(max, samples, numWorkers) {\n if(samples === 0) {\n // get overlap average\n var avg = Math.floor(max.reduce(function(avg, x) {\n return avg + x;\n }, 0) / max.length);\n util.cores = Math.max(1, avg);\n URL.revokeObjectURL(blobUrl);\n return callback(null, util.cores);\n }\n map(numWorkers, function(err, results) {\n max.push(reduce(numWorkers, results));\n sample(max, samples - 1, numWorkers);\n });\n }\n\n function map(numWorkers, callback) {\n var workers = [];\n var results = [];\n for(var i = 0; i < numWorkers; ++i) {\n var worker = new Worker(blobUrl);\n worker.addEventListener('message', function(e) {\n results.push(e.data);\n if(results.length === numWorkers) {\n for(var i = 0; i < numWorkers; ++i) {\n workers[i].terminate();\n }\n callback(null, results);\n }\n });\n workers.push(worker);\n }\n for(var i = 0; i < numWorkers; ++i) {\n workers[i].postMessage(i);\n }\n }\n\n function reduce(numWorkers, results) {\n // find overlapping time windows\n var overlaps = [];\n for(var n = 0; n < numWorkers; ++n) {\n var r1 = results[n];\n var overlap = overlaps[n] = [];\n for(var i = 0; i < numWorkers; ++i) {\n if(n === i) {\n continue;\n }\n var r2 = results[i];\n if((r1.st > r2.st && r1.st < r2.et) ||\n (r2.st > r1.st && r2.st < r1.et)) {\n overlap.push(i);\n }\n }\n }\n // get maximum overlaps ... don't include overlapping worker itself\n // as the main JS process was also being scheduled during the work and\n // would have to be subtracted from the estimate anyway\n return overlaps.reduce(function(max, overlap) {\n return Math.max(max, overlap.length);\n }, 0);\n }\n};\n","/**\n * Javascript implementation of Abstract Syntax Notation Number One.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n *\n * An API for storing data using the Abstract Syntax Notation Number One\n * format using DER (Distinguished Encoding Rules) encoding. This encoding is\n * commonly used to store data for PKI, i.e. X.509 Certificates, and this\n * implementation exists for that purpose.\n *\n * Abstract Syntax Notation Number One (ASN.1) is used to define the abstract\n * syntax of information without restricting the way the information is encoded\n * for transmission. It provides a standard that allows for open systems\n * communication. ASN.1 defines the syntax of information data and a number of\n * simple data types as well as a notation for describing them and specifying\n * values for them.\n *\n * The RSA algorithm creates public and private keys that are often stored in\n * X.509 or PKCS#X formats -- which use ASN.1 (encoded in DER format). This\n * class provides the most basic functionality required to store and load DSA\n * keys that are encoded according to ASN.1.\n *\n * The most common binary encodings for ASN.1 are BER (Basic Encoding Rules)\n * and DER (Distinguished Encoding Rules). DER is just a subset of BER that\n * has stricter requirements for how data must be encoded.\n *\n * Each ASN.1 structure has a tag (a byte identifying the ASN.1 structure type)\n * and a byte array for the value of this ASN1 structure which may be data or a\n * list of ASN.1 structures.\n *\n * Each ASN.1 structure using BER is (Tag-Length-Value):\n *\n * | byte 0 | bytes X | bytes Y |\n * |--------|---------|----------\n * | tag | length | value |\n *\n * ASN.1 allows for tags to be of \"High-tag-number form\" which allows a tag to\n * be two or more octets, but that is not supported by this class. A tag is\n * only 1 byte. Bits 1-5 give the tag number (ie the data type within a\n * particular 'class'), 6 indicates whether or not the ASN.1 value is\n * constructed from other ASN.1 values, and bits 7 and 8 give the 'class'. If\n * bits 7 and 8 are both zero, the class is UNIVERSAL. If only bit 7 is set,\n * then the class is APPLICATION. If only bit 8 is set, then the class is\n * CONTEXT_SPECIFIC. If both bits 7 and 8 are set, then the class is PRIVATE.\n * The tag numbers for the data types for the class UNIVERSAL are listed below:\n *\n * UNIVERSAL 0 Reserved for use by the encoding rules\n * UNIVERSAL 1 Boolean type\n * UNIVERSAL 2 Integer type\n * UNIVERSAL 3 Bitstring type\n * UNIVERSAL 4 Octetstring type\n * UNIVERSAL 5 Null type\n * UNIVERSAL 6 Object identifier type\n * UNIVERSAL 7 Object descriptor type\n * UNIVERSAL 8 External type and Instance-of type\n * UNIVERSAL 9 Real type\n * UNIVERSAL 10 Enumerated type\n * UNIVERSAL 11 Embedded-pdv type\n * UNIVERSAL 12 UTF8String type\n * UNIVERSAL 13 Relative object identifier type\n * UNIVERSAL 14-15 Reserved for future editions\n * UNIVERSAL 16 Sequence and Sequence-of types\n * UNIVERSAL 17 Set and Set-of types\n * UNIVERSAL 18-22, 25-30 Character string types\n * UNIVERSAL 23-24 Time types\n *\n * The length of an ASN.1 structure is specified after the tag identifier.\n * There is a definite form and an indefinite form. The indefinite form may\n * be used if the encoding is constructed and not all immediately available.\n * The indefinite form is encoded using a length byte with only the 8th bit\n * set. The end of the constructed object is marked using end-of-contents\n * octets (two zero bytes).\n *\n * The definite form looks like this:\n *\n * The length may take up 1 or more bytes, it depends on the length of the\n * value of the ASN.1 structure. DER encoding requires that if the ASN.1\n * structure has a value that has a length greater than 127, more than 1 byte\n * will be used to store its length, otherwise just one byte will be used.\n * This is strict.\n *\n * In the case that the length of the ASN.1 value is less than 127, 1 octet\n * (byte) is used to store the \"short form\" length. The 8th bit has a value of\n * 0 indicating the length is \"short form\" and not \"long form\" and bits 7-1\n * give the length of the data. (The 8th bit is the left-most, most significant\n * bit: also known as big endian or network format).\n *\n * In the case that the length of the ASN.1 value is greater than 127, 2 to\n * 127 octets (bytes) are used to store the \"long form\" length. The first\n * byte's 8th bit is set to 1 to indicate the length is \"long form.\" Bits 7-1\n * give the number of additional octets. All following octets are in base 256\n * with the most significant digit first (typical big-endian binary unsigned\n * integer storage). So, for instance, if the length of a value was 257, the\n * first byte would be set to:\n *\n * 10000010 = 130 = 0x82.\n *\n * This indicates there are 2 octets (base 256) for the length. The second and\n * third bytes (the octets just mentioned) would store the length in base 256:\n *\n * octet 2: 00000001 = 1 * 256^1 = 256\n * octet 3: 00000001 = 1 * 256^0 = 1\n * total = 257\n *\n * The algorithm for converting a js integer value of 257 to base-256 is:\n *\n * var value = 257;\n * var bytes = [];\n * bytes[0] = (value >>> 8) & 0xFF; // most significant byte first\n * bytes[1] = value & 0xFF; // least significant byte last\n *\n * On the ASN.1 UNIVERSAL Object Identifier (OID) type:\n *\n * An OID can be written like: \"value1.value2.value3...valueN\"\n *\n * The DER encoding rules:\n *\n * The first byte has the value 40 * value1 + value2.\n * The following bytes, if any, encode the remaining values. Each value is\n * encoded in base 128, most significant digit first (big endian), with as\n * few digits as possible, and the most significant bit of each byte set\n * to 1 except the last in each value's encoding. For example: Given the\n * OID \"1.2.840.113549\", its DER encoding is (remember each byte except the\n * last one in each encoding is OR'd with 0x80):\n *\n * byte 1: 40 * 1 + 2 = 42 = 0x2A.\n * bytes 2-3: 128 * 6 + 72 = 840 = 6 72 = 6 72 = 0x0648 = 0x8648\n * bytes 4-6: 16384 * 6 + 128 * 119 + 13 = 6 119 13 = 0x06770D = 0x86F70D\n *\n * The final value is: 0x2A864886F70D.\n * The full OID (including ASN.1 tag and length of 6 bytes) is:\n * 0x06062A864886F70D\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./oids');\n\n/* ASN.1 API */\nvar asn1 = module.exports = forge.asn1 = forge.asn1 || {};\n\n/**\n * ASN.1 classes.\n */\nasn1.Class = {\n UNIVERSAL: 0x00,\n APPLICATION: 0x40,\n CONTEXT_SPECIFIC: 0x80,\n PRIVATE: 0xC0\n};\n\n/**\n * ASN.1 types. Not all types are supported by this implementation, only\n * those necessary to implement a simple PKI are implemented.\n */\nasn1.Type = {\n NONE: 0,\n BOOLEAN: 1,\n INTEGER: 2,\n BITSTRING: 3,\n OCTETSTRING: 4,\n NULL: 5,\n OID: 6,\n ODESC: 7,\n EXTERNAL: 8,\n REAL: 9,\n ENUMERATED: 10,\n EMBEDDED: 11,\n UTF8: 12,\n ROID: 13,\n SEQUENCE: 16,\n SET: 17,\n PRINTABLESTRING: 19,\n IA5STRING: 22,\n UTCTIME: 23,\n GENERALIZEDTIME: 24,\n BMPSTRING: 30\n};\n\n/**\n * Creates a new asn1 object.\n *\n * @param tagClass the tag class for the object.\n * @param type the data type (tag number) for the object.\n * @param constructed true if the asn1 object is in constructed form.\n * @param value the value for the object, if it is not constructed.\n * @param [options] the options to use:\n * [bitStringContents] the plain BIT STRING content including padding\n * byte.\n *\n * @return the asn1 object.\n */\nasn1.create = function(tagClass, type, constructed, value, options) {\n /* An asn1 object has a tagClass, a type, a constructed flag, and a\n value. The value's type depends on the constructed flag. If\n constructed, it will contain a list of other asn1 objects. If not,\n it will contain the ASN.1 value as an array of bytes formatted\n according to the ASN.1 data type. */\n\n // remove undefined values\n if(forge.util.isArray(value)) {\n var tmp = [];\n for(var i = 0; i < value.length; ++i) {\n if(value[i] !== undefined) {\n tmp.push(value[i]);\n }\n }\n value = tmp;\n }\n\n var obj = {\n tagClass: tagClass,\n type: type,\n constructed: constructed,\n composed: constructed || forge.util.isArray(value),\n value: value\n };\n if(options && 'bitStringContents' in options) {\n // TODO: copy byte buffer if it's a buffer not a string\n obj.bitStringContents = options.bitStringContents;\n // TODO: add readonly flag to avoid this overhead\n // save copy to detect changes\n obj.original = asn1.copy(obj);\n }\n return obj;\n};\n\n/**\n * Copies an asn1 object.\n *\n * @param obj the asn1 object.\n * @param [options] copy options:\n * [excludeBitStringContents] true to not copy bitStringContents\n *\n * @return the a copy of the asn1 object.\n */\nasn1.copy = function(obj, options) {\n var copy;\n\n if(forge.util.isArray(obj)) {\n copy = [];\n for(var i = 0; i < obj.length; ++i) {\n copy.push(asn1.copy(obj[i], options));\n }\n return copy;\n }\n\n if(typeof obj === 'string') {\n // TODO: copy byte buffer if it's a buffer not a string\n return obj;\n }\n\n copy = {\n tagClass: obj.tagClass,\n type: obj.type,\n constructed: obj.constructed,\n composed: obj.composed,\n value: asn1.copy(obj.value, options)\n };\n if(options && !options.excludeBitStringContents) {\n // TODO: copy byte buffer if it's a buffer not a string\n copy.bitStringContents = obj.bitStringContents;\n }\n return copy;\n};\n\n/**\n * Compares asn1 objects for equality.\n *\n * Note this function does not run in constant time.\n *\n * @param obj1 the first asn1 object.\n * @param obj2 the second asn1 object.\n * @param [options] compare options:\n * [includeBitStringContents] true to compare bitStringContents\n *\n * @return true if the asn1 objects are equal.\n */\nasn1.equals = function(obj1, obj2, options) {\n if(forge.util.isArray(obj1)) {\n if(!forge.util.isArray(obj2)) {\n return false;\n }\n if(obj1.length !== obj2.length) {\n return false;\n }\n for(var i = 0; i < obj1.length; ++i) {\n if(!asn1.equals(obj1[i], obj2[i])) {\n return false;\n }\n }\n return true;\n }\n\n if(typeof obj1 !== typeof obj2) {\n return false;\n }\n\n if(typeof obj1 === 'string') {\n return obj1 === obj2;\n }\n\n var equal = obj1.tagClass === obj2.tagClass &&\n obj1.type === obj2.type &&\n obj1.constructed === obj2.constructed &&\n obj1.composed === obj2.composed &&\n asn1.equals(obj1.value, obj2.value);\n if(options && options.includeBitStringContents) {\n equal = equal && (obj1.bitStringContents === obj2.bitStringContents);\n }\n\n return equal;\n};\n\n/**\n * Gets the length of a BER-encoded ASN.1 value.\n *\n * In case the length is not specified, undefined is returned.\n *\n * @param b the BER-encoded ASN.1 byte buffer, starting with the first\n * length byte.\n *\n * @return the length of the BER-encoded ASN.1 value or undefined.\n */\nasn1.getBerValueLength = function(b) {\n // TODO: move this function and related DER/BER functions to a der.js\n // file; better abstract ASN.1 away from der/ber.\n var b2 = b.getByte();\n if(b2 === 0x80) {\n return undefined;\n }\n\n // see if the length is \"short form\" or \"long form\" (bit 8 set)\n var length;\n var longForm = b2 & 0x80;\n if(!longForm) {\n // length is just the first byte\n length = b2;\n } else {\n // the number of bytes the length is specified in bits 7 through 1\n // and each length byte is in big-endian base-256\n length = b.getInt((b2 & 0x7F) << 3);\n }\n return length;\n};\n\n/**\n * Check if the byte buffer has enough bytes. Throws an Error if not.\n *\n * @param bytes the byte buffer to parse from.\n * @param remaining the bytes remaining in the current parsing state.\n * @param n the number of bytes the buffer must have.\n */\nfunction _checkBufferLength(bytes, remaining, n) {\n if(n > remaining) {\n var error = new Error('Too few bytes to parse DER.');\n error.available = bytes.length();\n error.remaining = remaining;\n error.requested = n;\n throw error;\n }\n}\n\n/**\n * Gets the length of a BER-encoded ASN.1 value.\n *\n * In case the length is not specified, undefined is returned.\n *\n * @param bytes the byte buffer to parse from.\n * @param remaining the bytes remaining in the current parsing state.\n *\n * @return the length of the BER-encoded ASN.1 value or undefined.\n */\nvar _getValueLength = function(bytes, remaining) {\n // TODO: move this function and related DER/BER functions to a der.js\n // file; better abstract ASN.1 away from der/ber.\n // fromDer already checked that this byte exists\n var b2 = bytes.getByte();\n remaining--;\n if(b2 === 0x80) {\n return undefined;\n }\n\n // see if the length is \"short form\" or \"long form\" (bit 8 set)\n var length;\n var longForm = b2 & 0x80;\n if(!longForm) {\n // length is just the first byte\n length = b2;\n } else {\n // the number of bytes the length is specified in bits 7 through 1\n // and each length byte is in big-endian base-256\n var longFormBytes = b2 & 0x7F;\n _checkBufferLength(bytes, remaining, longFormBytes);\n length = bytes.getInt(longFormBytes << 3);\n }\n // FIXME: this will only happen for 32 bit getInt with high bit set\n if(length < 0) {\n throw new Error('Negative length: ' + length);\n }\n return length;\n};\n\n/**\n * Parses an asn1 object from a byte buffer in DER format.\n *\n * @param bytes the byte buffer to parse from.\n * @param [strict] true to be strict when checking value lengths, false to\n * allow truncated values (default: true).\n * @param [options] object with options or boolean strict flag\n * [strict] true to be strict when checking value lengths, false to\n * allow truncated values (default: true).\n * [decodeBitStrings] true to attempt to decode the content of\n * BIT STRINGs (not OCTET STRINGs) using strict mode. Note that\n * without schema support to understand the data context this can\n * erroneously decode values that happen to be valid ASN.1. This\n * flag will be deprecated or removed as soon as schema support is\n * available. (default: true)\n *\n * @return the parsed asn1 object.\n */\nasn1.fromDer = function(bytes, options) {\n if(options === undefined) {\n options = {\n strict: true,\n decodeBitStrings: true\n };\n }\n if(typeof options === 'boolean') {\n options = {\n strict: options,\n decodeBitStrings: true\n };\n }\n if(!('strict' in options)) {\n options.strict = true;\n }\n if(!('decodeBitStrings' in options)) {\n options.decodeBitStrings = true;\n }\n\n // wrap in buffer if needed\n if(typeof bytes === 'string') {\n bytes = forge.util.createBuffer(bytes);\n }\n\n return _fromDer(bytes, bytes.length(), 0, options);\n};\n\n/**\n * Internal function to parse an asn1 object from a byte buffer in DER format.\n *\n * @param bytes the byte buffer to parse from.\n * @param remaining the number of bytes remaining for this chunk.\n * @param depth the current parsing depth.\n * @param options object with same options as fromDer().\n *\n * @return the parsed asn1 object.\n */\nfunction _fromDer(bytes, remaining, depth, options) {\n // temporary storage for consumption calculations\n var start;\n\n // minimum length for ASN.1 DER structure is 2\n _checkBufferLength(bytes, remaining, 2);\n\n // get the first byte\n var b1 = bytes.getByte();\n // consumed one byte\n remaining--;\n\n // get the tag class\n var tagClass = (b1 & 0xC0);\n\n // get the type (bits 1-5)\n var type = b1 & 0x1F;\n\n // get the variable value length and adjust remaining bytes\n start = bytes.length();\n var length = _getValueLength(bytes, remaining);\n remaining -= start - bytes.length();\n\n // ensure there are enough bytes to get the value\n if(length !== undefined && length > remaining) {\n if(options.strict) {\n var error = new Error('Too few bytes to read ASN.1 value.');\n error.available = bytes.length();\n error.remaining = remaining;\n error.requested = length;\n throw error;\n }\n // Note: be lenient with truncated values and use remaining state bytes\n length = remaining;\n }\n\n // value storage\n var value;\n // possible BIT STRING contents storage\n var bitStringContents;\n\n // constructed flag is bit 6 (32 = 0x20) of the first byte\n var constructed = ((b1 & 0x20) === 0x20);\n if(constructed) {\n // parse child asn1 objects from the value\n value = [];\n if(length === undefined) {\n // asn1 object of indefinite length, read until end tag\n for(;;) {\n _checkBufferLength(bytes, remaining, 2);\n if(bytes.bytes(2) === String.fromCharCode(0, 0)) {\n bytes.getBytes(2);\n remaining -= 2;\n break;\n }\n start = bytes.length();\n value.push(_fromDer(bytes, remaining, depth + 1, options));\n remaining -= start - bytes.length();\n }\n } else {\n // parsing asn1 object of definite length\n while(length > 0) {\n start = bytes.length();\n value.push(_fromDer(bytes, length, depth + 1, options));\n remaining -= start - bytes.length();\n length -= start - bytes.length();\n }\n }\n }\n\n // if a BIT STRING, save the contents including padding\n if(value === undefined && tagClass === asn1.Class.UNIVERSAL &&\n type === asn1.Type.BITSTRING) {\n bitStringContents = bytes.bytes(length);\n }\n\n // determine if a non-constructed value should be decoded as a composed\n // value that contains other ASN.1 objects. BIT STRINGs (and OCTET STRINGs)\n // can be used this way.\n if(value === undefined && options.decodeBitStrings &&\n tagClass === asn1.Class.UNIVERSAL &&\n // FIXME: OCTET STRINGs not yet supported here\n // .. other parts of forge expect to decode OCTET STRINGs manually\n (type === asn1.Type.BITSTRING /*|| type === asn1.Type.OCTETSTRING*/) &&\n length > 1) {\n // save read position\n var savedRead = bytes.read;\n var savedRemaining = remaining;\n var unused = 0;\n if(type === asn1.Type.BITSTRING) {\n /* The first octet gives the number of bits by which the length of the\n bit string is less than the next multiple of eight (this is called\n the \"number of unused bits\").\n\n The second and following octets give the value of the bit string\n converted to an octet string. */\n _checkBufferLength(bytes, remaining, 1);\n unused = bytes.getByte();\n remaining--;\n }\n // if all bits are used, maybe the BIT/OCTET STRING holds ASN.1 objs\n if(unused === 0) {\n try {\n // attempt to parse child asn1 object from the value\n // (stored in array to signal composed value)\n start = bytes.length();\n var subOptions = {\n // enforce strict mode to avoid parsing ASN.1 from plain data\n verbose: options.verbose,\n strict: true,\n decodeBitStrings: true\n };\n var composed = _fromDer(bytes, remaining, depth + 1, subOptions);\n var used = start - bytes.length();\n remaining -= used;\n if(type == asn1.Type.BITSTRING) {\n used++;\n }\n\n // if the data all decoded and the class indicates UNIVERSAL or\n // CONTEXT_SPECIFIC then assume we've got an encapsulated ASN.1 object\n var tc = composed.tagClass;\n if(used === length &&\n (tc === asn1.Class.UNIVERSAL || tc === asn1.Class.CONTEXT_SPECIFIC)) {\n value = [composed];\n }\n } catch(ex) {\n }\n }\n if(value === undefined) {\n // restore read position\n bytes.read = savedRead;\n remaining = savedRemaining;\n }\n }\n\n if(value === undefined) {\n // asn1 not constructed or composed, get raw value\n // TODO: do DER to OID conversion and vice-versa in .toDer?\n\n if(length === undefined) {\n if(options.strict) {\n throw new Error('Non-constructed ASN.1 object of indefinite length.');\n }\n // be lenient and use remaining state bytes\n length = remaining;\n }\n\n if(type === asn1.Type.BMPSTRING) {\n value = '';\n for(; length > 0; length -= 2) {\n _checkBufferLength(bytes, remaining, 2);\n value += String.fromCharCode(bytes.getInt16());\n remaining -= 2;\n }\n } else {\n value = bytes.getBytes(length);\n }\n }\n\n // add BIT STRING contents if available\n var asn1Options = bitStringContents === undefined ? null : {\n bitStringContents: bitStringContents\n };\n\n // create and return asn1 object\n return asn1.create(tagClass, type, constructed, value, asn1Options);\n}\n\n/**\n * Converts the given asn1 object to a buffer of bytes in DER format.\n *\n * @param asn1 the asn1 object to convert to bytes.\n *\n * @return the buffer of bytes.\n */\nasn1.toDer = function(obj) {\n var bytes = forge.util.createBuffer();\n\n // build the first byte\n var b1 = obj.tagClass | obj.type;\n\n // for storing the ASN.1 value\n var value = forge.util.createBuffer();\n\n // use BIT STRING contents if available and data not changed\n var useBitStringContents = false;\n if('bitStringContents' in obj) {\n useBitStringContents = true;\n if(obj.original) {\n useBitStringContents = asn1.equals(obj, obj.original);\n }\n }\n\n if(useBitStringContents) {\n value.putBytes(obj.bitStringContents);\n } else if(obj.composed) {\n // if composed, use each child asn1 object's DER bytes as value\n // turn on 6th bit (0x20 = 32) to indicate asn1 is constructed\n // from other asn1 objects\n if(obj.constructed) {\n b1 |= 0x20;\n } else {\n // type is a bit string, add unused bits of 0x00\n value.putByte(0x00);\n }\n\n // add all of the child DER bytes together\n for(var i = 0; i < obj.value.length; ++i) {\n if(obj.value[i] !== undefined) {\n value.putBuffer(asn1.toDer(obj.value[i]));\n }\n }\n } else {\n // use asn1.value directly\n if(obj.type === asn1.Type.BMPSTRING) {\n for(var i = 0; i < obj.value.length; ++i) {\n value.putInt16(obj.value.charCodeAt(i));\n }\n } else {\n // ensure integer is minimally-encoded\n // TODO: should all leading bytes be stripped vs just one?\n // .. ex '00 00 01' => '01'?\n if(obj.type === asn1.Type.INTEGER &&\n obj.value.length > 1 &&\n // leading 0x00 for positive integer\n ((obj.value.charCodeAt(0) === 0 &&\n (obj.value.charCodeAt(1) & 0x80) === 0) ||\n // leading 0xFF for negative integer\n (obj.value.charCodeAt(0) === 0xFF &&\n (obj.value.charCodeAt(1) & 0x80) === 0x80))) {\n value.putBytes(obj.value.substr(1));\n } else {\n value.putBytes(obj.value);\n }\n }\n }\n\n // add tag byte\n bytes.putByte(b1);\n\n // use \"short form\" encoding\n if(value.length() <= 127) {\n // one byte describes the length\n // bit 8 = 0 and bits 7-1 = length\n bytes.putByte(value.length() & 0x7F);\n } else {\n // use \"long form\" encoding\n // 2 to 127 bytes describe the length\n // first byte: bit 8 = 1 and bits 7-1 = # of additional bytes\n // other bytes: length in base 256, big-endian\n var len = value.length();\n var lenBytes = '';\n do {\n lenBytes += String.fromCharCode(len & 0xFF);\n len = len >>> 8;\n } while(len > 0);\n\n // set first byte to # bytes used to store the length and turn on\n // bit 8 to indicate long-form length is used\n bytes.putByte(lenBytes.length | 0x80);\n\n // concatenate length bytes in reverse since they were generated\n // little endian and we need big endian\n for(var i = lenBytes.length - 1; i >= 0; --i) {\n bytes.putByte(lenBytes.charCodeAt(i));\n }\n }\n\n // concatenate value bytes\n bytes.putBuffer(value);\n return bytes;\n};\n\n/**\n * Converts an OID dot-separated string to a byte buffer. The byte buffer\n * contains only the DER-encoded value, not any tag or length bytes.\n *\n * @param oid the OID dot-separated string.\n *\n * @return the byte buffer.\n */\nasn1.oidToDer = function(oid) {\n // split OID into individual values\n var values = oid.split('.');\n var bytes = forge.util.createBuffer();\n\n // first byte is 40 * value1 + value2\n bytes.putByte(40 * parseInt(values[0], 10) + parseInt(values[1], 10));\n // other bytes are each value in base 128 with 8th bit set except for\n // the last byte for each value\n var last, valueBytes, value, b;\n for(var i = 2; i < values.length; ++i) {\n // produce value bytes in reverse because we don't know how many\n // bytes it will take to store the value\n last = true;\n valueBytes = [];\n value = parseInt(values[i], 10);\n do {\n b = value & 0x7F;\n value = value >>> 7;\n // if value is not last, then turn on 8th bit\n if(!last) {\n b |= 0x80;\n }\n valueBytes.push(b);\n last = false;\n } while(value > 0);\n\n // add value bytes in reverse (needs to be in big endian)\n for(var n = valueBytes.length - 1; n >= 0; --n) {\n bytes.putByte(valueBytes[n]);\n }\n }\n\n return bytes;\n};\n\n/**\n * Converts a DER-encoded byte buffer to an OID dot-separated string. The\n * byte buffer should contain only the DER-encoded value, not any tag or\n * length bytes.\n *\n * @param bytes the byte buffer.\n *\n * @return the OID dot-separated string.\n */\nasn1.derToOid = function(bytes) {\n var oid;\n\n // wrap in buffer if needed\n if(typeof bytes === 'string') {\n bytes = forge.util.createBuffer(bytes);\n }\n\n // first byte is 40 * value1 + value2\n var b = bytes.getByte();\n oid = Math.floor(b / 40) + '.' + (b % 40);\n\n // other bytes are each value in base 128 with 8th bit set except for\n // the last byte for each value\n var value = 0;\n while(bytes.length() > 0) {\n b = bytes.getByte();\n value = value << 7;\n // not the last byte for the value\n if(b & 0x80) {\n value += b & 0x7F;\n } else {\n // last byte\n oid += '.' + (value + b);\n value = 0;\n }\n }\n\n return oid;\n};\n\n/**\n * Converts a UTCTime value to a date.\n *\n * Note: GeneralizedTime has 4 digits for the year and is used for X.509\n * dates past 2049. Parsing that structure hasn't been implemented yet.\n *\n * @param utc the UTCTime value to convert.\n *\n * @return the date.\n */\nasn1.utcTimeToDate = function(utc) {\n /* The following formats can be used:\n\n YYMMDDhhmmZ\n YYMMDDhhmm+hh'mm'\n YYMMDDhhmm-hh'mm'\n YYMMDDhhmmssZ\n YYMMDDhhmmss+hh'mm'\n YYMMDDhhmmss-hh'mm'\n\n Where:\n\n YY is the least significant two digits of the year\n MM is the month (01 to 12)\n DD is the day (01 to 31)\n hh is the hour (00 to 23)\n mm are the minutes (00 to 59)\n ss are the seconds (00 to 59)\n Z indicates that local time is GMT, + indicates that local time is\n later than GMT, and - indicates that local time is earlier than GMT\n hh' is the absolute value of the offset from GMT in hours\n mm' is the absolute value of the offset from GMT in minutes */\n var date = new Date();\n\n // if YY >= 50 use 19xx, if YY < 50 use 20xx\n var year = parseInt(utc.substr(0, 2), 10);\n year = (year >= 50) ? 1900 + year : 2000 + year;\n var MM = parseInt(utc.substr(2, 2), 10) - 1; // use 0-11 for month\n var DD = parseInt(utc.substr(4, 2), 10);\n var hh = parseInt(utc.substr(6, 2), 10);\n var mm = parseInt(utc.substr(8, 2), 10);\n var ss = 0;\n\n // not just YYMMDDhhmmZ\n if(utc.length > 11) {\n // get character after minutes\n var c = utc.charAt(10);\n var end = 10;\n\n // see if seconds are present\n if(c !== '+' && c !== '-') {\n // get seconds\n ss = parseInt(utc.substr(10, 2), 10);\n end += 2;\n }\n }\n\n // update date\n date.setUTCFullYear(year, MM, DD);\n date.setUTCHours(hh, mm, ss, 0);\n\n if(end) {\n // get +/- after end of time\n c = utc.charAt(end);\n if(c === '+' || c === '-') {\n // get hours+minutes offset\n var hhoffset = parseInt(utc.substr(end + 1, 2), 10);\n var mmoffset = parseInt(utc.substr(end + 4, 2), 10);\n\n // calculate offset in milliseconds\n var offset = hhoffset * 60 + mmoffset;\n offset *= 60000;\n\n // apply offset\n if(c === '+') {\n date.setTime(+date - offset);\n } else {\n date.setTime(+date + offset);\n }\n }\n }\n\n return date;\n};\n\n/**\n * Converts a GeneralizedTime value to a date.\n *\n * @param gentime the GeneralizedTime value to convert.\n *\n * @return the date.\n */\nasn1.generalizedTimeToDate = function(gentime) {\n /* The following formats can be used:\n\n YYYYMMDDHHMMSS\n YYYYMMDDHHMMSS.fff\n YYYYMMDDHHMMSSZ\n YYYYMMDDHHMMSS.fffZ\n YYYYMMDDHHMMSS+hh'mm'\n YYYYMMDDHHMMSS.fff+hh'mm'\n YYYYMMDDHHMMSS-hh'mm'\n YYYYMMDDHHMMSS.fff-hh'mm'\n\n Where:\n\n YYYY is the year\n MM is the month (01 to 12)\n DD is the day (01 to 31)\n hh is the hour (00 to 23)\n mm are the minutes (00 to 59)\n ss are the seconds (00 to 59)\n .fff is the second fraction, accurate to three decimal places\n Z indicates that local time is GMT, + indicates that local time is\n later than GMT, and - indicates that local time is earlier than GMT\n hh' is the absolute value of the offset from GMT in hours\n mm' is the absolute value of the offset from GMT in minutes */\n var date = new Date();\n\n var YYYY = parseInt(gentime.substr(0, 4), 10);\n var MM = parseInt(gentime.substr(4, 2), 10) - 1; // use 0-11 for month\n var DD = parseInt(gentime.substr(6, 2), 10);\n var hh = parseInt(gentime.substr(8, 2), 10);\n var mm = parseInt(gentime.substr(10, 2), 10);\n var ss = parseInt(gentime.substr(12, 2), 10);\n var fff = 0;\n var offset = 0;\n var isUTC = false;\n\n if(gentime.charAt(gentime.length - 1) === 'Z') {\n isUTC = true;\n }\n\n var end = gentime.length - 5, c = gentime.charAt(end);\n if(c === '+' || c === '-') {\n // get hours+minutes offset\n var hhoffset = parseInt(gentime.substr(end + 1, 2), 10);\n var mmoffset = parseInt(gentime.substr(end + 4, 2), 10);\n\n // calculate offset in milliseconds\n offset = hhoffset * 60 + mmoffset;\n offset *= 60000;\n\n // apply offset\n if(c === '+') {\n offset *= -1;\n }\n\n isUTC = true;\n }\n\n // check for second fraction\n if(gentime.charAt(14) === '.') {\n fff = parseFloat(gentime.substr(14), 10) * 1000;\n }\n\n if(isUTC) {\n date.setUTCFullYear(YYYY, MM, DD);\n date.setUTCHours(hh, mm, ss, fff);\n\n // apply offset\n date.setTime(+date + offset);\n } else {\n date.setFullYear(YYYY, MM, DD);\n date.setHours(hh, mm, ss, fff);\n }\n\n return date;\n};\n\n/**\n * Converts a date to a UTCTime value.\n *\n * Note: GeneralizedTime has 4 digits for the year and is used for X.509\n * dates past 2049. Converting to a GeneralizedTime hasn't been\n * implemented yet.\n *\n * @param date the date to convert.\n *\n * @return the UTCTime value.\n */\nasn1.dateToUtcTime = function(date) {\n // TODO: validate; currently assumes proper format\n if(typeof date === 'string') {\n return date;\n }\n\n var rval = '';\n\n // create format YYMMDDhhmmssZ\n var format = [];\n format.push(('' + date.getUTCFullYear()).substr(2));\n format.push('' + (date.getUTCMonth() + 1));\n format.push('' + date.getUTCDate());\n format.push('' + date.getUTCHours());\n format.push('' + date.getUTCMinutes());\n format.push('' + date.getUTCSeconds());\n\n // ensure 2 digits are used for each format entry\n for(var i = 0; i < format.length; ++i) {\n if(format[i].length < 2) {\n rval += '0';\n }\n rval += format[i];\n }\n rval += 'Z';\n\n return rval;\n};\n\n/**\n * Converts a date to a GeneralizedTime value.\n *\n * @param date the date to convert.\n *\n * @return the GeneralizedTime value as a string.\n */\nasn1.dateToGeneralizedTime = function(date) {\n // TODO: validate; currently assumes proper format\n if(typeof date === 'string') {\n return date;\n }\n\n var rval = '';\n\n // create format YYYYMMDDHHMMSSZ\n var format = [];\n format.push('' + date.getUTCFullYear());\n format.push('' + (date.getUTCMonth() + 1));\n format.push('' + date.getUTCDate());\n format.push('' + date.getUTCHours());\n format.push('' + date.getUTCMinutes());\n format.push('' + date.getUTCSeconds());\n\n // ensure 2 digits are used for each format entry\n for(var i = 0; i < format.length; ++i) {\n if(format[i].length < 2) {\n rval += '0';\n }\n rval += format[i];\n }\n rval += 'Z';\n\n return rval;\n};\n\n/**\n * Converts a javascript integer to a DER-encoded byte buffer to be used\n * as the value for an INTEGER type.\n *\n * @param x the integer.\n *\n * @return the byte buffer.\n */\nasn1.integerToDer = function(x) {\n var rval = forge.util.createBuffer();\n if(x >= -0x80 && x < 0x80) {\n return rval.putSignedInt(x, 8);\n }\n if(x >= -0x8000 && x < 0x8000) {\n return rval.putSignedInt(x, 16);\n }\n if(x >= -0x800000 && x < 0x800000) {\n return rval.putSignedInt(x, 24);\n }\n if(x >= -0x80000000 && x < 0x80000000) {\n return rval.putSignedInt(x, 32);\n }\n var error = new Error('Integer too large; max is 32-bits.');\n error.integer = x;\n throw error;\n};\n\n/**\n * Converts a DER-encoded byte buffer to a javascript integer. This is\n * typically used to decode the value of an INTEGER type.\n *\n * @param bytes the byte buffer.\n *\n * @return the integer.\n */\nasn1.derToInteger = function(bytes) {\n // wrap in buffer if needed\n if(typeof bytes === 'string') {\n bytes = forge.util.createBuffer(bytes);\n }\n\n var n = bytes.length() * 8;\n if(n > 32) {\n throw new Error('Integer too large; max is 32-bits.');\n }\n return bytes.getSignedInt(n);\n};\n\n/**\n * Validates that the given ASN.1 object is at least a super set of the\n * given ASN.1 structure. Only tag classes and types are checked. An\n * optional map may also be provided to capture ASN.1 values while the\n * structure is checked.\n *\n * To capture an ASN.1 value, set an object in the validator's 'capture'\n * parameter to the key to use in the capture map. To capture the full\n * ASN.1 object, specify 'captureAsn1'. To capture BIT STRING bytes, including\n * the leading unused bits counter byte, specify 'captureBitStringContents'.\n * To capture BIT STRING bytes, without the leading unused bits counter byte,\n * specify 'captureBitStringValue'.\n *\n * Objects in the validator may set a field 'optional' to true to indicate\n * that it isn't necessary to pass validation.\n *\n * @param obj the ASN.1 object to validate.\n * @param v the ASN.1 structure validator.\n * @param capture an optional map to capture values in.\n * @param errors an optional array for storing validation errors.\n *\n * @return true on success, false on failure.\n */\nasn1.validate = function(obj, v, capture, errors) {\n var rval = false;\n\n // ensure tag class and type are the same if specified\n if((obj.tagClass === v.tagClass || typeof(v.tagClass) === 'undefined') &&\n (obj.type === v.type || typeof(v.type) === 'undefined')) {\n // ensure constructed flag is the same if specified\n if(obj.constructed === v.constructed ||\n typeof(v.constructed) === 'undefined') {\n rval = true;\n\n // handle sub values\n if(v.value && forge.util.isArray(v.value)) {\n var j = 0;\n for(var i = 0; rval && i < v.value.length; ++i) {\n rval = v.value[i].optional || false;\n if(obj.value[j]) {\n rval = asn1.validate(obj.value[j], v.value[i], capture, errors);\n if(rval) {\n ++j;\n } else if(v.value[i].optional) {\n rval = true;\n }\n }\n if(!rval && errors) {\n errors.push(\n '[' + v.name + '] ' +\n 'Tag class \"' + v.tagClass + '\", type \"' +\n v.type + '\" expected value length \"' +\n v.value.length + '\", got \"' +\n obj.value.length + '\"');\n }\n }\n }\n\n if(rval && capture) {\n if(v.capture) {\n capture[v.capture] = obj.value;\n }\n if(v.captureAsn1) {\n capture[v.captureAsn1] = obj;\n }\n if(v.captureBitStringContents && 'bitStringContents' in obj) {\n capture[v.captureBitStringContents] = obj.bitStringContents;\n }\n if(v.captureBitStringValue && 'bitStringContents' in obj) {\n var value;\n if(obj.bitStringContents.length < 2) {\n capture[v.captureBitStringValue] = '';\n } else {\n // FIXME: support unused bits with data shifting\n var unused = obj.bitStringContents.charCodeAt(0);\n if(unused !== 0) {\n throw new Error(\n 'captureBitStringValue only supported for zero unused bits');\n }\n capture[v.captureBitStringValue] = obj.bitStringContents.slice(1);\n }\n }\n }\n } else if(errors) {\n errors.push(\n '[' + v.name + '] ' +\n 'Expected constructed \"' + v.constructed + '\", got \"' +\n obj.constructed + '\"');\n }\n } else if(errors) {\n if(obj.tagClass !== v.tagClass) {\n errors.push(\n '[' + v.name + '] ' +\n 'Expected tag class \"' + v.tagClass + '\", got \"' +\n obj.tagClass + '\"');\n }\n if(obj.type !== v.type) {\n errors.push(\n '[' + v.name + '] ' +\n 'Expected type \"' + v.type + '\", got \"' + obj.type + '\"');\n }\n }\n return rval;\n};\n\n// regex for testing for non-latin characters\nvar _nonLatinRegex = /[^\\\\u0000-\\\\u00ff]/;\n\n/**\n * Pretty prints an ASN.1 object to a string.\n *\n * @param obj the object to write out.\n * @param level the level in the tree.\n * @param indentation the indentation to use.\n *\n * @return the string.\n */\nasn1.prettyPrint = function(obj, level, indentation) {\n var rval = '';\n\n // set default level and indentation\n level = level || 0;\n indentation = indentation || 2;\n\n // start new line for deep levels\n if(level > 0) {\n rval += '\\n';\n }\n\n // create indent\n var indent = '';\n for(var i = 0; i < level * indentation; ++i) {\n indent += ' ';\n }\n\n // print class:type\n rval += indent + 'Tag: ';\n switch(obj.tagClass) {\n case asn1.Class.UNIVERSAL:\n rval += 'Universal:';\n break;\n case asn1.Class.APPLICATION:\n rval += 'Application:';\n break;\n case asn1.Class.CONTEXT_SPECIFIC:\n rval += 'Context-Specific:';\n break;\n case asn1.Class.PRIVATE:\n rval += 'Private:';\n break;\n }\n\n if(obj.tagClass === asn1.Class.UNIVERSAL) {\n rval += obj.type;\n\n // known types\n switch(obj.type) {\n case asn1.Type.NONE:\n rval += ' (None)';\n break;\n case asn1.Type.BOOLEAN:\n rval += ' (Boolean)';\n break;\n case asn1.Type.INTEGER:\n rval += ' (Integer)';\n break;\n case asn1.Type.BITSTRING:\n rval += ' (Bit string)';\n break;\n case asn1.Type.OCTETSTRING:\n rval += ' (Octet string)';\n break;\n case asn1.Type.NULL:\n rval += ' (Null)';\n break;\n case asn1.Type.OID:\n rval += ' (Object Identifier)';\n break;\n case asn1.Type.ODESC:\n rval += ' (Object Descriptor)';\n break;\n case asn1.Type.EXTERNAL:\n rval += ' (External or Instance of)';\n break;\n case asn1.Type.REAL:\n rval += ' (Real)';\n break;\n case asn1.Type.ENUMERATED:\n rval += ' (Enumerated)';\n break;\n case asn1.Type.EMBEDDED:\n rval += ' (Embedded PDV)';\n break;\n case asn1.Type.UTF8:\n rval += ' (UTF8)';\n break;\n case asn1.Type.ROID:\n rval += ' (Relative Object Identifier)';\n break;\n case asn1.Type.SEQUENCE:\n rval += ' (Sequence)';\n break;\n case asn1.Type.SET:\n rval += ' (Set)';\n break;\n case asn1.Type.PRINTABLESTRING:\n rval += ' (Printable String)';\n break;\n case asn1.Type.IA5String:\n rval += ' (IA5String (ASCII))';\n break;\n case asn1.Type.UTCTIME:\n rval += ' (UTC time)';\n break;\n case asn1.Type.GENERALIZEDTIME:\n rval += ' (Generalized time)';\n break;\n case asn1.Type.BMPSTRING:\n rval += ' (BMP String)';\n break;\n }\n } else {\n rval += obj.type;\n }\n\n rval += '\\n';\n rval += indent + 'Constructed: ' + obj.constructed + '\\n';\n\n if(obj.composed) {\n var subvalues = 0;\n var sub = '';\n for(var i = 0; i < obj.value.length; ++i) {\n if(obj.value[i] !== undefined) {\n subvalues += 1;\n sub += asn1.prettyPrint(obj.value[i], level + 1, indentation);\n if((i + 1) < obj.value.length) {\n sub += ',';\n }\n }\n }\n rval += indent + 'Sub values: ' + subvalues + sub;\n } else {\n rval += indent + 'Value: ';\n if(obj.type === asn1.Type.OID) {\n var oid = asn1.derToOid(obj.value);\n rval += oid;\n if(forge.pki && forge.pki.oids) {\n if(oid in forge.pki.oids) {\n rval += ' (' + forge.pki.oids[oid] + ') ';\n }\n }\n }\n if(obj.type === asn1.Type.INTEGER) {\n try {\n rval += asn1.derToInteger(obj.value);\n } catch(ex) {\n rval += '0x' + forge.util.bytesToHex(obj.value);\n }\n } else if(obj.type === asn1.Type.BITSTRING) {\n // TODO: shift bits as needed to display without padding\n if(obj.value.length > 1) {\n // remove unused bits field\n rval += '0x' + forge.util.bytesToHex(obj.value.slice(1));\n } else {\n rval += '(none)';\n }\n // show unused bit count\n if(obj.value.length > 0) {\n var unused = obj.value.charCodeAt(0);\n if(unused == 1) {\n rval += ' (1 unused bit shown)';\n } else if(unused > 1) {\n rval += ' (' + unused + ' unused bits shown)';\n }\n }\n } else if(obj.type === asn1.Type.OCTETSTRING) {\n if(!_nonLatinRegex.test(obj.value)) {\n rval += '(' + obj.value + ') ';\n }\n rval += '0x' + forge.util.bytesToHex(obj.value);\n } else if(obj.type === asn1.Type.UTF8) {\n rval += forge.util.decodeUtf8(obj.value);\n } else if(obj.type === asn1.Type.PRINTABLESTRING ||\n obj.type === asn1.Type.IA5String) {\n rval += obj.value;\n } else if(_nonLatinRegex.test(obj.value)) {\n rval += '0x' + forge.util.bytesToHex(obj.value);\n } else if(obj.value.length === 0) {\n rval += '[null]';\n } else {\n rval += obj.value;\n }\n }\n\n return rval;\n};\n","/**\n * An API for getting cryptographically-secure random bytes. The bytes are\n * generated using the Fortuna algorithm devised by Bruce Schneier and\n * Niels Ferguson.\n *\n * Getting strong random bytes is not yet easy to do in javascript. The only\n * truish random entropy that can be collected is from the mouse, keyboard, or\n * from timing with respect to page loads, etc. This generator makes a poor\n * attempt at providing random bytes when those sources haven't yet provided\n * enough entropy to initially seed or to reseed the PRNG.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2009-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./sha256');\nrequire('./prng');\nrequire('./util');\n\n(function() {\n\n// forge.random already defined\nif(forge.random && forge.random.getBytes) {\n module.exports = forge.random;\n return;\n}\n\n(function(jQuery) {\n\n// the default prng plugin, uses AES-128\nvar prng_aes = {};\nvar _prng_aes_output = new Array(4);\nvar _prng_aes_buffer = forge.util.createBuffer();\nprng_aes.formatKey = function(key) {\n // convert the key into 32-bit integers\n var tmp = forge.util.createBuffer(key);\n key = new Array(4);\n key[0] = tmp.getInt32();\n key[1] = tmp.getInt32();\n key[2] = tmp.getInt32();\n key[3] = tmp.getInt32();\n\n // return the expanded key\n return forge.aes._expandKey(key, false);\n};\nprng_aes.formatSeed = function(seed) {\n // convert seed into 32-bit integers\n var tmp = forge.util.createBuffer(seed);\n seed = new Array(4);\n seed[0] = tmp.getInt32();\n seed[1] = tmp.getInt32();\n seed[2] = tmp.getInt32();\n seed[3] = tmp.getInt32();\n return seed;\n};\nprng_aes.cipher = function(key, seed) {\n forge.aes._updateBlock(key, seed, _prng_aes_output, false);\n _prng_aes_buffer.putInt32(_prng_aes_output[0]);\n _prng_aes_buffer.putInt32(_prng_aes_output[1]);\n _prng_aes_buffer.putInt32(_prng_aes_output[2]);\n _prng_aes_buffer.putInt32(_prng_aes_output[3]);\n return _prng_aes_buffer.getBytes();\n};\nprng_aes.increment = function(seed) {\n // FIXME: do we care about carry or signed issues?\n ++seed[3];\n return seed;\n};\nprng_aes.md = forge.md.sha256;\n\n/**\n * Creates a new PRNG.\n */\nfunction spawnPrng() {\n var ctx = forge.prng.create(prng_aes);\n\n /**\n * Gets random bytes. If a native secure crypto API is unavailable, this\n * method tries to make the bytes more unpredictable by drawing from data that\n * can be collected from the user of the browser, eg: mouse movement.\n *\n * If a callback is given, this method will be called asynchronously.\n *\n * @param count the number of random bytes to get.\n * @param [callback(err, bytes)] called once the operation completes.\n *\n * @return the random bytes in a string.\n */\n ctx.getBytes = function(count, callback) {\n return ctx.generate(count, callback);\n };\n\n /**\n * Gets random bytes asynchronously. If a native secure crypto API is\n * unavailable, this method tries to make the bytes more unpredictable by\n * drawing from data that can be collected from the user of the browser,\n * eg: mouse movement.\n *\n * @param count the number of random bytes to get.\n *\n * @return the random bytes in a string.\n */\n ctx.getBytesSync = function(count) {\n return ctx.generate(count);\n };\n\n return ctx;\n}\n\n// create default prng context\nvar _ctx = spawnPrng();\n\n// add other sources of entropy only if window.crypto.getRandomValues is not\n// available -- otherwise this source will be automatically used by the prng\nvar getRandomValues = null;\nvar globalScope = forge.util.globalScope;\nvar _crypto = globalScope.crypto || globalScope.msCrypto;\nif(_crypto && _crypto.getRandomValues) {\n getRandomValues = function(arr) {\n return _crypto.getRandomValues(arr);\n };\n}\n\nif(forge.options.usePureJavaScript ||\n (!forge.util.isNodejs && !getRandomValues)) {\n // if this is a web worker, do not use weak entropy, instead register to\n // receive strong entropy asynchronously from the main thread\n if(typeof window === 'undefined' || window.document === undefined) {\n // FIXME:\n }\n\n // get load time entropy\n _ctx.collectInt(+new Date(), 32);\n\n // add some entropy from navigator object\n if(typeof(navigator) !== 'undefined') {\n var _navBytes = '';\n for(var key in navigator) {\n try {\n if(typeof(navigator[key]) == 'string') {\n _navBytes += navigator[key];\n }\n } catch(e) {\n /* Some navigator keys might not be accessible, e.g. the geolocation\n attribute throws an exception if touched in Mozilla chrome://\n context.\n\n Silently ignore this and just don't use this as a source of\n entropy. */\n }\n }\n _ctx.collect(_navBytes);\n _navBytes = null;\n }\n\n // add mouse and keyboard collectors if jquery is available\n if(jQuery) {\n // set up mouse entropy capture\n jQuery().mousemove(function(e) {\n // add mouse coords\n _ctx.collectInt(e.clientX, 16);\n _ctx.collectInt(e.clientY, 16);\n });\n\n // set up keyboard entropy capture\n jQuery().keypress(function(e) {\n _ctx.collectInt(e.charCode, 8);\n });\n }\n}\n\n/* Random API */\nif(!forge.random) {\n forge.random = _ctx;\n} else {\n // extend forge.random with _ctx\n for(var key in _ctx) {\n forge.random[key] = _ctx[key];\n }\n}\n\n// expose spawn PRNG\nforge.random.createInstance = spawnPrng;\n\nmodule.exports = forge.random;\n\n})(typeof(jQuery) !== 'undefined' ? jQuery : null);\n\n})();\n","/**\n * Node.js module for Forge message digests.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2017 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\n\nmodule.exports = forge.md = forge.md || {};\nforge.md.algorithms = forge.md.algorithms || {};\n","/*!\n * jQuery JavaScript Library v3.5.0\n * https://jquery.com/\n *\n * Includes Sizzle.js\n * https://sizzlejs.com/\n *\n * Copyright JS Foundation and other contributors\n * Released under the MIT license\n * https://jquery.org/license\n *\n * Date: 2020-04-10T15:07Z\n */\n( function( global, factory ) {\n\n\t\"use strict\";\n\n\tif ( typeof module === \"object\" && typeof module.exports === \"object\" ) {\n\n\t\t// For CommonJS and CommonJS-like environments where a proper `window`\n\t\t// is present, execute the factory and get jQuery.\n\t\t// For environments that do not have a `window` with a `document`\n\t\t// (such as Node.js), expose a factory as module.exports.\n\t\t// This accentuates the need for the creation of a real `window`.\n\t\t// e.g. var jQuery = require(\"jquery\")(window);\n\t\t// See ticket #14549 for more info.\n\t\tmodule.exports = global.document ?\n\t\t\tfactory( global, true ) :\n\t\t\tfunction( w ) {\n\t\t\t\tif ( !w.document ) {\n\t\t\t\t\tthrow new Error( \"jQuery requires a window with a document\" );\n\t\t\t\t}\n\t\t\t\treturn factory( w );\n\t\t\t};\n\t} else {\n\t\tfactory( global );\n\t}\n\n// Pass this if window is not defined yet\n} )( typeof window !== \"undefined\" ? window : this, function( window, noGlobal ) {\n\n// Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1\n// throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode\n// arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common\n// enough that all such attempts are guarded in a try block.\n\"use strict\";\n\nvar arr = [];\n\nvar getProto = Object.getPrototypeOf;\n\nvar slice = arr.slice;\n\nvar flat = arr.flat ? function( array ) {\n\treturn arr.flat.call( array );\n} : function( array ) {\n\treturn arr.concat.apply( [], array );\n};\n\n\nvar push = arr.push;\n\nvar indexOf = arr.indexOf;\n\nvar class2type = {};\n\nvar toString = class2type.toString;\n\nvar hasOwn = class2type.hasOwnProperty;\n\nvar fnToString = hasOwn.toString;\n\nvar ObjectFunctionString = fnToString.call( Object );\n\nvar support = {};\n\nvar isFunction = function isFunction( obj ) {\n\n // Support: Chrome <=57, Firefox <=52\n // In some browsers, typeof returns \"function\" for HTML <object> elements\n // (i.e., `typeof document.createElement( \"object\" ) === \"function\"`).\n // We don't want to classify *any* DOM node as a function.\n return typeof obj === \"function\" && typeof obj.nodeType !== \"number\";\n };\n\n\nvar isWindow = function isWindow( obj ) {\n\t\treturn obj != null && obj === obj.window;\n\t};\n\n\nvar document = window.document;\n\n\n\n\tvar preservedScriptAttributes = {\n\t\ttype: true,\n\t\tsrc: true,\n\t\tnonce: true,\n\t\tnoModule: true\n\t};\n\n\tfunction DOMEval( code, node, doc ) {\n\t\tdoc = doc || document;\n\n\t\tvar i, val,\n\t\t\tscript = doc.createElement( \"script\" );\n\n\t\tscript.text = code;\n\t\tif ( node ) {\n\t\t\tfor ( i in preservedScriptAttributes ) {\n\n\t\t\t\t// Support: Firefox 64+, Edge 18+\n\t\t\t\t// Some browsers don't support the \"nonce\" property on scripts.\n\t\t\t\t// On the other hand, just using `getAttribute` is not enough as\n\t\t\t\t// the `nonce` attribute is reset to an empty string whenever it\n\t\t\t\t// becomes browsing-context connected.\n\t\t\t\t// See https://github.com/whatwg/html/issues/2369\n\t\t\t\t// See https://html.spec.whatwg.org/#nonce-attributes\n\t\t\t\t// The `node.getAttribute` check was added for the sake of\n\t\t\t\t// `jQuery.globalEval` so that it can fake a nonce-containing node\n\t\t\t\t// via an object.\n\t\t\t\tval = node[ i ] || node.getAttribute && node.getAttribute( i );\n\t\t\t\tif ( val ) {\n\t\t\t\t\tscript.setAttribute( i, val );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tdoc.head.appendChild( script ).parentNode.removeChild( script );\n\t}\n\n\nfunction toType( obj ) {\n\tif ( obj == null ) {\n\t\treturn obj + \"\";\n\t}\n\n\t// Support: Android <=2.3 only (functionish RegExp)\n\treturn typeof obj === \"object\" || typeof obj === \"function\" ?\n\t\tclass2type[ toString.call( obj ) ] || \"object\" :\n\t\ttypeof obj;\n}\n/* global Symbol */\n// Defining this global in .eslintrc.json would create a danger of using the global\n// unguarded in another place, it seems safer to define global only for this module\n\n\n\nvar\n\tversion = \"3.5.0\",\n\n\t// Define a local copy of jQuery\n\tjQuery = function( selector, context ) {\n\n\t\t// The jQuery object is actually just the init constructor 'enhanced'\n\t\t// Need init if jQuery is called (just allow error to be thrown if not included)\n\t\treturn new jQuery.fn.init( selector, context );\n\t};\n\njQuery.fn = jQuery.prototype = {\n\n\t// The current version of jQuery being used\n\tjquery: version,\n\n\tconstructor: jQuery,\n\n\t// The default length of a jQuery object is 0\n\tlength: 0,\n\n\ttoArray: function() {\n\t\treturn slice.call( this );\n\t},\n\n\t// Get the Nth element in the matched element set OR\n\t// Get the whole matched element set as a clean array\n\tget: function( num ) {\n\n\t\t// Return all the elements in a clean array\n\t\tif ( num == null ) {\n\t\t\treturn slice.call( this );\n\t\t}\n\n\t\t// Return just the one element from the set\n\t\treturn num < 0 ? this[ num + this.length ] : this[ num ];\n\t},\n\n\t// Take an array of elements and push it onto the stack\n\t// (returning the new matched element set)\n\tpushStack: function( elems ) {\n\n\t\t// Build a new jQuery matched element set\n\t\tvar ret = jQuery.merge( this.constructor(), elems );\n\n\t\t// Add the old object onto the stack (as a reference)\n\t\tret.prevObject = this;\n\n\t\t// Return the newly-formed element set\n\t\treturn ret;\n\t},\n\n\t// Execute a callback for every element in the matched set.\n\teach: function( callback ) {\n\t\treturn jQuery.each( this, callback );\n\t},\n\n\tmap: function( callback ) {\n\t\treturn this.pushStack( jQuery.map( this, function( elem, i ) {\n\t\t\treturn callback.call( elem, i, elem );\n\t\t} ) );\n\t},\n\n\tslice: function() {\n\t\treturn this.pushStack( slice.apply( this, arguments ) );\n\t},\n\n\tfirst: function() {\n\t\treturn this.eq( 0 );\n\t},\n\n\tlast: function() {\n\t\treturn this.eq( -1 );\n\t},\n\n\teven: function() {\n\t\treturn this.pushStack( jQuery.grep( this, function( _elem, i ) {\n\t\t\treturn ( i + 1 ) % 2;\n\t\t} ) );\n\t},\n\n\todd: function() {\n\t\treturn this.pushStack( jQuery.grep( this, function( _elem, i ) {\n\t\t\treturn i % 2;\n\t\t} ) );\n\t},\n\n\teq: function( i ) {\n\t\tvar len = this.length,\n\t\t\tj = +i + ( i < 0 ? len : 0 );\n\t\treturn this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] );\n\t},\n\n\tend: function() {\n\t\treturn this.prevObject || this.constructor();\n\t},\n\n\t// For internal use only.\n\t// Behaves like an Array's method, not like a jQuery method.\n\tpush: push,\n\tsort: arr.sort,\n\tsplice: arr.splice\n};\n\njQuery.extend = jQuery.fn.extend = function() {\n\tvar options, name, src, copy, copyIsArray, clone,\n\t\ttarget = arguments[ 0 ] || {},\n\t\ti = 1,\n\t\tlength = arguments.length,\n\t\tdeep = false;\n\n\t// Handle a deep copy situation\n\tif ( typeof target === \"boolean\" ) {\n\t\tdeep = target;\n\n\t\t// Skip the boolean and the target\n\t\ttarget = arguments[ i ] || {};\n\t\ti++;\n\t}\n\n\t// Handle case when target is a string or something (possible in deep copy)\n\tif ( typeof target !== \"object\" && !isFunction( target ) ) {\n\t\ttarget = {};\n\t}\n\n\t// Extend jQuery itself if only one argument is passed\n\tif ( i === length ) {\n\t\ttarget = this;\n\t\ti--;\n\t}\n\n\tfor ( ; i < length; i++ ) {\n\n\t\t// Only deal with non-null/undefined values\n\t\tif ( ( options = arguments[ i ] ) != null ) {\n\n\t\t\t// Extend the base object\n\t\t\tfor ( name in options ) {\n\t\t\t\tcopy = options[ name ];\n\n\t\t\t\t// Prevent Object.prototype pollution\n\t\t\t\t// Prevent never-ending loop\n\t\t\t\tif ( name === \"__proto__\" || target === copy ) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Recurse if we're merging plain objects or arrays\n\t\t\t\tif ( deep && copy && ( jQuery.isPlainObject( copy ) ||\n\t\t\t\t\t( copyIsArray = Array.isArray( copy ) ) ) ) {\n\t\t\t\t\tsrc = target[ name ];\n\n\t\t\t\t\t// Ensure proper type for the source value\n\t\t\t\t\tif ( copyIsArray && !Array.isArray( src ) ) {\n\t\t\t\t\t\tclone = [];\n\t\t\t\t\t} else if ( !copyIsArray && !jQuery.isPlainObject( src ) ) {\n\t\t\t\t\t\tclone = {};\n\t\t\t\t\t} else {\n\t\t\t\t\t\tclone = src;\n\t\t\t\t\t}\n\t\t\t\t\tcopyIsArray = false;\n\n\t\t\t\t\t// Never move original objects, clone them\n\t\t\t\t\ttarget[ name ] = jQuery.extend( deep, clone, copy );\n\n\t\t\t\t// Don't bring in undefined values\n\t\t\t\t} else if ( copy !== undefined ) {\n\t\t\t\t\ttarget[ name ] = copy;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Return the modified object\n\treturn target;\n};\n\njQuery.extend( {\n\n\t// Unique for each copy of jQuery on the page\n\texpando: \"jQuery\" + ( version + Math.random() ).replace( /\\D/g, \"\" ),\n\n\t// Assume jQuery is ready without the ready module\n\tisReady: true,\n\n\terror: function( msg ) {\n\t\tthrow new Error( msg );\n\t},\n\n\tnoop: function() {},\n\n\tisPlainObject: function( obj ) {\n\t\tvar proto, Ctor;\n\n\t\t// Detect obvious negatives\n\t\t// Use toString instead of jQuery.type to catch host objects\n\t\tif ( !obj || toString.call( obj ) !== \"[object Object]\" ) {\n\t\t\treturn false;\n\t\t}\n\n\t\tproto = getProto( obj );\n\n\t\t// Objects with no prototype (e.g., `Object.create( null )`) are plain\n\t\tif ( !proto ) {\n\t\t\treturn true;\n\t\t}\n\n\t\t// Objects with prototype are plain iff they were constructed by a global Object function\n\t\tCtor = hasOwn.call( proto, \"constructor\" ) && proto.constructor;\n\t\treturn typeof Ctor === \"function\" && fnToString.call( Ctor ) === ObjectFunctionString;\n\t},\n\n\tisEmptyObject: function( obj ) {\n\t\tvar name;\n\n\t\tfor ( name in obj ) {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t},\n\n\t// Evaluates a script in a provided context; falls back to the global one\n\t// if not specified.\n\tglobalEval: function( code, options, doc ) {\n\t\tDOMEval( code, { nonce: options && options.nonce }, doc );\n\t},\n\n\teach: function( obj, callback ) {\n\t\tvar length, i = 0;\n\n\t\tif ( isArrayLike( obj ) ) {\n\t\t\tlength = obj.length;\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tif ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tfor ( i in obj ) {\n\t\t\t\tif ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn obj;\n\t},\n\n\t// results is for internal usage only\n\tmakeArray: function( arr, results ) {\n\t\tvar ret = results || [];\n\n\t\tif ( arr != null ) {\n\t\t\tif ( isArrayLike( Object( arr ) ) ) {\n\t\t\t\tjQuery.merge( ret,\n\t\t\t\t\ttypeof arr === \"string\" ?\n\t\t\t\t\t[ arr ] : arr\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tpush.call( ret, arr );\n\t\t\t}\n\t\t}\n\n\t\treturn ret;\n\t},\n\n\tinArray: function( elem, arr, i ) {\n\t\treturn arr == null ? -1 : indexOf.call( arr, elem, i );\n\t},\n\n\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t// push.apply(_, arraylike) throws on ancient WebKit\n\tmerge: function( first, second ) {\n\t\tvar len = +second.length,\n\t\t\tj = 0,\n\t\t\ti = first.length;\n\n\t\tfor ( ; j < len; j++ ) {\n\t\t\tfirst[ i++ ] = second[ j ];\n\t\t}\n\n\t\tfirst.length = i;\n\n\t\treturn first;\n\t},\n\n\tgrep: function( elems, callback, invert ) {\n\t\tvar callbackInverse,\n\t\t\tmatches = [],\n\t\t\ti = 0,\n\t\t\tlength = elems.length,\n\t\t\tcallbackExpect = !invert;\n\n\t\t// Go through the array, only saving the items\n\t\t// that pass the validator function\n\t\tfor ( ; i < length; i++ ) {\n\t\t\tcallbackInverse = !callback( elems[ i ], i );\n\t\t\tif ( callbackInverse !== callbackExpect ) {\n\t\t\t\tmatches.push( elems[ i ] );\n\t\t\t}\n\t\t}\n\n\t\treturn matches;\n\t},\n\n\t// arg is for internal usage only\n\tmap: function( elems, callback, arg ) {\n\t\tvar length, value,\n\t\t\ti = 0,\n\t\t\tret = [];\n\n\t\t// Go through the array, translating each of the items to their new values\n\t\tif ( isArrayLike( elems ) ) {\n\t\t\tlength = elems.length;\n\t\t\tfor ( ; i < length; i++ ) {\n\t\t\t\tvalue = callback( elems[ i ], i, arg );\n\n\t\t\t\tif ( value != null ) {\n\t\t\t\t\tret.push( value );\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Go through every key on the object,\n\t\t} else {\n\t\t\tfor ( i in elems ) {\n\t\t\t\tvalue = callback( elems[ i ], i, arg );\n\n\t\t\t\tif ( value != null ) {\n\t\t\t\t\tret.push( value );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Flatten any nested arrays\n\t\treturn flat( ret );\n\t},\n\n\t// A global GUID counter for objects\n\tguid: 1,\n\n\t// jQuery.support is not used in Core but other projects attach their\n\t// properties to it so it needs to exist.\n\tsupport: support\n} );\n\nif ( typeof Symbol === \"function\" ) {\n\tjQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ];\n}\n\n// Populate the class2type map\njQuery.each( \"Boolean Number String Function Array Date RegExp Object Error Symbol\".split( \" \" ),\nfunction( _i, name ) {\n\tclass2type[ \"[object \" + name + \"]\" ] = name.toLowerCase();\n} );\n\nfunction isArrayLike( obj ) {\n\n\t// Support: real iOS 8.2 only (not reproducible in simulator)\n\t// `in` check used to prevent JIT error (gh-2145)\n\t// hasOwn isn't used here due to false negatives\n\t// regarding Nodelist length in IE\n\tvar length = !!obj && \"length\" in obj && obj.length,\n\t\ttype = toType( obj );\n\n\tif ( isFunction( obj ) || isWindow( obj ) ) {\n\t\treturn false;\n\t}\n\n\treturn type === \"array\" || length === 0 ||\n\t\ttypeof length === \"number\" && length > 0 && ( length - 1 ) in obj;\n}\nvar Sizzle =\n/*!\n * Sizzle CSS Selector Engine v2.3.5\n * https://sizzlejs.com/\n *\n * Copyright JS Foundation and other contributors\n * Released under the MIT license\n * https://js.foundation/\n *\n * Date: 2020-03-14\n */\n( function( window ) {\nvar i,\n\tsupport,\n\tExpr,\n\tgetText,\n\tisXML,\n\ttokenize,\n\tcompile,\n\tselect,\n\toutermostContext,\n\tsortInput,\n\thasDuplicate,\n\n\t// Local document vars\n\tsetDocument,\n\tdocument,\n\tdocElem,\n\tdocumentIsHTML,\n\trbuggyQSA,\n\trbuggyMatches,\n\tmatches,\n\tcontains,\n\n\t// Instance-specific data\n\texpando = \"sizzle\" + 1 * new Date(),\n\tpreferredDoc = window.document,\n\tdirruns = 0,\n\tdone = 0,\n\tclassCache = createCache(),\n\ttokenCache = createCache(),\n\tcompilerCache = createCache(),\n\tnonnativeSelectorCache = createCache(),\n\tsortOrder = function( a, b ) {\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t}\n\t\treturn 0;\n\t},\n\n\t// Instance methods\n\thasOwn = ( {} ).hasOwnProperty,\n\tarr = [],\n\tpop = arr.pop,\n\tpushNative = arr.push,\n\tpush = arr.push,\n\tslice = arr.slice,\n\n\t// Use a stripped-down indexOf as it's faster than native\n\t// https://jsperf.com/thor-indexof-vs-for/5\n\tindexOf = function( list, elem ) {\n\t\tvar i = 0,\n\t\t\tlen = list.length;\n\t\tfor ( ; i < len; i++ ) {\n\t\t\tif ( list[ i ] === elem ) {\n\t\t\t\treturn i;\n\t\t\t}\n\t\t}\n\t\treturn -1;\n\t},\n\n\tbooleans = \"checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|\" +\n\t\t\"ismap|loop|multiple|open|readonly|required|scoped\",\n\n\t// Regular expressions\n\n\t// http://www.w3.org/TR/css3-selectors/#whitespace\n\twhitespace = \"[\\\\x20\\\\t\\\\r\\\\n\\\\f]\",\n\n\t// https://www.w3.org/TR/css-syntax-3/#ident-token-diagram\n\tidentifier = \"(?:\\\\\\\\[\\\\da-fA-F]{1,6}\" + whitespace +\n\t\t\"?|\\\\\\\\[^\\\\r\\\\n\\\\f]|[\\\\w-]|[^\\0-\\\\x7f])+\",\n\n\t// Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors\n\tattributes = \"\\\\[\" + whitespace + \"*(\" + identifier + \")(?:\" + whitespace +\n\n\t\t// Operator (capture 2)\n\t\t\"*([*^$|!~]?=)\" + whitespace +\n\n\t\t// \"Attribute values must be CSS identifiers [capture 5]\n\t\t// or strings [capture 3 or capture 4]\"\n\t\t\"*(?:'((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\"|(\" + identifier + \"))|)\" +\n\t\twhitespace + \"*\\\\]\",\n\n\tpseudos = \":(\" + identifier + \")(?:\\\\((\" +\n\n\t\t// To reduce the number of selectors needing tokenize in the preFilter, prefer arguments:\n\t\t// 1. quoted (capture 3; capture 4 or capture 5)\n\t\t\"('((?:\\\\\\\\.|[^\\\\\\\\'])*)'|\\\"((?:\\\\\\\\.|[^\\\\\\\\\\\"])*)\\\")|\" +\n\n\t\t// 2. simple (capture 6)\n\t\t\"((?:\\\\\\\\.|[^\\\\\\\\()[\\\\]]|\" + attributes + \")*)|\" +\n\n\t\t// 3. anything else (capture 2)\n\t\t\".*\" +\n\t\t\")\\\\)|)\",\n\n\t// Leading and non-escaped trailing whitespace, capturing some non-whitespace characters preceding the latter\n\trwhitespace = new RegExp( whitespace + \"+\", \"g\" ),\n\trtrim = new RegExp( \"^\" + whitespace + \"+|((?:^|[^\\\\\\\\])(?:\\\\\\\\.)*)\" +\n\t\twhitespace + \"+$\", \"g\" ),\n\n\trcomma = new RegExp( \"^\" + whitespace + \"*,\" + whitespace + \"*\" ),\n\trcombinators = new RegExp( \"^\" + whitespace + \"*([>+~]|\" + whitespace + \")\" + whitespace +\n\t\t\"*\" ),\n\trdescend = new RegExp( whitespace + \"|>\" ),\n\n\trpseudo = new RegExp( pseudos ),\n\tridentifier = new RegExp( \"^\" + identifier + \"$\" ),\n\n\tmatchExpr = {\n\t\t\"ID\": new RegExp( \"^#(\" + identifier + \")\" ),\n\t\t\"CLASS\": new RegExp( \"^\\\\.(\" + identifier + \")\" ),\n\t\t\"TAG\": new RegExp( \"^(\" + identifier + \"|[*])\" ),\n\t\t\"ATTR\": new RegExp( \"^\" + attributes ),\n\t\t\"PSEUDO\": new RegExp( \"^\" + pseudos ),\n\t\t\"CHILD\": new RegExp( \"^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\\\(\" +\n\t\t\twhitespace + \"*(even|odd|(([+-]|)(\\\\d*)n|)\" + whitespace + \"*(?:([+-]|)\" +\n\t\t\twhitespace + \"*(\\\\d+)|))\" + whitespace + \"*\\\\)|)\", \"i\" ),\n\t\t\"bool\": new RegExp( \"^(?:\" + booleans + \")$\", \"i\" ),\n\n\t\t// For use in libraries implementing .is()\n\t\t// We use this for POS matching in `select`\n\t\t\"needsContext\": new RegExp( \"^\" + whitespace +\n\t\t\t\"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\\\(\" + whitespace +\n\t\t\t\"*((?:-\\\\d)?\\\\d*)\" + whitespace + \"*\\\\)|)(?=[^-]|$)\", \"i\" )\n\t},\n\n\trhtml = /HTML$/i,\n\trinputs = /^(?:input|select|textarea|button)$/i,\n\trheader = /^h\\d$/i,\n\n\trnative = /^[^{]+\\{\\s*\\[native \\w/,\n\n\t// Easily-parseable/retrievable ID or TAG or CLASS selectors\n\trquickExpr = /^(?:#([\\w-]+)|(\\w+)|\\.([\\w-]+))$/,\n\n\trsibling = /[+~]/,\n\n\t// CSS escapes\n\t// http://www.w3.org/TR/CSS21/syndata.html#escaped-characters\n\trunescape = new RegExp( \"\\\\\\\\[\\\\da-fA-F]{1,6}\" + whitespace + \"?|\\\\\\\\([^\\\\r\\\\n\\\\f])\", \"g\" ),\n\tfunescape = function( escape, nonHex ) {\n\t\tvar high = \"0x\" + escape.slice( 1 ) - 0x10000;\n\n\t\treturn nonHex ?\n\n\t\t\t// Strip the backslash prefix from a non-hex escape sequence\n\t\t\tnonHex :\n\n\t\t\t// Replace a hexadecimal escape sequence with the encoded Unicode code point\n\t\t\t// Support: IE <=11+\n\t\t\t// For values outside the Basic Multilingual Plane (BMP), manually construct a\n\t\t\t// surrogate pair\n\t\t\thigh < 0 ?\n\t\t\t\tString.fromCharCode( high + 0x10000 ) :\n\t\t\t\tString.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 );\n\t},\n\n\t// CSS string/identifier serialization\n\t// https://drafts.csswg.org/cssom/#common-serializing-idioms\n\trcssescape = /([\\0-\\x1f\\x7f]|^-?\\d)|^-$|[^\\0-\\x1f\\x7f-\\uFFFF\\w-]/g,\n\tfcssescape = function( ch, asCodePoint ) {\n\t\tif ( asCodePoint ) {\n\n\t\t\t// U+0000 NULL becomes U+FFFD REPLACEMENT CHARACTER\n\t\t\tif ( ch === \"\\0\" ) {\n\t\t\t\treturn \"\\uFFFD\";\n\t\t\t}\n\n\t\t\t// Control characters and (dependent upon position) numbers get escaped as code points\n\t\t\treturn ch.slice( 0, -1 ) + \"\\\\\" +\n\t\t\t\tch.charCodeAt( ch.length - 1 ).toString( 16 ) + \" \";\n\t\t}\n\n\t\t// Other potentially-special ASCII characters get backslash-escaped\n\t\treturn \"\\\\\" + ch;\n\t},\n\n\t// Used for iframes\n\t// See setDocument()\n\t// Removing the function wrapper causes a \"Permission Denied\"\n\t// error in IE\n\tunloadHandler = function() {\n\t\tsetDocument();\n\t},\n\n\tinDisabledFieldset = addCombinator(\n\t\tfunction( elem ) {\n\t\t\treturn elem.disabled === true && elem.nodeName.toLowerCase() === \"fieldset\";\n\t\t},\n\t\t{ dir: \"parentNode\", next: \"legend\" }\n\t);\n\n// Optimize for push.apply( _, NodeList )\ntry {\n\tpush.apply(\n\t\t( arr = slice.call( preferredDoc.childNodes ) ),\n\t\tpreferredDoc.childNodes\n\t);\n\n\t// Support: Android<4.0\n\t// Detect silently failing push.apply\n\t// eslint-disable-next-line no-unused-expressions\n\tarr[ preferredDoc.childNodes.length ].nodeType;\n} catch ( e ) {\n\tpush = { apply: arr.length ?\n\n\t\t// Leverage slice if possible\n\t\tfunction( target, els ) {\n\t\t\tpushNative.apply( target, slice.call( els ) );\n\t\t} :\n\n\t\t// Support: IE<9\n\t\t// Otherwise append directly\n\t\tfunction( target, els ) {\n\t\t\tvar j = target.length,\n\t\t\t\ti = 0;\n\n\t\t\t// Can't trust NodeList.length\n\t\t\twhile ( ( target[ j++ ] = els[ i++ ] ) ) {}\n\t\t\ttarget.length = j - 1;\n\t\t}\n\t};\n}\n\nfunction Sizzle( selector, context, results, seed ) {\n\tvar m, i, elem, nid, match, groups, newSelector,\n\t\tnewContext = context && context.ownerDocument,\n\n\t\t// nodeType defaults to 9, since context defaults to document\n\t\tnodeType = context ? context.nodeType : 9;\n\n\tresults = results || [];\n\n\t// Return early from calls with invalid selector or context\n\tif ( typeof selector !== \"string\" || !selector ||\n\t\tnodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) {\n\n\t\treturn results;\n\t}\n\n\t// Try to shortcut find operations (as opposed to filters) in HTML documents\n\tif ( !seed ) {\n\t\tsetDocument( context );\n\t\tcontext = context || document;\n\n\t\tif ( documentIsHTML ) {\n\n\t\t\t// If the selector is sufficiently simple, try using a \"get*By*\" DOM method\n\t\t\t// (excepting DocumentFragment context, where the methods don't exist)\n\t\t\tif ( nodeType !== 11 && ( match = rquickExpr.exec( selector ) ) ) {\n\n\t\t\t\t// ID selector\n\t\t\t\tif ( ( m = match[ 1 ] ) ) {\n\n\t\t\t\t\t// Document context\n\t\t\t\t\tif ( nodeType === 9 ) {\n\t\t\t\t\t\tif ( ( elem = context.getElementById( m ) ) ) {\n\n\t\t\t\t\t\t\t// Support: IE, Opera, Webkit\n\t\t\t\t\t\t\t// TODO: identify versions\n\t\t\t\t\t\t\t// getElementById can match elements by name instead of ID\n\t\t\t\t\t\t\tif ( elem.id === m ) {\n\t\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t// Element context\n\t\t\t\t\t} else {\n\n\t\t\t\t\t\t// Support: IE, Opera, Webkit\n\t\t\t\t\t\t// TODO: identify versions\n\t\t\t\t\t\t// getElementById can match elements by name instead of ID\n\t\t\t\t\t\tif ( newContext && ( elem = newContext.getElementById( m ) ) &&\n\t\t\t\t\t\t\tcontains( context, elem ) &&\n\t\t\t\t\t\t\telem.id === m ) {\n\n\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\treturn results;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t// Type selector\n\t\t\t\t} else if ( match[ 2 ] ) {\n\t\t\t\t\tpush.apply( results, context.getElementsByTagName( selector ) );\n\t\t\t\t\treturn results;\n\n\t\t\t\t// Class selector\n\t\t\t\t} else if ( ( m = match[ 3 ] ) && support.getElementsByClassName &&\n\t\t\t\t\tcontext.getElementsByClassName ) {\n\n\t\t\t\t\tpush.apply( results, context.getElementsByClassName( m ) );\n\t\t\t\t\treturn results;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Take advantage of querySelectorAll\n\t\t\tif ( support.qsa &&\n\t\t\t\t!nonnativeSelectorCache[ selector + \" \" ] &&\n\t\t\t\t( !rbuggyQSA || !rbuggyQSA.test( selector ) ) &&\n\n\t\t\t\t// Support: IE 8 only\n\t\t\t\t// Exclude object elements\n\t\t\t\t( nodeType !== 1 || context.nodeName.toLowerCase() !== \"object\" ) ) {\n\n\t\t\t\tnewSelector = selector;\n\t\t\t\tnewContext = context;\n\n\t\t\t\t// qSA considers elements outside a scoping root when evaluating child or\n\t\t\t\t// descendant combinators, which is not what we want.\n\t\t\t\t// In such cases, we work around the behavior by prefixing every selector in the\n\t\t\t\t// list with an ID selector referencing the scope context.\n\t\t\t\t// The technique has to be used as well when a leading combinator is used\n\t\t\t\t// as such selectors are not recognized by querySelectorAll.\n\t\t\t\t// Thanks to Andrew Dupont for this technique.\n\t\t\t\tif ( nodeType === 1 &&\n\t\t\t\t\t( rdescend.test( selector ) || rcombinators.test( selector ) ) ) {\n\n\t\t\t\t\t// Expand context for sibling selectors\n\t\t\t\t\tnewContext = rsibling.test( selector ) && testContext( context.parentNode ) ||\n\t\t\t\t\t\tcontext;\n\n\t\t\t\t\t// We can use :scope instead of the ID hack if the browser\n\t\t\t\t\t// supports it & if we're not changing the context.\n\t\t\t\t\tif ( newContext !== context || !support.scope ) {\n\n\t\t\t\t\t\t// Capture the context ID, setting it first if necessary\n\t\t\t\t\t\tif ( ( nid = context.getAttribute( \"id\" ) ) ) {\n\t\t\t\t\t\t\tnid = nid.replace( rcssescape, fcssescape );\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tcontext.setAttribute( \"id\", ( nid = expando ) );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Prefix every selector in the list\n\t\t\t\t\tgroups = tokenize( selector );\n\t\t\t\t\ti = groups.length;\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tgroups[ i ] = ( nid ? \"#\" + nid : \":scope\" ) + \" \" +\n\t\t\t\t\t\t\ttoSelector( groups[ i ] );\n\t\t\t\t\t}\n\t\t\t\t\tnewSelector = groups.join( \",\" );\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tpush.apply( results,\n\t\t\t\t\t\tnewContext.querySelectorAll( newSelector )\n\t\t\t\t\t);\n\t\t\t\t\treturn results;\n\t\t\t\t} catch ( qsaError ) {\n\t\t\t\t\tnonnativeSelectorCache( selector, true );\n\t\t\t\t} finally {\n\t\t\t\t\tif ( nid === expando ) {\n\t\t\t\t\t\tcontext.removeAttribute( \"id\" );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// All others\n\treturn select( selector.replace( rtrim, \"$1\" ), context, results, seed );\n}\n\n/**\n * Create key-value caches of limited size\n * @returns {function(string, object)} Returns the Object data after storing it on itself with\n *\tproperty name the (space-suffixed) string and (if the cache is larger than Expr.cacheLength)\n *\tdeleting the oldest entry\n */\nfunction createCache() {\n\tvar keys = [];\n\n\tfunction cache( key, value ) {\n\n\t\t// Use (key + \" \") to avoid collision with native prototype properties (see Issue #157)\n\t\tif ( keys.push( key + \" \" ) > Expr.cacheLength ) {\n\n\t\t\t// Only keep the most recent entries\n\t\t\tdelete cache[ keys.shift() ];\n\t\t}\n\t\treturn ( cache[ key + \" \" ] = value );\n\t}\n\treturn cache;\n}\n\n/**\n * Mark a function for special use by Sizzle\n * @param {Function} fn The function to mark\n */\nfunction markFunction( fn ) {\n\tfn[ expando ] = true;\n\treturn fn;\n}\n\n/**\n * Support testing using an element\n * @param {Function} fn Passed the created element and returns a boolean result\n */\nfunction assert( fn ) {\n\tvar el = document.createElement( \"fieldset\" );\n\n\ttry {\n\t\treturn !!fn( el );\n\t} catch ( e ) {\n\t\treturn false;\n\t} finally {\n\n\t\t// Remove from its parent by default\n\t\tif ( el.parentNode ) {\n\t\t\tel.parentNode.removeChild( el );\n\t\t}\n\n\t\t// release memory in IE\n\t\tel = null;\n\t}\n}\n\n/**\n * Adds the same handler for all of the specified attrs\n * @param {String} attrs Pipe-separated list of attributes\n * @param {Function} handler The method that will be applied\n */\nfunction addHandle( attrs, handler ) {\n\tvar arr = attrs.split( \"|\" ),\n\t\ti = arr.length;\n\n\twhile ( i-- ) {\n\t\tExpr.attrHandle[ arr[ i ] ] = handler;\n\t}\n}\n\n/**\n * Checks document order of two siblings\n * @param {Element} a\n * @param {Element} b\n * @returns {Number} Returns less than 0 if a precedes b, greater than 0 if a follows b\n */\nfunction siblingCheck( a, b ) {\n\tvar cur = b && a,\n\t\tdiff = cur && a.nodeType === 1 && b.nodeType === 1 &&\n\t\t\ta.sourceIndex - b.sourceIndex;\n\n\t// Use IE sourceIndex if available on both nodes\n\tif ( diff ) {\n\t\treturn diff;\n\t}\n\n\t// Check if b follows a\n\tif ( cur ) {\n\t\twhile ( ( cur = cur.nextSibling ) ) {\n\t\t\tif ( cur === b ) {\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t}\n\t}\n\n\treturn a ? 1 : -1;\n}\n\n/**\n * Returns a function to use in pseudos for input types\n * @param {String} type\n */\nfunction createInputPseudo( type ) {\n\treturn function( elem ) {\n\t\tvar name = elem.nodeName.toLowerCase();\n\t\treturn name === \"input\" && elem.type === type;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for buttons\n * @param {String} type\n */\nfunction createButtonPseudo( type ) {\n\treturn function( elem ) {\n\t\tvar name = elem.nodeName.toLowerCase();\n\t\treturn ( name === \"input\" || name === \"button\" ) && elem.type === type;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for :enabled/:disabled\n * @param {Boolean} disabled true for :disabled; false for :enabled\n */\nfunction createDisabledPseudo( disabled ) {\n\n\t// Known :disabled false positives: fieldset[disabled] > legend:nth-of-type(n+2) :can-disable\n\treturn function( elem ) {\n\n\t\t// Only certain elements can match :enabled or :disabled\n\t\t// https://html.spec.whatwg.org/multipage/scripting.html#selector-enabled\n\t\t// https://html.spec.whatwg.org/multipage/scripting.html#selector-disabled\n\t\tif ( \"form\" in elem ) {\n\n\t\t\t// Check for inherited disabledness on relevant non-disabled elements:\n\t\t\t// * listed form-associated elements in a disabled fieldset\n\t\t\t// https://html.spec.whatwg.org/multipage/forms.html#category-listed\n\t\t\t// https://html.spec.whatwg.org/multipage/forms.html#concept-fe-disabled\n\t\t\t// * option elements in a disabled optgroup\n\t\t\t// https://html.spec.whatwg.org/multipage/forms.html#concept-option-disabled\n\t\t\t// All such elements have a \"form\" property.\n\t\t\tif ( elem.parentNode && elem.disabled === false ) {\n\n\t\t\t\t// Option elements defer to a parent optgroup if present\n\t\t\t\tif ( \"label\" in elem ) {\n\t\t\t\t\tif ( \"label\" in elem.parentNode ) {\n\t\t\t\t\t\treturn elem.parentNode.disabled === disabled;\n\t\t\t\t\t} else {\n\t\t\t\t\t\treturn elem.disabled === disabled;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Support: IE 6 - 11\n\t\t\t\t// Use the isDisabled shortcut property to check for disabled fieldset ancestors\n\t\t\t\treturn elem.isDisabled === disabled ||\n\n\t\t\t\t\t// Where there is no isDisabled, check manually\n\t\t\t\t\t/* jshint -W018 */\n\t\t\t\t\telem.isDisabled !== !disabled &&\n\t\t\t\t\tinDisabledFieldset( elem ) === disabled;\n\t\t\t}\n\n\t\t\treturn elem.disabled === disabled;\n\n\t\t// Try to winnow out elements that can't be disabled before trusting the disabled property.\n\t\t// Some victims get caught in our net (label, legend, menu, track), but it shouldn't\n\t\t// even exist on them, let alone have a boolean value.\n\t\t} else if ( \"label\" in elem ) {\n\t\t\treturn elem.disabled === disabled;\n\t\t}\n\n\t\t// Remaining elements are neither :enabled nor :disabled\n\t\treturn false;\n\t};\n}\n\n/**\n * Returns a function to use in pseudos for positionals\n * @param {Function} fn\n */\nfunction createPositionalPseudo( fn ) {\n\treturn markFunction( function( argument ) {\n\t\targument = +argument;\n\t\treturn markFunction( function( seed, matches ) {\n\t\t\tvar j,\n\t\t\t\tmatchIndexes = fn( [], seed.length, argument ),\n\t\t\t\ti = matchIndexes.length;\n\n\t\t\t// Match elements found at the specified indexes\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( seed[ ( j = matchIndexes[ i ] ) ] ) {\n\t\t\t\t\tseed[ j ] = !( matches[ j ] = seed[ j ] );\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t} );\n}\n\n/**\n * Checks a node for validity as a Sizzle context\n * @param {Element|Object=} context\n * @returns {Element|Object|Boolean} The input node if acceptable, otherwise a falsy value\n */\nfunction testContext( context ) {\n\treturn context && typeof context.getElementsByTagName !== \"undefined\" && context;\n}\n\n// Expose support vars for convenience\nsupport = Sizzle.support = {};\n\n/**\n * Detects XML nodes\n * @param {Element|Object} elem An element or a document\n * @returns {Boolean} True iff elem is a non-HTML XML node\n */\nisXML = Sizzle.isXML = function( elem ) {\n\tvar namespace = elem.namespaceURI,\n\t\tdocElem = ( elem.ownerDocument || elem ).documentElement;\n\n\t// Support: IE <=8\n\t// Assume HTML when documentElement doesn't yet exist, such as inside loading iframes\n\t// https://bugs.jquery.com/ticket/4833\n\treturn !rhtml.test( namespace || docElem && docElem.nodeName || \"HTML\" );\n};\n\n/**\n * Sets document-related variables once based on the current document\n * @param {Element|Object} [doc] An element or document object to use to set the document\n * @returns {Object} Returns the current document\n */\nsetDocument = Sizzle.setDocument = function( node ) {\n\tvar hasCompare, subWindow,\n\t\tdoc = node ? node.ownerDocument || node : preferredDoc;\n\n\t// Return early if doc is invalid or already selected\n\t// Support: IE 11+, Edge 17 - 18+\n\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t// two documents; shallow comparisons work.\n\t// eslint-disable-next-line eqeqeq\n\tif ( doc == document || doc.nodeType !== 9 || !doc.documentElement ) {\n\t\treturn document;\n\t}\n\n\t// Update global variables\n\tdocument = doc;\n\tdocElem = document.documentElement;\n\tdocumentIsHTML = !isXML( document );\n\n\t// Support: IE 9 - 11+, Edge 12 - 18+\n\t// Accessing iframe documents after unload throws \"permission denied\" errors (jQuery #13936)\n\t// Support: IE 11+, Edge 17 - 18+\n\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t// two documents; shallow comparisons work.\n\t// eslint-disable-next-line eqeqeq\n\tif ( preferredDoc != document &&\n\t\t( subWindow = document.defaultView ) && subWindow.top !== subWindow ) {\n\n\t\t// Support: IE 11, Edge\n\t\tif ( subWindow.addEventListener ) {\n\t\t\tsubWindow.addEventListener( \"unload\", unloadHandler, false );\n\n\t\t// Support: IE 9 - 10 only\n\t\t} else if ( subWindow.attachEvent ) {\n\t\t\tsubWindow.attachEvent( \"onunload\", unloadHandler );\n\t\t}\n\t}\n\n\t// Support: IE 8 - 11+, Edge 12 - 18+, Chrome <=16 - 25 only, Firefox <=3.6 - 31 only,\n\t// Safari 4 - 5 only, Opera <=11.6 - 12.x only\n\t// IE/Edge & older browsers don't support the :scope pseudo-class.\n\t// Support: Safari 6.0 only\n\t// Safari 6.0 supports :scope but it's an alias of :root there.\n\tsupport.scope = assert( function( el ) {\n\t\tdocElem.appendChild( el ).appendChild( document.createElement( \"div\" ) );\n\t\treturn typeof el.querySelectorAll !== \"undefined\" &&\n\t\t\t!el.querySelectorAll( \":scope fieldset div\" ).length;\n\t} );\n\n\t/* Attributes\n\t---------------------------------------------------------------------- */\n\n\t// Support: IE<8\n\t// Verify that getAttribute really returns attributes and not properties\n\t// (excepting IE8 booleans)\n\tsupport.attributes = assert( function( el ) {\n\t\tel.className = \"i\";\n\t\treturn !el.getAttribute( \"className\" );\n\t} );\n\n\t/* getElement(s)By*\n\t---------------------------------------------------------------------- */\n\n\t// Check if getElementsByTagName(\"*\") returns only elements\n\tsupport.getElementsByTagName = assert( function( el ) {\n\t\tel.appendChild( document.createComment( \"\" ) );\n\t\treturn !el.getElementsByTagName( \"*\" ).length;\n\t} );\n\n\t// Support: IE<9\n\tsupport.getElementsByClassName = rnative.test( document.getElementsByClassName );\n\n\t// Support: IE<10\n\t// Check if getElementById returns elements by name\n\t// The broken getElementById methods don't pick up programmatically-set names,\n\t// so use a roundabout getElementsByName test\n\tsupport.getById = assert( function( el ) {\n\t\tdocElem.appendChild( el ).id = expando;\n\t\treturn !document.getElementsByName || !document.getElementsByName( expando ).length;\n\t} );\n\n\t// ID filter and find\n\tif ( support.getById ) {\n\t\tExpr.filter[ \"ID\" ] = function( id ) {\n\t\t\tvar attrId = id.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\treturn elem.getAttribute( \"id\" ) === attrId;\n\t\t\t};\n\t\t};\n\t\tExpr.find[ \"ID\" ] = function( id, context ) {\n\t\t\tif ( typeof context.getElementById !== \"undefined\" && documentIsHTML ) {\n\t\t\t\tvar elem = context.getElementById( id );\n\t\t\t\treturn elem ? [ elem ] : [];\n\t\t\t}\n\t\t};\n\t} else {\n\t\tExpr.filter[ \"ID\" ] = function( id ) {\n\t\t\tvar attrId = id.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\tvar node = typeof elem.getAttributeNode !== \"undefined\" &&\n\t\t\t\t\telem.getAttributeNode( \"id\" );\n\t\t\t\treturn node && node.value === attrId;\n\t\t\t};\n\t\t};\n\n\t\t// Support: IE 6 - 7 only\n\t\t// getElementById is not reliable as a find shortcut\n\t\tExpr.find[ \"ID\" ] = function( id, context ) {\n\t\t\tif ( typeof context.getElementById !== \"undefined\" && documentIsHTML ) {\n\t\t\t\tvar node, i, elems,\n\t\t\t\t\telem = context.getElementById( id );\n\n\t\t\t\tif ( elem ) {\n\n\t\t\t\t\t// Verify the id attribute\n\t\t\t\t\tnode = elem.getAttributeNode( \"id\" );\n\t\t\t\t\tif ( node && node.value === id ) {\n\t\t\t\t\t\treturn [ elem ];\n\t\t\t\t\t}\n\n\t\t\t\t\t// Fall back on getElementsByName\n\t\t\t\t\telems = context.getElementsByName( id );\n\t\t\t\t\ti = 0;\n\t\t\t\t\twhile ( ( elem = elems[ i++ ] ) ) {\n\t\t\t\t\t\tnode = elem.getAttributeNode( \"id\" );\n\t\t\t\t\t\tif ( node && node.value === id ) {\n\t\t\t\t\t\t\treturn [ elem ];\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn [];\n\t\t\t}\n\t\t};\n\t}\n\n\t// Tag\n\tExpr.find[ \"TAG\" ] = support.getElementsByTagName ?\n\t\tfunction( tag, context ) {\n\t\t\tif ( typeof context.getElementsByTagName !== \"undefined\" ) {\n\t\t\t\treturn context.getElementsByTagName( tag );\n\n\t\t\t// DocumentFragment nodes don't have gEBTN\n\t\t\t} else if ( support.qsa ) {\n\t\t\t\treturn context.querySelectorAll( tag );\n\t\t\t}\n\t\t} :\n\n\t\tfunction( tag, context ) {\n\t\t\tvar elem,\n\t\t\t\ttmp = [],\n\t\t\t\ti = 0,\n\n\t\t\t\t// By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too\n\t\t\t\tresults = context.getElementsByTagName( tag );\n\n\t\t\t// Filter out possible comments\n\t\t\tif ( tag === \"*\" ) {\n\t\t\t\twhile ( ( elem = results[ i++ ] ) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 ) {\n\t\t\t\t\t\ttmp.push( elem );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn tmp;\n\t\t\t}\n\t\t\treturn results;\n\t\t};\n\n\t// Class\n\tExpr.find[ \"CLASS\" ] = support.getElementsByClassName && function( className, context ) {\n\t\tif ( typeof context.getElementsByClassName !== \"undefined\" && documentIsHTML ) {\n\t\t\treturn context.getElementsByClassName( className );\n\t\t}\n\t};\n\n\t/* QSA/matchesSelector\n\t---------------------------------------------------------------------- */\n\n\t// QSA and matchesSelector support\n\n\t// matchesSelector(:active) reports false when true (IE9/Opera 11.5)\n\trbuggyMatches = [];\n\n\t// qSa(:focus) reports false when true (Chrome 21)\n\t// We allow this because of a bug in IE8/9 that throws an error\n\t// whenever `document.activeElement` is accessed on an iframe\n\t// So, we allow :focus to pass through QSA all the time to avoid the IE error\n\t// See https://bugs.jquery.com/ticket/13378\n\trbuggyQSA = [];\n\n\tif ( ( support.qsa = rnative.test( document.querySelectorAll ) ) ) {\n\n\t\t// Build QSA regex\n\t\t// Regex strategy adopted from Diego Perini\n\t\tassert( function( el ) {\n\n\t\t\tvar input;\n\n\t\t\t// Select is set to empty string on purpose\n\t\t\t// This is to test IE's treatment of not explicitly\n\t\t\t// setting a boolean content attribute,\n\t\t\t// since its presence should be enough\n\t\t\t// https://bugs.jquery.com/ticket/12359\n\t\t\tdocElem.appendChild( el ).innerHTML = \"<a id='\" + expando + \"'></a>\" +\n\t\t\t\t\"<select id='\" + expando + \"-\\r\\\\' msallowcapture=''>\" +\n\t\t\t\t\"<option selected=''></option></select>\";\n\n\t\t\t// Support: IE8, Opera 11-12.16\n\t\t\t// Nothing should be selected when empty strings follow ^= or $= or *=\n\t\t\t// The test attribute must be unknown in Opera but \"safe\" for WinRT\n\t\t\t// https://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section\n\t\t\tif ( el.querySelectorAll( \"[msallowcapture^='']\" ).length ) {\n\t\t\t\trbuggyQSA.push( \"[*^$]=\" + whitespace + \"*(?:''|\\\"\\\")\" );\n\t\t\t}\n\n\t\t\t// Support: IE8\n\t\t\t// Boolean attributes and \"value\" are not treated correctly\n\t\t\tif ( !el.querySelectorAll( \"[selected]\" ).length ) {\n\t\t\t\trbuggyQSA.push( \"\\\\[\" + whitespace + \"*(?:value|\" + booleans + \")\" );\n\t\t\t}\n\n\t\t\t// Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+\n\t\t\tif ( !el.querySelectorAll( \"[id~=\" + expando + \"-]\" ).length ) {\n\t\t\t\trbuggyQSA.push( \"~=\" );\n\t\t\t}\n\n\t\t\t// Support: IE 11+, Edge 15 - 18+\n\t\t\t// IE 11/Edge don't find elements on a `[name='']` query in some cases.\n\t\t\t// Adding a temporary attribute to the document before the selection works\n\t\t\t// around the issue.\n\t\t\t// Interestingly, IE 10 & older don't seem to have the issue.\n\t\t\tinput = document.createElement( \"input\" );\n\t\t\tinput.setAttribute( \"name\", \"\" );\n\t\t\tel.appendChild( input );\n\t\t\tif ( !el.querySelectorAll( \"[name='']\" ).length ) {\n\t\t\t\trbuggyQSA.push( \"\\\\[\" + whitespace + \"*name\" + whitespace + \"*=\" +\n\t\t\t\t\twhitespace + \"*(?:''|\\\"\\\")\" );\n\t\t\t}\n\n\t\t\t// Webkit/Opera - :checked should return selected option elements\n\t\t\t// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked\n\t\t\t// IE8 throws error here and will not see later tests\n\t\t\tif ( !el.querySelectorAll( \":checked\" ).length ) {\n\t\t\t\trbuggyQSA.push( \":checked\" );\n\t\t\t}\n\n\t\t\t// Support: Safari 8+, iOS 8+\n\t\t\t// https://bugs.webkit.org/show_bug.cgi?id=136851\n\t\t\t// In-page `selector#id sibling-combinator selector` fails\n\t\t\tif ( !el.querySelectorAll( \"a#\" + expando + \"+*\" ).length ) {\n\t\t\t\trbuggyQSA.push( \".#.+[+~]\" );\n\t\t\t}\n\n\t\t\t// Support: Firefox <=3.6 - 5 only\n\t\t\t// Old Firefox doesn't throw on a badly-escaped identifier.\n\t\t\tel.querySelectorAll( \"\\\\\\f\" );\n\t\t\trbuggyQSA.push( \"[\\\\r\\\\n\\\\f]\" );\n\t\t} );\n\n\t\tassert( function( el ) {\n\t\t\tel.innerHTML = \"<a href='' disabled='disabled'></a>\" +\n\t\t\t\t\"<select disabled='disabled'><option/></select>\";\n\n\t\t\t// Support: Windows 8 Native Apps\n\t\t\t// The type and name attributes are restricted during .innerHTML assignment\n\t\t\tvar input = document.createElement( \"input\" );\n\t\t\tinput.setAttribute( \"type\", \"hidden\" );\n\t\t\tel.appendChild( input ).setAttribute( \"name\", \"D\" );\n\n\t\t\t// Support: IE8\n\t\t\t// Enforce case-sensitivity of name attribute\n\t\t\tif ( el.querySelectorAll( \"[name=d]\" ).length ) {\n\t\t\t\trbuggyQSA.push( \"name\" + whitespace + \"*[*^$|!~]?=\" );\n\t\t\t}\n\n\t\t\t// FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled)\n\t\t\t// IE8 throws error here and will not see later tests\n\t\t\tif ( el.querySelectorAll( \":enabled\" ).length !== 2 ) {\n\t\t\t\trbuggyQSA.push( \":enabled\", \":disabled\" );\n\t\t\t}\n\n\t\t\t// Support: IE9-11+\n\t\t\t// IE's :disabled selector does not pick up the children of disabled fieldsets\n\t\t\tdocElem.appendChild( el ).disabled = true;\n\t\t\tif ( el.querySelectorAll( \":disabled\" ).length !== 2 ) {\n\t\t\t\trbuggyQSA.push( \":enabled\", \":disabled\" );\n\t\t\t}\n\n\t\t\t// Support: Opera 10 - 11 only\n\t\t\t// Opera 10-11 does not throw on post-comma invalid pseudos\n\t\t\tel.querySelectorAll( \"*,:x\" );\n\t\t\trbuggyQSA.push( \",.*:\" );\n\t\t} );\n\t}\n\n\tif ( ( support.matchesSelector = rnative.test( ( matches = docElem.matches ||\n\t\tdocElem.webkitMatchesSelector ||\n\t\tdocElem.mozMatchesSelector ||\n\t\tdocElem.oMatchesSelector ||\n\t\tdocElem.msMatchesSelector ) ) ) ) {\n\n\t\tassert( function( el ) {\n\n\t\t\t// Check to see if it's possible to do matchesSelector\n\t\t\t// on a disconnected node (IE 9)\n\t\t\tsupport.disconnectedMatch = matches.call( el, \"*\" );\n\n\t\t\t// This should fail with an exception\n\t\t\t// Gecko does not error, returns false instead\n\t\t\tmatches.call( el, \"[s!='']:x\" );\n\t\t\trbuggyMatches.push( \"!=\", pseudos );\n\t\t} );\n\t}\n\n\trbuggyQSA = rbuggyQSA.length && new RegExp( rbuggyQSA.join( \"|\" ) );\n\trbuggyMatches = rbuggyMatches.length && new RegExp( rbuggyMatches.join( \"|\" ) );\n\n\t/* Contains\n\t---------------------------------------------------------------------- */\n\thasCompare = rnative.test( docElem.compareDocumentPosition );\n\n\t// Element contains another\n\t// Purposefully self-exclusive\n\t// As in, an element does not contain itself\n\tcontains = hasCompare || rnative.test( docElem.contains ) ?\n\t\tfunction( a, b ) {\n\t\t\tvar adown = a.nodeType === 9 ? a.documentElement : a,\n\t\t\t\tbup = b && b.parentNode;\n\t\t\treturn a === bup || !!( bup && bup.nodeType === 1 && (\n\t\t\t\tadown.contains ?\n\t\t\t\t\tadown.contains( bup ) :\n\t\t\t\t\ta.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16\n\t\t\t) );\n\t\t} :\n\t\tfunction( a, b ) {\n\t\t\tif ( b ) {\n\t\t\t\twhile ( ( b = b.parentNode ) ) {\n\t\t\t\t\tif ( b === a ) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n\n\t/* Sorting\n\t---------------------------------------------------------------------- */\n\n\t// Document order sorting\n\tsortOrder = hasCompare ?\n\tfunction( a, b ) {\n\n\t\t// Flag for duplicate removal\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t\treturn 0;\n\t\t}\n\n\t\t// Sort on method existence if only one input has compareDocumentPosition\n\t\tvar compare = !a.compareDocumentPosition - !b.compareDocumentPosition;\n\t\tif ( compare ) {\n\t\t\treturn compare;\n\t\t}\n\n\t\t// Calculate position if both inputs belong to the same document\n\t\t// Support: IE 11+, Edge 17 - 18+\n\t\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t\t// two documents; shallow comparisons work.\n\t\t// eslint-disable-next-line eqeqeq\n\t\tcompare = ( a.ownerDocument || a ) == ( b.ownerDocument || b ) ?\n\t\t\ta.compareDocumentPosition( b ) :\n\n\t\t\t// Otherwise we know they are disconnected\n\t\t\t1;\n\n\t\t// Disconnected nodes\n\t\tif ( compare & 1 ||\n\t\t\t( !support.sortDetached && b.compareDocumentPosition( a ) === compare ) ) {\n\n\t\t\t// Choose the first element that is related to our preferred document\n\t\t\t// Support: IE 11+, Edge 17 - 18+\n\t\t\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t\t\t// two documents; shallow comparisons work.\n\t\t\t// eslint-disable-next-line eqeqeq\n\t\t\tif ( a == document || a.ownerDocument == preferredDoc &&\n\t\t\t\tcontains( preferredDoc, a ) ) {\n\t\t\t\treturn -1;\n\t\t\t}\n\n\t\t\t// Support: IE 11+, Edge 17 - 18+\n\t\t\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t\t\t// two documents; shallow comparisons work.\n\t\t\t// eslint-disable-next-line eqeqeq\n\t\t\tif ( b == document || b.ownerDocument == preferredDoc &&\n\t\t\t\tcontains( preferredDoc, b ) ) {\n\t\t\t\treturn 1;\n\t\t\t}\n\n\t\t\t// Maintain original order\n\t\t\treturn sortInput ?\n\t\t\t\t( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :\n\t\t\t\t0;\n\t\t}\n\n\t\treturn compare & 4 ? -1 : 1;\n\t} :\n\tfunction( a, b ) {\n\n\t\t// Exit early if the nodes are identical\n\t\tif ( a === b ) {\n\t\t\thasDuplicate = true;\n\t\t\treturn 0;\n\t\t}\n\n\t\tvar cur,\n\t\t\ti = 0,\n\t\t\taup = a.parentNode,\n\t\t\tbup = b.parentNode,\n\t\t\tap = [ a ],\n\t\t\tbp = [ b ];\n\n\t\t// Parentless nodes are either documents or disconnected\n\t\tif ( !aup || !bup ) {\n\n\t\t\t// Support: IE 11+, Edge 17 - 18+\n\t\t\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t\t\t// two documents; shallow comparisons work.\n\t\t\t/* eslint-disable eqeqeq */\n\t\t\treturn a == document ? -1 :\n\t\t\t\tb == document ? 1 :\n\t\t\t\t/* eslint-enable eqeqeq */\n\t\t\t\taup ? -1 :\n\t\t\t\tbup ? 1 :\n\t\t\t\tsortInput ?\n\t\t\t\t( indexOf( sortInput, a ) - indexOf( sortInput, b ) ) :\n\t\t\t\t0;\n\n\t\t// If the nodes are siblings, we can do a quick check\n\t\t} else if ( aup === bup ) {\n\t\t\treturn siblingCheck( a, b );\n\t\t}\n\n\t\t// Otherwise we need full lists of their ancestors for comparison\n\t\tcur = a;\n\t\twhile ( ( cur = cur.parentNode ) ) {\n\t\t\tap.unshift( cur );\n\t\t}\n\t\tcur = b;\n\t\twhile ( ( cur = cur.parentNode ) ) {\n\t\t\tbp.unshift( cur );\n\t\t}\n\n\t\t// Walk down the tree looking for a discrepancy\n\t\twhile ( ap[ i ] === bp[ i ] ) {\n\t\t\ti++;\n\t\t}\n\n\t\treturn i ?\n\n\t\t\t// Do a sibling check if the nodes have a common ancestor\n\t\t\tsiblingCheck( ap[ i ], bp[ i ] ) :\n\n\t\t\t// Otherwise nodes in our document sort first\n\t\t\t// Support: IE 11+, Edge 17 - 18+\n\t\t\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t\t\t// two documents; shallow comparisons work.\n\t\t\t/* eslint-disable eqeqeq */\n\t\t\tap[ i ] == preferredDoc ? -1 :\n\t\t\tbp[ i ] == preferredDoc ? 1 :\n\t\t\t/* eslint-enable eqeqeq */\n\t\t\t0;\n\t};\n\n\treturn document;\n};\n\nSizzle.matches = function( expr, elements ) {\n\treturn Sizzle( expr, null, null, elements );\n};\n\nSizzle.matchesSelector = function( elem, expr ) {\n\tsetDocument( elem );\n\n\tif ( support.matchesSelector && documentIsHTML &&\n\t\t!nonnativeSelectorCache[ expr + \" \" ] &&\n\t\t( !rbuggyMatches || !rbuggyMatches.test( expr ) ) &&\n\t\t( !rbuggyQSA || !rbuggyQSA.test( expr ) ) ) {\n\n\t\ttry {\n\t\t\tvar ret = matches.call( elem, expr );\n\n\t\t\t// IE 9's matchesSelector returns false on disconnected nodes\n\t\t\tif ( ret || support.disconnectedMatch ||\n\n\t\t\t\t// As well, disconnected nodes are said to be in a document\n\t\t\t\t// fragment in IE 9\n\t\t\t\telem.document && elem.document.nodeType !== 11 ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\t\t} catch ( e ) {\n\t\t\tnonnativeSelectorCache( expr, true );\n\t\t}\n\t}\n\n\treturn Sizzle( expr, document, null, [ elem ] ).length > 0;\n};\n\nSizzle.contains = function( context, elem ) {\n\n\t// Set document vars if needed\n\t// Support: IE 11+, Edge 17 - 18+\n\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t// two documents; shallow comparisons work.\n\t// eslint-disable-next-line eqeqeq\n\tif ( ( context.ownerDocument || context ) != document ) {\n\t\tsetDocument( context );\n\t}\n\treturn contains( context, elem );\n};\n\nSizzle.attr = function( elem, name ) {\n\n\t// Set document vars if needed\n\t// Support: IE 11+, Edge 17 - 18+\n\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t// two documents; shallow comparisons work.\n\t// eslint-disable-next-line eqeqeq\n\tif ( ( elem.ownerDocument || elem ) != document ) {\n\t\tsetDocument( elem );\n\t}\n\n\tvar fn = Expr.attrHandle[ name.toLowerCase() ],\n\n\t\t// Don't get fooled by Object.prototype properties (jQuery #13807)\n\t\tval = fn && hasOwn.call( Expr.attrHandle, name.toLowerCase() ) ?\n\t\t\tfn( elem, name, !documentIsHTML ) :\n\t\t\tundefined;\n\n\treturn val !== undefined ?\n\t\tval :\n\t\tsupport.attributes || !documentIsHTML ?\n\t\t\telem.getAttribute( name ) :\n\t\t\t( val = elem.getAttributeNode( name ) ) && val.specified ?\n\t\t\t\tval.value :\n\t\t\t\tnull;\n};\n\nSizzle.escape = function( sel ) {\n\treturn ( sel + \"\" ).replace( rcssescape, fcssescape );\n};\n\nSizzle.error = function( msg ) {\n\tthrow new Error( \"Syntax error, unrecognized expression: \" + msg );\n};\n\n/**\n * Document sorting and removing duplicates\n * @param {ArrayLike} results\n */\nSizzle.uniqueSort = function( results ) {\n\tvar elem,\n\t\tduplicates = [],\n\t\tj = 0,\n\t\ti = 0;\n\n\t// Unless we *know* we can detect duplicates, assume their presence\n\thasDuplicate = !support.detectDuplicates;\n\tsortInput = !support.sortStable && results.slice( 0 );\n\tresults.sort( sortOrder );\n\n\tif ( hasDuplicate ) {\n\t\twhile ( ( elem = results[ i++ ] ) ) {\n\t\t\tif ( elem === results[ i ] ) {\n\t\t\t\tj = duplicates.push( i );\n\t\t\t}\n\t\t}\n\t\twhile ( j-- ) {\n\t\t\tresults.splice( duplicates[ j ], 1 );\n\t\t}\n\t}\n\n\t// Clear input after sorting to release objects\n\t// See https://github.com/jquery/sizzle/pull/225\n\tsortInput = null;\n\n\treturn results;\n};\n\n/**\n * Utility function for retrieving the text value of an array of DOM nodes\n * @param {Array|Element} elem\n */\ngetText = Sizzle.getText = function( elem ) {\n\tvar node,\n\t\tret = \"\",\n\t\ti = 0,\n\t\tnodeType = elem.nodeType;\n\n\tif ( !nodeType ) {\n\n\t\t// If no nodeType, this is expected to be an array\n\t\twhile ( ( node = elem[ i++ ] ) ) {\n\n\t\t\t// Do not traverse comment nodes\n\t\t\tret += getText( node );\n\t\t}\n\t} else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) {\n\n\t\t// Use textContent for elements\n\t\t// innerText usage removed for consistency of new lines (jQuery #11153)\n\t\tif ( typeof elem.textContent === \"string\" ) {\n\t\t\treturn elem.textContent;\n\t\t} else {\n\n\t\t\t// Traverse its children\n\t\t\tfor ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {\n\t\t\t\tret += getText( elem );\n\t\t\t}\n\t\t}\n\t} else if ( nodeType === 3 || nodeType === 4 ) {\n\t\treturn elem.nodeValue;\n\t}\n\n\t// Do not include comment or processing instruction nodes\n\n\treturn ret;\n};\n\nExpr = Sizzle.selectors = {\n\n\t// Can be adjusted by the user\n\tcacheLength: 50,\n\n\tcreatePseudo: markFunction,\n\n\tmatch: matchExpr,\n\n\tattrHandle: {},\n\n\tfind: {},\n\n\trelative: {\n\t\t\">\": { dir: \"parentNode\", first: true },\n\t\t\" \": { dir: \"parentNode\" },\n\t\t\"+\": { dir: \"previousSibling\", first: true },\n\t\t\"~\": { dir: \"previousSibling\" }\n\t},\n\n\tpreFilter: {\n\t\t\"ATTR\": function( match ) {\n\t\t\tmatch[ 1 ] = match[ 1 ].replace( runescape, funescape );\n\n\t\t\t// Move the given value to match[3] whether quoted or unquoted\n\t\t\tmatch[ 3 ] = ( match[ 3 ] || match[ 4 ] ||\n\t\t\t\tmatch[ 5 ] || \"\" ).replace( runescape, funescape );\n\n\t\t\tif ( match[ 2 ] === \"~=\" ) {\n\t\t\t\tmatch[ 3 ] = \" \" + match[ 3 ] + \" \";\n\t\t\t}\n\n\t\t\treturn match.slice( 0, 4 );\n\t\t},\n\n\t\t\"CHILD\": function( match ) {\n\n\t\t\t/* matches from matchExpr[\"CHILD\"]\n\t\t\t\t1 type (only|nth|...)\n\t\t\t\t2 what (child|of-type)\n\t\t\t\t3 argument (even|odd|\\d*|\\d*n([+-]\\d+)?|...)\n\t\t\t\t4 xn-component of xn+y argument ([+-]?\\d*n|)\n\t\t\t\t5 sign of xn-component\n\t\t\t\t6 x of xn-component\n\t\t\t\t7 sign of y-component\n\t\t\t\t8 y of y-component\n\t\t\t*/\n\t\t\tmatch[ 1 ] = match[ 1 ].toLowerCase();\n\n\t\t\tif ( match[ 1 ].slice( 0, 3 ) === \"nth\" ) {\n\n\t\t\t\t// nth-* requires argument\n\t\t\t\tif ( !match[ 3 ] ) {\n\t\t\t\t\tSizzle.error( match[ 0 ] );\n\t\t\t\t}\n\n\t\t\t\t// numeric x and y parameters for Expr.filter.CHILD\n\t\t\t\t// remember that false/true cast respectively to 0/1\n\t\t\t\tmatch[ 4 ] = +( match[ 4 ] ?\n\t\t\t\t\tmatch[ 5 ] + ( match[ 6 ] || 1 ) :\n\t\t\t\t\t2 * ( match[ 3 ] === \"even\" || match[ 3 ] === \"odd\" ) );\n\t\t\t\tmatch[ 5 ] = +( ( match[ 7 ] + match[ 8 ] ) || match[ 3 ] === \"odd\" );\n\n\t\t\t\t// other types prohibit arguments\n\t\t\t} else if ( match[ 3 ] ) {\n\t\t\t\tSizzle.error( match[ 0 ] );\n\t\t\t}\n\n\t\t\treturn match;\n\t\t},\n\n\t\t\"PSEUDO\": function( match ) {\n\t\t\tvar excess,\n\t\t\t\tunquoted = !match[ 6 ] && match[ 2 ];\n\n\t\t\tif ( matchExpr[ \"CHILD\" ].test( match[ 0 ] ) ) {\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\t// Accept quoted arguments as-is\n\t\t\tif ( match[ 3 ] ) {\n\t\t\t\tmatch[ 2 ] = match[ 4 ] || match[ 5 ] || \"\";\n\n\t\t\t// Strip excess characters from unquoted arguments\n\t\t\t} else if ( unquoted && rpseudo.test( unquoted ) &&\n\n\t\t\t\t// Get excess from tokenize (recursively)\n\t\t\t\t( excess = tokenize( unquoted, true ) ) &&\n\n\t\t\t\t// advance to the next closing parenthesis\n\t\t\t\t( excess = unquoted.indexOf( \")\", unquoted.length - excess ) - unquoted.length ) ) {\n\n\t\t\t\t// excess is a negative index\n\t\t\t\tmatch[ 0 ] = match[ 0 ].slice( 0, excess );\n\t\t\t\tmatch[ 2 ] = unquoted.slice( 0, excess );\n\t\t\t}\n\n\t\t\t// Return only captures needed by the pseudo filter method (type and argument)\n\t\t\treturn match.slice( 0, 3 );\n\t\t}\n\t},\n\n\tfilter: {\n\n\t\t\"TAG\": function( nodeNameSelector ) {\n\t\t\tvar nodeName = nodeNameSelector.replace( runescape, funescape ).toLowerCase();\n\t\t\treturn nodeNameSelector === \"*\" ?\n\t\t\t\tfunction() {\n\t\t\t\t\treturn true;\n\t\t\t\t} :\n\t\t\t\tfunction( elem ) {\n\t\t\t\t\treturn elem.nodeName && elem.nodeName.toLowerCase() === nodeName;\n\t\t\t\t};\n\t\t},\n\n\t\t\"CLASS\": function( className ) {\n\t\t\tvar pattern = classCache[ className + \" \" ];\n\n\t\t\treturn pattern ||\n\t\t\t\t( pattern = new RegExp( \"(^|\" + whitespace +\n\t\t\t\t\t\")\" + className + \"(\" + whitespace + \"|$)\" ) ) && classCache(\n\t\t\t\t\t\tclassName, function( elem ) {\n\t\t\t\t\t\t\treturn pattern.test(\n\t\t\t\t\t\t\t\ttypeof elem.className === \"string\" && elem.className ||\n\t\t\t\t\t\t\t\ttypeof elem.getAttribute !== \"undefined\" &&\n\t\t\t\t\t\t\t\t\telem.getAttribute( \"class\" ) ||\n\t\t\t\t\t\t\t\t\"\"\n\t\t\t\t\t\t\t);\n\t\t\t\t} );\n\t\t},\n\n\t\t\"ATTR\": function( name, operator, check ) {\n\t\t\treturn function( elem ) {\n\t\t\t\tvar result = Sizzle.attr( elem, name );\n\n\t\t\t\tif ( result == null ) {\n\t\t\t\t\treturn operator === \"!=\";\n\t\t\t\t}\n\t\t\t\tif ( !operator ) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\n\t\t\t\tresult += \"\";\n\n\t\t\t\t/* eslint-disable max-len */\n\n\t\t\t\treturn operator === \"=\" ? result === check :\n\t\t\t\t\toperator === \"!=\" ? result !== check :\n\t\t\t\t\toperator === \"^=\" ? check && result.indexOf( check ) === 0 :\n\t\t\t\t\toperator === \"*=\" ? check && result.indexOf( check ) > -1 :\n\t\t\t\t\toperator === \"$=\" ? check && result.slice( -check.length ) === check :\n\t\t\t\t\toperator === \"~=\" ? ( \" \" + result.replace( rwhitespace, \" \" ) + \" \" ).indexOf( check ) > -1 :\n\t\t\t\t\toperator === \"|=\" ? result === check || result.slice( 0, check.length + 1 ) === check + \"-\" :\n\t\t\t\t\tfalse;\n\t\t\t\t/* eslint-enable max-len */\n\n\t\t\t};\n\t\t},\n\n\t\t\"CHILD\": function( type, what, _argument, first, last ) {\n\t\t\tvar simple = type.slice( 0, 3 ) !== \"nth\",\n\t\t\t\tforward = type.slice( -4 ) !== \"last\",\n\t\t\t\tofType = what === \"of-type\";\n\n\t\t\treturn first === 1 && last === 0 ?\n\n\t\t\t\t// Shortcut for :nth-*(n)\n\t\t\t\tfunction( elem ) {\n\t\t\t\t\treturn !!elem.parentNode;\n\t\t\t\t} :\n\n\t\t\t\tfunction( elem, _context, xml ) {\n\t\t\t\t\tvar cache, uniqueCache, outerCache, node, nodeIndex, start,\n\t\t\t\t\t\tdir = simple !== forward ? \"nextSibling\" : \"previousSibling\",\n\t\t\t\t\t\tparent = elem.parentNode,\n\t\t\t\t\t\tname = ofType && elem.nodeName.toLowerCase(),\n\t\t\t\t\t\tuseCache = !xml && !ofType,\n\t\t\t\t\t\tdiff = false;\n\n\t\t\t\t\tif ( parent ) {\n\n\t\t\t\t\t\t// :(first|last|only)-(child|of-type)\n\t\t\t\t\t\tif ( simple ) {\n\t\t\t\t\t\t\twhile ( dir ) {\n\t\t\t\t\t\t\t\tnode = elem;\n\t\t\t\t\t\t\t\twhile ( ( node = node[ dir ] ) ) {\n\t\t\t\t\t\t\t\t\tif ( ofType ?\n\t\t\t\t\t\t\t\t\t\tnode.nodeName.toLowerCase() === name :\n\t\t\t\t\t\t\t\t\t\tnode.nodeType === 1 ) {\n\n\t\t\t\t\t\t\t\t\t\treturn false;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t// Reverse direction for :only-* (if we haven't yet done so)\n\t\t\t\t\t\t\t\tstart = dir = type === \"only\" && !start && \"nextSibling\";\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tstart = [ forward ? parent.firstChild : parent.lastChild ];\n\n\t\t\t\t\t\t// non-xml :nth-child(...) stores cache data on `parent`\n\t\t\t\t\t\tif ( forward && useCache ) {\n\n\t\t\t\t\t\t\t// Seek `elem` from a previously-cached index\n\n\t\t\t\t\t\t\t// ...in a gzip-friendly way\n\t\t\t\t\t\t\tnode = parent;\n\t\t\t\t\t\t\touterCache = node[ expando ] || ( node[ expando ] = {} );\n\n\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t( outerCache[ node.uniqueID ] = {} );\n\n\t\t\t\t\t\t\tcache = uniqueCache[ type ] || [];\n\t\t\t\t\t\t\tnodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];\n\t\t\t\t\t\t\tdiff = nodeIndex && cache[ 2 ];\n\t\t\t\t\t\t\tnode = nodeIndex && parent.childNodes[ nodeIndex ];\n\n\t\t\t\t\t\t\twhile ( ( node = ++nodeIndex && node && node[ dir ] ||\n\n\t\t\t\t\t\t\t\t// Fallback to seeking `elem` from the start\n\t\t\t\t\t\t\t\t( diff = nodeIndex = 0 ) || start.pop() ) ) {\n\n\t\t\t\t\t\t\t\t// When found, cache indexes on `parent` and break\n\t\t\t\t\t\t\t\tif ( node.nodeType === 1 && ++diff && node === elem ) {\n\t\t\t\t\t\t\t\t\tuniqueCache[ type ] = [ dirruns, nodeIndex, diff ];\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t// Use previously-cached element index if available\n\t\t\t\t\t\t\tif ( useCache ) {\n\n\t\t\t\t\t\t\t\t// ...in a gzip-friendly way\n\t\t\t\t\t\t\t\tnode = elem;\n\t\t\t\t\t\t\t\touterCache = node[ expando ] || ( node[ expando ] = {} );\n\n\t\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t\t( outerCache[ node.uniqueID ] = {} );\n\n\t\t\t\t\t\t\t\tcache = uniqueCache[ type ] || [];\n\t\t\t\t\t\t\t\tnodeIndex = cache[ 0 ] === dirruns && cache[ 1 ];\n\t\t\t\t\t\t\t\tdiff = nodeIndex;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// xml :nth-child(...)\n\t\t\t\t\t\t\t// or :nth-last-child(...) or :nth(-last)?-of-type(...)\n\t\t\t\t\t\t\tif ( diff === false ) {\n\n\t\t\t\t\t\t\t\t// Use the same loop as above to seek `elem` from the start\n\t\t\t\t\t\t\t\twhile ( ( node = ++nodeIndex && node && node[ dir ] ||\n\t\t\t\t\t\t\t\t\t( diff = nodeIndex = 0 ) || start.pop() ) ) {\n\n\t\t\t\t\t\t\t\t\tif ( ( ofType ?\n\t\t\t\t\t\t\t\t\t\tnode.nodeName.toLowerCase() === name :\n\t\t\t\t\t\t\t\t\t\tnode.nodeType === 1 ) &&\n\t\t\t\t\t\t\t\t\t\t++diff ) {\n\n\t\t\t\t\t\t\t\t\t\t// Cache the index of each encountered element\n\t\t\t\t\t\t\t\t\t\tif ( useCache ) {\n\t\t\t\t\t\t\t\t\t\t\touterCache = node[ expando ] ||\n\t\t\t\t\t\t\t\t\t\t\t\t( node[ expando ] = {} );\n\n\t\t\t\t\t\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\t\t\t\t\t\tuniqueCache = outerCache[ node.uniqueID ] ||\n\t\t\t\t\t\t\t\t\t\t\t\t( outerCache[ node.uniqueID ] = {} );\n\n\t\t\t\t\t\t\t\t\t\t\tuniqueCache[ type ] = [ dirruns, diff ];\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\tif ( node === elem ) {\n\t\t\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Incorporate the offset, then check against cycle size\n\t\t\t\t\t\tdiff -= last;\n\t\t\t\t\t\treturn diff === first || ( diff % first === 0 && diff / first >= 0 );\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t},\n\n\t\t\"PSEUDO\": function( pseudo, argument ) {\n\n\t\t\t// pseudo-class names are case-insensitive\n\t\t\t// http://www.w3.org/TR/selectors/#pseudo-classes\n\t\t\t// Prioritize by case sensitivity in case custom pseudos are added with uppercase letters\n\t\t\t// Remember that setFilters inherits from pseudos\n\t\t\tvar args,\n\t\t\t\tfn = Expr.pseudos[ pseudo ] || Expr.setFilters[ pseudo.toLowerCase() ] ||\n\t\t\t\t\tSizzle.error( \"unsupported pseudo: \" + pseudo );\n\n\t\t\t// The user may use createPseudo to indicate that\n\t\t\t// arguments are needed to create the filter function\n\t\t\t// just as Sizzle does\n\t\t\tif ( fn[ expando ] ) {\n\t\t\t\treturn fn( argument );\n\t\t\t}\n\n\t\t\t// But maintain support for old signatures\n\t\t\tif ( fn.length > 1 ) {\n\t\t\t\targs = [ pseudo, pseudo, \"\", argument ];\n\t\t\t\treturn Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ?\n\t\t\t\t\tmarkFunction( function( seed, matches ) {\n\t\t\t\t\t\tvar idx,\n\t\t\t\t\t\t\tmatched = fn( seed, argument ),\n\t\t\t\t\t\t\ti = matched.length;\n\t\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\t\tidx = indexOf( seed, matched[ i ] );\n\t\t\t\t\t\t\tseed[ idx ] = !( matches[ idx ] = matched[ i ] );\n\t\t\t\t\t\t}\n\t\t\t\t\t} ) :\n\t\t\t\t\tfunction( elem ) {\n\t\t\t\t\t\treturn fn( elem, 0, args );\n\t\t\t\t\t};\n\t\t\t}\n\n\t\t\treturn fn;\n\t\t}\n\t},\n\n\tpseudos: {\n\n\t\t// Potentially complex pseudos\n\t\t\"not\": markFunction( function( selector ) {\n\n\t\t\t// Trim the selector passed to compile\n\t\t\t// to avoid treating leading and trailing\n\t\t\t// spaces as combinators\n\t\t\tvar input = [],\n\t\t\t\tresults = [],\n\t\t\t\tmatcher = compile( selector.replace( rtrim, \"$1\" ) );\n\n\t\t\treturn matcher[ expando ] ?\n\t\t\t\tmarkFunction( function( seed, matches, _context, xml ) {\n\t\t\t\t\tvar elem,\n\t\t\t\t\t\tunmatched = matcher( seed, null, xml, [] ),\n\t\t\t\t\t\ti = seed.length;\n\n\t\t\t\t\t// Match elements unmatched by `matcher`\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tif ( ( elem = unmatched[ i ] ) ) {\n\t\t\t\t\t\t\tseed[ i ] = !( matches[ i ] = elem );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} ) :\n\t\t\t\tfunction( elem, _context, xml ) {\n\t\t\t\t\tinput[ 0 ] = elem;\n\t\t\t\t\tmatcher( input, null, xml, results );\n\n\t\t\t\t\t// Don't keep the element (issue #299)\n\t\t\t\t\tinput[ 0 ] = null;\n\t\t\t\t\treturn !results.pop();\n\t\t\t\t};\n\t\t} ),\n\n\t\t\"has\": markFunction( function( selector ) {\n\t\t\treturn function( elem ) {\n\t\t\t\treturn Sizzle( selector, elem ).length > 0;\n\t\t\t};\n\t\t} ),\n\n\t\t\"contains\": markFunction( function( text ) {\n\t\t\ttext = text.replace( runescape, funescape );\n\t\t\treturn function( elem ) {\n\t\t\t\treturn ( elem.textContent || getText( elem ) ).indexOf( text ) > -1;\n\t\t\t};\n\t\t} ),\n\n\t\t// \"Whether an element is represented by a :lang() selector\n\t\t// is based solely on the element's language value\n\t\t// being equal to the identifier C,\n\t\t// or beginning with the identifier C immediately followed by \"-\".\n\t\t// The matching of C against the element's language value is performed case-insensitively.\n\t\t// The identifier C does not have to be a valid language name.\"\n\t\t// http://www.w3.org/TR/selectors/#lang-pseudo\n\t\t\"lang\": markFunction( function( lang ) {\n\n\t\t\t// lang value must be a valid identifier\n\t\t\tif ( !ridentifier.test( lang || \"\" ) ) {\n\t\t\t\tSizzle.error( \"unsupported lang: \" + lang );\n\t\t\t}\n\t\t\tlang = lang.replace( runescape, funescape ).toLowerCase();\n\t\t\treturn function( elem ) {\n\t\t\t\tvar elemLang;\n\t\t\t\tdo {\n\t\t\t\t\tif ( ( elemLang = documentIsHTML ?\n\t\t\t\t\t\telem.lang :\n\t\t\t\t\t\telem.getAttribute( \"xml:lang\" ) || elem.getAttribute( \"lang\" ) ) ) {\n\n\t\t\t\t\t\telemLang = elemLang.toLowerCase();\n\t\t\t\t\t\treturn elemLang === lang || elemLang.indexOf( lang + \"-\" ) === 0;\n\t\t\t\t\t}\n\t\t\t\t} while ( ( elem = elem.parentNode ) && elem.nodeType === 1 );\n\t\t\t\treturn false;\n\t\t\t};\n\t\t} ),\n\n\t\t// Miscellaneous\n\t\t\"target\": function( elem ) {\n\t\t\tvar hash = window.location && window.location.hash;\n\t\t\treturn hash && hash.slice( 1 ) === elem.id;\n\t\t},\n\n\t\t\"root\": function( elem ) {\n\t\t\treturn elem === docElem;\n\t\t},\n\n\t\t\"focus\": function( elem ) {\n\t\t\treturn elem === document.activeElement &&\n\t\t\t\t( !document.hasFocus || document.hasFocus() ) &&\n\t\t\t\t!!( elem.type || elem.href || ~elem.tabIndex );\n\t\t},\n\n\t\t// Boolean properties\n\t\t\"enabled\": createDisabledPseudo( false ),\n\t\t\"disabled\": createDisabledPseudo( true ),\n\n\t\t\"checked\": function( elem ) {\n\n\t\t\t// In CSS3, :checked should return both checked and selected elements\n\t\t\t// http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked\n\t\t\tvar nodeName = elem.nodeName.toLowerCase();\n\t\t\treturn ( nodeName === \"input\" && !!elem.checked ) ||\n\t\t\t\t( nodeName === \"option\" && !!elem.selected );\n\t\t},\n\n\t\t\"selected\": function( elem ) {\n\n\t\t\t// Accessing this property makes selected-by-default\n\t\t\t// options in Safari work properly\n\t\t\tif ( elem.parentNode ) {\n\t\t\t\t// eslint-disable-next-line no-unused-expressions\n\t\t\t\telem.parentNode.selectedIndex;\n\t\t\t}\n\n\t\t\treturn elem.selected === true;\n\t\t},\n\n\t\t// Contents\n\t\t\"empty\": function( elem ) {\n\n\t\t\t// http://www.w3.org/TR/selectors/#empty-pseudo\n\t\t\t// :empty is negated by element (1) or content nodes (text: 3; cdata: 4; entity ref: 5),\n\t\t\t// but not by others (comment: 8; processing instruction: 7; etc.)\n\t\t\t// nodeType < 6 works because attributes (2) do not appear as children\n\t\t\tfor ( elem = elem.firstChild; elem; elem = elem.nextSibling ) {\n\t\t\t\tif ( elem.nodeType < 6 ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t},\n\n\t\t\"parent\": function( elem ) {\n\t\t\treturn !Expr.pseudos[ \"empty\" ]( elem );\n\t\t},\n\n\t\t// Element/input types\n\t\t\"header\": function( elem ) {\n\t\t\treturn rheader.test( elem.nodeName );\n\t\t},\n\n\t\t\"input\": function( elem ) {\n\t\t\treturn rinputs.test( elem.nodeName );\n\t\t},\n\n\t\t\"button\": function( elem ) {\n\t\t\tvar name = elem.nodeName.toLowerCase();\n\t\t\treturn name === \"input\" && elem.type === \"button\" || name === \"button\";\n\t\t},\n\n\t\t\"text\": function( elem ) {\n\t\t\tvar attr;\n\t\t\treturn elem.nodeName.toLowerCase() === \"input\" &&\n\t\t\t\telem.type === \"text\" &&\n\n\t\t\t\t// Support: IE<8\n\t\t\t\t// New HTML5 attribute values (e.g., \"search\") appear with elem.type === \"text\"\n\t\t\t\t( ( attr = elem.getAttribute( \"type\" ) ) == null ||\n\t\t\t\t\tattr.toLowerCase() === \"text\" );\n\t\t},\n\n\t\t// Position-in-collection\n\t\t\"first\": createPositionalPseudo( function() {\n\t\t\treturn [ 0 ];\n\t\t} ),\n\n\t\t\"last\": createPositionalPseudo( function( _matchIndexes, length ) {\n\t\t\treturn [ length - 1 ];\n\t\t} ),\n\n\t\t\"eq\": createPositionalPseudo( function( _matchIndexes, length, argument ) {\n\t\t\treturn [ argument < 0 ? argument + length : argument ];\n\t\t} ),\n\n\t\t\"even\": createPositionalPseudo( function( matchIndexes, length ) {\n\t\t\tvar i = 0;\n\t\t\tfor ( ; i < length; i += 2 ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t} ),\n\n\t\t\"odd\": createPositionalPseudo( function( matchIndexes, length ) {\n\t\t\tvar i = 1;\n\t\t\tfor ( ; i < length; i += 2 ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t} ),\n\n\t\t\"lt\": createPositionalPseudo( function( matchIndexes, length, argument ) {\n\t\t\tvar i = argument < 0 ?\n\t\t\t\targument + length :\n\t\t\t\targument > length ?\n\t\t\t\t\tlength :\n\t\t\t\t\targument;\n\t\t\tfor ( ; --i >= 0; ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t} ),\n\n\t\t\"gt\": createPositionalPseudo( function( matchIndexes, length, argument ) {\n\t\t\tvar i = argument < 0 ? argument + length : argument;\n\t\t\tfor ( ; ++i < length; ) {\n\t\t\t\tmatchIndexes.push( i );\n\t\t\t}\n\t\t\treturn matchIndexes;\n\t\t} )\n\t}\n};\n\nExpr.pseudos[ \"nth\" ] = Expr.pseudos[ \"eq\" ];\n\n// Add button/input type pseudos\nfor ( i in { radio: true, checkbox: true, file: true, password: true, image: true } ) {\n\tExpr.pseudos[ i ] = createInputPseudo( i );\n}\nfor ( i in { submit: true, reset: true } ) {\n\tExpr.pseudos[ i ] = createButtonPseudo( i );\n}\n\n// Easy API for creating new setFilters\nfunction setFilters() {}\nsetFilters.prototype = Expr.filters = Expr.pseudos;\nExpr.setFilters = new setFilters();\n\ntokenize = Sizzle.tokenize = function( selector, parseOnly ) {\n\tvar matched, match, tokens, type,\n\t\tsoFar, groups, preFilters,\n\t\tcached = tokenCache[ selector + \" \" ];\n\n\tif ( cached ) {\n\t\treturn parseOnly ? 0 : cached.slice( 0 );\n\t}\n\n\tsoFar = selector;\n\tgroups = [];\n\tpreFilters = Expr.preFilter;\n\n\twhile ( soFar ) {\n\n\t\t// Comma and first run\n\t\tif ( !matched || ( match = rcomma.exec( soFar ) ) ) {\n\t\t\tif ( match ) {\n\n\t\t\t\t// Don't consume trailing commas as valid\n\t\t\t\tsoFar = soFar.slice( match[ 0 ].length ) || soFar;\n\t\t\t}\n\t\t\tgroups.push( ( tokens = [] ) );\n\t\t}\n\n\t\tmatched = false;\n\n\t\t// Combinators\n\t\tif ( ( match = rcombinators.exec( soFar ) ) ) {\n\t\t\tmatched = match.shift();\n\t\t\ttokens.push( {\n\t\t\t\tvalue: matched,\n\n\t\t\t\t// Cast descendant combinators to space\n\t\t\t\ttype: match[ 0 ].replace( rtrim, \" \" )\n\t\t\t} );\n\t\t\tsoFar = soFar.slice( matched.length );\n\t\t}\n\n\t\t// Filters\n\t\tfor ( type in Expr.filter ) {\n\t\t\tif ( ( match = matchExpr[ type ].exec( soFar ) ) && ( !preFilters[ type ] ||\n\t\t\t\t( match = preFilters[ type ]( match ) ) ) ) {\n\t\t\t\tmatched = match.shift();\n\t\t\t\ttokens.push( {\n\t\t\t\t\tvalue: matched,\n\t\t\t\t\ttype: type,\n\t\t\t\t\tmatches: match\n\t\t\t\t} );\n\t\t\t\tsoFar = soFar.slice( matched.length );\n\t\t\t}\n\t\t}\n\n\t\tif ( !matched ) {\n\t\t\tbreak;\n\t\t}\n\t}\n\n\t// Return the length of the invalid excess\n\t// if we're just parsing\n\t// Otherwise, throw an error or return tokens\n\treturn parseOnly ?\n\t\tsoFar.length :\n\t\tsoFar ?\n\t\t\tSizzle.error( selector ) :\n\n\t\t\t// Cache the tokens\n\t\t\ttokenCache( selector, groups ).slice( 0 );\n};\n\nfunction toSelector( tokens ) {\n\tvar i = 0,\n\t\tlen = tokens.length,\n\t\tselector = \"\";\n\tfor ( ; i < len; i++ ) {\n\t\tselector += tokens[ i ].value;\n\t}\n\treturn selector;\n}\n\nfunction addCombinator( matcher, combinator, base ) {\n\tvar dir = combinator.dir,\n\t\tskip = combinator.next,\n\t\tkey = skip || dir,\n\t\tcheckNonElements = base && key === \"parentNode\",\n\t\tdoneName = done++;\n\n\treturn combinator.first ?\n\n\t\t// Check against closest ancestor/preceding element\n\t\tfunction( elem, context, xml ) {\n\t\t\twhile ( ( elem = elem[ dir ] ) ) {\n\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\treturn matcher( elem, context, xml );\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t} :\n\n\t\t// Check against all ancestor/preceding elements\n\t\tfunction( elem, context, xml ) {\n\t\t\tvar oldCache, uniqueCache, outerCache,\n\t\t\t\tnewCache = [ dirruns, doneName ];\n\n\t\t\t// We can't set arbitrary data on XML nodes, so they don't benefit from combinator caching\n\t\t\tif ( xml ) {\n\t\t\t\twhile ( ( elem = elem[ dir ] ) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\t\tif ( matcher( elem, context, xml ) ) {\n\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\twhile ( ( elem = elem[ dir ] ) ) {\n\t\t\t\t\tif ( elem.nodeType === 1 || checkNonElements ) {\n\t\t\t\t\t\touterCache = elem[ expando ] || ( elem[ expando ] = {} );\n\n\t\t\t\t\t\t// Support: IE <9 only\n\t\t\t\t\t\t// Defend against cloned attroperties (jQuery gh-1709)\n\t\t\t\t\t\tuniqueCache = outerCache[ elem.uniqueID ] ||\n\t\t\t\t\t\t\t( outerCache[ elem.uniqueID ] = {} );\n\n\t\t\t\t\t\tif ( skip && skip === elem.nodeName.toLowerCase() ) {\n\t\t\t\t\t\t\telem = elem[ dir ] || elem;\n\t\t\t\t\t\t} else if ( ( oldCache = uniqueCache[ key ] ) &&\n\t\t\t\t\t\t\toldCache[ 0 ] === dirruns && oldCache[ 1 ] === doneName ) {\n\n\t\t\t\t\t\t\t// Assign to newCache so results back-propagate to previous elements\n\t\t\t\t\t\t\treturn ( newCache[ 2 ] = oldCache[ 2 ] );\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t// Reuse newcache so results back-propagate to previous elements\n\t\t\t\t\t\t\tuniqueCache[ key ] = newCache;\n\n\t\t\t\t\t\t\t// A match means we're done; a fail means we have to keep checking\n\t\t\t\t\t\t\tif ( ( newCache[ 2 ] = matcher( elem, context, xml ) ) ) {\n\t\t\t\t\t\t\t\treturn true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn false;\n\t\t};\n}\n\nfunction elementMatcher( matchers ) {\n\treturn matchers.length > 1 ?\n\t\tfunction( elem, context, xml ) {\n\t\t\tvar i = matchers.length;\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( !matchers[ i ]( elem, context, xml ) ) {\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn true;\n\t\t} :\n\t\tmatchers[ 0 ];\n}\n\nfunction multipleContexts( selector, contexts, results ) {\n\tvar i = 0,\n\t\tlen = contexts.length;\n\tfor ( ; i < len; i++ ) {\n\t\tSizzle( selector, contexts[ i ], results );\n\t}\n\treturn results;\n}\n\nfunction condense( unmatched, map, filter, context, xml ) {\n\tvar elem,\n\t\tnewUnmatched = [],\n\t\ti = 0,\n\t\tlen = unmatched.length,\n\t\tmapped = map != null;\n\n\tfor ( ; i < len; i++ ) {\n\t\tif ( ( elem = unmatched[ i ] ) ) {\n\t\t\tif ( !filter || filter( elem, context, xml ) ) {\n\t\t\t\tnewUnmatched.push( elem );\n\t\t\t\tif ( mapped ) {\n\t\t\t\t\tmap.push( i );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn newUnmatched;\n}\n\nfunction setMatcher( preFilter, selector, matcher, postFilter, postFinder, postSelector ) {\n\tif ( postFilter && !postFilter[ expando ] ) {\n\t\tpostFilter = setMatcher( postFilter );\n\t}\n\tif ( postFinder && !postFinder[ expando ] ) {\n\t\tpostFinder = setMatcher( postFinder, postSelector );\n\t}\n\treturn markFunction( function( seed, results, context, xml ) {\n\t\tvar temp, i, elem,\n\t\t\tpreMap = [],\n\t\t\tpostMap = [],\n\t\t\tpreexisting = results.length,\n\n\t\t\t// Get initial elements from seed or context\n\t\t\telems = seed || multipleContexts(\n\t\t\t\tselector || \"*\",\n\t\t\t\tcontext.nodeType ? [ context ] : context,\n\t\t\t\t[]\n\t\t\t),\n\n\t\t\t// Prefilter to get matcher input, preserving a map for seed-results synchronization\n\t\t\tmatcherIn = preFilter && ( seed || !selector ) ?\n\t\t\t\tcondense( elems, preMap, preFilter, context, xml ) :\n\t\t\t\telems,\n\n\t\t\tmatcherOut = matcher ?\n\n\t\t\t\t// If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results,\n\t\t\t\tpostFinder || ( seed ? preFilter : preexisting || postFilter ) ?\n\n\t\t\t\t\t// ...intermediate processing is necessary\n\t\t\t\t\t[] :\n\n\t\t\t\t\t// ...otherwise use results directly\n\t\t\t\t\tresults :\n\t\t\t\tmatcherIn;\n\n\t\t// Find primary matches\n\t\tif ( matcher ) {\n\t\t\tmatcher( matcherIn, matcherOut, context, xml );\n\t\t}\n\n\t\t// Apply postFilter\n\t\tif ( postFilter ) {\n\t\t\ttemp = condense( matcherOut, postMap );\n\t\t\tpostFilter( temp, [], context, xml );\n\n\t\t\t// Un-match failing elements by moving them back to matcherIn\n\t\t\ti = temp.length;\n\t\t\twhile ( i-- ) {\n\t\t\t\tif ( ( elem = temp[ i ] ) ) {\n\t\t\t\t\tmatcherOut[ postMap[ i ] ] = !( matcherIn[ postMap[ i ] ] = elem );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif ( seed ) {\n\t\t\tif ( postFinder || preFilter ) {\n\t\t\t\tif ( postFinder ) {\n\n\t\t\t\t\t// Get the final matcherOut by condensing this intermediate into postFinder contexts\n\t\t\t\t\ttemp = [];\n\t\t\t\t\ti = matcherOut.length;\n\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\tif ( ( elem = matcherOut[ i ] ) ) {\n\n\t\t\t\t\t\t\t// Restore matcherIn since elem is not yet a final match\n\t\t\t\t\t\t\ttemp.push( ( matcherIn[ i ] = elem ) );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tpostFinder( null, ( matcherOut = [] ), temp, xml );\n\t\t\t\t}\n\n\t\t\t\t// Move matched elements from seed to results to keep them synchronized\n\t\t\t\ti = matcherOut.length;\n\t\t\t\twhile ( i-- ) {\n\t\t\t\t\tif ( ( elem = matcherOut[ i ] ) &&\n\t\t\t\t\t\t( temp = postFinder ? indexOf( seed, elem ) : preMap[ i ] ) > -1 ) {\n\n\t\t\t\t\t\tseed[ temp ] = !( results[ temp ] = elem );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Add elements to results, through postFinder if defined\n\t\t} else {\n\t\t\tmatcherOut = condense(\n\t\t\t\tmatcherOut === results ?\n\t\t\t\t\tmatcherOut.splice( preexisting, matcherOut.length ) :\n\t\t\t\t\tmatcherOut\n\t\t\t);\n\t\t\tif ( postFinder ) {\n\t\t\t\tpostFinder( null, results, matcherOut, xml );\n\t\t\t} else {\n\t\t\t\tpush.apply( results, matcherOut );\n\t\t\t}\n\t\t}\n\t} );\n}\n\nfunction matcherFromTokens( tokens ) {\n\tvar checkContext, matcher, j,\n\t\tlen = tokens.length,\n\t\tleadingRelative = Expr.relative[ tokens[ 0 ].type ],\n\t\timplicitRelative = leadingRelative || Expr.relative[ \" \" ],\n\t\ti = leadingRelative ? 1 : 0,\n\n\t\t// The foundational matcher ensures that elements are reachable from top-level context(s)\n\t\tmatchContext = addCombinator( function( elem ) {\n\t\t\treturn elem === checkContext;\n\t\t}, implicitRelative, true ),\n\t\tmatchAnyContext = addCombinator( function( elem ) {\n\t\t\treturn indexOf( checkContext, elem ) > -1;\n\t\t}, implicitRelative, true ),\n\t\tmatchers = [ function( elem, context, xml ) {\n\t\t\tvar ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || (\n\t\t\t\t( checkContext = context ).nodeType ?\n\t\t\t\t\tmatchContext( elem, context, xml ) :\n\t\t\t\t\tmatchAnyContext( elem, context, xml ) );\n\n\t\t\t// Avoid hanging onto element (issue #299)\n\t\t\tcheckContext = null;\n\t\t\treturn ret;\n\t\t} ];\n\n\tfor ( ; i < len; i++ ) {\n\t\tif ( ( matcher = Expr.relative[ tokens[ i ].type ] ) ) {\n\t\t\tmatchers = [ addCombinator( elementMatcher( matchers ), matcher ) ];\n\t\t} else {\n\t\t\tmatcher = Expr.filter[ tokens[ i ].type ].apply( null, tokens[ i ].matches );\n\n\t\t\t// Return special upon seeing a positional matcher\n\t\t\tif ( matcher[ expando ] ) {\n\n\t\t\t\t// Find the next relative operator (if any) for proper handling\n\t\t\t\tj = ++i;\n\t\t\t\tfor ( ; j < len; j++ ) {\n\t\t\t\t\tif ( Expr.relative[ tokens[ j ].type ] ) {\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn setMatcher(\n\t\t\t\t\ti > 1 && elementMatcher( matchers ),\n\t\t\t\t\ti > 1 && toSelector(\n\n\t\t\t\t\t// If the preceding token was a descendant combinator, insert an implicit any-element `*`\n\t\t\t\t\ttokens\n\t\t\t\t\t\t.slice( 0, i - 1 )\n\t\t\t\t\t\t.concat( { value: tokens[ i - 2 ].type === \" \" ? \"*\" : \"\" } )\n\t\t\t\t\t).replace( rtrim, \"$1\" ),\n\t\t\t\t\tmatcher,\n\t\t\t\t\ti < j && matcherFromTokens( tokens.slice( i, j ) ),\n\t\t\t\t\tj < len && matcherFromTokens( ( tokens = tokens.slice( j ) ) ),\n\t\t\t\t\tj < len && toSelector( tokens )\n\t\t\t\t);\n\t\t\t}\n\t\t\tmatchers.push( matcher );\n\t\t}\n\t}\n\n\treturn elementMatcher( matchers );\n}\n\nfunction matcherFromGroupMatchers( elementMatchers, setMatchers ) {\n\tvar bySet = setMatchers.length > 0,\n\t\tbyElement = elementMatchers.length > 0,\n\t\tsuperMatcher = function( seed, context, xml, results, outermost ) {\n\t\t\tvar elem, j, matcher,\n\t\t\t\tmatchedCount = 0,\n\t\t\t\ti = \"0\",\n\t\t\t\tunmatched = seed && [],\n\t\t\t\tsetMatched = [],\n\t\t\t\tcontextBackup = outermostContext,\n\n\t\t\t\t// We must always have either seed elements or outermost context\n\t\t\t\telems = seed || byElement && Expr.find[ \"TAG\" ]( \"*\", outermost ),\n\n\t\t\t\t// Use integer dirruns iff this is the outermost matcher\n\t\t\t\tdirrunsUnique = ( dirruns += contextBackup == null ? 1 : Math.random() || 0.1 ),\n\t\t\t\tlen = elems.length;\n\n\t\t\tif ( outermost ) {\n\n\t\t\t\t// Support: IE 11+, Edge 17 - 18+\n\t\t\t\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t\t\t\t// two documents; shallow comparisons work.\n\t\t\t\t// eslint-disable-next-line eqeqeq\n\t\t\t\toutermostContext = context == document || context || outermost;\n\t\t\t}\n\n\t\t\t// Add elements passing elementMatchers directly to results\n\t\t\t// Support: IE<9, Safari\n\t\t\t// Tolerate NodeList properties (IE: \"length\"; Safari: <number>) matching elements by id\n\t\t\tfor ( ; i !== len && ( elem = elems[ i ] ) != null; i++ ) {\n\t\t\t\tif ( byElement && elem ) {\n\t\t\t\t\tj = 0;\n\n\t\t\t\t\t// Support: IE 11+, Edge 17 - 18+\n\t\t\t\t\t// IE/Edge sometimes throw a \"Permission denied\" error when strict-comparing\n\t\t\t\t\t// two documents; shallow comparisons work.\n\t\t\t\t\t// eslint-disable-next-line eqeqeq\n\t\t\t\t\tif ( !context && elem.ownerDocument != document ) {\n\t\t\t\t\t\tsetDocument( elem );\n\t\t\t\t\t\txml = !documentIsHTML;\n\t\t\t\t\t}\n\t\t\t\t\twhile ( ( matcher = elementMatchers[ j++ ] ) ) {\n\t\t\t\t\t\tif ( matcher( elem, context || document, xml ) ) {\n\t\t\t\t\t\t\tresults.push( elem );\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif ( outermost ) {\n\t\t\t\t\t\tdirruns = dirrunsUnique;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Track unmatched elements for set filters\n\t\t\t\tif ( bySet ) {\n\n\t\t\t\t\t// They will have gone through all possible matchers\n\t\t\t\t\tif ( ( elem = !matcher && elem ) ) {\n\t\t\t\t\t\tmatchedCount--;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Lengthen the array for every element, matched or not\n\t\t\t\t\tif ( seed ) {\n\t\t\t\t\t\tunmatched.push( elem );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// `i` is now the count of elements visited above, and adding it to `matchedCount`\n\t\t\t// makes the latter nonnegative.\n\t\t\tmatchedCount += i;\n\n\t\t\t// Apply set filters to unmatched elements\n\t\t\t// NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount`\n\t\t\t// equals `i`), unless we didn't visit _any_ elements in the above loop because we have\n\t\t\t// no element matchers and no seed.\n\t\t\t// Incrementing an initially-string \"0\" `i` allows `i` to remain a string only in that\n\t\t\t// case, which will result in a \"00\" `matchedCount` that differs from `i` but is also\n\t\t\t// numerically zero.\n\t\t\tif ( bySet && i !== matchedCount ) {\n\t\t\t\tj = 0;\n\t\t\t\twhile ( ( matcher = setMatchers[ j++ ] ) ) {\n\t\t\t\t\tmatcher( unmatched, setMatched, context, xml );\n\t\t\t\t}\n\n\t\t\t\tif ( seed ) {\n\n\t\t\t\t\t// Reintegrate element matches to eliminate the need for sorting\n\t\t\t\t\tif ( matchedCount > 0 ) {\n\t\t\t\t\t\twhile ( i-- ) {\n\t\t\t\t\t\t\tif ( !( unmatched[ i ] || setMatched[ i ] ) ) {\n\t\t\t\t\t\t\t\tsetMatched[ i ] = pop.call( results );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Discard index placeholder values to get only actual matches\n\t\t\t\t\tsetMatched = condense( setMatched );\n\t\t\t\t}\n\n\t\t\t\t// Add matches to results\n\t\t\t\tpush.apply( results, setMatched );\n\n\t\t\t\t// Seedless set matches succeeding multiple successful matchers stipulate sorting\n\t\t\t\tif ( outermost && !seed && setMatched.length > 0 &&\n\t\t\t\t\t( matchedCount + setMatchers.length ) > 1 ) {\n\n\t\t\t\t\tSizzle.uniqueSort( results );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Override manipulation of globals by nested matchers\n\t\t\tif ( outermost ) {\n\t\t\t\tdirruns = dirrunsUnique;\n\t\t\t\toutermostContext = contextBackup;\n\t\t\t}\n\n\t\t\treturn unmatched;\n\t\t};\n\n\treturn bySet ?\n\t\tmarkFunction( superMatcher ) :\n\t\tsuperMatcher;\n}\n\ncompile = Sizzle.compile = function( selector, match /* Internal Use Only */ ) {\n\tvar i,\n\t\tsetMatchers = [],\n\t\telementMatchers = [],\n\t\tcached = compilerCache[ selector + \" \" ];\n\n\tif ( !cached ) {\n\n\t\t// Generate a function of recursive functions that can be used to check each element\n\t\tif ( !match ) {\n\t\t\tmatch = tokenize( selector );\n\t\t}\n\t\ti = match.length;\n\t\twhile ( i-- ) {\n\t\t\tcached = matcherFromTokens( match[ i ] );\n\t\t\tif ( cached[ expando ] ) {\n\t\t\t\tsetMatchers.push( cached );\n\t\t\t} else {\n\t\t\t\telementMatchers.push( cached );\n\t\t\t}\n\t\t}\n\n\t\t// Cache the compiled function\n\t\tcached = compilerCache(\n\t\t\tselector,\n\t\t\tmatcherFromGroupMatchers( elementMatchers, setMatchers )\n\t\t);\n\n\t\t// Save selector and tokenization\n\t\tcached.selector = selector;\n\t}\n\treturn cached;\n};\n\n/**\n * A low-level selection function that works with Sizzle's compiled\n * selector functions\n * @param {String|Function} selector A selector or a pre-compiled\n * selector function built with Sizzle.compile\n * @param {Element} context\n * @param {Array} [results]\n * @param {Array} [seed] A set of elements to match against\n */\nselect = Sizzle.select = function( selector, context, results, seed ) {\n\tvar i, tokens, token, type, find,\n\t\tcompiled = typeof selector === \"function\" && selector,\n\t\tmatch = !seed && tokenize( ( selector = compiled.selector || selector ) );\n\n\tresults = results || [];\n\n\t// Try to minimize operations if there is only one selector in the list and no seed\n\t// (the latter of which guarantees us context)\n\tif ( match.length === 1 ) {\n\n\t\t// Reduce context if the leading compound selector is an ID\n\t\ttokens = match[ 0 ] = match[ 0 ].slice( 0 );\n\t\tif ( tokens.length > 2 && ( token = tokens[ 0 ] ).type === \"ID\" &&\n\t\t\tcontext.nodeType === 9 && documentIsHTML && Expr.relative[ tokens[ 1 ].type ] ) {\n\n\t\t\tcontext = ( Expr.find[ \"ID\" ]( token.matches[ 0 ]\n\t\t\t\t.replace( runescape, funescape ), context ) || [] )[ 0 ];\n\t\t\tif ( !context ) {\n\t\t\t\treturn results;\n\n\t\t\t// Precompiled matchers will still verify ancestry, so step up a level\n\t\t\t} else if ( compiled ) {\n\t\t\t\tcontext = context.parentNode;\n\t\t\t}\n\n\t\t\tselector = selector.slice( tokens.shift().value.length );\n\t\t}\n\n\t\t// Fetch a seed set for right-to-left matching\n\t\ti = matchExpr[ \"needsContext\" ].test( selector ) ? 0 : tokens.length;\n\t\twhile ( i-- ) {\n\t\t\ttoken = tokens[ i ];\n\n\t\t\t// Abort if we hit a combinator\n\t\t\tif ( Expr.relative[ ( type = token.type ) ] ) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif ( ( find = Expr.find[ type ] ) ) {\n\n\t\t\t\t// Search, expanding context for leading sibling combinators\n\t\t\t\tif ( ( seed = find(\n\t\t\t\t\ttoken.matches[ 0 ].replace( runescape, funescape ),\n\t\t\t\t\trsibling.test( tokens[ 0 ].type ) && testContext( context.parentNode ) ||\n\t\t\t\t\t\tcontext\n\t\t\t\t) ) ) {\n\n\t\t\t\t\t// If seed is empty or no tokens remain, we can return early\n\t\t\t\t\ttokens.splice( i, 1 );\n\t\t\t\t\tselector = seed.length && toSelector( tokens );\n\t\t\t\t\tif ( !selector ) {\n\t\t\t\t\t\tpush.apply( results, seed );\n\t\t\t\t\t\treturn results;\n\t\t\t\t\t}\n\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Compile and execute a filtering function if one is not provided\n\t// Provide `match` to avoid retokenization if we modified the selector above\n\t( compiled || compile( selector, match ) )(\n\t\tseed,\n\t\tcontext,\n\t\t!documentIsHTML,\n\t\tresults,\n\t\t!context || rsibling.test( selector ) && testContext( context.parentNode ) || context\n\t);\n\treturn results;\n};\n\n// One-time assignments\n\n// Sort stability\nsupport.sortStable = expando.split( \"\" ).sort( sortOrder ).join( \"\" ) === expando;\n\n// Support: Chrome 14-35+\n// Always assume duplicates if they aren't passed to the comparison function\nsupport.detectDuplicates = !!hasDuplicate;\n\n// Initialize against the default document\nsetDocument();\n\n// Support: Webkit<537.32 - Safari 6.0.3/Chrome 25 (fixed in Chrome 27)\n// Detached nodes confoundingly follow *each other*\nsupport.sortDetached = assert( function( el ) {\n\n\t// Should return 1, but returns 4 (following)\n\treturn el.compareDocumentPosition( document.createElement( \"fieldset\" ) ) & 1;\n} );\n\n// Support: IE<8\n// Prevent attribute/property \"interpolation\"\n// https://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx\nif ( !assert( function( el ) {\n\tel.innerHTML = \"<a href='#'></a>\";\n\treturn el.firstChild.getAttribute( \"href\" ) === \"#\";\n} ) ) {\n\taddHandle( \"type|href|height|width\", function( elem, name, isXML ) {\n\t\tif ( !isXML ) {\n\t\t\treturn elem.getAttribute( name, name.toLowerCase() === \"type\" ? 1 : 2 );\n\t\t}\n\t} );\n}\n\n// Support: IE<9\n// Use defaultValue in place of getAttribute(\"value\")\nif ( !support.attributes || !assert( function( el ) {\n\tel.innerHTML = \"<input/>\";\n\tel.firstChild.setAttribute( \"value\", \"\" );\n\treturn el.firstChild.getAttribute( \"value\" ) === \"\";\n} ) ) {\n\taddHandle( \"value\", function( elem, _name, isXML ) {\n\t\tif ( !isXML && elem.nodeName.toLowerCase() === \"input\" ) {\n\t\t\treturn elem.defaultValue;\n\t\t}\n\t} );\n}\n\n// Support: IE<9\n// Use getAttributeNode to fetch booleans when getAttribute lies\nif ( !assert( function( el ) {\n\treturn el.getAttribute( \"disabled\" ) == null;\n} ) ) {\n\taddHandle( booleans, function( elem, name, isXML ) {\n\t\tvar val;\n\t\tif ( !isXML ) {\n\t\t\treturn elem[ name ] === true ? name.toLowerCase() :\n\t\t\t\t( val = elem.getAttributeNode( name ) ) && val.specified ?\n\t\t\t\t\tval.value :\n\t\t\t\t\tnull;\n\t\t}\n\t} );\n}\n\nreturn Sizzle;\n\n} )( window );\n\n\n\njQuery.find = Sizzle;\njQuery.expr = Sizzle.selectors;\n\n// Deprecated\njQuery.expr[ \":\" ] = jQuery.expr.pseudos;\njQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort;\njQuery.text = Sizzle.getText;\njQuery.isXMLDoc = Sizzle.isXML;\njQuery.contains = Sizzle.contains;\njQuery.escapeSelector = Sizzle.escape;\n\n\n\n\nvar dir = function( elem, dir, until ) {\n\tvar matched = [],\n\t\ttruncate = until !== undefined;\n\n\twhile ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) {\n\t\tif ( elem.nodeType === 1 ) {\n\t\t\tif ( truncate && jQuery( elem ).is( until ) ) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tmatched.push( elem );\n\t\t}\n\t}\n\treturn matched;\n};\n\n\nvar siblings = function( n, elem ) {\n\tvar matched = [];\n\n\tfor ( ; n; n = n.nextSibling ) {\n\t\tif ( n.nodeType === 1 && n !== elem ) {\n\t\t\tmatched.push( n );\n\t\t}\n\t}\n\n\treturn matched;\n};\n\n\nvar rneedsContext = jQuery.expr.match.needsContext;\n\n\n\nfunction nodeName( elem, name ) {\n\n return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase();\n\n};\nvar rsingleTag = ( /^<([a-z][^\\/\\0>:\\x20\\t\\r\\n\\f]*)[\\x20\\t\\r\\n\\f]*\\/?>(?:<\\/\\1>|)$/i );\n\n\n\n// Implement the identical functionality for filter and not\nfunction winnow( elements, qualifier, not ) {\n\tif ( isFunction( qualifier ) ) {\n\t\treturn jQuery.grep( elements, function( elem, i ) {\n\t\t\treturn !!qualifier.call( elem, i, elem ) !== not;\n\t\t} );\n\t}\n\n\t// Single element\n\tif ( qualifier.nodeType ) {\n\t\treturn jQuery.grep( elements, function( elem ) {\n\t\t\treturn ( elem === qualifier ) !== not;\n\t\t} );\n\t}\n\n\t// Arraylike of elements (jQuery, arguments, Array)\n\tif ( typeof qualifier !== \"string\" ) {\n\t\treturn jQuery.grep( elements, function( elem ) {\n\t\t\treturn ( indexOf.call( qualifier, elem ) > -1 ) !== not;\n\t\t} );\n\t}\n\n\t// Filtered directly for both simple and complex selectors\n\treturn jQuery.filter( qualifier, elements, not );\n}\n\njQuery.filter = function( expr, elems, not ) {\n\tvar elem = elems[ 0 ];\n\n\tif ( not ) {\n\t\texpr = \":not(\" + expr + \")\";\n\t}\n\n\tif ( elems.length === 1 && elem.nodeType === 1 ) {\n\t\treturn jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [];\n\t}\n\n\treturn jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) {\n\t\treturn elem.nodeType === 1;\n\t} ) );\n};\n\njQuery.fn.extend( {\n\tfind: function( selector ) {\n\t\tvar i, ret,\n\t\t\tlen = this.length,\n\t\t\tself = this;\n\n\t\tif ( typeof selector !== \"string\" ) {\n\t\t\treturn this.pushStack( jQuery( selector ).filter( function() {\n\t\t\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\t\t\tif ( jQuery.contains( self[ i ], this ) ) {\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} ) );\n\t\t}\n\n\t\tret = this.pushStack( [] );\n\n\t\tfor ( i = 0; i < len; i++ ) {\n\t\t\tjQuery.find( selector, self[ i ], ret );\n\t\t}\n\n\t\treturn len > 1 ? jQuery.uniqueSort( ret ) : ret;\n\t},\n\tfilter: function( selector ) {\n\t\treturn this.pushStack( winnow( this, selector || [], false ) );\n\t},\n\tnot: function( selector ) {\n\t\treturn this.pushStack( winnow( this, selector || [], true ) );\n\t},\n\tis: function( selector ) {\n\t\treturn !!winnow(\n\t\t\tthis,\n\n\t\t\t// If this is a positional/relative selector, check membership in the returned set\n\t\t\t// so $(\"p:first\").is(\"p:last\") won't return true for a doc with two \"p\".\n\t\t\ttypeof selector === \"string\" && rneedsContext.test( selector ) ?\n\t\t\t\tjQuery( selector ) :\n\t\t\t\tselector || [],\n\t\t\tfalse\n\t\t).length;\n\t}\n} );\n\n\n// Initialize a jQuery object\n\n\n// A central reference to the root jQuery(document)\nvar rootjQuery,\n\n\t// A simple way to check for HTML strings\n\t// Prioritize #id over <tag> to avoid XSS via location.hash (#9521)\n\t// Strict HTML recognition (#11290: must start with <)\n\t// Shortcut simple #id case for speed\n\trquickExpr = /^(?:\\s*(<[\\w\\W]+>)[^>]*|#([\\w-]+))$/,\n\n\tinit = jQuery.fn.init = function( selector, context, root ) {\n\t\tvar match, elem;\n\n\t\t// HANDLE: $(\"\"), $(null), $(undefined), $(false)\n\t\tif ( !selector ) {\n\t\t\treturn this;\n\t\t}\n\n\t\t// Method init() accepts an alternate rootjQuery\n\t\t// so migrate can support jQuery.sub (gh-2101)\n\t\troot = root || rootjQuery;\n\n\t\t// Handle HTML strings\n\t\tif ( typeof selector === \"string\" ) {\n\t\t\tif ( selector[ 0 ] === \"<\" &&\n\t\t\t\tselector[ selector.length - 1 ] === \">\" &&\n\t\t\t\tselector.length >= 3 ) {\n\n\t\t\t\t// Assume that strings that start and end with <> are HTML and skip the regex check\n\t\t\t\tmatch = [ null, selector, null ];\n\n\t\t\t} else {\n\t\t\t\tmatch = rquickExpr.exec( selector );\n\t\t\t}\n\n\t\t\t// Match html or make sure no context is specified for #id\n\t\t\tif ( match && ( match[ 1 ] || !context ) ) {\n\n\t\t\t\t// HANDLE: $(html) -> $(array)\n\t\t\t\tif ( match[ 1 ] ) {\n\t\t\t\t\tcontext = context instanceof jQuery ? context[ 0 ] : context;\n\n\t\t\t\t\t// Option to run scripts is true for back-compat\n\t\t\t\t\t// Intentionally let the error be thrown if parseHTML is not present\n\t\t\t\t\tjQuery.merge( this, jQuery.parseHTML(\n\t\t\t\t\t\tmatch[ 1 ],\n\t\t\t\t\t\tcontext && context.nodeType ? context.ownerDocument || context : document,\n\t\t\t\t\t\ttrue\n\t\t\t\t\t) );\n\n\t\t\t\t\t// HANDLE: $(html, props)\n\t\t\t\t\tif ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) {\n\t\t\t\t\t\tfor ( match in context ) {\n\n\t\t\t\t\t\t\t// Properties of context are called as methods if possible\n\t\t\t\t\t\t\tif ( isFunction( this[ match ] ) ) {\n\t\t\t\t\t\t\t\tthis[ match ]( context[ match ] );\n\n\t\t\t\t\t\t\t// ...and otherwise set as attributes\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tthis.attr( match, context[ match ] );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\treturn this;\n\n\t\t\t\t// HANDLE: $(#id)\n\t\t\t\t} else {\n\t\t\t\t\telem = document.getElementById( match[ 2 ] );\n\n\t\t\t\t\tif ( elem ) {\n\n\t\t\t\t\t\t// Inject the element directly into the jQuery object\n\t\t\t\t\t\tthis[ 0 ] = elem;\n\t\t\t\t\t\tthis.length = 1;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\n\t\t\t// HANDLE: $(expr, $(...))\n\t\t\t} else if ( !context || context.jquery ) {\n\t\t\t\treturn ( context || root ).find( selector );\n\n\t\t\t// HANDLE: $(expr, context)\n\t\t\t// (which is just equivalent to: $(context).find(expr)\n\t\t\t} else {\n\t\t\t\treturn this.constructor( context ).find( selector );\n\t\t\t}\n\n\t\t// HANDLE: $(DOMElement)\n\t\t} else if ( selector.nodeType ) {\n\t\t\tthis[ 0 ] = selector;\n\t\t\tthis.length = 1;\n\t\t\treturn this;\n\n\t\t// HANDLE: $(function)\n\t\t// Shortcut for document ready\n\t\t} else if ( isFunction( selector ) ) {\n\t\t\treturn root.ready !== undefined ?\n\t\t\t\troot.ready( selector ) :\n\n\t\t\t\t// Execute immediately if ready is not present\n\t\t\t\tselector( jQuery );\n\t\t}\n\n\t\treturn jQuery.makeArray( selector, this );\n\t};\n\n// Give the init function the jQuery prototype for later instantiation\ninit.prototype = jQuery.fn;\n\n// Initialize central reference\nrootjQuery = jQuery( document );\n\n\nvar rparentsprev = /^(?:parents|prev(?:Until|All))/,\n\n\t// Methods guaranteed to produce a unique set when starting from a unique set\n\tguaranteedUnique = {\n\t\tchildren: true,\n\t\tcontents: true,\n\t\tnext: true,\n\t\tprev: true\n\t};\n\njQuery.fn.extend( {\n\thas: function( target ) {\n\t\tvar targets = jQuery( target, this ),\n\t\t\tl = targets.length;\n\n\t\treturn this.filter( function() {\n\t\t\tvar i = 0;\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tif ( jQuery.contains( this, targets[ i ] ) ) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t},\n\n\tclosest: function( selectors, context ) {\n\t\tvar cur,\n\t\t\ti = 0,\n\t\t\tl = this.length,\n\t\t\tmatched = [],\n\t\t\ttargets = typeof selectors !== \"string\" && jQuery( selectors );\n\n\t\t// Positional selectors never match, since there's no _selection_ context\n\t\tif ( !rneedsContext.test( selectors ) ) {\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tfor ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) {\n\n\t\t\t\t\t// Always skip document fragments\n\t\t\t\t\tif ( cur.nodeType < 11 && ( targets ?\n\t\t\t\t\t\ttargets.index( cur ) > -1 :\n\n\t\t\t\t\t\t// Don't pass non-elements to Sizzle\n\t\t\t\t\t\tcur.nodeType === 1 &&\n\t\t\t\t\t\t\tjQuery.find.matchesSelector( cur, selectors ) ) ) {\n\n\t\t\t\t\t\tmatched.push( cur );\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this.pushStack( matched.length > 1 ? jQuery.uniqueSort( matched ) : matched );\n\t},\n\n\t// Determine the position of an element within the set\n\tindex: function( elem ) {\n\n\t\t// No argument, return index in parent\n\t\tif ( !elem ) {\n\t\t\treturn ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1;\n\t\t}\n\n\t\t// Index in selector\n\t\tif ( typeof elem === \"string\" ) {\n\t\t\treturn indexOf.call( jQuery( elem ), this[ 0 ] );\n\t\t}\n\n\t\t// Locate the position of the desired element\n\t\treturn indexOf.call( this,\n\n\t\t\t// If it receives a jQuery object, the first element is used\n\t\t\telem.jquery ? elem[ 0 ] : elem\n\t\t);\n\t},\n\n\tadd: function( selector, context ) {\n\t\treturn this.pushStack(\n\t\t\tjQuery.uniqueSort(\n\t\t\t\tjQuery.merge( this.get(), jQuery( selector, context ) )\n\t\t\t)\n\t\t);\n\t},\n\n\taddBack: function( selector ) {\n\t\treturn this.add( selector == null ?\n\t\t\tthis.prevObject : this.prevObject.filter( selector )\n\t\t);\n\t}\n} );\n\nfunction sibling( cur, dir ) {\n\twhile ( ( cur = cur[ dir ] ) && cur.nodeType !== 1 ) {}\n\treturn cur;\n}\n\njQuery.each( {\n\tparent: function( elem ) {\n\t\tvar parent = elem.parentNode;\n\t\treturn parent && parent.nodeType !== 11 ? parent : null;\n\t},\n\tparents: function( elem ) {\n\t\treturn dir( elem, \"parentNode\" );\n\t},\n\tparentsUntil: function( elem, _i, until ) {\n\t\treturn dir( elem, \"parentNode\", until );\n\t},\n\tnext: function( elem ) {\n\t\treturn sibling( elem, \"nextSibling\" );\n\t},\n\tprev: function( elem ) {\n\t\treturn sibling( elem, \"previousSibling\" );\n\t},\n\tnextAll: function( elem ) {\n\t\treturn dir( elem, \"nextSibling\" );\n\t},\n\tprevAll: function( elem ) {\n\t\treturn dir( elem, \"previousSibling\" );\n\t},\n\tnextUntil: function( elem, _i, until ) {\n\t\treturn dir( elem, \"nextSibling\", until );\n\t},\n\tprevUntil: function( elem, _i, until ) {\n\t\treturn dir( elem, \"previousSibling\", until );\n\t},\n\tsiblings: function( elem ) {\n\t\treturn siblings( ( elem.parentNode || {} ).firstChild, elem );\n\t},\n\tchildren: function( elem ) {\n\t\treturn siblings( elem.firstChild );\n\t},\n\tcontents: function( elem ) {\n\t\tif ( elem.contentDocument != null &&\n\n\t\t\t// Support: IE 11+\n\t\t\t// <object> elements with no `data` attribute has an object\n\t\t\t// `contentDocument` with a `null` prototype.\n\t\t\tgetProto( elem.contentDocument ) ) {\n\n\t\t\treturn elem.contentDocument;\n\t\t}\n\n\t\t// Support: IE 9 - 11 only, iOS 7 only, Android Browser <=4.3 only\n\t\t// Treat the template element as a regular one in browsers that\n\t\t// don't support it.\n\t\tif ( nodeName( elem, \"template\" ) ) {\n\t\t\telem = elem.content || elem;\n\t\t}\n\n\t\treturn jQuery.merge( [], elem.childNodes );\n\t}\n}, function( name, fn ) {\n\tjQuery.fn[ name ] = function( until, selector ) {\n\t\tvar matched = jQuery.map( this, fn, until );\n\n\t\tif ( name.slice( -5 ) !== \"Until\" ) {\n\t\t\tselector = until;\n\t\t}\n\n\t\tif ( selector && typeof selector === \"string\" ) {\n\t\t\tmatched = jQuery.filter( selector, matched );\n\t\t}\n\n\t\tif ( this.length > 1 ) {\n\n\t\t\t// Remove duplicates\n\t\t\tif ( !guaranteedUnique[ name ] ) {\n\t\t\t\tjQuery.uniqueSort( matched );\n\t\t\t}\n\n\t\t\t// Reverse order for parents* and prev-derivatives\n\t\t\tif ( rparentsprev.test( name ) ) {\n\t\t\t\tmatched.reverse();\n\t\t\t}\n\t\t}\n\n\t\treturn this.pushStack( matched );\n\t};\n} );\nvar rnothtmlwhite = ( /[^\\x20\\t\\r\\n\\f]+/g );\n\n\n\n// Convert String-formatted options into Object-formatted ones\nfunction createOptions( options ) {\n\tvar object = {};\n\tjQuery.each( options.match( rnothtmlwhite ) || [], function( _, flag ) {\n\t\tobject[ flag ] = true;\n\t} );\n\treturn object;\n}\n\n/*\n * Create a callback list using the following parameters:\n *\n *\toptions: an optional list of space-separated options that will change how\n *\t\t\tthe callback list behaves or a more traditional option object\n *\n * By default a callback list will act like an event callback list and can be\n * \"fired\" multiple times.\n *\n * Possible options:\n *\n *\tonce:\t\t\twill ensure the callback list can only be fired once (like a Deferred)\n *\n *\tmemory:\t\t\twill keep track of previous values and will call any callback added\n *\t\t\t\t\tafter the list has been fired right away with the latest \"memorized\"\n *\t\t\t\t\tvalues (like a Deferred)\n *\n *\tunique:\t\t\twill ensure a callback can only be added once (no duplicate in the list)\n *\n *\tstopOnFalse:\tinterrupt callings when a callback returns false\n *\n */\njQuery.Callbacks = function( options ) {\n\n\t// Convert options from String-formatted to Object-formatted if needed\n\t// (we check in cache first)\n\toptions = typeof options === \"string\" ?\n\t\tcreateOptions( options ) :\n\t\tjQuery.extend( {}, options );\n\n\tvar // Flag to know if list is currently firing\n\t\tfiring,\n\n\t\t// Last fire value for non-forgettable lists\n\t\tmemory,\n\n\t\t// Flag to know if list was already fired\n\t\tfired,\n\n\t\t// Flag to prevent firing\n\t\tlocked,\n\n\t\t// Actual callback list\n\t\tlist = [],\n\n\t\t// Queue of execution data for repeatable lists\n\t\tqueue = [],\n\n\t\t// Index of currently firing callback (modified by add/remove as needed)\n\t\tfiringIndex = -1,\n\n\t\t// Fire callbacks\n\t\tfire = function() {\n\n\t\t\t// Enforce single-firing\n\t\t\tlocked = locked || options.once;\n\n\t\t\t// Execute callbacks for all pending executions,\n\t\t\t// respecting firingIndex overrides and runtime changes\n\t\t\tfired = firing = true;\n\t\t\tfor ( ; queue.length; firingIndex = -1 ) {\n\t\t\t\tmemory = queue.shift();\n\t\t\t\twhile ( ++firingIndex < list.length ) {\n\n\t\t\t\t\t// Run callback and check for early termination\n\t\t\t\t\tif ( list[ firingIndex ].apply( memory[ 0 ], memory[ 1 ] ) === false &&\n\t\t\t\t\t\toptions.stopOnFalse ) {\n\n\t\t\t\t\t\t// Jump to end and forget the data so .add doesn't re-fire\n\t\t\t\t\t\tfiringIndex = list.length;\n\t\t\t\t\t\tmemory = false;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Forget the data if we're done with it\n\t\t\tif ( !options.memory ) {\n\t\t\t\tmemory = false;\n\t\t\t}\n\n\t\t\tfiring = false;\n\n\t\t\t// Clean up if we're done firing for good\n\t\t\tif ( locked ) {\n\n\t\t\t\t// Keep an empty list if we have data for future add calls\n\t\t\t\tif ( memory ) {\n\t\t\t\t\tlist = [];\n\n\t\t\t\t// Otherwise, this object is spent\n\t\t\t\t} else {\n\t\t\t\t\tlist = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\n\t\t// Actual Callbacks object\n\t\tself = {\n\n\t\t\t// Add a callback or a collection of callbacks to the list\n\t\t\tadd: function() {\n\t\t\t\tif ( list ) {\n\n\t\t\t\t\t// If we have memory from a past run, we should fire after adding\n\t\t\t\t\tif ( memory && !firing ) {\n\t\t\t\t\t\tfiringIndex = list.length - 1;\n\t\t\t\t\t\tqueue.push( memory );\n\t\t\t\t\t}\n\n\t\t\t\t\t( function add( args ) {\n\t\t\t\t\t\tjQuery.each( args, function( _, arg ) {\n\t\t\t\t\t\t\tif ( isFunction( arg ) ) {\n\t\t\t\t\t\t\t\tif ( !options.unique || !self.has( arg ) ) {\n\t\t\t\t\t\t\t\t\tlist.push( arg );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else if ( arg && arg.length && toType( arg ) !== \"string\" ) {\n\n\t\t\t\t\t\t\t\t// Inspect recursively\n\t\t\t\t\t\t\t\tadd( arg );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} );\n\t\t\t\t\t} )( arguments );\n\n\t\t\t\t\tif ( memory && !firing ) {\n\t\t\t\t\t\tfire();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Remove a callback from the list\n\t\t\tremove: function() {\n\t\t\t\tjQuery.each( arguments, function( _, arg ) {\n\t\t\t\t\tvar index;\n\t\t\t\t\twhile ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) {\n\t\t\t\t\t\tlist.splice( index, 1 );\n\n\t\t\t\t\t\t// Handle firing indexes\n\t\t\t\t\t\tif ( index <= firingIndex ) {\n\t\t\t\t\t\t\tfiringIndex--;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Check if a given callback is in the list.\n\t\t\t// If no argument is given, return whether or not list has callbacks attached.\n\t\t\thas: function( fn ) {\n\t\t\t\treturn fn ?\n\t\t\t\t\tjQuery.inArray( fn, list ) > -1 :\n\t\t\t\t\tlist.length > 0;\n\t\t\t},\n\n\t\t\t// Remove all callbacks from the list\n\t\t\tempty: function() {\n\t\t\t\tif ( list ) {\n\t\t\t\t\tlist = [];\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Disable .fire and .add\n\t\t\t// Abort any current/pending executions\n\t\t\t// Clear all callbacks and values\n\t\t\tdisable: function() {\n\t\t\t\tlocked = queue = [];\n\t\t\t\tlist = memory = \"\";\n\t\t\t\treturn this;\n\t\t\t},\n\t\t\tdisabled: function() {\n\t\t\t\treturn !list;\n\t\t\t},\n\n\t\t\t// Disable .fire\n\t\t\t// Also disable .add unless we have memory (since it would have no effect)\n\t\t\t// Abort any pending executions\n\t\t\tlock: function() {\n\t\t\t\tlocked = queue = [];\n\t\t\t\tif ( !memory && !firing ) {\n\t\t\t\t\tlist = memory = \"\";\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\t\t\tlocked: function() {\n\t\t\t\treturn !!locked;\n\t\t\t},\n\n\t\t\t// Call all callbacks with the given context and arguments\n\t\t\tfireWith: function( context, args ) {\n\t\t\t\tif ( !locked ) {\n\t\t\t\t\targs = args || [];\n\t\t\t\t\targs = [ context, args.slice ? args.slice() : args ];\n\t\t\t\t\tqueue.push( args );\n\t\t\t\t\tif ( !firing ) {\n\t\t\t\t\t\tfire();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// Call all the callbacks with the given arguments\n\t\t\tfire: function() {\n\t\t\t\tself.fireWith( this, arguments );\n\t\t\t\treturn this;\n\t\t\t},\n\n\t\t\t// To know if the callbacks have already been called at least once\n\t\t\tfired: function() {\n\t\t\t\treturn !!fired;\n\t\t\t}\n\t\t};\n\n\treturn self;\n};\n\n\nfunction Identity( v ) {\n\treturn v;\n}\nfunction Thrower( ex ) {\n\tthrow ex;\n}\n\nfunction adoptValue( value, resolve, reject, noValue ) {\n\tvar method;\n\n\ttry {\n\n\t\t// Check for promise aspect first to privilege synchronous behavior\n\t\tif ( value && isFunction( ( method = value.promise ) ) ) {\n\t\t\tmethod.call( value ).done( resolve ).fail( reject );\n\n\t\t// Other thenables\n\t\t} else if ( value && isFunction( ( method = value.then ) ) ) {\n\t\t\tmethod.call( value, resolve, reject );\n\n\t\t// Other non-thenables\n\t\t} else {\n\n\t\t\t// Control `resolve` arguments by letting Array#slice cast boolean `noValue` to integer:\n\t\t\t// * false: [ value ].slice( 0 ) => resolve( value )\n\t\t\t// * true: [ value ].slice( 1 ) => resolve()\n\t\t\tresolve.apply( undefined, [ value ].slice( noValue ) );\n\t\t}\n\n\t// For Promises/A+, convert exceptions into rejections\n\t// Since jQuery.when doesn't unwrap thenables, we can skip the extra checks appearing in\n\t// Deferred#then to conditionally suppress rejection.\n\t} catch ( value ) {\n\n\t\t// Support: Android 4.0 only\n\t\t// Strict mode functions invoked without .call/.apply get global-object context\n\t\treject.apply( undefined, [ value ] );\n\t}\n}\n\njQuery.extend( {\n\n\tDeferred: function( func ) {\n\t\tvar tuples = [\n\n\t\t\t\t// action, add listener, callbacks,\n\t\t\t\t// ... .then handlers, argument index, [final state]\n\t\t\t\t[ \"notify\", \"progress\", jQuery.Callbacks( \"memory\" ),\n\t\t\t\t\tjQuery.Callbacks( \"memory\" ), 2 ],\n\t\t\t\t[ \"resolve\", \"done\", jQuery.Callbacks( \"once memory\" ),\n\t\t\t\t\tjQuery.Callbacks( \"once memory\" ), 0, \"resolved\" ],\n\t\t\t\t[ \"reject\", \"fail\", jQuery.Callbacks( \"once memory\" ),\n\t\t\t\t\tjQuery.Callbacks( \"once memory\" ), 1, \"rejected\" ]\n\t\t\t],\n\t\t\tstate = \"pending\",\n\t\t\tpromise = {\n\t\t\t\tstate: function() {\n\t\t\t\t\treturn state;\n\t\t\t\t},\n\t\t\t\talways: function() {\n\t\t\t\t\tdeferred.done( arguments ).fail( arguments );\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\t\t\t\t\"catch\": function( fn ) {\n\t\t\t\t\treturn promise.then( null, fn );\n\t\t\t\t},\n\n\t\t\t\t// Keep pipe for back-compat\n\t\t\t\tpipe: function( /* fnDone, fnFail, fnProgress */ ) {\n\t\t\t\t\tvar fns = arguments;\n\n\t\t\t\t\treturn jQuery.Deferred( function( newDefer ) {\n\t\t\t\t\t\tjQuery.each( tuples, function( _i, tuple ) {\n\n\t\t\t\t\t\t\t// Map tuples (progress, done, fail) to arguments (done, fail, progress)\n\t\t\t\t\t\t\tvar fn = isFunction( fns[ tuple[ 4 ] ] ) && fns[ tuple[ 4 ] ];\n\n\t\t\t\t\t\t\t// deferred.progress(function() { bind to newDefer or newDefer.notify })\n\t\t\t\t\t\t\t// deferred.done(function() { bind to newDefer or newDefer.resolve })\n\t\t\t\t\t\t\t// deferred.fail(function() { bind to newDefer or newDefer.reject })\n\t\t\t\t\t\t\tdeferred[ tuple[ 1 ] ]( function() {\n\t\t\t\t\t\t\t\tvar returned = fn && fn.apply( this, arguments );\n\t\t\t\t\t\t\t\tif ( returned && isFunction( returned.promise ) ) {\n\t\t\t\t\t\t\t\t\treturned.promise()\n\t\t\t\t\t\t\t\t\t\t.progress( newDefer.notify )\n\t\t\t\t\t\t\t\t\t\t.done( newDefer.resolve )\n\t\t\t\t\t\t\t\t\t\t.fail( newDefer.reject );\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tnewDefer[ tuple[ 0 ] + \"With\" ](\n\t\t\t\t\t\t\t\t\t\tthis,\n\t\t\t\t\t\t\t\t\t\tfn ? [ returned ] : arguments\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t} );\n\t\t\t\t\t\tfns = null;\n\t\t\t\t\t} ).promise();\n\t\t\t\t},\n\t\t\t\tthen: function( onFulfilled, onRejected, onProgress ) {\n\t\t\t\t\tvar maxDepth = 0;\n\t\t\t\t\tfunction resolve( depth, deferred, handler, special ) {\n\t\t\t\t\t\treturn function() {\n\t\t\t\t\t\t\tvar that = this,\n\t\t\t\t\t\t\t\targs = arguments,\n\t\t\t\t\t\t\t\tmightThrow = function() {\n\t\t\t\t\t\t\t\t\tvar returned, then;\n\n\t\t\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.3.3.3\n\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-59\n\t\t\t\t\t\t\t\t\t// Ignore double-resolution attempts\n\t\t\t\t\t\t\t\t\tif ( depth < maxDepth ) {\n\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\treturned = handler.apply( that, args );\n\n\t\t\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.1\n\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-48\n\t\t\t\t\t\t\t\t\tif ( returned === deferred.promise() ) {\n\t\t\t\t\t\t\t\t\t\tthrow new TypeError( \"Thenable self-resolution\" );\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t// Support: Promises/A+ sections 2.3.3.1, 3.5\n\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-54\n\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-75\n\t\t\t\t\t\t\t\t\t// Retrieve `then` only once\n\t\t\t\t\t\t\t\t\tthen = returned &&\n\n\t\t\t\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.4\n\t\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-64\n\t\t\t\t\t\t\t\t\t\t// Only check objects and functions for thenability\n\t\t\t\t\t\t\t\t\t\t( typeof returned === \"object\" ||\n\t\t\t\t\t\t\t\t\t\t\ttypeof returned === \"function\" ) &&\n\t\t\t\t\t\t\t\t\t\treturned.then;\n\n\t\t\t\t\t\t\t\t\t// Handle a returned thenable\n\t\t\t\t\t\t\t\t\tif ( isFunction( then ) ) {\n\n\t\t\t\t\t\t\t\t\t\t// Special processors (notify) just wait for resolution\n\t\t\t\t\t\t\t\t\t\tif ( special ) {\n\t\t\t\t\t\t\t\t\t\t\tthen.call(\n\t\t\t\t\t\t\t\t\t\t\t\treturned,\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Identity, special ),\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Thrower, special )\n\t\t\t\t\t\t\t\t\t\t\t);\n\n\t\t\t\t\t\t\t\t\t\t// Normal processors (resolve) also hook into progress\n\t\t\t\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t\t\t\t// ...and disregard older resolution values\n\t\t\t\t\t\t\t\t\t\t\tmaxDepth++;\n\n\t\t\t\t\t\t\t\t\t\t\tthen.call(\n\t\t\t\t\t\t\t\t\t\t\t\treturned,\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Identity, special ),\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Thrower, special ),\n\t\t\t\t\t\t\t\t\t\t\t\tresolve( maxDepth, deferred, Identity,\n\t\t\t\t\t\t\t\t\t\t\t\t\tdeferred.notifyWith )\n\t\t\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t// Handle all other returned values\n\t\t\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t\t\t// Only substitute handlers pass on context\n\t\t\t\t\t\t\t\t\t\t// and multiple values (non-spec behavior)\n\t\t\t\t\t\t\t\t\t\tif ( handler !== Identity ) {\n\t\t\t\t\t\t\t\t\t\t\tthat = undefined;\n\t\t\t\t\t\t\t\t\t\t\targs = [ returned ];\n\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t// Process the value(s)\n\t\t\t\t\t\t\t\t\t\t// Default process is resolve\n\t\t\t\t\t\t\t\t\t\t( special || deferred.resolveWith )( that, args );\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t},\n\n\t\t\t\t\t\t\t\t// Only normal processors (resolve) catch and reject exceptions\n\t\t\t\t\t\t\t\tprocess = special ?\n\t\t\t\t\t\t\t\t\tmightThrow :\n\t\t\t\t\t\t\t\t\tfunction() {\n\t\t\t\t\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\t\t\t\t\tmightThrow();\n\t\t\t\t\t\t\t\t\t\t} catch ( e ) {\n\n\t\t\t\t\t\t\t\t\t\t\tif ( jQuery.Deferred.exceptionHook ) {\n\t\t\t\t\t\t\t\t\t\t\t\tjQuery.Deferred.exceptionHook( e,\n\t\t\t\t\t\t\t\t\t\t\t\t\tprocess.stackTrace );\n\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.3.3.4.1\n\t\t\t\t\t\t\t\t\t\t\t// https://promisesaplus.com/#point-61\n\t\t\t\t\t\t\t\t\t\t\t// Ignore post-resolution exceptions\n\t\t\t\t\t\t\t\t\t\t\tif ( depth + 1 >= maxDepth ) {\n\n\t\t\t\t\t\t\t\t\t\t\t\t// Only substitute handlers pass on context\n\t\t\t\t\t\t\t\t\t\t\t\t// and multiple values (non-spec behavior)\n\t\t\t\t\t\t\t\t\t\t\t\tif ( handler !== Thrower ) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tthat = undefined;\n\t\t\t\t\t\t\t\t\t\t\t\t\targs = [ e ];\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\tdeferred.rejectWith( that, args );\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t};\n\n\t\t\t\t\t\t\t// Support: Promises/A+ section 2.3.3.3.1\n\t\t\t\t\t\t\t// https://promisesaplus.com/#point-57\n\t\t\t\t\t\t\t// Re-resolve promises immediately to dodge false rejection from\n\t\t\t\t\t\t\t// subsequent errors\n\t\t\t\t\t\t\tif ( depth ) {\n\t\t\t\t\t\t\t\tprocess();\n\t\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t\t// Call an optional hook to record the stack, in case of exception\n\t\t\t\t\t\t\t\t// since it's otherwise lost when execution goes async\n\t\t\t\t\t\t\t\tif ( jQuery.Deferred.getStackHook ) {\n\t\t\t\t\t\t\t\t\tprocess.stackTrace = jQuery.Deferred.getStackHook();\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\twindow.setTimeout( process );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\n\t\t\t\t\treturn jQuery.Deferred( function( newDefer ) {\n\n\t\t\t\t\t\t// progress_handlers.add( ... )\n\t\t\t\t\t\ttuples[ 0 ][ 3 ].add(\n\t\t\t\t\t\t\tresolve(\n\t\t\t\t\t\t\t\t0,\n\t\t\t\t\t\t\t\tnewDefer,\n\t\t\t\t\t\t\t\tisFunction( onProgress ) ?\n\t\t\t\t\t\t\t\t\tonProgress :\n\t\t\t\t\t\t\t\t\tIdentity,\n\t\t\t\t\t\t\t\tnewDefer.notifyWith\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// fulfilled_handlers.add( ... )\n\t\t\t\t\t\ttuples[ 1 ][ 3 ].add(\n\t\t\t\t\t\t\tresolve(\n\t\t\t\t\t\t\t\t0,\n\t\t\t\t\t\t\t\tnewDefer,\n\t\t\t\t\t\t\t\tisFunction( onFulfilled ) ?\n\t\t\t\t\t\t\t\t\tonFulfilled :\n\t\t\t\t\t\t\t\t\tIdentity\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// rejected_handlers.add( ... )\n\t\t\t\t\t\ttuples[ 2 ][ 3 ].add(\n\t\t\t\t\t\t\tresolve(\n\t\t\t\t\t\t\t\t0,\n\t\t\t\t\t\t\t\tnewDefer,\n\t\t\t\t\t\t\t\tisFunction( onRejected ) ?\n\t\t\t\t\t\t\t\t\tonRejected :\n\t\t\t\t\t\t\t\t\tThrower\n\t\t\t\t\t\t\t)\n\t\t\t\t\t\t);\n\t\t\t\t\t} ).promise();\n\t\t\t\t},\n\n\t\t\t\t// Get a promise for this deferred\n\t\t\t\t// If obj is provided, the promise aspect is added to the object\n\t\t\t\tpromise: function( obj ) {\n\t\t\t\t\treturn obj != null ? jQuery.extend( obj, promise ) : promise;\n\t\t\t\t}\n\t\t\t},\n\t\t\tdeferred = {};\n\n\t\t// Add list-specific methods\n\t\tjQuery.each( tuples, function( i, tuple ) {\n\t\t\tvar list = tuple[ 2 ],\n\t\t\t\tstateString = tuple[ 5 ];\n\n\t\t\t// promise.progress = list.add\n\t\t\t// promise.done = list.add\n\t\t\t// promise.fail = list.add\n\t\t\tpromise[ tuple[ 1 ] ] = list.add;\n\n\t\t\t// Handle state\n\t\t\tif ( stateString ) {\n\t\t\t\tlist.add(\n\t\t\t\t\tfunction() {\n\n\t\t\t\t\t\t// state = \"resolved\" (i.e., fulfilled)\n\t\t\t\t\t\t// state = \"rejected\"\n\t\t\t\t\t\tstate = stateString;\n\t\t\t\t\t},\n\n\t\t\t\t\t// rejected_callbacks.disable\n\t\t\t\t\t// fulfilled_callbacks.disable\n\t\t\t\t\ttuples[ 3 - i ][ 2 ].disable,\n\n\t\t\t\t\t// rejected_handlers.disable\n\t\t\t\t\t// fulfilled_handlers.disable\n\t\t\t\t\ttuples[ 3 - i ][ 3 ].disable,\n\n\t\t\t\t\t// progress_callbacks.lock\n\t\t\t\t\ttuples[ 0 ][ 2 ].lock,\n\n\t\t\t\t\t// progress_handlers.lock\n\t\t\t\t\ttuples[ 0 ][ 3 ].lock\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// progress_handlers.fire\n\t\t\t// fulfilled_handlers.fire\n\t\t\t// rejected_handlers.fire\n\t\t\tlist.add( tuple[ 3 ].fire );\n\n\t\t\t// deferred.notify = function() { deferred.notifyWith(...) }\n\t\t\t// deferred.resolve = function() { deferred.resolveWith(...) }\n\t\t\t// deferred.reject = function() { deferred.rejectWith(...) }\n\t\t\tdeferred[ tuple[ 0 ] ] = function() {\n\t\t\t\tdeferred[ tuple[ 0 ] + \"With\" ]( this === deferred ? undefined : this, arguments );\n\t\t\t\treturn this;\n\t\t\t};\n\n\t\t\t// deferred.notifyWith = list.fireWith\n\t\t\t// deferred.resolveWith = list.fireWith\n\t\t\t// deferred.rejectWith = list.fireWith\n\t\t\tdeferred[ tuple[ 0 ] + \"With\" ] = list.fireWith;\n\t\t} );\n\n\t\t// Make the deferred a promise\n\t\tpromise.promise( deferred );\n\n\t\t// Call given func if any\n\t\tif ( func ) {\n\t\t\tfunc.call( deferred, deferred );\n\t\t}\n\n\t\t// All done!\n\t\treturn deferred;\n\t},\n\n\t// Deferred helper\n\twhen: function( singleValue ) {\n\t\tvar\n\n\t\t\t// count of uncompleted subordinates\n\t\t\tremaining = arguments.length,\n\n\t\t\t// count of unprocessed arguments\n\t\t\ti = remaining,\n\n\t\t\t// subordinate fulfillment data\n\t\t\tresolveContexts = Array( i ),\n\t\t\tresolveValues = slice.call( arguments ),\n\n\t\t\t// the master Deferred\n\t\t\tmaster = jQuery.Deferred(),\n\n\t\t\t// subordinate callback factory\n\t\t\tupdateFunc = function( i ) {\n\t\t\t\treturn function( value ) {\n\t\t\t\t\tresolveContexts[ i ] = this;\n\t\t\t\t\tresolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;\n\t\t\t\t\tif ( !( --remaining ) ) {\n\t\t\t\t\t\tmaster.resolveWith( resolveContexts, resolveValues );\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t};\n\n\t\t// Single- and empty arguments are adopted like Promise.resolve\n\t\tif ( remaining <= 1 ) {\n\t\t\tadoptValue( singleValue, master.done( updateFunc( i ) ).resolve, master.reject,\n\t\t\t\t!remaining );\n\n\t\t\t// Use .then() to unwrap secondary thenables (cf. gh-3000)\n\t\t\tif ( master.state() === \"pending\" ||\n\t\t\t\tisFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) {\n\n\t\t\t\treturn master.then();\n\t\t\t}\n\t\t}\n\n\t\t// Multiple arguments are aggregated like Promise.all array elements\n\t\twhile ( i-- ) {\n\t\t\tadoptValue( resolveValues[ i ], updateFunc( i ), master.reject );\n\t\t}\n\n\t\treturn master.promise();\n\t}\n} );\n\n\n// These usually indicate a programmer mistake during development,\n// warn about them ASAP rather than swallowing them by default.\nvar rerrorNames = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;\n\njQuery.Deferred.exceptionHook = function( error, stack ) {\n\n\t// Support: IE 8 - 9 only\n\t// Console exists when dev tools are open, which can happen at any time\n\tif ( window.console && window.console.warn && error && rerrorNames.test( error.name ) ) {\n\t\twindow.console.warn( \"jQuery.Deferred exception: \" + error.message, error.stack, stack );\n\t}\n};\n\n\n\n\njQuery.readyException = function( error ) {\n\twindow.setTimeout( function() {\n\t\tthrow error;\n\t} );\n};\n\n\n\n\n// The deferred used on DOM ready\nvar readyList = jQuery.Deferred();\n\njQuery.fn.ready = function( fn ) {\n\n\treadyList\n\t\t.then( fn )\n\n\t\t// Wrap jQuery.readyException in a function so that the lookup\n\t\t// happens at the time of error handling instead of callback\n\t\t// registration.\n\t\t.catch( function( error ) {\n\t\t\tjQuery.readyException( error );\n\t\t} );\n\n\treturn this;\n};\n\njQuery.extend( {\n\n\t// Is the DOM ready to be used? Set to true once it occurs.\n\tisReady: false,\n\n\t// A counter to track how many items to wait for before\n\t// the ready event fires. See #6781\n\treadyWait: 1,\n\n\t// Handle when the DOM is ready\n\tready: function( wait ) {\n\n\t\t// Abort if there are pending holds or we're already ready\n\t\tif ( wait === true ? --jQuery.readyWait : jQuery.isReady ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Remember that the DOM is ready\n\t\tjQuery.isReady = true;\n\n\t\t// If a normal DOM Ready event fired, decrement, and wait if need be\n\t\tif ( wait !== true && --jQuery.readyWait > 0 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// If there are functions bound, to execute\n\t\treadyList.resolveWith( document, [ jQuery ] );\n\t}\n} );\n\njQuery.ready.then = readyList.then;\n\n// The ready event handler and self cleanup method\nfunction completed() {\n\tdocument.removeEventListener( \"DOMContentLoaded\", completed );\n\twindow.removeEventListener( \"load\", completed );\n\tjQuery.ready();\n}\n\n// Catch cases where $(document).ready() is called\n// after the browser event has already occurred.\n// Support: IE <=9 - 10 only\n// Older IE sometimes signals \"interactive\" too soon\nif ( document.readyState === \"complete\" ||\n\t( document.readyState !== \"loading\" && !document.documentElement.doScroll ) ) {\n\n\t// Handle it asynchronously to allow scripts the opportunity to delay ready\n\twindow.setTimeout( jQuery.ready );\n\n} else {\n\n\t// Use the handy event callback\n\tdocument.addEventListener( \"DOMContentLoaded\", completed );\n\n\t// A fallback to window.onload, that will always work\n\twindow.addEventListener( \"load\", completed );\n}\n\n\n\n\n// Multifunctional method to get and set values of a collection\n// The value/s can optionally be executed if it's a function\nvar access = function( elems, fn, key, value, chainable, emptyGet, raw ) {\n\tvar i = 0,\n\t\tlen = elems.length,\n\t\tbulk = key == null;\n\n\t// Sets many values\n\tif ( toType( key ) === \"object\" ) {\n\t\tchainable = true;\n\t\tfor ( i in key ) {\n\t\t\taccess( elems, fn, i, key[ i ], true, emptyGet, raw );\n\t\t}\n\n\t// Sets one value\n\t} else if ( value !== undefined ) {\n\t\tchainable = true;\n\n\t\tif ( !isFunction( value ) ) {\n\t\t\traw = true;\n\t\t}\n\n\t\tif ( bulk ) {\n\n\t\t\t// Bulk operations run against the entire set\n\t\t\tif ( raw ) {\n\t\t\t\tfn.call( elems, value );\n\t\t\t\tfn = null;\n\n\t\t\t// ...except when executing function values\n\t\t\t} else {\n\t\t\t\tbulk = fn;\n\t\t\t\tfn = function( elem, _key, value ) {\n\t\t\t\t\treturn bulk.call( jQuery( elem ), value );\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\n\t\tif ( fn ) {\n\t\t\tfor ( ; i < len; i++ ) {\n\t\t\t\tfn(\n\t\t\t\t\telems[ i ], key, raw ?\n\t\t\t\t\tvalue :\n\t\t\t\t\tvalue.call( elems[ i ], i, fn( elems[ i ], key ) )\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\tif ( chainable ) {\n\t\treturn elems;\n\t}\n\n\t// Gets\n\tif ( bulk ) {\n\t\treturn fn.call( elems );\n\t}\n\n\treturn len ? fn( elems[ 0 ], key ) : emptyGet;\n};\n\n\n// Matches dashed string for camelizing\nvar rmsPrefix = /^-ms-/,\n\trdashAlpha = /-([a-z])/g;\n\n// Used by camelCase as callback to replace()\nfunction fcamelCase( _all, letter ) {\n\treturn letter.toUpperCase();\n}\n\n// Convert dashed to camelCase; used by the css and data modules\n// Support: IE <=9 - 11, Edge 12 - 15\n// Microsoft forgot to hump their vendor prefix (#9572)\nfunction camelCase( string ) {\n\treturn string.replace( rmsPrefix, \"ms-\" ).replace( rdashAlpha, fcamelCase );\n}\nvar acceptData = function( owner ) {\n\n\t// Accepts only:\n\t// - Node\n\t// - Node.ELEMENT_NODE\n\t// - Node.DOCUMENT_NODE\n\t// - Object\n\t// - Any\n\treturn owner.nodeType === 1 || owner.nodeType === 9 || !( +owner.nodeType );\n};\n\n\n\n\nfunction Data() {\n\tthis.expando = jQuery.expando + Data.uid++;\n}\n\nData.uid = 1;\n\nData.prototype = {\n\n\tcache: function( owner ) {\n\n\t\t// Check if the owner object already has a cache\n\t\tvar value = owner[ this.expando ];\n\n\t\t// If not, create one\n\t\tif ( !value ) {\n\t\t\tvalue = Object.create( null );\n\n\t\t\t// We can accept data for non-element nodes in modern browsers,\n\t\t\t// but we should not, see #8335.\n\t\t\t// Always return an empty object.\n\t\t\tif ( acceptData( owner ) ) {\n\n\t\t\t\t// If it is a node unlikely to be stringify-ed or looped over\n\t\t\t\t// use plain assignment\n\t\t\t\tif ( owner.nodeType ) {\n\t\t\t\t\towner[ this.expando ] = value;\n\n\t\t\t\t// Otherwise secure it in a non-enumerable property\n\t\t\t\t// configurable must be true to allow the property to be\n\t\t\t\t// deleted when data is removed\n\t\t\t\t} else {\n\t\t\t\t\tObject.defineProperty( owner, this.expando, {\n\t\t\t\t\t\tvalue: value,\n\t\t\t\t\t\tconfigurable: true\n\t\t\t\t\t} );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn value;\n\t},\n\tset: function( owner, data, value ) {\n\t\tvar prop,\n\t\t\tcache = this.cache( owner );\n\n\t\t// Handle: [ owner, key, value ] args\n\t\t// Always use camelCase key (gh-2257)\n\t\tif ( typeof data === \"string\" ) {\n\t\t\tcache[ camelCase( data ) ] = value;\n\n\t\t// Handle: [ owner, { properties } ] args\n\t\t} else {\n\n\t\t\t// Copy the properties one-by-one to the cache object\n\t\t\tfor ( prop in data ) {\n\t\t\t\tcache[ camelCase( prop ) ] = data[ prop ];\n\t\t\t}\n\t\t}\n\t\treturn cache;\n\t},\n\tget: function( owner, key ) {\n\t\treturn key === undefined ?\n\t\t\tthis.cache( owner ) :\n\n\t\t\t// Always use camelCase key (gh-2257)\n\t\t\towner[ this.expando ] && owner[ this.expando ][ camelCase( key ) ];\n\t},\n\taccess: function( owner, key, value ) {\n\n\t\t// In cases where either:\n\t\t//\n\t\t// 1. No key was specified\n\t\t// 2. A string key was specified, but no value provided\n\t\t//\n\t\t// Take the \"read\" path and allow the get method to determine\n\t\t// which value to return, respectively either:\n\t\t//\n\t\t// 1. The entire cache object\n\t\t// 2. The data stored at the key\n\t\t//\n\t\tif ( key === undefined ||\n\t\t\t\t( ( key && typeof key === \"string\" ) && value === undefined ) ) {\n\n\t\t\treturn this.get( owner, key );\n\t\t}\n\n\t\t// When the key is not a string, or both a key and value\n\t\t// are specified, set or extend (existing objects) with either:\n\t\t//\n\t\t// 1. An object of properties\n\t\t// 2. A key and value\n\t\t//\n\t\tthis.set( owner, key, value );\n\n\t\t// Since the \"set\" path can have two possible entry points\n\t\t// return the expected data based on which path was taken[*]\n\t\treturn value !== undefined ? value : key;\n\t},\n\tremove: function( owner, key ) {\n\t\tvar i,\n\t\t\tcache = owner[ this.expando ];\n\n\t\tif ( cache === undefined ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( key !== undefined ) {\n\n\t\t\t// Support array or space separated string of keys\n\t\t\tif ( Array.isArray( key ) ) {\n\n\t\t\t\t// If key is an array of keys...\n\t\t\t\t// We always set camelCase keys, so remove that.\n\t\t\t\tkey = key.map( camelCase );\n\t\t\t} else {\n\t\t\t\tkey = camelCase( key );\n\n\t\t\t\t// If a key with the spaces exists, use it.\n\t\t\t\t// Otherwise, create an array by matching non-whitespace\n\t\t\t\tkey = key in cache ?\n\t\t\t\t\t[ key ] :\n\t\t\t\t\t( key.match( rnothtmlwhite ) || [] );\n\t\t\t}\n\n\t\t\ti = key.length;\n\n\t\t\twhile ( i-- ) {\n\t\t\t\tdelete cache[ key[ i ] ];\n\t\t\t}\n\t\t}\n\n\t\t// Remove the expando if there's no more data\n\t\tif ( key === undefined || jQuery.isEmptyObject( cache ) ) {\n\n\t\t\t// Support: Chrome <=35 - 45\n\t\t\t// Webkit & Blink performance suffers when deleting properties\n\t\t\t// from DOM nodes, so set to undefined instead\n\t\t\t// https://bugs.chromium.org/p/chromium/issues/detail?id=378607 (bug restricted)\n\t\t\tif ( owner.nodeType ) {\n\t\t\t\towner[ this.expando ] = undefined;\n\t\t\t} else {\n\t\t\t\tdelete owner[ this.expando ];\n\t\t\t}\n\t\t}\n\t},\n\thasData: function( owner ) {\n\t\tvar cache = owner[ this.expando ];\n\t\treturn cache !== undefined && !jQuery.isEmptyObject( cache );\n\t}\n};\nvar dataPriv = new Data();\n\nvar dataUser = new Data();\n\n\n\n//\tImplementation Summary\n//\n//\t1. Enforce API surface and semantic compatibility with 1.9.x branch\n//\t2. Improve the module's maintainability by reducing the storage\n//\t\tpaths to a single mechanism.\n//\t3. Use the same single mechanism to support \"private\" and \"user\" data.\n//\t4. _Never_ expose \"private\" data to user code (TODO: Drop _data, _removeData)\n//\t5. Avoid exposing implementation details on user objects (eg. expando properties)\n//\t6. Provide a clear path for implementation upgrade to WeakMap in 2014\n\nvar rbrace = /^(?:\\{[\\w\\W]*\\}|\\[[\\w\\W]*\\])$/,\n\trmultiDash = /[A-Z]/g;\n\nfunction getData( data ) {\n\tif ( data === \"true\" ) {\n\t\treturn true;\n\t}\n\n\tif ( data === \"false\" ) {\n\t\treturn false;\n\t}\n\n\tif ( data === \"null\" ) {\n\t\treturn null;\n\t}\n\n\t// Only convert to a number if it doesn't change the string\n\tif ( data === +data + \"\" ) {\n\t\treturn +data;\n\t}\n\n\tif ( rbrace.test( data ) ) {\n\t\treturn JSON.parse( data );\n\t}\n\n\treturn data;\n}\n\nfunction dataAttr( elem, key, data ) {\n\tvar name;\n\n\t// If nothing was found internally, try to fetch any\n\t// data from the HTML5 data-* attribute\n\tif ( data === undefined && elem.nodeType === 1 ) {\n\t\tname = \"data-\" + key.replace( rmultiDash, \"-$&\" ).toLowerCase();\n\t\tdata = elem.getAttribute( name );\n\n\t\tif ( typeof data === \"string\" ) {\n\t\t\ttry {\n\t\t\t\tdata = getData( data );\n\t\t\t} catch ( e ) {}\n\n\t\t\t// Make sure we set the data so it isn't changed later\n\t\t\tdataUser.set( elem, key, data );\n\t\t} else {\n\t\t\tdata = undefined;\n\t\t}\n\t}\n\treturn data;\n}\n\njQuery.extend( {\n\thasData: function( elem ) {\n\t\treturn dataUser.hasData( elem ) || dataPriv.hasData( elem );\n\t},\n\n\tdata: function( elem, name, data ) {\n\t\treturn dataUser.access( elem, name, data );\n\t},\n\n\tremoveData: function( elem, name ) {\n\t\tdataUser.remove( elem, name );\n\t},\n\n\t// TODO: Now that all calls to _data and _removeData have been replaced\n\t// with direct calls to dataPriv methods, these can be deprecated.\n\t_data: function( elem, name, data ) {\n\t\treturn dataPriv.access( elem, name, data );\n\t},\n\n\t_removeData: function( elem, name ) {\n\t\tdataPriv.remove( elem, name );\n\t}\n} );\n\njQuery.fn.extend( {\n\tdata: function( key, value ) {\n\t\tvar i, name, data,\n\t\t\telem = this[ 0 ],\n\t\t\tattrs = elem && elem.attributes;\n\n\t\t// Gets all values\n\t\tif ( key === undefined ) {\n\t\t\tif ( this.length ) {\n\t\t\t\tdata = dataUser.get( elem );\n\n\t\t\t\tif ( elem.nodeType === 1 && !dataPriv.get( elem, \"hasDataAttrs\" ) ) {\n\t\t\t\t\ti = attrs.length;\n\t\t\t\t\twhile ( i-- ) {\n\n\t\t\t\t\t\t// Support: IE 11 only\n\t\t\t\t\t\t// The attrs elements can be null (#14894)\n\t\t\t\t\t\tif ( attrs[ i ] ) {\n\t\t\t\t\t\t\tname = attrs[ i ].name;\n\t\t\t\t\t\t\tif ( name.indexOf( \"data-\" ) === 0 ) {\n\t\t\t\t\t\t\t\tname = camelCase( name.slice( 5 ) );\n\t\t\t\t\t\t\t\tdataAttr( elem, name, data[ name ] );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tdataPriv.set( elem, \"hasDataAttrs\", true );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn data;\n\t\t}\n\n\t\t// Sets multiple values\n\t\tif ( typeof key === \"object\" ) {\n\t\t\treturn this.each( function() {\n\t\t\t\tdataUser.set( this, key );\n\t\t\t} );\n\t\t}\n\n\t\treturn access( this, function( value ) {\n\t\t\tvar data;\n\n\t\t\t// The calling jQuery object (element matches) is not empty\n\t\t\t// (and therefore has an element appears at this[ 0 ]) and the\n\t\t\t// `value` parameter was not undefined. An empty jQuery object\n\t\t\t// will result in `undefined` for elem = this[ 0 ] which will\n\t\t\t// throw an exception if an attempt to read a data cache is made.\n\t\t\tif ( elem && value === undefined ) {\n\n\t\t\t\t// Attempt to get data from the cache\n\t\t\t\t// The key will always be camelCased in Data\n\t\t\t\tdata = dataUser.get( elem, key );\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\t// Attempt to \"discover\" the data in\n\t\t\t\t// HTML5 custom data-* attrs\n\t\t\t\tdata = dataAttr( elem, key );\n\t\t\t\tif ( data !== undefined ) {\n\t\t\t\t\treturn data;\n\t\t\t\t}\n\n\t\t\t\t// We tried really hard, but the data doesn't exist.\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Set the data...\n\t\t\tthis.each( function() {\n\n\t\t\t\t// We always store the camelCased key\n\t\t\t\tdataUser.set( this, key, value );\n\t\t\t} );\n\t\t}, null, value, arguments.length > 1, null, true );\n\t},\n\n\tremoveData: function( key ) {\n\t\treturn this.each( function() {\n\t\t\tdataUser.remove( this, key );\n\t\t} );\n\t}\n} );\n\n\njQuery.extend( {\n\tqueue: function( elem, type, data ) {\n\t\tvar queue;\n\n\t\tif ( elem ) {\n\t\t\ttype = ( type || \"fx\" ) + \"queue\";\n\t\t\tqueue = dataPriv.get( elem, type );\n\n\t\t\t// Speed up dequeue by getting out quickly if this is just a lookup\n\t\t\tif ( data ) {\n\t\t\t\tif ( !queue || Array.isArray( data ) ) {\n\t\t\t\t\tqueue = dataPriv.access( elem, type, jQuery.makeArray( data ) );\n\t\t\t\t} else {\n\t\t\t\t\tqueue.push( data );\n\t\t\t\t}\n\t\t\t}\n\t\t\treturn queue || [];\n\t\t}\n\t},\n\n\tdequeue: function( elem, type ) {\n\t\ttype = type || \"fx\";\n\n\t\tvar queue = jQuery.queue( elem, type ),\n\t\t\tstartLength = queue.length,\n\t\t\tfn = queue.shift(),\n\t\t\thooks = jQuery._queueHooks( elem, type ),\n\t\t\tnext = function() {\n\t\t\t\tjQuery.dequeue( elem, type );\n\t\t\t};\n\n\t\t// If the fx queue is dequeued, always remove the progress sentinel\n\t\tif ( fn === \"inprogress\" ) {\n\t\t\tfn = queue.shift();\n\t\t\tstartLength--;\n\t\t}\n\n\t\tif ( fn ) {\n\n\t\t\t// Add a progress sentinel to prevent the fx queue from being\n\t\t\t// automatically dequeued\n\t\t\tif ( type === \"fx\" ) {\n\t\t\t\tqueue.unshift( \"inprogress\" );\n\t\t\t}\n\n\t\t\t// Clear up the last queue stop function\n\t\t\tdelete hooks.stop;\n\t\t\tfn.call( elem, next, hooks );\n\t\t}\n\n\t\tif ( !startLength && hooks ) {\n\t\t\thooks.empty.fire();\n\t\t}\n\t},\n\n\t// Not public - generate a queueHooks object, or return the current one\n\t_queueHooks: function( elem, type ) {\n\t\tvar key = type + \"queueHooks\";\n\t\treturn dataPriv.get( elem, key ) || dataPriv.access( elem, key, {\n\t\t\tempty: jQuery.Callbacks( \"once memory\" ).add( function() {\n\t\t\t\tdataPriv.remove( elem, [ type + \"queue\", key ] );\n\t\t\t} )\n\t\t} );\n\t}\n} );\n\njQuery.fn.extend( {\n\tqueue: function( type, data ) {\n\t\tvar setter = 2;\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tdata = type;\n\t\t\ttype = \"fx\";\n\t\t\tsetter--;\n\t\t}\n\n\t\tif ( arguments.length < setter ) {\n\t\t\treturn jQuery.queue( this[ 0 ], type );\n\t\t}\n\n\t\treturn data === undefined ?\n\t\t\tthis :\n\t\t\tthis.each( function() {\n\t\t\t\tvar queue = jQuery.queue( this, type, data );\n\n\t\t\t\t// Ensure a hooks for this queue\n\t\t\t\tjQuery._queueHooks( this, type );\n\n\t\t\t\tif ( type === \"fx\" && queue[ 0 ] !== \"inprogress\" ) {\n\t\t\t\t\tjQuery.dequeue( this, type );\n\t\t\t\t}\n\t\t\t} );\n\t},\n\tdequeue: function( type ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.dequeue( this, type );\n\t\t} );\n\t},\n\tclearQueue: function( type ) {\n\t\treturn this.queue( type || \"fx\", [] );\n\t},\n\n\t// Get a promise resolved when queues of a certain type\n\t// are emptied (fx is the type by default)\n\tpromise: function( type, obj ) {\n\t\tvar tmp,\n\t\t\tcount = 1,\n\t\t\tdefer = jQuery.Deferred(),\n\t\t\telements = this,\n\t\t\ti = this.length,\n\t\t\tresolve = function() {\n\t\t\t\tif ( !( --count ) ) {\n\t\t\t\t\tdefer.resolveWith( elements, [ elements ] );\n\t\t\t\t}\n\t\t\t};\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tobj = type;\n\t\t\ttype = undefined;\n\t\t}\n\t\ttype = type || \"fx\";\n\n\t\twhile ( i-- ) {\n\t\t\ttmp = dataPriv.get( elements[ i ], type + \"queueHooks\" );\n\t\t\tif ( tmp && tmp.empty ) {\n\t\t\t\tcount++;\n\t\t\t\ttmp.empty.add( resolve );\n\t\t\t}\n\t\t}\n\t\tresolve();\n\t\treturn defer.promise( obj );\n\t}\n} );\nvar pnum = ( /[+-]?(?:\\d*\\.|)\\d+(?:[eE][+-]?\\d+|)/ ).source;\n\nvar rcssNum = new RegExp( \"^(?:([+-])=|)(\" + pnum + \")([a-z%]*)$\", \"i\" );\n\n\nvar cssExpand = [ \"Top\", \"Right\", \"Bottom\", \"Left\" ];\n\nvar documentElement = document.documentElement;\n\n\n\n\tvar isAttached = function( elem ) {\n\t\t\treturn jQuery.contains( elem.ownerDocument, elem );\n\t\t},\n\t\tcomposed = { composed: true };\n\n\t// Support: IE 9 - 11+, Edge 12 - 18+, iOS 10.0 - 10.2 only\n\t// Check attachment across shadow DOM boundaries when possible (gh-3504)\n\t// Support: iOS 10.0-10.2 only\n\t// Early iOS 10 versions support `attachShadow` but not `getRootNode`,\n\t// leading to errors. We need to check for `getRootNode`.\n\tif ( documentElement.getRootNode ) {\n\t\tisAttached = function( elem ) {\n\t\t\treturn jQuery.contains( elem.ownerDocument, elem ) ||\n\t\t\t\telem.getRootNode( composed ) === elem.ownerDocument;\n\t\t};\n\t}\nvar isHiddenWithinTree = function( elem, el ) {\n\n\t\t// isHiddenWithinTree might be called from jQuery#filter function;\n\t\t// in that case, element will be second argument\n\t\telem = el || elem;\n\n\t\t// Inline style trumps all\n\t\treturn elem.style.display === \"none\" ||\n\t\t\telem.style.display === \"\" &&\n\n\t\t\t// Otherwise, check computed style\n\t\t\t// Support: Firefox <=43 - 45\n\t\t\t// Disconnected elements can have computed display: none, so first confirm that elem is\n\t\t\t// in the document.\n\t\t\tisAttached( elem ) &&\n\n\t\t\tjQuery.css( elem, \"display\" ) === \"none\";\n\t};\n\n\n\nfunction adjustCSS( elem, prop, valueParts, tween ) {\n\tvar adjusted, scale,\n\t\tmaxIterations = 20,\n\t\tcurrentValue = tween ?\n\t\t\tfunction() {\n\t\t\t\treturn tween.cur();\n\t\t\t} :\n\t\t\tfunction() {\n\t\t\t\treturn jQuery.css( elem, prop, \"\" );\n\t\t\t},\n\t\tinitial = currentValue(),\n\t\tunit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? \"\" : \"px\" ),\n\n\t\t// Starting value computation is required for potential unit mismatches\n\t\tinitialInUnit = elem.nodeType &&\n\t\t\t( jQuery.cssNumber[ prop ] || unit !== \"px\" && +initial ) &&\n\t\t\trcssNum.exec( jQuery.css( elem, prop ) );\n\n\tif ( initialInUnit && initialInUnit[ 3 ] !== unit ) {\n\n\t\t// Support: Firefox <=54\n\t\t// Halve the iteration target value to prevent interference from CSS upper bounds (gh-2144)\n\t\tinitial = initial / 2;\n\n\t\t// Trust units reported by jQuery.css\n\t\tunit = unit || initialInUnit[ 3 ];\n\n\t\t// Iteratively approximate from a nonzero starting point\n\t\tinitialInUnit = +initial || 1;\n\n\t\twhile ( maxIterations-- ) {\n\n\t\t\t// Evaluate and update our best guess (doubling guesses that zero out).\n\t\t\t// Finish if the scale equals or crosses 1 (making the old*new product non-positive).\n\t\t\tjQuery.style( elem, prop, initialInUnit + unit );\n\t\t\tif ( ( 1 - scale ) * ( 1 - ( scale = currentValue() / initial || 0.5 ) ) <= 0 ) {\n\t\t\t\tmaxIterations = 0;\n\t\t\t}\n\t\t\tinitialInUnit = initialInUnit / scale;\n\n\t\t}\n\n\t\tinitialInUnit = initialInUnit * 2;\n\t\tjQuery.style( elem, prop, initialInUnit + unit );\n\n\t\t// Make sure we update the tween properties later on\n\t\tvalueParts = valueParts || [];\n\t}\n\n\tif ( valueParts ) {\n\t\tinitialInUnit = +initialInUnit || +initial || 0;\n\n\t\t// Apply relative offset (+=/-=) if specified\n\t\tadjusted = valueParts[ 1 ] ?\n\t\t\tinitialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] :\n\t\t\t+valueParts[ 2 ];\n\t\tif ( tween ) {\n\t\t\ttween.unit = unit;\n\t\t\ttween.start = initialInUnit;\n\t\t\ttween.end = adjusted;\n\t\t}\n\t}\n\treturn adjusted;\n}\n\n\nvar defaultDisplayMap = {};\n\nfunction getDefaultDisplay( elem ) {\n\tvar temp,\n\t\tdoc = elem.ownerDocument,\n\t\tnodeName = elem.nodeName,\n\t\tdisplay = defaultDisplayMap[ nodeName ];\n\n\tif ( display ) {\n\t\treturn display;\n\t}\n\n\ttemp = doc.body.appendChild( doc.createElement( nodeName ) );\n\tdisplay = jQuery.css( temp, \"display\" );\n\n\ttemp.parentNode.removeChild( temp );\n\n\tif ( display === \"none\" ) {\n\t\tdisplay = \"block\";\n\t}\n\tdefaultDisplayMap[ nodeName ] = display;\n\n\treturn display;\n}\n\nfunction showHide( elements, show ) {\n\tvar display, elem,\n\t\tvalues = [],\n\t\tindex = 0,\n\t\tlength = elements.length;\n\n\t// Determine new display value for elements that need to change\n\tfor ( ; index < length; index++ ) {\n\t\telem = elements[ index ];\n\t\tif ( !elem.style ) {\n\t\t\tcontinue;\n\t\t}\n\n\t\tdisplay = elem.style.display;\n\t\tif ( show ) {\n\n\t\t\t// Since we force visibility upon cascade-hidden elements, an immediate (and slow)\n\t\t\t// check is required in this first loop unless we have a nonempty display value (either\n\t\t\t// inline or about-to-be-restored)\n\t\t\tif ( display === \"none\" ) {\n\t\t\t\tvalues[ index ] = dataPriv.get( elem, \"display\" ) || null;\n\t\t\t\tif ( !values[ index ] ) {\n\t\t\t\t\telem.style.display = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t\tif ( elem.style.display === \"\" && isHiddenWithinTree( elem ) ) {\n\t\t\t\tvalues[ index ] = getDefaultDisplay( elem );\n\t\t\t}\n\t\t} else {\n\t\t\tif ( display !== \"none\" ) {\n\t\t\t\tvalues[ index ] = \"none\";\n\n\t\t\t\t// Remember what we're overwriting\n\t\t\t\tdataPriv.set( elem, \"display\", display );\n\t\t\t}\n\t\t}\n\t}\n\n\t// Set the display of the elements in a second loop to avoid constant reflow\n\tfor ( index = 0; index < length; index++ ) {\n\t\tif ( values[ index ] != null ) {\n\t\t\telements[ index ].style.display = values[ index ];\n\t\t}\n\t}\n\n\treturn elements;\n}\n\njQuery.fn.extend( {\n\tshow: function() {\n\t\treturn showHide( this, true );\n\t},\n\thide: function() {\n\t\treturn showHide( this );\n\t},\n\ttoggle: function( state ) {\n\t\tif ( typeof state === \"boolean\" ) {\n\t\t\treturn state ? this.show() : this.hide();\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tif ( isHiddenWithinTree( this ) ) {\n\t\t\t\tjQuery( this ).show();\n\t\t\t} else {\n\t\t\t\tjQuery( this ).hide();\n\t\t\t}\n\t\t} );\n\t}\n} );\nvar rcheckableType = ( /^(?:checkbox|radio)$/i );\n\nvar rtagName = ( /<([a-z][^\\/\\0>\\x20\\t\\r\\n\\f]*)/i );\n\nvar rscriptType = ( /^$|^module$|\\/(?:java|ecma)script/i );\n\n\n\n( function() {\n\tvar fragment = document.createDocumentFragment(),\n\t\tdiv = fragment.appendChild( document.createElement( \"div\" ) ),\n\t\tinput = document.createElement( \"input\" );\n\n\t// Support: Android 4.0 - 4.3 only\n\t// Check state lost if the name is set (#11217)\n\t// Support: Windows Web Apps (WWA)\n\t// `name` and `type` must use .setAttribute for WWA (#14901)\n\tinput.setAttribute( \"type\", \"radio\" );\n\tinput.setAttribute( \"checked\", \"checked\" );\n\tinput.setAttribute( \"name\", \"t\" );\n\n\tdiv.appendChild( input );\n\n\t// Support: Android <=4.1 only\n\t// Older WebKit doesn't clone checked state correctly in fragments\n\tsupport.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked;\n\n\t// Support: IE <=11 only\n\t// Make sure textarea (and checkbox) defaultValue is properly cloned\n\tdiv.innerHTML = \"<textarea>x</textarea>\";\n\tsupport.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue;\n\n\t// Support: IE <=9 only\n\t// IE <=9 replaces <option> tags with their contents when inserted outside of\n\t// the select element.\n\tdiv.innerHTML = \"<option></option>\";\n\tsupport.option = !!div.lastChild;\n} )();\n\n\n// We have to close these tags to support XHTML (#13200)\nvar wrapMap = {\n\n\t// XHTML parsers do not magically insert elements in the\n\t// same way that tag soup parsers do. So we cannot shorten\n\t// this by omitting <tbody> or other required elements.\n\tthead: [ 1, \"<table>\", \"</table>\" ],\n\tcol: [ 2, \"<table><colgroup>\", \"</colgroup></table>\" ],\n\ttr: [ 2, \"<table><tbody>\", \"</tbody></table>\" ],\n\ttd: [ 3, \"<table><tbody><tr>\", \"</tr></tbody></table>\" ],\n\n\t_default: [ 0, \"\", \"\" ]\n};\n\nwrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead;\nwrapMap.th = wrapMap.td;\n\n// Support: IE <=9 only\nif ( !support.option ) {\n\twrapMap.optgroup = wrapMap.option = [ 1, \"<select multiple='multiple'>\", \"</select>\" ];\n}\n\n\nfunction getAll( context, tag ) {\n\n\t// Support: IE <=9 - 11 only\n\t// Use typeof to avoid zero-argument method invocation on host objects (#15151)\n\tvar ret;\n\n\tif ( typeof context.getElementsByTagName !== \"undefined\" ) {\n\t\tret = context.getElementsByTagName( tag || \"*\" );\n\n\t} else if ( typeof context.querySelectorAll !== \"undefined\" ) {\n\t\tret = context.querySelectorAll( tag || \"*\" );\n\n\t} else {\n\t\tret = [];\n\t}\n\n\tif ( tag === undefined || tag && nodeName( context, tag ) ) {\n\t\treturn jQuery.merge( [ context ], ret );\n\t}\n\n\treturn ret;\n}\n\n\n// Mark scripts as having already been evaluated\nfunction setGlobalEval( elems, refElements ) {\n\tvar i = 0,\n\t\tl = elems.length;\n\n\tfor ( ; i < l; i++ ) {\n\t\tdataPriv.set(\n\t\t\telems[ i ],\n\t\t\t\"globalEval\",\n\t\t\t!refElements || dataPriv.get( refElements[ i ], \"globalEval\" )\n\t\t);\n\t}\n}\n\n\nvar rhtml = /<|&#?\\w+;/;\n\nfunction buildFragment( elems, context, scripts, selection, ignored ) {\n\tvar elem, tmp, tag, wrap, attached, j,\n\t\tfragment = context.createDocumentFragment(),\n\t\tnodes = [],\n\t\ti = 0,\n\t\tl = elems.length;\n\n\tfor ( ; i < l; i++ ) {\n\t\telem = elems[ i ];\n\n\t\tif ( elem || elem === 0 ) {\n\n\t\t\t// Add nodes directly\n\t\t\tif ( toType( elem ) === \"object\" ) {\n\n\t\t\t\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\tjQuery.merge( nodes, elem.nodeType ? [ elem ] : elem );\n\n\t\t\t// Convert non-html into a text node\n\t\t\t} else if ( !rhtml.test( elem ) ) {\n\t\t\t\tnodes.push( context.createTextNode( elem ) );\n\n\t\t\t// Convert html into DOM nodes\n\t\t\t} else {\n\t\t\t\ttmp = tmp || fragment.appendChild( context.createElement( \"div\" ) );\n\n\t\t\t\t// Deserialize a standard representation\n\t\t\t\ttag = ( rtagName.exec( elem ) || [ \"\", \"\" ] )[ 1 ].toLowerCase();\n\t\t\t\twrap = wrapMap[ tag ] || wrapMap._default;\n\t\t\t\ttmp.innerHTML = wrap[ 1 ] + jQuery.htmlPrefilter( elem ) + wrap[ 2 ];\n\n\t\t\t\t// Descend through wrappers to the right content\n\t\t\t\tj = wrap[ 0 ];\n\t\t\t\twhile ( j-- ) {\n\t\t\t\t\ttmp = tmp.lastChild;\n\t\t\t\t}\n\n\t\t\t\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\tjQuery.merge( nodes, tmp.childNodes );\n\n\t\t\t\t// Remember the top-level container\n\t\t\t\ttmp = fragment.firstChild;\n\n\t\t\t\t// Ensure the created nodes are orphaned (#12392)\n\t\t\t\ttmp.textContent = \"\";\n\t\t\t}\n\t\t}\n\t}\n\n\t// Remove wrapper from fragment\n\tfragment.textContent = \"\";\n\n\ti = 0;\n\twhile ( ( elem = nodes[ i++ ] ) ) {\n\n\t\t// Skip elements already in the context collection (trac-4087)\n\t\tif ( selection && jQuery.inArray( elem, selection ) > -1 ) {\n\t\t\tif ( ignored ) {\n\t\t\t\tignored.push( elem );\n\t\t\t}\n\t\t\tcontinue;\n\t\t}\n\n\t\tattached = isAttached( elem );\n\n\t\t// Append to fragment\n\t\ttmp = getAll( fragment.appendChild( elem ), \"script\" );\n\n\t\t// Preserve script evaluation history\n\t\tif ( attached ) {\n\t\t\tsetGlobalEval( tmp );\n\t\t}\n\n\t\t// Capture executables\n\t\tif ( scripts ) {\n\t\t\tj = 0;\n\t\t\twhile ( ( elem = tmp[ j++ ] ) ) {\n\t\t\t\tif ( rscriptType.test( elem.type || \"\" ) ) {\n\t\t\t\t\tscripts.push( elem );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn fragment;\n}\n\n\nvar\n\trkeyEvent = /^key/,\n\trmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,\n\trtypenamespace = /^([^.]*)(?:\\.(.+)|)/;\n\nfunction returnTrue() {\n\treturn true;\n}\n\nfunction returnFalse() {\n\treturn false;\n}\n\n// Support: IE <=9 - 11+\n// focus() and blur() are asynchronous, except when they are no-op.\n// So expect focus to be synchronous when the element is already active,\n// and blur to be synchronous when the element is not already active.\n// (focus and blur are always synchronous in other supported browsers,\n// this just defines when we can count on it).\nfunction expectSync( elem, type ) {\n\treturn ( elem === safeActiveElement() ) === ( type === \"focus\" );\n}\n\n// Support: IE <=9 only\n// Accessing document.activeElement can throw unexpectedly\n// https://bugs.jquery.com/ticket/13393\nfunction safeActiveElement() {\n\ttry {\n\t\treturn document.activeElement;\n\t} catch ( err ) { }\n}\n\nfunction on( elem, types, selector, data, fn, one ) {\n\tvar origFn, type;\n\n\t// Types can be a map of types/handlers\n\tif ( typeof types === \"object\" ) {\n\n\t\t// ( types-Object, selector, data )\n\t\tif ( typeof selector !== \"string\" ) {\n\n\t\t\t// ( types-Object, data )\n\t\t\tdata = data || selector;\n\t\t\tselector = undefined;\n\t\t}\n\t\tfor ( type in types ) {\n\t\t\ton( elem, type, selector, data, types[ type ], one );\n\t\t}\n\t\treturn elem;\n\t}\n\n\tif ( data == null && fn == null ) {\n\n\t\t// ( types, fn )\n\t\tfn = selector;\n\t\tdata = selector = undefined;\n\t} else if ( fn == null ) {\n\t\tif ( typeof selector === \"string\" ) {\n\n\t\t\t// ( types, selector, fn )\n\t\t\tfn = data;\n\t\t\tdata = undefined;\n\t\t} else {\n\n\t\t\t// ( types, data, fn )\n\t\t\tfn = data;\n\t\t\tdata = selector;\n\t\t\tselector = undefined;\n\t\t}\n\t}\n\tif ( fn === false ) {\n\t\tfn = returnFalse;\n\t} else if ( !fn ) {\n\t\treturn elem;\n\t}\n\n\tif ( one === 1 ) {\n\t\torigFn = fn;\n\t\tfn = function( event ) {\n\n\t\t\t// Can use an empty set, since event contains the info\n\t\t\tjQuery().off( event );\n\t\t\treturn origFn.apply( this, arguments );\n\t\t};\n\n\t\t// Use same guid so caller can remove using origFn\n\t\tfn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ );\n\t}\n\treturn elem.each( function() {\n\t\tjQuery.event.add( this, types, fn, data, selector );\n\t} );\n}\n\n/*\n * Helper functions for managing events -- not part of the public interface.\n * Props to Dean Edwards' addEvent library for many of the ideas.\n */\njQuery.event = {\n\n\tglobal: {},\n\n\tadd: function( elem, types, handler, data, selector ) {\n\n\t\tvar handleObjIn, eventHandle, tmp,\n\t\t\tevents, t, handleObj,\n\t\t\tspecial, handlers, type, namespaces, origType,\n\t\t\telemData = dataPriv.get( elem );\n\n\t\t// Only attach events to objects that accept data\n\t\tif ( !acceptData( elem ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Caller can pass in an object of custom data in lieu of the handler\n\t\tif ( handler.handler ) {\n\t\t\thandleObjIn = handler;\n\t\t\thandler = handleObjIn.handler;\n\t\t\tselector = handleObjIn.selector;\n\t\t}\n\n\t\t// Ensure that invalid selectors throw exceptions at attach time\n\t\t// Evaluate against documentElement in case elem is a non-element node (e.g., document)\n\t\tif ( selector ) {\n\t\t\tjQuery.find.matchesSelector( documentElement, selector );\n\t\t}\n\n\t\t// Make sure that the handler has a unique ID, used to find/remove it later\n\t\tif ( !handler.guid ) {\n\t\t\thandler.guid = jQuery.guid++;\n\t\t}\n\n\t\t// Init the element's event structure and main handler, if this is the first\n\t\tif ( !( events = elemData.events ) ) {\n\t\t\tevents = elemData.events = Object.create( null );\n\t\t}\n\t\tif ( !( eventHandle = elemData.handle ) ) {\n\t\t\teventHandle = elemData.handle = function( e ) {\n\n\t\t\t\t// Discard the second event of a jQuery.event.trigger() and\n\t\t\t\t// when an event is called after a page has unloaded\n\t\t\t\treturn typeof jQuery !== \"undefined\" && jQuery.event.triggered !== e.type ?\n\t\t\t\t\tjQuery.event.dispatch.apply( elem, arguments ) : undefined;\n\t\t\t};\n\t\t}\n\n\t\t// Handle multiple events separated by a space\n\t\ttypes = ( types || \"\" ).match( rnothtmlwhite ) || [ \"\" ];\n\t\tt = types.length;\n\t\twhile ( t-- ) {\n\t\t\ttmp = rtypenamespace.exec( types[ t ] ) || [];\n\t\t\ttype = origType = tmp[ 1 ];\n\t\t\tnamespaces = ( tmp[ 2 ] || \"\" ).split( \".\" ).sort();\n\n\t\t\t// There *must* be a type, no attaching namespace-only handlers\n\t\t\tif ( !type ) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// If event changes its type, use the special event handlers for the changed type\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\n\t\t\t// If selector defined, determine special event api type, otherwise given type\n\t\t\ttype = ( selector ? special.delegateType : special.bindType ) || type;\n\n\t\t\t// Update special based on newly reset type\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\n\t\t\t// handleObj is passed to all event handlers\n\t\t\thandleObj = jQuery.extend( {\n\t\t\t\ttype: type,\n\t\t\t\torigType: origType,\n\t\t\t\tdata: data,\n\t\t\t\thandler: handler,\n\t\t\t\tguid: handler.guid,\n\t\t\t\tselector: selector,\n\t\t\t\tneedsContext: selector && jQuery.expr.match.needsContext.test( selector ),\n\t\t\t\tnamespace: namespaces.join( \".\" )\n\t\t\t}, handleObjIn );\n\n\t\t\t// Init the event handler queue if we're the first\n\t\t\tif ( !( handlers = events[ type ] ) ) {\n\t\t\t\thandlers = events[ type ] = [];\n\t\t\t\thandlers.delegateCount = 0;\n\n\t\t\t\t// Only use addEventListener if the special events handler returns false\n\t\t\t\tif ( !special.setup ||\n\t\t\t\t\tspecial.setup.call( elem, data, namespaces, eventHandle ) === false ) {\n\n\t\t\t\t\tif ( elem.addEventListener ) {\n\t\t\t\t\t\telem.addEventListener( type, eventHandle );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif ( special.add ) {\n\t\t\t\tspecial.add.call( elem, handleObj );\n\n\t\t\t\tif ( !handleObj.handler.guid ) {\n\t\t\t\t\thandleObj.handler.guid = handler.guid;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add to the element's handler list, delegates in front\n\t\t\tif ( selector ) {\n\t\t\t\thandlers.splice( handlers.delegateCount++, 0, handleObj );\n\t\t\t} else {\n\t\t\t\thandlers.push( handleObj );\n\t\t\t}\n\n\t\t\t// Keep track of which events have ever been used, for event optimization\n\t\t\tjQuery.event.global[ type ] = true;\n\t\t}\n\n\t},\n\n\t// Detach an event or set of events from an element\n\tremove: function( elem, types, handler, selector, mappedTypes ) {\n\n\t\tvar j, origCount, tmp,\n\t\t\tevents, t, handleObj,\n\t\t\tspecial, handlers, type, namespaces, origType,\n\t\t\telemData = dataPriv.hasData( elem ) && dataPriv.get( elem );\n\n\t\tif ( !elemData || !( events = elemData.events ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Once for each type.namespace in types; type may be omitted\n\t\ttypes = ( types || \"\" ).match( rnothtmlwhite ) || [ \"\" ];\n\t\tt = types.length;\n\t\twhile ( t-- ) {\n\t\t\ttmp = rtypenamespace.exec( types[ t ] ) || [];\n\t\t\ttype = origType = tmp[ 1 ];\n\t\t\tnamespaces = ( tmp[ 2 ] || \"\" ).split( \".\" ).sort();\n\n\t\t\t// Unbind all events (on this namespace, if provided) for the element\n\t\t\tif ( !type ) {\n\t\t\t\tfor ( type in events ) {\n\t\t\t\t\tjQuery.event.remove( elem, type + types[ t ], handler, selector, true );\n\t\t\t\t}\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tspecial = jQuery.event.special[ type ] || {};\n\t\t\ttype = ( selector ? special.delegateType : special.bindType ) || type;\n\t\t\thandlers = events[ type ] || [];\n\t\t\ttmp = tmp[ 2 ] &&\n\t\t\t\tnew RegExp( \"(^|\\\\.)\" + namespaces.join( \"\\\\.(?:.*\\\\.|)\" ) + \"(\\\\.|$)\" );\n\n\t\t\t// Remove matching events\n\t\t\torigCount = j = handlers.length;\n\t\t\twhile ( j-- ) {\n\t\t\t\thandleObj = handlers[ j ];\n\n\t\t\t\tif ( ( mappedTypes || origType === handleObj.origType ) &&\n\t\t\t\t\t( !handler || handler.guid === handleObj.guid ) &&\n\t\t\t\t\t( !tmp || tmp.test( handleObj.namespace ) ) &&\n\t\t\t\t\t( !selector || selector === handleObj.selector ||\n\t\t\t\t\t\tselector === \"**\" && handleObj.selector ) ) {\n\t\t\t\t\thandlers.splice( j, 1 );\n\n\t\t\t\t\tif ( handleObj.selector ) {\n\t\t\t\t\t\thandlers.delegateCount--;\n\t\t\t\t\t}\n\t\t\t\t\tif ( special.remove ) {\n\t\t\t\t\t\tspecial.remove.call( elem, handleObj );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Remove generic event handler if we removed something and no more handlers exist\n\t\t\t// (avoids potential for endless recursion during removal of special event handlers)\n\t\t\tif ( origCount && !handlers.length ) {\n\t\t\t\tif ( !special.teardown ||\n\t\t\t\t\tspecial.teardown.call( elem, namespaces, elemData.handle ) === false ) {\n\n\t\t\t\t\tjQuery.removeEvent( elem, type, elemData.handle );\n\t\t\t\t}\n\n\t\t\t\tdelete events[ type ];\n\t\t\t}\n\t\t}\n\n\t\t// Remove data and the expando if it's no longer used\n\t\tif ( jQuery.isEmptyObject( events ) ) {\n\t\t\tdataPriv.remove( elem, \"handle events\" );\n\t\t}\n\t},\n\n\tdispatch: function( nativeEvent ) {\n\n\t\tvar i, j, ret, matched, handleObj, handlerQueue,\n\t\t\targs = new Array( arguments.length ),\n\n\t\t\t// Make a writable jQuery.Event from the native event object\n\t\t\tevent = jQuery.event.fix( nativeEvent ),\n\n\t\t\thandlers = (\n\t\t\t\t\tdataPriv.get( this, \"events\" ) || Object.create( null )\n\t\t\t\t)[ event.type ] || [],\n\t\t\tspecial = jQuery.event.special[ event.type ] || {};\n\n\t\t// Use the fix-ed jQuery.Event rather than the (read-only) native event\n\t\targs[ 0 ] = event;\n\n\t\tfor ( i = 1; i < arguments.length; i++ ) {\n\t\t\targs[ i ] = arguments[ i ];\n\t\t}\n\n\t\tevent.delegateTarget = this;\n\n\t\t// Call the preDispatch hook for the mapped type, and let it bail if desired\n\t\tif ( special.preDispatch && special.preDispatch.call( this, event ) === false ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Determine handlers\n\t\thandlerQueue = jQuery.event.handlers.call( this, event, handlers );\n\n\t\t// Run delegates first; they may want to stop propagation beneath us\n\t\ti = 0;\n\t\twhile ( ( matched = handlerQueue[ i++ ] ) && !event.isPropagationStopped() ) {\n\t\t\tevent.currentTarget = matched.elem;\n\n\t\t\tj = 0;\n\t\t\twhile ( ( handleObj = matched.handlers[ j++ ] ) &&\n\t\t\t\t!event.isImmediatePropagationStopped() ) {\n\n\t\t\t\t// If the event is namespaced, then each handler is only invoked if it is\n\t\t\t\t// specially universal or its namespaces are a superset of the event's.\n\t\t\t\tif ( !event.rnamespace || handleObj.namespace === false ||\n\t\t\t\t\tevent.rnamespace.test( handleObj.namespace ) ) {\n\n\t\t\t\t\tevent.handleObj = handleObj;\n\t\t\t\t\tevent.data = handleObj.data;\n\n\t\t\t\t\tret = ( ( jQuery.event.special[ handleObj.origType ] || {} ).handle ||\n\t\t\t\t\t\thandleObj.handler ).apply( matched.elem, args );\n\n\t\t\t\t\tif ( ret !== undefined ) {\n\t\t\t\t\t\tif ( ( event.result = ret ) === false ) {\n\t\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Call the postDispatch hook for the mapped type\n\t\tif ( special.postDispatch ) {\n\t\t\tspecial.postDispatch.call( this, event );\n\t\t}\n\n\t\treturn event.result;\n\t},\n\n\thandlers: function( event, handlers ) {\n\t\tvar i, handleObj, sel, matchedHandlers, matchedSelectors,\n\t\t\thandlerQueue = [],\n\t\t\tdelegateCount = handlers.delegateCount,\n\t\t\tcur = event.target;\n\n\t\t// Find delegate handlers\n\t\tif ( delegateCount &&\n\n\t\t\t// Support: IE <=9\n\t\t\t// Black-hole SVG <use> instance trees (trac-13180)\n\t\t\tcur.nodeType &&\n\n\t\t\t// Support: Firefox <=42\n\t\t\t// Suppress spec-violating clicks indicating a non-primary pointer button (trac-3861)\n\t\t\t// https://www.w3.org/TR/DOM-Level-3-Events/#event-type-click\n\t\t\t// Support: IE 11 only\n\t\t\t// ...but not arrow key \"clicks\" of radio inputs, which can have `button` -1 (gh-2343)\n\t\t\t!( event.type === \"click\" && event.button >= 1 ) ) {\n\n\t\t\tfor ( ; cur !== this; cur = cur.parentNode || this ) {\n\n\t\t\t\t// Don't check non-elements (#13208)\n\t\t\t\t// Don't process clicks on disabled elements (#6911, #8165, #11382, #11764)\n\t\t\t\tif ( cur.nodeType === 1 && !( event.type === \"click\" && cur.disabled === true ) ) {\n\t\t\t\t\tmatchedHandlers = [];\n\t\t\t\t\tmatchedSelectors = {};\n\t\t\t\t\tfor ( i = 0; i < delegateCount; i++ ) {\n\t\t\t\t\t\thandleObj = handlers[ i ];\n\n\t\t\t\t\t\t// Don't conflict with Object.prototype properties (#13203)\n\t\t\t\t\t\tsel = handleObj.selector + \" \";\n\n\t\t\t\t\t\tif ( matchedSelectors[ sel ] === undefined ) {\n\t\t\t\t\t\t\tmatchedSelectors[ sel ] = handleObj.needsContext ?\n\t\t\t\t\t\t\t\tjQuery( sel, this ).index( cur ) > -1 :\n\t\t\t\t\t\t\t\tjQuery.find( sel, this, null, [ cur ] ).length;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif ( matchedSelectors[ sel ] ) {\n\t\t\t\t\t\t\tmatchedHandlers.push( handleObj );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif ( matchedHandlers.length ) {\n\t\t\t\t\t\thandlerQueue.push( { elem: cur, handlers: matchedHandlers } );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\t// Add the remaining (directly-bound) handlers\n\t\tcur = this;\n\t\tif ( delegateCount < handlers.length ) {\n\t\t\thandlerQueue.push( { elem: cur, handlers: handlers.slice( delegateCount ) } );\n\t\t}\n\n\t\treturn handlerQueue;\n\t},\n\n\taddProp: function( name, hook ) {\n\t\tObject.defineProperty( jQuery.Event.prototype, name, {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: true,\n\n\t\t\tget: isFunction( hook ) ?\n\t\t\t\tfunction() {\n\t\t\t\t\tif ( this.originalEvent ) {\n\t\t\t\t\t\t\treturn hook( this.originalEvent );\n\t\t\t\t\t}\n\t\t\t\t} :\n\t\t\t\tfunction() {\n\t\t\t\t\tif ( this.originalEvent ) {\n\t\t\t\t\t\t\treturn this.originalEvent[ name ];\n\t\t\t\t\t}\n\t\t\t\t},\n\n\t\t\tset: function( value ) {\n\t\t\t\tObject.defineProperty( this, name, {\n\t\t\t\t\tenumerable: true,\n\t\t\t\t\tconfigurable: true,\n\t\t\t\t\twritable: true,\n\t\t\t\t\tvalue: value\n\t\t\t\t} );\n\t\t\t}\n\t\t} );\n\t},\n\n\tfix: function( originalEvent ) {\n\t\treturn originalEvent[ jQuery.expando ] ?\n\t\t\toriginalEvent :\n\t\t\tnew jQuery.Event( originalEvent );\n\t},\n\n\tspecial: {\n\t\tload: {\n\n\t\t\t// Prevent triggered image.load events from bubbling to window.load\n\t\t\tnoBubble: true\n\t\t},\n\t\tclick: {\n\n\t\t\t// Utilize native event to ensure correct state for checkable inputs\n\t\t\tsetup: function( data ) {\n\n\t\t\t\t// For mutual compressibility with _default, replace `this` access with a local var.\n\t\t\t\t// `|| data` is dead code meant only to preserve the variable through minification.\n\t\t\t\tvar el = this || data;\n\n\t\t\t\t// Claim the first handler\n\t\t\t\tif ( rcheckableType.test( el.type ) &&\n\t\t\t\t\tel.click && nodeName( el, \"input\" ) ) {\n\n\t\t\t\t\t// dataPriv.set( el, \"click\", ... )\n\t\t\t\t\tleverageNative( el, \"click\", returnTrue );\n\t\t\t\t}\n\n\t\t\t\t// Return false to allow normal processing in the caller\n\t\t\t\treturn false;\n\t\t\t},\n\t\t\ttrigger: function( data ) {\n\n\t\t\t\t// For mutual compressibility with _default, replace `this` access with a local var.\n\t\t\t\t// `|| data` is dead code meant only to preserve the variable through minification.\n\t\t\t\tvar el = this || data;\n\n\t\t\t\t// Force setup before triggering a click\n\t\t\t\tif ( rcheckableType.test( el.type ) &&\n\t\t\t\t\tel.click && nodeName( el, \"input\" ) ) {\n\n\t\t\t\t\tleverageNative( el, \"click\" );\n\t\t\t\t}\n\n\t\t\t\t// Return non-false to allow normal event-path propagation\n\t\t\t\treturn true;\n\t\t\t},\n\n\t\t\t// For cross-browser consistency, suppress native .click() on links\n\t\t\t// Also prevent it if we're currently inside a leveraged native-event stack\n\t\t\t_default: function( event ) {\n\t\t\t\tvar target = event.target;\n\t\t\t\treturn rcheckableType.test( target.type ) &&\n\t\t\t\t\ttarget.click && nodeName( target, \"input\" ) &&\n\t\t\t\t\tdataPriv.get( target, \"click\" ) ||\n\t\t\t\t\tnodeName( target, \"a\" );\n\t\t\t}\n\t\t},\n\n\t\tbeforeunload: {\n\t\t\tpostDispatch: function( event ) {\n\n\t\t\t\t// Support: Firefox 20+\n\t\t\t\t// Firefox doesn't alert if the returnValue field is not set.\n\t\t\t\tif ( event.result !== undefined && event.originalEvent ) {\n\t\t\t\t\tevent.originalEvent.returnValue = event.result;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n};\n\n// Ensure the presence of an event listener that handles manually-triggered\n// synthetic events by interrupting progress until reinvoked in response to\n// *native* events that it fires directly, ensuring that state changes have\n// already occurred before other listeners are invoked.\nfunction leverageNative( el, type, expectSync ) {\n\n\t// Missing expectSync indicates a trigger call, which must force setup through jQuery.event.add\n\tif ( !expectSync ) {\n\t\tif ( dataPriv.get( el, type ) === undefined ) {\n\t\t\tjQuery.event.add( el, type, returnTrue );\n\t\t}\n\t\treturn;\n\t}\n\n\t// Register the controller as a special universal handler for all event namespaces\n\tdataPriv.set( el, type, false );\n\tjQuery.event.add( el, type, {\n\t\tnamespace: false,\n\t\thandler: function( event ) {\n\t\t\tvar notAsync, result,\n\t\t\t\tsaved = dataPriv.get( this, type );\n\n\t\t\tif ( ( event.isTrigger & 1 ) && this[ type ] ) {\n\n\t\t\t\t// Interrupt processing of the outer synthetic .trigger()ed event\n\t\t\t\t// Saved data should be false in such cases, but might be a leftover capture object\n\t\t\t\t// from an async native handler (gh-4350)\n\t\t\t\tif ( !saved.length ) {\n\n\t\t\t\t\t// Store arguments for use when handling the inner native event\n\t\t\t\t\t// There will always be at least one argument (an event object), so this array\n\t\t\t\t\t// will not be confused with a leftover capture object.\n\t\t\t\t\tsaved = slice.call( arguments );\n\t\t\t\t\tdataPriv.set( this, type, saved );\n\n\t\t\t\t\t// Trigger the native event and capture its result\n\t\t\t\t\t// Support: IE <=9 - 11+\n\t\t\t\t\t// focus() and blur() are asynchronous\n\t\t\t\t\tnotAsync = expectSync( this, type );\n\t\t\t\t\tthis[ type ]();\n\t\t\t\t\tresult = dataPriv.get( this, type );\n\t\t\t\t\tif ( saved !== result || notAsync ) {\n\t\t\t\t\t\tdataPriv.set( this, type, false );\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult = {};\n\t\t\t\t\t}\n\t\t\t\t\tif ( saved !== result ) {\n\n\t\t\t\t\t\t// Cancel the outer synthetic event\n\t\t\t\t\t\tevent.stopImmediatePropagation();\n\t\t\t\t\t\tevent.preventDefault();\n\t\t\t\t\t\treturn result.value;\n\t\t\t\t\t}\n\n\t\t\t\t// If this is an inner synthetic event for an event with a bubbling surrogate\n\t\t\t\t// (focus or blur), assume that the surrogate already propagated from triggering the\n\t\t\t\t// native event and prevent that from happening again here.\n\t\t\t\t// This technically gets the ordering wrong w.r.t. to `.trigger()` (in which the\n\t\t\t\t// bubbling surrogate propagates *after* the non-bubbling base), but that seems\n\t\t\t\t// less bad than duplication.\n\t\t\t\t} else if ( ( jQuery.event.special[ type ] || {} ).delegateType ) {\n\t\t\t\t\tevent.stopPropagation();\n\t\t\t\t}\n\n\t\t\t// If this is a native event triggered above, everything is now in order\n\t\t\t// Fire an inner synthetic event with the original arguments\n\t\t\t} else if ( saved.length ) {\n\n\t\t\t\t// ...and capture the result\n\t\t\t\tdataPriv.set( this, type, {\n\t\t\t\t\tvalue: jQuery.event.trigger(\n\n\t\t\t\t\t\t// Support: IE <=9 - 11+\n\t\t\t\t\t\t// Extend with the prototype to reset the above stopImmediatePropagation()\n\t\t\t\t\t\tjQuery.extend( saved[ 0 ], jQuery.Event.prototype ),\n\t\t\t\t\t\tsaved.slice( 1 ),\n\t\t\t\t\t\tthis\n\t\t\t\t\t)\n\t\t\t\t} );\n\n\t\t\t\t// Abort handling of the native event\n\t\t\t\tevent.stopImmediatePropagation();\n\t\t\t}\n\t\t}\n\t} );\n}\n\njQuery.removeEvent = function( elem, type, handle ) {\n\n\t// This \"if\" is needed for plain objects\n\tif ( elem.removeEventListener ) {\n\t\telem.removeEventListener( type, handle );\n\t}\n};\n\njQuery.Event = function( src, props ) {\n\n\t// Allow instantiation without the 'new' keyword\n\tif ( !( this instanceof jQuery.Event ) ) {\n\t\treturn new jQuery.Event( src, props );\n\t}\n\n\t// Event object\n\tif ( src && src.type ) {\n\t\tthis.originalEvent = src;\n\t\tthis.type = src.type;\n\n\t\t// Events bubbling up the document may have been marked as prevented\n\t\t// by a handler lower down the tree; reflect the correct value.\n\t\tthis.isDefaultPrevented = src.defaultPrevented ||\n\t\t\t\tsrc.defaultPrevented === undefined &&\n\n\t\t\t\t// Support: Android <=2.3 only\n\t\t\t\tsrc.returnValue === false ?\n\t\t\treturnTrue :\n\t\t\treturnFalse;\n\n\t\t// Create target properties\n\t\t// Support: Safari <=6 - 7 only\n\t\t// Target should not be a text node (#504, #13143)\n\t\tthis.target = ( src.target && src.target.nodeType === 3 ) ?\n\t\t\tsrc.target.parentNode :\n\t\t\tsrc.target;\n\n\t\tthis.currentTarget = src.currentTarget;\n\t\tthis.relatedTarget = src.relatedTarget;\n\n\t// Event type\n\t} else {\n\t\tthis.type = src;\n\t}\n\n\t// Put explicitly provided properties onto the event object\n\tif ( props ) {\n\t\tjQuery.extend( this, props );\n\t}\n\n\t// Create a timestamp if incoming event doesn't have one\n\tthis.timeStamp = src && src.timeStamp || Date.now();\n\n\t// Mark it as fixed\n\tthis[ jQuery.expando ] = true;\n};\n\n// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding\n// https://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html\njQuery.Event.prototype = {\n\tconstructor: jQuery.Event,\n\tisDefaultPrevented: returnFalse,\n\tisPropagationStopped: returnFalse,\n\tisImmediatePropagationStopped: returnFalse,\n\tisSimulated: false,\n\n\tpreventDefault: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isDefaultPrevented = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.preventDefault();\n\t\t}\n\t},\n\tstopPropagation: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isPropagationStopped = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.stopPropagation();\n\t\t}\n\t},\n\tstopImmediatePropagation: function() {\n\t\tvar e = this.originalEvent;\n\n\t\tthis.isImmediatePropagationStopped = returnTrue;\n\n\t\tif ( e && !this.isSimulated ) {\n\t\t\te.stopImmediatePropagation();\n\t\t}\n\n\t\tthis.stopPropagation();\n\t}\n};\n\n// Includes all common event props including KeyEvent and MouseEvent specific props\njQuery.each( {\n\taltKey: true,\n\tbubbles: true,\n\tcancelable: true,\n\tchangedTouches: true,\n\tctrlKey: true,\n\tdetail: true,\n\teventPhase: true,\n\tmetaKey: true,\n\tpageX: true,\n\tpageY: true,\n\tshiftKey: true,\n\tview: true,\n\t\"char\": true,\n\tcode: true,\n\tcharCode: true,\n\tkey: true,\n\tkeyCode: true,\n\tbutton: true,\n\tbuttons: true,\n\tclientX: true,\n\tclientY: true,\n\toffsetX: true,\n\toffsetY: true,\n\tpointerId: true,\n\tpointerType: true,\n\tscreenX: true,\n\tscreenY: true,\n\ttargetTouches: true,\n\ttoElement: true,\n\ttouches: true,\n\n\twhich: function( event ) {\n\t\tvar button = event.button;\n\n\t\t// Add which for key events\n\t\tif ( event.which == null && rkeyEvent.test( event.type ) ) {\n\t\t\treturn event.charCode != null ? event.charCode : event.keyCode;\n\t\t}\n\n\t\t// Add which for click: 1 === left; 2 === middle; 3 === right\n\t\tif ( !event.which && button !== undefined && rmouseEvent.test( event.type ) ) {\n\t\t\tif ( button & 1 ) {\n\t\t\t\treturn 1;\n\t\t\t}\n\n\t\t\tif ( button & 2 ) {\n\t\t\t\treturn 3;\n\t\t\t}\n\n\t\t\tif ( button & 4 ) {\n\t\t\t\treturn 2;\n\t\t\t}\n\n\t\t\treturn 0;\n\t\t}\n\n\t\treturn event.which;\n\t}\n}, jQuery.event.addProp );\n\njQuery.each( { focus: \"focusin\", blur: \"focusout\" }, function( type, delegateType ) {\n\tjQuery.event.special[ type ] = {\n\n\t\t// Utilize native event if possible so blur/focus sequence is correct\n\t\tsetup: function() {\n\n\t\t\t// Claim the first handler\n\t\t\t// dataPriv.set( this, \"focus\", ... )\n\t\t\t// dataPriv.set( this, \"blur\", ... )\n\t\t\tleverageNative( this, type, expectSync );\n\n\t\t\t// Return false to allow normal processing in the caller\n\t\t\treturn false;\n\t\t},\n\t\ttrigger: function() {\n\n\t\t\t// Force setup before trigger\n\t\t\tleverageNative( this, type );\n\n\t\t\t// Return non-false to allow normal event-path propagation\n\t\t\treturn true;\n\t\t},\n\n\t\tdelegateType: delegateType\n\t};\n} );\n\n// Create mouseenter/leave events using mouseover/out and event-time checks\n// so that event delegation works in jQuery.\n// Do the same for pointerenter/pointerleave and pointerover/pointerout\n//\n// Support: Safari 7 only\n// Safari sends mouseenter too often; see:\n// https://bugs.chromium.org/p/chromium/issues/detail?id=470258\n// for the description of the bug (it existed in older Chrome versions as well).\njQuery.each( {\n\tmouseenter: \"mouseover\",\n\tmouseleave: \"mouseout\",\n\tpointerenter: \"pointerover\",\n\tpointerleave: \"pointerout\"\n}, function( orig, fix ) {\n\tjQuery.event.special[ orig ] = {\n\t\tdelegateType: fix,\n\t\tbindType: fix,\n\n\t\thandle: function( event ) {\n\t\t\tvar ret,\n\t\t\t\ttarget = this,\n\t\t\t\trelated = event.relatedTarget,\n\t\t\t\thandleObj = event.handleObj;\n\n\t\t\t// For mouseenter/leave call the handler if related is outside the target.\n\t\t\t// NB: No relatedTarget if the mouse left/entered the browser window\n\t\t\tif ( !related || ( related !== target && !jQuery.contains( target, related ) ) ) {\n\t\t\t\tevent.type = handleObj.origType;\n\t\t\t\tret = handleObj.handler.apply( this, arguments );\n\t\t\t\tevent.type = fix;\n\t\t\t}\n\t\t\treturn ret;\n\t\t}\n\t};\n} );\n\njQuery.fn.extend( {\n\n\ton: function( types, selector, data, fn ) {\n\t\treturn on( this, types, selector, data, fn );\n\t},\n\tone: function( types, selector, data, fn ) {\n\t\treturn on( this, types, selector, data, fn, 1 );\n\t},\n\toff: function( types, selector, fn ) {\n\t\tvar handleObj, type;\n\t\tif ( types && types.preventDefault && types.handleObj ) {\n\n\t\t\t// ( event ) dispatched jQuery.Event\n\t\t\thandleObj = types.handleObj;\n\t\t\tjQuery( types.delegateTarget ).off(\n\t\t\t\thandleObj.namespace ?\n\t\t\t\t\thandleObj.origType + \".\" + handleObj.namespace :\n\t\t\t\t\thandleObj.origType,\n\t\t\t\thandleObj.selector,\n\t\t\t\thandleObj.handler\n\t\t\t);\n\t\t\treturn this;\n\t\t}\n\t\tif ( typeof types === \"object\" ) {\n\n\t\t\t// ( types-object [, selector] )\n\t\t\tfor ( type in types ) {\n\t\t\t\tthis.off( type, selector, types[ type ] );\n\t\t\t}\n\t\t\treturn this;\n\t\t}\n\t\tif ( selector === false || typeof selector === \"function\" ) {\n\n\t\t\t// ( types [, fn] )\n\t\t\tfn = selector;\n\t\t\tselector = undefined;\n\t\t}\n\t\tif ( fn === false ) {\n\t\t\tfn = returnFalse;\n\t\t}\n\t\treturn this.each( function() {\n\t\t\tjQuery.event.remove( this, types, fn, selector );\n\t\t} );\n\t}\n} );\n\n\nvar\n\n\t// Support: IE <=10 - 11, Edge 12 - 13 only\n\t// In IE/Edge using regex groups here causes severe slowdowns.\n\t// See https://connect.microsoft.com/IE/feedback/details/1736512/\n\trnoInnerhtml = /<script|<style|<link/i,\n\n\t// checked=\"checked\" or checked\n\trchecked = /checked\\s*(?:[^=]|=\\s*.checked.)/i,\n\trcleanScript = /^\\s*<!(?:\\[CDATA\\[|--)|(?:\\]\\]|--)>\\s*$/g;\n\n// Prefer a tbody over its parent table for containing new rows\nfunction manipulationTarget( elem, content ) {\n\tif ( nodeName( elem, \"table\" ) &&\n\t\tnodeName( content.nodeType !== 11 ? content : content.firstChild, \"tr\" ) ) {\n\n\t\treturn jQuery( elem ).children( \"tbody\" )[ 0 ] || elem;\n\t}\n\n\treturn elem;\n}\n\n// Replace/restore the type attribute of script elements for safe DOM manipulation\nfunction disableScript( elem ) {\n\telem.type = ( elem.getAttribute( \"type\" ) !== null ) + \"/\" + elem.type;\n\treturn elem;\n}\nfunction restoreScript( elem ) {\n\tif ( ( elem.type || \"\" ).slice( 0, 5 ) === \"true/\" ) {\n\t\telem.type = elem.type.slice( 5 );\n\t} else {\n\t\telem.removeAttribute( \"type\" );\n\t}\n\n\treturn elem;\n}\n\nfunction cloneCopyEvent( src, dest ) {\n\tvar i, l, type, pdataOld, udataOld, udataCur, events;\n\n\tif ( dest.nodeType !== 1 ) {\n\t\treturn;\n\t}\n\n\t// 1. Copy private data: events, handlers, etc.\n\tif ( dataPriv.hasData( src ) ) {\n\t\tpdataOld = dataPriv.get( src );\n\t\tevents = pdataOld.events;\n\n\t\tif ( events ) {\n\t\t\tdataPriv.remove( dest, \"handle events\" );\n\n\t\t\tfor ( type in events ) {\n\t\t\t\tfor ( i = 0, l = events[ type ].length; i < l; i++ ) {\n\t\t\t\t\tjQuery.event.add( dest, type, events[ type ][ i ] );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// 2. Copy user data\n\tif ( dataUser.hasData( src ) ) {\n\t\tudataOld = dataUser.access( src );\n\t\tudataCur = jQuery.extend( {}, udataOld );\n\n\t\tdataUser.set( dest, udataCur );\n\t}\n}\n\n// Fix IE bugs, see support tests\nfunction fixInput( src, dest ) {\n\tvar nodeName = dest.nodeName.toLowerCase();\n\n\t// Fails to persist the checked state of a cloned checkbox or radio button.\n\tif ( nodeName === \"input\" && rcheckableType.test( src.type ) ) {\n\t\tdest.checked = src.checked;\n\n\t// Fails to return the selected option to the default selected state when cloning options\n\t} else if ( nodeName === \"input\" || nodeName === \"textarea\" ) {\n\t\tdest.defaultValue = src.defaultValue;\n\t}\n}\n\nfunction domManip( collection, args, callback, ignored ) {\n\n\t// Flatten any nested arrays\n\targs = flat( args );\n\n\tvar fragment, first, scripts, hasScripts, node, doc,\n\t\ti = 0,\n\t\tl = collection.length,\n\t\tiNoClone = l - 1,\n\t\tvalue = args[ 0 ],\n\t\tvalueIsFunction = isFunction( value );\n\n\t// We can't cloneNode fragments that contain checked, in WebKit\n\tif ( valueIsFunction ||\n\t\t\t( l > 1 && typeof value === \"string\" &&\n\t\t\t\t!support.checkClone && rchecked.test( value ) ) ) {\n\t\treturn collection.each( function( index ) {\n\t\t\tvar self = collection.eq( index );\n\t\t\tif ( valueIsFunction ) {\n\t\t\t\targs[ 0 ] = value.call( this, index, self.html() );\n\t\t\t}\n\t\t\tdomManip( self, args, callback, ignored );\n\t\t} );\n\t}\n\n\tif ( l ) {\n\t\tfragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored );\n\t\tfirst = fragment.firstChild;\n\n\t\tif ( fragment.childNodes.length === 1 ) {\n\t\t\tfragment = first;\n\t\t}\n\n\t\t// Require either new content or an interest in ignored elements to invoke the callback\n\t\tif ( first || ignored ) {\n\t\t\tscripts = jQuery.map( getAll( fragment, \"script\" ), disableScript );\n\t\t\thasScripts = scripts.length;\n\n\t\t\t// Use the original fragment for the last item\n\t\t\t// instead of the first because it can end up\n\t\t\t// being emptied incorrectly in certain situations (#8070).\n\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\tnode = fragment;\n\n\t\t\t\tif ( i !== iNoClone ) {\n\t\t\t\t\tnode = jQuery.clone( node, true, true );\n\n\t\t\t\t\t// Keep references to cloned scripts for later restoration\n\t\t\t\t\tif ( hasScripts ) {\n\n\t\t\t\t\t\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t\t\t\t\t\t// push.apply(_, arraylike) throws on ancient WebKit\n\t\t\t\t\t\tjQuery.merge( scripts, getAll( node, \"script\" ) );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tcallback.call( collection[ i ], node, i );\n\t\t\t}\n\n\t\t\tif ( hasScripts ) {\n\t\t\t\tdoc = scripts[ scripts.length - 1 ].ownerDocument;\n\n\t\t\t\t// Reenable scripts\n\t\t\t\tjQuery.map( scripts, restoreScript );\n\n\t\t\t\t// Evaluate executable scripts on first document insertion\n\t\t\t\tfor ( i = 0; i < hasScripts; i++ ) {\n\t\t\t\t\tnode = scripts[ i ];\n\t\t\t\t\tif ( rscriptType.test( node.type || \"\" ) &&\n\t\t\t\t\t\t!dataPriv.access( node, \"globalEval\" ) &&\n\t\t\t\t\t\tjQuery.contains( doc, node ) ) {\n\n\t\t\t\t\t\tif ( node.src && ( node.type || \"\" ).toLowerCase() !== \"module\" ) {\n\n\t\t\t\t\t\t\t// Optional AJAX dependency, but won't run scripts if not present\n\t\t\t\t\t\t\tif ( jQuery._evalUrl && !node.noModule ) {\n\t\t\t\t\t\t\t\tjQuery._evalUrl( node.src, {\n\t\t\t\t\t\t\t\t\tnonce: node.nonce || node.getAttribute( \"nonce\" )\n\t\t\t\t\t\t\t\t}, doc );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tDOMEval( node.textContent.replace( rcleanScript, \"\" ), node, doc );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn collection;\n}\n\nfunction remove( elem, selector, keepData ) {\n\tvar node,\n\t\tnodes = selector ? jQuery.filter( selector, elem ) : elem,\n\t\ti = 0;\n\n\tfor ( ; ( node = nodes[ i ] ) != null; i++ ) {\n\t\tif ( !keepData && node.nodeType === 1 ) {\n\t\t\tjQuery.cleanData( getAll( node ) );\n\t\t}\n\n\t\tif ( node.parentNode ) {\n\t\t\tif ( keepData && isAttached( node ) ) {\n\t\t\t\tsetGlobalEval( getAll( node, \"script\" ) );\n\t\t\t}\n\t\t\tnode.parentNode.removeChild( node );\n\t\t}\n\t}\n\n\treturn elem;\n}\n\njQuery.extend( {\n\thtmlPrefilter: function( html ) {\n\t\treturn html;\n\t},\n\n\tclone: function( elem, dataAndEvents, deepDataAndEvents ) {\n\t\tvar i, l, srcElements, destElements,\n\t\t\tclone = elem.cloneNode( true ),\n\t\t\tinPage = isAttached( elem );\n\n\t\t// Fix IE cloning issues\n\t\tif ( !support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) &&\n\t\t\t\t!jQuery.isXMLDoc( elem ) ) {\n\n\t\t\t// We eschew Sizzle here for performance reasons: https://jsperf.com/getall-vs-sizzle/2\n\t\t\tdestElements = getAll( clone );\n\t\t\tsrcElements = getAll( elem );\n\n\t\t\tfor ( i = 0, l = srcElements.length; i < l; i++ ) {\n\t\t\t\tfixInput( srcElements[ i ], destElements[ i ] );\n\t\t\t}\n\t\t}\n\n\t\t// Copy the events from the original to the clone\n\t\tif ( dataAndEvents ) {\n\t\t\tif ( deepDataAndEvents ) {\n\t\t\t\tsrcElements = srcElements || getAll( elem );\n\t\t\t\tdestElements = destElements || getAll( clone );\n\n\t\t\t\tfor ( i = 0, l = srcElements.length; i < l; i++ ) {\n\t\t\t\t\tcloneCopyEvent( srcElements[ i ], destElements[ i ] );\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tcloneCopyEvent( elem, clone );\n\t\t\t}\n\t\t}\n\n\t\t// Preserve script evaluation history\n\t\tdestElements = getAll( clone, \"script\" );\n\t\tif ( destElements.length > 0 ) {\n\t\t\tsetGlobalEval( destElements, !inPage && getAll( elem, \"script\" ) );\n\t\t}\n\n\t\t// Return the cloned set\n\t\treturn clone;\n\t},\n\n\tcleanData: function( elems ) {\n\t\tvar data, elem, type,\n\t\t\tspecial = jQuery.event.special,\n\t\t\ti = 0;\n\n\t\tfor ( ; ( elem = elems[ i ] ) !== undefined; i++ ) {\n\t\t\tif ( acceptData( elem ) ) {\n\t\t\t\tif ( ( data = elem[ dataPriv.expando ] ) ) {\n\t\t\t\t\tif ( data.events ) {\n\t\t\t\t\t\tfor ( type in data.events ) {\n\t\t\t\t\t\t\tif ( special[ type ] ) {\n\t\t\t\t\t\t\t\tjQuery.event.remove( elem, type );\n\n\t\t\t\t\t\t\t// This is a shortcut to avoid jQuery.event.remove's overhead\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tjQuery.removeEvent( elem, type, data.handle );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Support: Chrome <=35 - 45+\n\t\t\t\t\t// Assign undefined instead of using delete, see Data#remove\n\t\t\t\t\telem[ dataPriv.expando ] = undefined;\n\t\t\t\t}\n\t\t\t\tif ( elem[ dataUser.expando ] ) {\n\n\t\t\t\t\t// Support: Chrome <=35 - 45+\n\t\t\t\t\t// Assign undefined instead of using delete, see Data#remove\n\t\t\t\t\telem[ dataUser.expando ] = undefined;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n} );\n\njQuery.fn.extend( {\n\tdetach: function( selector ) {\n\t\treturn remove( this, selector, true );\n\t},\n\n\tremove: function( selector ) {\n\t\treturn remove( this, selector );\n\t},\n\n\ttext: function( value ) {\n\t\treturn access( this, function( value ) {\n\t\t\treturn value === undefined ?\n\t\t\t\tjQuery.text( this ) :\n\t\t\t\tthis.empty().each( function() {\n\t\t\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\t\t\tthis.textContent = value;\n\t\t\t\t\t}\n\t\t\t\t} );\n\t\t}, null, value, arguments.length );\n\t},\n\n\tappend: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\tvar target = manipulationTarget( this, elem );\n\t\t\t\ttarget.appendChild( elem );\n\t\t\t}\n\t\t} );\n\t},\n\n\tprepend: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) {\n\t\t\t\tvar target = manipulationTarget( this, elem );\n\t\t\t\ttarget.insertBefore( elem, target.firstChild );\n\t\t\t}\n\t\t} );\n\t},\n\n\tbefore: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.parentNode ) {\n\t\t\t\tthis.parentNode.insertBefore( elem, this );\n\t\t\t}\n\t\t} );\n\t},\n\n\tafter: function() {\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tif ( this.parentNode ) {\n\t\t\t\tthis.parentNode.insertBefore( elem, this.nextSibling );\n\t\t\t}\n\t\t} );\n\t},\n\n\tempty: function() {\n\t\tvar elem,\n\t\t\ti = 0;\n\n\t\tfor ( ; ( elem = this[ i ] ) != null; i++ ) {\n\t\t\tif ( elem.nodeType === 1 ) {\n\n\t\t\t\t// Prevent memory leaks\n\t\t\t\tjQuery.cleanData( getAll( elem, false ) );\n\n\t\t\t\t// Remove any remaining nodes\n\t\t\t\telem.textContent = \"\";\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tclone: function( dataAndEvents, deepDataAndEvents ) {\n\t\tdataAndEvents = dataAndEvents == null ? false : dataAndEvents;\n\t\tdeepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;\n\n\t\treturn this.map( function() {\n\t\t\treturn jQuery.clone( this, dataAndEvents, deepDataAndEvents );\n\t\t} );\n\t},\n\n\thtml: function( value ) {\n\t\treturn access( this, function( value ) {\n\t\t\tvar elem = this[ 0 ] || {},\n\t\t\t\ti = 0,\n\t\t\t\tl = this.length;\n\n\t\t\tif ( value === undefined && elem.nodeType === 1 ) {\n\t\t\t\treturn elem.innerHTML;\n\t\t\t}\n\n\t\t\t// See if we can take a shortcut and just use innerHTML\n\t\t\tif ( typeof value === \"string\" && !rnoInnerhtml.test( value ) &&\n\t\t\t\t!wrapMap[ ( rtagName.exec( value ) || [ \"\", \"\" ] )[ 1 ].toLowerCase() ] ) {\n\n\t\t\t\tvalue = jQuery.htmlPrefilter( value );\n\n\t\t\t\ttry {\n\t\t\t\t\tfor ( ; i < l; i++ ) {\n\t\t\t\t\t\telem = this[ i ] || {};\n\n\t\t\t\t\t\t// Remove element nodes and prevent memory leaks\n\t\t\t\t\t\tif ( elem.nodeType === 1 ) {\n\t\t\t\t\t\t\tjQuery.cleanData( getAll( elem, false ) );\n\t\t\t\t\t\t\telem.innerHTML = value;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\telem = 0;\n\n\t\t\t\t// If using innerHTML throws an exception, use the fallback method\n\t\t\t\t} catch ( e ) {}\n\t\t\t}\n\n\t\t\tif ( elem ) {\n\t\t\t\tthis.empty().append( value );\n\t\t\t}\n\t\t}, null, value, arguments.length );\n\t},\n\n\treplaceWith: function() {\n\t\tvar ignored = [];\n\n\t\t// Make the changes, replacing each non-ignored context element with the new content\n\t\treturn domManip( this, arguments, function( elem ) {\n\t\t\tvar parent = this.parentNode;\n\n\t\t\tif ( jQuery.inArray( this, ignored ) < 0 ) {\n\t\t\t\tjQuery.cleanData( getAll( this ) );\n\t\t\t\tif ( parent ) {\n\t\t\t\t\tparent.replaceChild( elem, this );\n\t\t\t\t}\n\t\t\t}\n\n\t\t// Force callback invocation\n\t\t}, ignored );\n\t}\n} );\n\njQuery.each( {\n\tappendTo: \"append\",\n\tprependTo: \"prepend\",\n\tinsertBefore: \"before\",\n\tinsertAfter: \"after\",\n\treplaceAll: \"replaceWith\"\n}, function( name, original ) {\n\tjQuery.fn[ name ] = function( selector ) {\n\t\tvar elems,\n\t\t\tret = [],\n\t\t\tinsert = jQuery( selector ),\n\t\t\tlast = insert.length - 1,\n\t\t\ti = 0;\n\n\t\tfor ( ; i <= last; i++ ) {\n\t\t\telems = i === last ? this : this.clone( true );\n\t\t\tjQuery( insert[ i ] )[ original ]( elems );\n\n\t\t\t// Support: Android <=4.0 only, PhantomJS 1 only\n\t\t\t// .get() because push.apply(_, arraylike) throws on ancient WebKit\n\t\t\tpush.apply( ret, elems.get() );\n\t\t}\n\n\t\treturn this.pushStack( ret );\n\t};\n} );\nvar rnumnonpx = new RegExp( \"^(\" + pnum + \")(?!px)[a-z%]+$\", \"i\" );\n\nvar getStyles = function( elem ) {\n\n\t\t// Support: IE <=11 only, Firefox <=30 (#15098, #14150)\n\t\t// IE throws on elements created in popups\n\t\t// FF meanwhile throws on frame elements through \"defaultView.getComputedStyle\"\n\t\tvar view = elem.ownerDocument.defaultView;\n\n\t\tif ( !view || !view.opener ) {\n\t\t\tview = window;\n\t\t}\n\n\t\treturn view.getComputedStyle( elem );\n\t};\n\nvar swap = function( elem, options, callback ) {\n\tvar ret, name,\n\t\told = {};\n\n\t// Remember the old values, and insert the new ones\n\tfor ( name in options ) {\n\t\told[ name ] = elem.style[ name ];\n\t\telem.style[ name ] = options[ name ];\n\t}\n\n\tret = callback.call( elem );\n\n\t// Revert the old values\n\tfor ( name in options ) {\n\t\telem.style[ name ] = old[ name ];\n\t}\n\n\treturn ret;\n};\n\n\nvar rboxStyle = new RegExp( cssExpand.join( \"|\" ), \"i\" );\n\n\n\n( function() {\n\n\t// Executing both pixelPosition & boxSizingReliable tests require only one layout\n\t// so they're executed at the same time to save the second computation.\n\tfunction computeStyleTests() {\n\n\t\t// This is a singleton, we need to execute it only once\n\t\tif ( !div ) {\n\t\t\treturn;\n\t\t}\n\n\t\tcontainer.style.cssText = \"position:absolute;left:-11111px;width:60px;\" +\n\t\t\t\"margin-top:1px;padding:0;border:0\";\n\t\tdiv.style.cssText =\n\t\t\t\"position:relative;display:block;box-sizing:border-box;overflow:scroll;\" +\n\t\t\t\"margin:auto;border:1px;padding:1px;\" +\n\t\t\t\"width:60%;top:1%\";\n\t\tdocumentElement.appendChild( container ).appendChild( div );\n\n\t\tvar divStyle = window.getComputedStyle( div );\n\t\tpixelPositionVal = divStyle.top !== \"1%\";\n\n\t\t// Support: Android 4.0 - 4.3 only, Firefox <=3 - 44\n\t\treliableMarginLeftVal = roundPixelMeasures( divStyle.marginLeft ) === 12;\n\n\t\t// Support: Android 4.0 - 4.3 only, Safari <=9.1 - 10.1, iOS <=7.0 - 9.3\n\t\t// Some styles come back with percentage values, even though they shouldn't\n\t\tdiv.style.right = \"60%\";\n\t\tpixelBoxStylesVal = roundPixelMeasures( divStyle.right ) === 36;\n\n\t\t// Support: IE 9 - 11 only\n\t\t// Detect misreporting of content dimensions for box-sizing:border-box elements\n\t\tboxSizingReliableVal = roundPixelMeasures( divStyle.width ) === 36;\n\n\t\t// Support: IE 9 only\n\t\t// Detect overflow:scroll screwiness (gh-3699)\n\t\t// Support: Chrome <=64\n\t\t// Don't get tricked when zoom affects offsetWidth (gh-4029)\n\t\tdiv.style.position = \"absolute\";\n\t\tscrollboxSizeVal = roundPixelMeasures( div.offsetWidth / 3 ) === 12;\n\n\t\tdocumentElement.removeChild( container );\n\n\t\t// Nullify the div so it wouldn't be stored in the memory and\n\t\t// it will also be a sign that checks already performed\n\t\tdiv = null;\n\t}\n\n\tfunction roundPixelMeasures( measure ) {\n\t\treturn Math.round( parseFloat( measure ) );\n\t}\n\n\tvar pixelPositionVal, boxSizingReliableVal, scrollboxSizeVal, pixelBoxStylesVal,\n\t\treliableTrDimensionsVal, reliableMarginLeftVal,\n\t\tcontainer = document.createElement( \"div\" ),\n\t\tdiv = document.createElement( \"div\" );\n\n\t// Finish early in limited (non-browser) environments\n\tif ( !div.style ) {\n\t\treturn;\n\t}\n\n\t// Support: IE <=9 - 11 only\n\t// Style of cloned element affects source element cloned (#8908)\n\tdiv.style.backgroundClip = \"content-box\";\n\tdiv.cloneNode( true ).style.backgroundClip = \"\";\n\tsupport.clearCloneStyle = div.style.backgroundClip === \"content-box\";\n\n\tjQuery.extend( support, {\n\t\tboxSizingReliable: function() {\n\t\t\tcomputeStyleTests();\n\t\t\treturn boxSizingReliableVal;\n\t\t},\n\t\tpixelBoxStyles: function() {\n\t\t\tcomputeStyleTests();\n\t\t\treturn pixelBoxStylesVal;\n\t\t},\n\t\tpixelPosition: function() {\n\t\t\tcomputeStyleTests();\n\t\t\treturn pixelPositionVal;\n\t\t},\n\t\treliableMarginLeft: function() {\n\t\t\tcomputeStyleTests();\n\t\t\treturn reliableMarginLeftVal;\n\t\t},\n\t\tscrollboxSize: function() {\n\t\t\tcomputeStyleTests();\n\t\t\treturn scrollboxSizeVal;\n\t\t},\n\n\t\t// Support: IE 9 - 11+, Edge 15 - 18+\n\t\t// IE/Edge misreport `getComputedStyle` of table rows with width/height\n\t\t// set in CSS while `offset*` properties report correct values.\n\t\t// Behavior in IE 9 is more subtle than in newer versions & it passes\n\t\t// some versions of this test; make sure not to make it pass there!\n\t\treliableTrDimensions: function() {\n\t\t\tvar table, tr, trChild, trStyle;\n\t\t\tif ( reliableTrDimensionsVal == null ) {\n\t\t\t\ttable = document.createElement( \"table\" );\n\t\t\t\ttr = document.createElement( \"tr\" );\n\t\t\t\ttrChild = document.createElement( \"div\" );\n\n\t\t\t\ttable.style.cssText = \"position:absolute;left:-11111px\";\n\t\t\t\ttr.style.height = \"1px\";\n\t\t\t\ttrChild.style.height = \"9px\";\n\n\t\t\t\tdocumentElement\n\t\t\t\t\t.appendChild( table )\n\t\t\t\t\t.appendChild( tr )\n\t\t\t\t\t.appendChild( trChild );\n\n\t\t\t\ttrStyle = window.getComputedStyle( tr );\n\t\t\t\treliableTrDimensionsVal = parseInt( trStyle.height ) > 3;\n\n\t\t\t\tdocumentElement.removeChild( table );\n\t\t\t}\n\t\t\treturn reliableTrDimensionsVal;\n\t\t}\n\t} );\n} )();\n\n\nfunction curCSS( elem, name, computed ) {\n\tvar width, minWidth, maxWidth, ret,\n\n\t\t// Support: Firefox 51+\n\t\t// Retrieving style before computed somehow\n\t\t// fixes an issue with getting wrong values\n\t\t// on detached elements\n\t\tstyle = elem.style;\n\n\tcomputed = computed || getStyles( elem );\n\n\t// getPropertyValue is needed for:\n\t// .css('filter') (IE 9 only, #12537)\n\t// .css('--customProperty) (#3144)\n\tif ( computed ) {\n\t\tret = computed.getPropertyValue( name ) || computed[ name ];\n\n\t\tif ( ret === \"\" && !isAttached( elem ) ) {\n\t\t\tret = jQuery.style( elem, name );\n\t\t}\n\n\t\t// A tribute to the \"awesome hack by Dean Edwards\"\n\t\t// Android Browser returns percentage for some values,\n\t\t// but width seems to be reliably pixels.\n\t\t// This is against the CSSOM draft spec:\n\t\t// https://drafts.csswg.org/cssom/#resolved-values\n\t\tif ( !support.pixelBoxStyles() && rnumnonpx.test( ret ) && rboxStyle.test( name ) ) {\n\n\t\t\t// Remember the original values\n\t\t\twidth = style.width;\n\t\t\tminWidth = style.minWidth;\n\t\t\tmaxWidth = style.maxWidth;\n\n\t\t\t// Put in the new values to get a computed value out\n\t\t\tstyle.minWidth = style.maxWidth = style.width = ret;\n\t\t\tret = computed.width;\n\n\t\t\t// Revert the changed values\n\t\t\tstyle.width = width;\n\t\t\tstyle.minWidth = minWidth;\n\t\t\tstyle.maxWidth = maxWidth;\n\t\t}\n\t}\n\n\treturn ret !== undefined ?\n\n\t\t// Support: IE <=9 - 11 only\n\t\t// IE returns zIndex value as an integer.\n\t\tret + \"\" :\n\t\tret;\n}\n\n\nfunction addGetHookIf( conditionFn, hookFn ) {\n\n\t// Define the hook, we'll check on the first run if it's really needed.\n\treturn {\n\t\tget: function() {\n\t\t\tif ( conditionFn() ) {\n\n\t\t\t\t// Hook not needed (or it's not possible to use it due\n\t\t\t\t// to missing dependency), remove it.\n\t\t\t\tdelete this.get;\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Hook needed; redefine it so that the support test is not executed again.\n\t\t\treturn ( this.get = hookFn ).apply( this, arguments );\n\t\t}\n\t};\n}\n\n\nvar cssPrefixes = [ \"Webkit\", \"Moz\", \"ms\" ],\n\temptyStyle = document.createElement( \"div\" ).style,\n\tvendorProps = {};\n\n// Return a vendor-prefixed property or undefined\nfunction vendorPropName( name ) {\n\n\t// Check for vendor prefixed names\n\tvar capName = name[ 0 ].toUpperCase() + name.slice( 1 ),\n\t\ti = cssPrefixes.length;\n\n\twhile ( i-- ) {\n\t\tname = cssPrefixes[ i ] + capName;\n\t\tif ( name in emptyStyle ) {\n\t\t\treturn name;\n\t\t}\n\t}\n}\n\n// Return a potentially-mapped jQuery.cssProps or vendor prefixed property\nfunction finalPropName( name ) {\n\tvar final = jQuery.cssProps[ name ] || vendorProps[ name ];\n\n\tif ( final ) {\n\t\treturn final;\n\t}\n\tif ( name in emptyStyle ) {\n\t\treturn name;\n\t}\n\treturn vendorProps[ name ] = vendorPropName( name ) || name;\n}\n\n\nvar\n\n\t// Swappable if display is none or starts with table\n\t// except \"table\", \"table-cell\", or \"table-caption\"\n\t// See here for display values: https://developer.mozilla.org/en-US/docs/CSS/display\n\trdisplayswap = /^(none|table(?!-c[ea]).+)/,\n\trcustomProp = /^--/,\n\tcssShow = { position: \"absolute\", visibility: \"hidden\", display: \"block\" },\n\tcssNormalTransform = {\n\t\tletterSpacing: \"0\",\n\t\tfontWeight: \"400\"\n\t};\n\nfunction setPositiveNumber( _elem, value, subtract ) {\n\n\t// Any relative (+/-) values have already been\n\t// normalized at this point\n\tvar matches = rcssNum.exec( value );\n\treturn matches ?\n\n\t\t// Guard against undefined \"subtract\", e.g., when used as in cssHooks\n\t\tMath.max( 0, matches[ 2 ] - ( subtract || 0 ) ) + ( matches[ 3 ] || \"px\" ) :\n\t\tvalue;\n}\n\nfunction boxModelAdjustment( elem, dimension, box, isBorderBox, styles, computedVal ) {\n\tvar i = dimension === \"width\" ? 1 : 0,\n\t\textra = 0,\n\t\tdelta = 0;\n\n\t// Adjustment may not be necessary\n\tif ( box === ( isBorderBox ? \"border\" : \"content\" ) ) {\n\t\treturn 0;\n\t}\n\n\tfor ( ; i < 4; i += 2 ) {\n\n\t\t// Both box models exclude margin\n\t\tif ( box === \"margin\" ) {\n\t\t\tdelta += jQuery.css( elem, box + cssExpand[ i ], true, styles );\n\t\t}\n\n\t\t// If we get here with a content-box, we're seeking \"padding\" or \"border\" or \"margin\"\n\t\tif ( !isBorderBox ) {\n\n\t\t\t// Add padding\n\t\t\tdelta += jQuery.css( elem, \"padding\" + cssExpand[ i ], true, styles );\n\n\t\t\t// For \"border\" or \"margin\", add border\n\t\t\tif ( box !== \"padding\" ) {\n\t\t\t\tdelta += jQuery.css( elem, \"border\" + cssExpand[ i ] + \"Width\", true, styles );\n\n\t\t\t// But still keep track of it otherwise\n\t\t\t} else {\n\t\t\t\textra += jQuery.css( elem, \"border\" + cssExpand[ i ] + \"Width\", true, styles );\n\t\t\t}\n\n\t\t// If we get here with a border-box (content + padding + border), we're seeking \"content\" or\n\t\t// \"padding\" or \"margin\"\n\t\t} else {\n\n\t\t\t// For \"content\", subtract padding\n\t\t\tif ( box === \"content\" ) {\n\t\t\t\tdelta -= jQuery.css( elem, \"padding\" + cssExpand[ i ], true, styles );\n\t\t\t}\n\n\t\t\t// For \"content\" or \"padding\", subtract border\n\t\t\tif ( box !== \"margin\" ) {\n\t\t\t\tdelta -= jQuery.css( elem, \"border\" + cssExpand[ i ] + \"Width\", true, styles );\n\t\t\t}\n\t\t}\n\t}\n\n\t// Account for positive content-box scroll gutter when requested by providing computedVal\n\tif ( !isBorderBox && computedVal >= 0 ) {\n\n\t\t// offsetWidth/offsetHeight is a rounded sum of content, padding, scroll gutter, and border\n\t\t// Assuming integer scroll gutter, subtract the rest and round down\n\t\tdelta += Math.max( 0, Math.ceil(\n\t\t\telem[ \"offset\" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] -\n\t\t\tcomputedVal -\n\t\t\tdelta -\n\t\t\textra -\n\t\t\t0.5\n\n\t\t// If offsetWidth/offsetHeight is unknown, then we can't determine content-box scroll gutter\n\t\t// Use an explicit zero to avoid NaN (gh-3964)\n\t\t) ) || 0;\n\t}\n\n\treturn delta;\n}\n\nfunction getWidthOrHeight( elem, dimension, extra ) {\n\n\t// Start with computed style\n\tvar styles = getStyles( elem ),\n\n\t\t// To avoid forcing a reflow, only fetch boxSizing if we need it (gh-4322).\n\t\t// Fake content-box until we know it's needed to know the true value.\n\t\tboxSizingNeeded = !support.boxSizingReliable() || extra,\n\t\tisBorderBox = boxSizingNeeded &&\n\t\t\tjQuery.css( elem, \"boxSizing\", false, styles ) === \"border-box\",\n\t\tvalueIsBorderBox = isBorderBox,\n\n\t\tval = curCSS( elem, dimension, styles ),\n\t\toffsetProp = \"offset\" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 );\n\n\t// Support: Firefox <=54\n\t// Return a confounding non-pixel value or feign ignorance, as appropriate.\n\tif ( rnumnonpx.test( val ) ) {\n\t\tif ( !extra ) {\n\t\t\treturn val;\n\t\t}\n\t\tval = \"auto\";\n\t}\n\n\n\t// Support: IE 9 - 11 only\n\t// Use offsetWidth/offsetHeight for when box sizing is unreliable.\n\t// In those cases, the computed value can be trusted to be border-box.\n\tif ( ( !support.boxSizingReliable() && isBorderBox ||\n\n\t\t// Support: IE 10 - 11+, Edge 15 - 18+\n\t\t// IE/Edge misreport `getComputedStyle` of table rows with width/height\n\t\t// set in CSS while `offset*` properties report correct values.\n\t\t// Interestingly, in some cases IE 9 doesn't suffer from this issue.\n\t\t!support.reliableTrDimensions() && nodeName( elem, \"tr\" ) ||\n\n\t\t// Fall back to offsetWidth/offsetHeight when value is \"auto\"\n\t\t// This happens for inline elements with no explicit setting (gh-3571)\n\t\tval === \"auto\" ||\n\n\t\t// Support: Android <=4.1 - 4.3 only\n\t\t// Also use offsetWidth/offsetHeight for misreported inline dimensions (gh-3602)\n\t\t!parseFloat( val ) && jQuery.css( elem, \"display\", false, styles ) === \"inline\" ) &&\n\n\t\t// Make sure the element is visible & connected\n\t\telem.getClientRects().length ) {\n\n\t\tisBorderBox = jQuery.css( elem, \"boxSizing\", false, styles ) === \"border-box\";\n\n\t\t// Where available, offsetWidth/offsetHeight approximate border box dimensions.\n\t\t// Where not available (e.g., SVG), assume unreliable box-sizing and interpret the\n\t\t// retrieved value as a content box dimension.\n\t\tvalueIsBorderBox = offsetProp in elem;\n\t\tif ( valueIsBorderBox ) {\n\t\t\tval = elem[ offsetProp ];\n\t\t}\n\t}\n\n\t// Normalize \"\" and auto\n\tval = parseFloat( val ) || 0;\n\n\t// Adjust for the element's box model\n\treturn ( val +\n\t\tboxModelAdjustment(\n\t\t\telem,\n\t\t\tdimension,\n\t\t\textra || ( isBorderBox ? \"border\" : \"content\" ),\n\t\t\tvalueIsBorderBox,\n\t\t\tstyles,\n\n\t\t\t// Provide the current computed size to request scroll gutter calculation (gh-3589)\n\t\t\tval\n\t\t)\n\t) + \"px\";\n}\n\njQuery.extend( {\n\n\t// Add in style property hooks for overriding the default\n\t// behavior of getting and setting a style property\n\tcssHooks: {\n\t\topacity: {\n\t\t\tget: function( elem, computed ) {\n\t\t\t\tif ( computed ) {\n\n\t\t\t\t\t// We should always get a number back from opacity\n\t\t\t\t\tvar ret = curCSS( elem, \"opacity\" );\n\t\t\t\t\treturn ret === \"\" ? \"1\" : ret;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\t// Don't automatically add \"px\" to these possibly-unitless properties\n\tcssNumber: {\n\t\t\"animationIterationCount\": true,\n\t\t\"columnCount\": true,\n\t\t\"fillOpacity\": true,\n\t\t\"flexGrow\": true,\n\t\t\"flexShrink\": true,\n\t\t\"fontWeight\": true,\n\t\t\"gridArea\": true,\n\t\t\"gridColumn\": true,\n\t\t\"gridColumnEnd\": true,\n\t\t\"gridColumnStart\": true,\n\t\t\"gridRow\": true,\n\t\t\"gridRowEnd\": true,\n\t\t\"gridRowStart\": true,\n\t\t\"lineHeight\": true,\n\t\t\"opacity\": true,\n\t\t\"order\": true,\n\t\t\"orphans\": true,\n\t\t\"widows\": true,\n\t\t\"zIndex\": true,\n\t\t\"zoom\": true\n\t},\n\n\t// Add in properties whose names you wish to fix before\n\t// setting or getting the value\n\tcssProps: {},\n\n\t// Get and set the style property on a DOM Node\n\tstyle: function( elem, name, value, extra ) {\n\n\t\t// Don't set styles on text and comment nodes\n\t\tif ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Make sure that we're working with the right name\n\t\tvar ret, type, hooks,\n\t\t\torigName = camelCase( name ),\n\t\t\tisCustomProp = rcustomProp.test( name ),\n\t\t\tstyle = elem.style;\n\n\t\t// Make sure that we're working with the right name. We don't\n\t\t// want to query the value if it is a CSS custom property\n\t\t// since they are user-defined.\n\t\tif ( !isCustomProp ) {\n\t\t\tname = finalPropName( origName );\n\t\t}\n\n\t\t// Gets hook for the prefixed version, then unprefixed version\n\t\thooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];\n\n\t\t// Check if we're setting a value\n\t\tif ( value !== undefined ) {\n\t\t\ttype = typeof value;\n\n\t\t\t// Convert \"+=\" or \"-=\" to relative numbers (#7345)\n\t\t\tif ( type === \"string\" && ( ret = rcssNum.exec( value ) ) && ret[ 1 ] ) {\n\t\t\t\tvalue = adjustCSS( elem, name, ret );\n\n\t\t\t\t// Fixes bug #9237\n\t\t\t\ttype = \"number\";\n\t\t\t}\n\n\t\t\t// Make sure that null and NaN values aren't set (#7116)\n\t\t\tif ( value == null || value !== value ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// If a number was passed in, add the unit (except for certain CSS properties)\n\t\t\t// The isCustomProp check can be removed in jQuery 4.0 when we only auto-append\n\t\t\t// \"px\" to a few hardcoded values.\n\t\t\tif ( type === \"number\" && !isCustomProp ) {\n\t\t\t\tvalue += ret && ret[ 3 ] || ( jQuery.cssNumber[ origName ] ? \"\" : \"px\" );\n\t\t\t}\n\n\t\t\t// background-* props affect original clone's values\n\t\t\tif ( !support.clearCloneStyle && value === \"\" && name.indexOf( \"background\" ) === 0 ) {\n\t\t\t\tstyle[ name ] = \"inherit\";\n\t\t\t}\n\n\t\t\t// If a hook was provided, use that value, otherwise just set the specified value\n\t\t\tif ( !hooks || !( \"set\" in hooks ) ||\n\t\t\t\t( value = hooks.set( elem, value, extra ) ) !== undefined ) {\n\n\t\t\t\tif ( isCustomProp ) {\n\t\t\t\t\tstyle.setProperty( name, value );\n\t\t\t\t} else {\n\t\t\t\t\tstyle[ name ] = value;\n\t\t\t\t}\n\t\t\t}\n\n\t\t} else {\n\n\t\t\t// If a hook was provided get the non-computed value from there\n\t\t\tif ( hooks && \"get\" in hooks &&\n\t\t\t\t( ret = hooks.get( elem, false, extra ) ) !== undefined ) {\n\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\t// Otherwise just get the value from the style object\n\t\t\treturn style[ name ];\n\t\t}\n\t},\n\n\tcss: function( elem, name, extra, styles ) {\n\t\tvar val, num, hooks,\n\t\t\torigName = camelCase( name ),\n\t\t\tisCustomProp = rcustomProp.test( name );\n\n\t\t// Make sure that we're working with the right name. We don't\n\t\t// want to modify the value if it is a CSS custom property\n\t\t// since they are user-defined.\n\t\tif ( !isCustomProp ) {\n\t\t\tname = finalPropName( origName );\n\t\t}\n\n\t\t// Try prefixed name followed by the unprefixed name\n\t\thooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ];\n\n\t\t// If a hook was provided get the computed value from there\n\t\tif ( hooks && \"get\" in hooks ) {\n\t\t\tval = hooks.get( elem, true, extra );\n\t\t}\n\n\t\t// Otherwise, if a way to get the computed value exists, use that\n\t\tif ( val === undefined ) {\n\t\t\tval = curCSS( elem, name, styles );\n\t\t}\n\n\t\t// Convert \"normal\" to computed value\n\t\tif ( val === \"normal\" && name in cssNormalTransform ) {\n\t\t\tval = cssNormalTransform[ name ];\n\t\t}\n\n\t\t// Make numeric if forced or a qualifier was provided and val looks numeric\n\t\tif ( extra === \"\" || extra ) {\n\t\t\tnum = parseFloat( val );\n\t\t\treturn extra === true || isFinite( num ) ? num || 0 : val;\n\t\t}\n\n\t\treturn val;\n\t}\n} );\n\njQuery.each( [ \"height\", \"width\" ], function( _i, dimension ) {\n\tjQuery.cssHooks[ dimension ] = {\n\t\tget: function( elem, computed, extra ) {\n\t\t\tif ( computed ) {\n\n\t\t\t\t// Certain elements can have dimension info if we invisibly show them\n\t\t\t\t// but it must have a current display style that would benefit\n\t\t\t\treturn rdisplayswap.test( jQuery.css( elem, \"display\" ) ) &&\n\n\t\t\t\t\t// Support: Safari 8+\n\t\t\t\t\t// Table columns in Safari have non-zero offsetWidth & zero\n\t\t\t\t\t// getBoundingClientRect().width unless display is changed.\n\t\t\t\t\t// Support: IE <=11 only\n\t\t\t\t\t// Running getBoundingClientRect on a disconnected node\n\t\t\t\t\t// in IE throws an error.\n\t\t\t\t\t( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ?\n\t\t\t\t\t\tswap( elem, cssShow, function() {\n\t\t\t\t\t\t\treturn getWidthOrHeight( elem, dimension, extra );\n\t\t\t\t\t\t} ) :\n\t\t\t\t\t\tgetWidthOrHeight( elem, dimension, extra );\n\t\t\t}\n\t\t},\n\n\t\tset: function( elem, value, extra ) {\n\t\t\tvar matches,\n\t\t\t\tstyles = getStyles( elem ),\n\n\t\t\t\t// Only read styles.position if the test has a chance to fail\n\t\t\t\t// to avoid forcing a reflow.\n\t\t\t\tscrollboxSizeBuggy = !support.scrollboxSize() &&\n\t\t\t\t\tstyles.position === \"absolute\",\n\n\t\t\t\t// To avoid forcing a reflow, only fetch boxSizing if we need it (gh-3991)\n\t\t\t\tboxSizingNeeded = scrollboxSizeBuggy || extra,\n\t\t\t\tisBorderBox = boxSizingNeeded &&\n\t\t\t\t\tjQuery.css( elem, \"boxSizing\", false, styles ) === \"border-box\",\n\t\t\t\tsubtract = extra ?\n\t\t\t\t\tboxModelAdjustment(\n\t\t\t\t\t\telem,\n\t\t\t\t\t\tdimension,\n\t\t\t\t\t\textra,\n\t\t\t\t\t\tisBorderBox,\n\t\t\t\t\t\tstyles\n\t\t\t\t\t) :\n\t\t\t\t\t0;\n\n\t\t\t// Account for unreliable border-box dimensions by comparing offset* to computed and\n\t\t\t// faking a content-box to get border and padding (gh-3699)\n\t\t\tif ( isBorderBox && scrollboxSizeBuggy ) {\n\t\t\t\tsubtract -= Math.ceil(\n\t\t\t\t\telem[ \"offset\" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] -\n\t\t\t\t\tparseFloat( styles[ dimension ] ) -\n\t\t\t\t\tboxModelAdjustment( elem, dimension, \"border\", false, styles ) -\n\t\t\t\t\t0.5\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Convert to pixels if value adjustment is needed\n\t\t\tif ( subtract && ( matches = rcssNum.exec( value ) ) &&\n\t\t\t\t( matches[ 3 ] || \"px\" ) !== \"px\" ) {\n\n\t\t\t\telem.style[ dimension ] = value;\n\t\t\t\tvalue = jQuery.css( elem, dimension );\n\t\t\t}\n\n\t\t\treturn setPositiveNumber( elem, value, subtract );\n\t\t}\n\t};\n} );\n\njQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,\n\tfunction( elem, computed ) {\n\t\tif ( computed ) {\n\t\t\treturn ( parseFloat( curCSS( elem, \"marginLeft\" ) ) ||\n\t\t\t\telem.getBoundingClientRect().left -\n\t\t\t\t\tswap( elem, { marginLeft: 0 }, function() {\n\t\t\t\t\t\treturn elem.getBoundingClientRect().left;\n\t\t\t\t\t} )\n\t\t\t\t) + \"px\";\n\t\t}\n\t}\n);\n\n// These hooks are used by animate to expand properties\njQuery.each( {\n\tmargin: \"\",\n\tpadding: \"\",\n\tborder: \"Width\"\n}, function( prefix, suffix ) {\n\tjQuery.cssHooks[ prefix + suffix ] = {\n\t\texpand: function( value ) {\n\t\t\tvar i = 0,\n\t\t\t\texpanded = {},\n\n\t\t\t\t// Assumes a single number if not a string\n\t\t\t\tparts = typeof value === \"string\" ? value.split( \" \" ) : [ value ];\n\n\t\t\tfor ( ; i < 4; i++ ) {\n\t\t\t\texpanded[ prefix + cssExpand[ i ] + suffix ] =\n\t\t\t\t\tparts[ i ] || parts[ i - 2 ] || parts[ 0 ];\n\t\t\t}\n\n\t\t\treturn expanded;\n\t\t}\n\t};\n\n\tif ( prefix !== \"margin\" ) {\n\t\tjQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber;\n\t}\n} );\n\njQuery.fn.extend( {\n\tcss: function( name, value ) {\n\t\treturn access( this, function( elem, name, value ) {\n\t\t\tvar styles, len,\n\t\t\t\tmap = {},\n\t\t\t\ti = 0;\n\n\t\t\tif ( Array.isArray( name ) ) {\n\t\t\t\tstyles = getStyles( elem );\n\t\t\t\tlen = name.length;\n\n\t\t\t\tfor ( ; i < len; i++ ) {\n\t\t\t\t\tmap[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles );\n\t\t\t\t}\n\n\t\t\t\treturn map;\n\t\t\t}\n\n\t\t\treturn value !== undefined ?\n\t\t\t\tjQuery.style( elem, name, value ) :\n\t\t\t\tjQuery.css( elem, name );\n\t\t}, name, value, arguments.length > 1 );\n\t}\n} );\n\n\nfunction Tween( elem, options, prop, end, easing ) {\n\treturn new Tween.prototype.init( elem, options, prop, end, easing );\n}\njQuery.Tween = Tween;\n\nTween.prototype = {\n\tconstructor: Tween,\n\tinit: function( elem, options, prop, end, easing, unit ) {\n\t\tthis.elem = elem;\n\t\tthis.prop = prop;\n\t\tthis.easing = easing || jQuery.easing._default;\n\t\tthis.options = options;\n\t\tthis.start = this.now = this.cur();\n\t\tthis.end = end;\n\t\tthis.unit = unit || ( jQuery.cssNumber[ prop ] ? \"\" : \"px\" );\n\t},\n\tcur: function() {\n\t\tvar hooks = Tween.propHooks[ this.prop ];\n\n\t\treturn hooks && hooks.get ?\n\t\t\thooks.get( this ) :\n\t\t\tTween.propHooks._default.get( this );\n\t},\n\trun: function( percent ) {\n\t\tvar eased,\n\t\t\thooks = Tween.propHooks[ this.prop ];\n\n\t\tif ( this.options.duration ) {\n\t\t\tthis.pos = eased = jQuery.easing[ this.easing ](\n\t\t\t\tpercent, this.options.duration * percent, 0, 1, this.options.duration\n\t\t\t);\n\t\t} else {\n\t\t\tthis.pos = eased = percent;\n\t\t}\n\t\tthis.now = ( this.end - this.start ) * eased + this.start;\n\n\t\tif ( this.options.step ) {\n\t\t\tthis.options.step.call( this.elem, this.now, this );\n\t\t}\n\n\t\tif ( hooks && hooks.set ) {\n\t\t\thooks.set( this );\n\t\t} else {\n\t\t\tTween.propHooks._default.set( this );\n\t\t}\n\t\treturn this;\n\t}\n};\n\nTween.prototype.init.prototype = Tween.prototype;\n\nTween.propHooks = {\n\t_default: {\n\t\tget: function( tween ) {\n\t\t\tvar result;\n\n\t\t\t// Use a property on the element directly when it is not a DOM element,\n\t\t\t// or when there is no matching style property that exists.\n\t\t\tif ( tween.elem.nodeType !== 1 ||\n\t\t\t\ttween.elem[ tween.prop ] != null && tween.elem.style[ tween.prop ] == null ) {\n\t\t\t\treturn tween.elem[ tween.prop ];\n\t\t\t}\n\n\t\t\t// Passing an empty string as a 3rd parameter to .css will automatically\n\t\t\t// attempt a parseFloat and fallback to a string if the parse fails.\n\t\t\t// Simple values such as \"10px\" are parsed to Float;\n\t\t\t// complex values such as \"rotate(1rad)\" are returned as-is.\n\t\t\tresult = jQuery.css( tween.elem, tween.prop, \"\" );\n\n\t\t\t// Empty strings, null, undefined and \"auto\" are converted to 0.\n\t\t\treturn !result || result === \"auto\" ? 0 : result;\n\t\t},\n\t\tset: function( tween ) {\n\n\t\t\t// Use step hook for back compat.\n\t\t\t// Use cssHook if its there.\n\t\t\t// Use .style if available and use plain properties where available.\n\t\t\tif ( jQuery.fx.step[ tween.prop ] ) {\n\t\t\t\tjQuery.fx.step[ tween.prop ]( tween );\n\t\t\t} else if ( tween.elem.nodeType === 1 && (\n\t\t\t\t\tjQuery.cssHooks[ tween.prop ] ||\n\t\t\t\t\ttween.elem.style[ finalPropName( tween.prop ) ] != null ) ) {\n\t\t\t\tjQuery.style( tween.elem, tween.prop, tween.now + tween.unit );\n\t\t\t} else {\n\t\t\t\ttween.elem[ tween.prop ] = tween.now;\n\t\t\t}\n\t\t}\n\t}\n};\n\n// Support: IE <=9 only\n// Panic based approach to setting things on disconnected nodes\nTween.propHooks.scrollTop = Tween.propHooks.scrollLeft = {\n\tset: function( tween ) {\n\t\tif ( tween.elem.nodeType && tween.elem.parentNode ) {\n\t\t\ttween.elem[ tween.prop ] = tween.now;\n\t\t}\n\t}\n};\n\njQuery.easing = {\n\tlinear: function( p ) {\n\t\treturn p;\n\t},\n\tswing: function( p ) {\n\t\treturn 0.5 - Math.cos( p * Math.PI ) / 2;\n\t},\n\t_default: \"swing\"\n};\n\njQuery.fx = Tween.prototype.init;\n\n// Back compat <1.8 extension point\njQuery.fx.step = {};\n\n\n\n\nvar\n\tfxNow, inProgress,\n\trfxtypes = /^(?:toggle|show|hide)$/,\n\trrun = /queueHooks$/;\n\nfunction schedule() {\n\tif ( inProgress ) {\n\t\tif ( document.hidden === false && window.requestAnimationFrame ) {\n\t\t\twindow.requestAnimationFrame( schedule );\n\t\t} else {\n\t\t\twindow.setTimeout( schedule, jQuery.fx.interval );\n\t\t}\n\n\t\tjQuery.fx.tick();\n\t}\n}\n\n// Animations created synchronously will run synchronously\nfunction createFxNow() {\n\twindow.setTimeout( function() {\n\t\tfxNow = undefined;\n\t} );\n\treturn ( fxNow = Date.now() );\n}\n\n// Generate parameters to create a standard animation\nfunction genFx( type, includeWidth ) {\n\tvar which,\n\t\ti = 0,\n\t\tattrs = { height: type };\n\n\t// If we include width, step value is 1 to do all cssExpand values,\n\t// otherwise step value is 2 to skip over Left and Right\n\tincludeWidth = includeWidth ? 1 : 0;\n\tfor ( ; i < 4; i += 2 - includeWidth ) {\n\t\twhich = cssExpand[ i ];\n\t\tattrs[ \"margin\" + which ] = attrs[ \"padding\" + which ] = type;\n\t}\n\n\tif ( includeWidth ) {\n\t\tattrs.opacity = attrs.width = type;\n\t}\n\n\treturn attrs;\n}\n\nfunction createTween( value, prop, animation ) {\n\tvar tween,\n\t\tcollection = ( Animation.tweeners[ prop ] || [] ).concat( Animation.tweeners[ \"*\" ] ),\n\t\tindex = 0,\n\t\tlength = collection.length;\n\tfor ( ; index < length; index++ ) {\n\t\tif ( ( tween = collection[ index ].call( animation, prop, value ) ) ) {\n\n\t\t\t// We're done with this property\n\t\t\treturn tween;\n\t\t}\n\t}\n}\n\nfunction defaultPrefilter( elem, props, opts ) {\n\tvar prop, value, toggle, hooks, oldfire, propTween, restoreDisplay, display,\n\t\tisBox = \"width\" in props || \"height\" in props,\n\t\tanim = this,\n\t\torig = {},\n\t\tstyle = elem.style,\n\t\thidden = elem.nodeType && isHiddenWithinTree( elem ),\n\t\tdataShow = dataPriv.get( elem, \"fxshow\" );\n\n\t// Queue-skipping animations hijack the fx hooks\n\tif ( !opts.queue ) {\n\t\thooks = jQuery._queueHooks( elem, \"fx\" );\n\t\tif ( hooks.unqueued == null ) {\n\t\t\thooks.unqueued = 0;\n\t\t\toldfire = hooks.empty.fire;\n\t\t\thooks.empty.fire = function() {\n\t\t\t\tif ( !hooks.unqueued ) {\n\t\t\t\t\toldfire();\n\t\t\t\t}\n\t\t\t};\n\t\t}\n\t\thooks.unqueued++;\n\n\t\tanim.always( function() {\n\n\t\t\t// Ensure the complete handler is called before this completes\n\t\t\tanim.always( function() {\n\t\t\t\thooks.unqueued--;\n\t\t\t\tif ( !jQuery.queue( elem, \"fx\" ).length ) {\n\t\t\t\t\thooks.empty.fire();\n\t\t\t\t}\n\t\t\t} );\n\t\t} );\n\t}\n\n\t// Detect show/hide animations\n\tfor ( prop in props ) {\n\t\tvalue = props[ prop ];\n\t\tif ( rfxtypes.test( value ) ) {\n\t\t\tdelete props[ prop ];\n\t\t\ttoggle = toggle || value === \"toggle\";\n\t\t\tif ( value === ( hidden ? \"hide\" : \"show\" ) ) {\n\n\t\t\t\t// Pretend to be hidden if this is a \"show\" and\n\t\t\t\t// there is still data from a stopped show/hide\n\t\t\t\tif ( value === \"show\" && dataShow && dataShow[ prop ] !== undefined ) {\n\t\t\t\t\thidden = true;\n\n\t\t\t\t// Ignore all other no-op show/hide data\n\t\t\t\t} else {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t}\n\t\t\torig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop );\n\t\t}\n\t}\n\n\t// Bail out if this is a no-op like .hide().hide()\n\tpropTween = !jQuery.isEmptyObject( props );\n\tif ( !propTween && jQuery.isEmptyObject( orig ) ) {\n\t\treturn;\n\t}\n\n\t// Restrict \"overflow\" and \"display\" styles during box animations\n\tif ( isBox && elem.nodeType === 1 ) {\n\n\t\t// Support: IE <=9 - 11, Edge 12 - 15\n\t\t// Record all 3 overflow attributes because IE does not infer the shorthand\n\t\t// from identically-valued overflowX and overflowY and Edge just mirrors\n\t\t// the overflowX value there.\n\t\topts.overflow = [ style.overflow, style.overflowX, style.overflowY ];\n\n\t\t// Identify a display type, preferring old show/hide data over the CSS cascade\n\t\trestoreDisplay = dataShow && dataShow.display;\n\t\tif ( restoreDisplay == null ) {\n\t\t\trestoreDisplay = dataPriv.get( elem, \"display\" );\n\t\t}\n\t\tdisplay = jQuery.css( elem, \"display\" );\n\t\tif ( display === \"none\" ) {\n\t\t\tif ( restoreDisplay ) {\n\t\t\t\tdisplay = restoreDisplay;\n\t\t\t} else {\n\n\t\t\t\t// Get nonempty value(s) by temporarily forcing visibility\n\t\t\t\tshowHide( [ elem ], true );\n\t\t\t\trestoreDisplay = elem.style.display || restoreDisplay;\n\t\t\t\tdisplay = jQuery.css( elem, \"display\" );\n\t\t\t\tshowHide( [ elem ] );\n\t\t\t}\n\t\t}\n\n\t\t// Animate inline elements as inline-block\n\t\tif ( display === \"inline\" || display === \"inline-block\" && restoreDisplay != null ) {\n\t\t\tif ( jQuery.css( elem, \"float\" ) === \"none\" ) {\n\n\t\t\t\t// Restore the original display value at the end of pure show/hide animations\n\t\t\t\tif ( !propTween ) {\n\t\t\t\t\tanim.done( function() {\n\t\t\t\t\t\tstyle.display = restoreDisplay;\n\t\t\t\t\t} );\n\t\t\t\t\tif ( restoreDisplay == null ) {\n\t\t\t\t\t\tdisplay = style.display;\n\t\t\t\t\t\trestoreDisplay = display === \"none\" ? \"\" : display;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tstyle.display = \"inline-block\";\n\t\t\t}\n\t\t}\n\t}\n\n\tif ( opts.overflow ) {\n\t\tstyle.overflow = \"hidden\";\n\t\tanim.always( function() {\n\t\t\tstyle.overflow = opts.overflow[ 0 ];\n\t\t\tstyle.overflowX = opts.overflow[ 1 ];\n\t\t\tstyle.overflowY = opts.overflow[ 2 ];\n\t\t} );\n\t}\n\n\t// Implement show/hide animations\n\tpropTween = false;\n\tfor ( prop in orig ) {\n\n\t\t// General show/hide setup for this element animation\n\t\tif ( !propTween ) {\n\t\t\tif ( dataShow ) {\n\t\t\t\tif ( \"hidden\" in dataShow ) {\n\t\t\t\t\thidden = dataShow.hidden;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tdataShow = dataPriv.access( elem, \"fxshow\", { display: restoreDisplay } );\n\t\t\t}\n\n\t\t\t// Store hidden/visible for toggle so `.stop().toggle()` \"reverses\"\n\t\t\tif ( toggle ) {\n\t\t\t\tdataShow.hidden = !hidden;\n\t\t\t}\n\n\t\t\t// Show elements before animating them\n\t\t\tif ( hidden ) {\n\t\t\t\tshowHide( [ elem ], true );\n\t\t\t}\n\n\t\t\t/* eslint-disable no-loop-func */\n\n\t\t\tanim.done( function() {\n\n\t\t\t/* eslint-enable no-loop-func */\n\n\t\t\t\t// The final step of a \"hide\" animation is actually hiding the element\n\t\t\t\tif ( !hidden ) {\n\t\t\t\t\tshowHide( [ elem ] );\n\t\t\t\t}\n\t\t\t\tdataPriv.remove( elem, \"fxshow\" );\n\t\t\t\tfor ( prop in orig ) {\n\t\t\t\t\tjQuery.style( elem, prop, orig[ prop ] );\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\n\t\t// Per-property setup\n\t\tpropTween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim );\n\t\tif ( !( prop in dataShow ) ) {\n\t\t\tdataShow[ prop ] = propTween.start;\n\t\t\tif ( hidden ) {\n\t\t\t\tpropTween.end = propTween.start;\n\t\t\t\tpropTween.start = 0;\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction propFilter( props, specialEasing ) {\n\tvar index, name, easing, value, hooks;\n\n\t// camelCase, specialEasing and expand cssHook pass\n\tfor ( index in props ) {\n\t\tname = camelCase( index );\n\t\teasing = specialEasing[ name ];\n\t\tvalue = props[ index ];\n\t\tif ( Array.isArray( value ) ) {\n\t\t\teasing = value[ 1 ];\n\t\t\tvalue = props[ index ] = value[ 0 ];\n\t\t}\n\n\t\tif ( index !== name ) {\n\t\t\tprops[ name ] = value;\n\t\t\tdelete props[ index ];\n\t\t}\n\n\t\thooks = jQuery.cssHooks[ name ];\n\t\tif ( hooks && \"expand\" in hooks ) {\n\t\t\tvalue = hooks.expand( value );\n\t\t\tdelete props[ name ];\n\n\t\t\t// Not quite $.extend, this won't overwrite existing keys.\n\t\t\t// Reusing 'index' because we have the correct \"name\"\n\t\t\tfor ( index in value ) {\n\t\t\t\tif ( !( index in props ) ) {\n\t\t\t\t\tprops[ index ] = value[ index ];\n\t\t\t\t\tspecialEasing[ index ] = easing;\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\tspecialEasing[ name ] = easing;\n\t\t}\n\t}\n}\n\nfunction Animation( elem, properties, options ) {\n\tvar result,\n\t\tstopped,\n\t\tindex = 0,\n\t\tlength = Animation.prefilters.length,\n\t\tdeferred = jQuery.Deferred().always( function() {\n\n\t\t\t// Don't match elem in the :animated selector\n\t\t\tdelete tick.elem;\n\t\t} ),\n\t\ttick = function() {\n\t\t\tif ( stopped ) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\tvar currentTime = fxNow || createFxNow(),\n\t\t\t\tremaining = Math.max( 0, animation.startTime + animation.duration - currentTime ),\n\n\t\t\t\t// Support: Android 2.3 only\n\t\t\t\t// Archaic crash bug won't allow us to use `1 - ( 0.5 || 0 )` (#12497)\n\t\t\t\ttemp = remaining / animation.duration || 0,\n\t\t\t\tpercent = 1 - temp,\n\t\t\t\tindex = 0,\n\t\t\t\tlength = animation.tweens.length;\n\n\t\t\tfor ( ; index < length; index++ ) {\n\t\t\t\tanimation.tweens[ index ].run( percent );\n\t\t\t}\n\n\t\t\tdeferred.notifyWith( elem, [ animation, percent, remaining ] );\n\n\t\t\t// If there's more to do, yield\n\t\t\tif ( percent < 1 && length ) {\n\t\t\t\treturn remaining;\n\t\t\t}\n\n\t\t\t// If this was an empty animation, synthesize a final progress notification\n\t\t\tif ( !length ) {\n\t\t\t\tdeferred.notifyWith( elem, [ animation, 1, 0 ] );\n\t\t\t}\n\n\t\t\t// Resolve the animation and report its conclusion\n\t\t\tdeferred.resolveWith( elem, [ animation ] );\n\t\t\treturn false;\n\t\t},\n\t\tanimation = deferred.promise( {\n\t\t\telem: elem,\n\t\t\tprops: jQuery.extend( {}, properties ),\n\t\t\topts: jQuery.extend( true, {\n\t\t\t\tspecialEasing: {},\n\t\t\t\teasing: jQuery.easing._default\n\t\t\t}, options ),\n\t\t\toriginalProperties: properties,\n\t\t\toriginalOptions: options,\n\t\t\tstartTime: fxNow || createFxNow(),\n\t\t\tduration: options.duration,\n\t\t\ttweens: [],\n\t\t\tcreateTween: function( prop, end ) {\n\t\t\t\tvar tween = jQuery.Tween( elem, animation.opts, prop, end,\n\t\t\t\t\t\tanimation.opts.specialEasing[ prop ] || animation.opts.easing );\n\t\t\t\tanimation.tweens.push( tween );\n\t\t\t\treturn tween;\n\t\t\t},\n\t\t\tstop: function( gotoEnd ) {\n\t\t\t\tvar index = 0,\n\n\t\t\t\t\t// If we are going to the end, we want to run all the tweens\n\t\t\t\t\t// otherwise we skip this part\n\t\t\t\t\tlength = gotoEnd ? animation.tweens.length : 0;\n\t\t\t\tif ( stopped ) {\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t\tstopped = true;\n\t\t\t\tfor ( ; index < length; index++ ) {\n\t\t\t\t\tanimation.tweens[ index ].run( 1 );\n\t\t\t\t}\n\n\t\t\t\t// Resolve when we played the last frame; otherwise, reject\n\t\t\t\tif ( gotoEnd ) {\n\t\t\t\t\tdeferred.notifyWith( elem, [ animation, 1, 0 ] );\n\t\t\t\t\tdeferred.resolveWith( elem, [ animation, gotoEnd ] );\n\t\t\t\t} else {\n\t\t\t\t\tdeferred.rejectWith( elem, [ animation, gotoEnd ] );\n\t\t\t\t}\n\t\t\t\treturn this;\n\t\t\t}\n\t\t} ),\n\t\tprops = animation.props;\n\n\tpropFilter( props, animation.opts.specialEasing );\n\n\tfor ( ; index < length; index++ ) {\n\t\tresult = Animation.prefilters[ index ].call( animation, elem, props, animation.opts );\n\t\tif ( result ) {\n\t\t\tif ( isFunction( result.stop ) ) {\n\t\t\t\tjQuery._queueHooks( animation.elem, animation.opts.queue ).stop =\n\t\t\t\t\tresult.stop.bind( result );\n\t\t\t}\n\t\t\treturn result;\n\t\t}\n\t}\n\n\tjQuery.map( props, createTween, animation );\n\n\tif ( isFunction( animation.opts.start ) ) {\n\t\tanimation.opts.start.call( elem, animation );\n\t}\n\n\t// Attach callbacks from options\n\tanimation\n\t\t.progress( animation.opts.progress )\n\t\t.done( animation.opts.done, animation.opts.complete )\n\t\t.fail( animation.opts.fail )\n\t\t.always( animation.opts.always );\n\n\tjQuery.fx.timer(\n\t\tjQuery.extend( tick, {\n\t\t\telem: elem,\n\t\t\tanim: animation,\n\t\t\tqueue: animation.opts.queue\n\t\t} )\n\t);\n\n\treturn animation;\n}\n\njQuery.Animation = jQuery.extend( Animation, {\n\n\ttweeners: {\n\t\t\"*\": [ function( prop, value ) {\n\t\t\tvar tween = this.createTween( prop, value );\n\t\t\tadjustCSS( tween.elem, prop, rcssNum.exec( value ), tween );\n\t\t\treturn tween;\n\t\t} ]\n\t},\n\n\ttweener: function( props, callback ) {\n\t\tif ( isFunction( props ) ) {\n\t\t\tcallback = props;\n\t\t\tprops = [ \"*\" ];\n\t\t} else {\n\t\t\tprops = props.match( rnothtmlwhite );\n\t\t}\n\n\t\tvar prop,\n\t\t\tindex = 0,\n\t\t\tlength = props.length;\n\n\t\tfor ( ; index < length; index++ ) {\n\t\t\tprop = props[ index ];\n\t\t\tAnimation.tweeners[ prop ] = Animation.tweeners[ prop ] || [];\n\t\t\tAnimation.tweeners[ prop ].unshift( callback );\n\t\t}\n\t},\n\n\tprefilters: [ defaultPrefilter ],\n\n\tprefilter: function( callback, prepend ) {\n\t\tif ( prepend ) {\n\t\t\tAnimation.prefilters.unshift( callback );\n\t\t} else {\n\t\t\tAnimation.prefilters.push( callback );\n\t\t}\n\t}\n} );\n\njQuery.speed = function( speed, easing, fn ) {\n\tvar opt = speed && typeof speed === \"object\" ? jQuery.extend( {}, speed ) : {\n\t\tcomplete: fn || !fn && easing ||\n\t\t\tisFunction( speed ) && speed,\n\t\tduration: speed,\n\t\teasing: fn && easing || easing && !isFunction( easing ) && easing\n\t};\n\n\t// Go to the end state if fx are off\n\tif ( jQuery.fx.off ) {\n\t\topt.duration = 0;\n\n\t} else {\n\t\tif ( typeof opt.duration !== \"number\" ) {\n\t\t\tif ( opt.duration in jQuery.fx.speeds ) {\n\t\t\t\topt.duration = jQuery.fx.speeds[ opt.duration ];\n\n\t\t\t} else {\n\t\t\t\topt.duration = jQuery.fx.speeds._default;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Normalize opt.queue - true/undefined/null -> \"fx\"\n\tif ( opt.queue == null || opt.queue === true ) {\n\t\topt.queue = \"fx\";\n\t}\n\n\t// Queueing\n\topt.old = opt.complete;\n\n\topt.complete = function() {\n\t\tif ( isFunction( opt.old ) ) {\n\t\t\topt.old.call( this );\n\t\t}\n\n\t\tif ( opt.queue ) {\n\t\t\tjQuery.dequeue( this, opt.queue );\n\t\t}\n\t};\n\n\treturn opt;\n};\n\njQuery.fn.extend( {\n\tfadeTo: function( speed, to, easing, callback ) {\n\n\t\t// Show any hidden elements after setting opacity to 0\n\t\treturn this.filter( isHiddenWithinTree ).css( \"opacity\", 0 ).show()\n\n\t\t\t// Animate to the value specified\n\t\t\t.end().animate( { opacity: to }, speed, easing, callback );\n\t},\n\tanimate: function( prop, speed, easing, callback ) {\n\t\tvar empty = jQuery.isEmptyObject( prop ),\n\t\t\toptall = jQuery.speed( speed, easing, callback ),\n\t\t\tdoAnimation = function() {\n\n\t\t\t\t// Operate on a copy of prop so per-property easing won't be lost\n\t\t\t\tvar anim = Animation( this, jQuery.extend( {}, prop ), optall );\n\n\t\t\t\t// Empty animations, or finishing resolves immediately\n\t\t\t\tif ( empty || dataPriv.get( this, \"finish\" ) ) {\n\t\t\t\t\tanim.stop( true );\n\t\t\t\t}\n\t\t\t};\n\t\t\tdoAnimation.finish = doAnimation;\n\n\t\treturn empty || optall.queue === false ?\n\t\t\tthis.each( doAnimation ) :\n\t\t\tthis.queue( optall.queue, doAnimation );\n\t},\n\tstop: function( type, clearQueue, gotoEnd ) {\n\t\tvar stopQueue = function( hooks ) {\n\t\t\tvar stop = hooks.stop;\n\t\t\tdelete hooks.stop;\n\t\t\tstop( gotoEnd );\n\t\t};\n\n\t\tif ( typeof type !== \"string\" ) {\n\t\t\tgotoEnd = clearQueue;\n\t\t\tclearQueue = type;\n\t\t\ttype = undefined;\n\t\t}\n\t\tif ( clearQueue ) {\n\t\t\tthis.queue( type || \"fx\", [] );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar dequeue = true,\n\t\t\t\tindex = type != null && type + \"queueHooks\",\n\t\t\t\ttimers = jQuery.timers,\n\t\t\t\tdata = dataPriv.get( this );\n\n\t\t\tif ( index ) {\n\t\t\t\tif ( data[ index ] && data[ index ].stop ) {\n\t\t\t\t\tstopQueue( data[ index ] );\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tfor ( index in data ) {\n\t\t\t\t\tif ( data[ index ] && data[ index ].stop && rrun.test( index ) ) {\n\t\t\t\t\t\tstopQueue( data[ index ] );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor ( index = timers.length; index--; ) {\n\t\t\t\tif ( timers[ index ].elem === this &&\n\t\t\t\t\t( type == null || timers[ index ].queue === type ) ) {\n\n\t\t\t\t\ttimers[ index ].anim.stop( gotoEnd );\n\t\t\t\t\tdequeue = false;\n\t\t\t\t\ttimers.splice( index, 1 );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Start the next in the queue if the last step wasn't forced.\n\t\t\t// Timers currently will call their complete callbacks, which\n\t\t\t// will dequeue but only if they were gotoEnd.\n\t\t\tif ( dequeue || !gotoEnd ) {\n\t\t\t\tjQuery.dequeue( this, type );\n\t\t\t}\n\t\t} );\n\t},\n\tfinish: function( type ) {\n\t\tif ( type !== false ) {\n\t\t\ttype = type || \"fx\";\n\t\t}\n\t\treturn this.each( function() {\n\t\t\tvar index,\n\t\t\t\tdata = dataPriv.get( this ),\n\t\t\t\tqueue = data[ type + \"queue\" ],\n\t\t\t\thooks = data[ type + \"queueHooks\" ],\n\t\t\t\ttimers = jQuery.timers,\n\t\t\t\tlength = queue ? queue.length : 0;\n\n\t\t\t// Enable finishing flag on private data\n\t\t\tdata.finish = true;\n\n\t\t\t// Empty the queue first\n\t\t\tjQuery.queue( this, type, [] );\n\n\t\t\tif ( hooks && hooks.stop ) {\n\t\t\t\thooks.stop.call( this, true );\n\t\t\t}\n\n\t\t\t// Look for any active animations, and finish them\n\t\t\tfor ( index = timers.length; index--; ) {\n\t\t\t\tif ( timers[ index ].elem === this && timers[ index ].queue === type ) {\n\t\t\t\t\ttimers[ index ].anim.stop( true );\n\t\t\t\t\ttimers.splice( index, 1 );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Look for any animations in the old queue and finish them\n\t\t\tfor ( index = 0; index < length; index++ ) {\n\t\t\t\tif ( queue[ index ] && queue[ index ].finish ) {\n\t\t\t\t\tqueue[ index ].finish.call( this );\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Turn off finishing flag\n\t\t\tdelete data.finish;\n\t\t} );\n\t}\n} );\n\njQuery.each( [ \"toggle\", \"show\", \"hide\" ], function( _i, name ) {\n\tvar cssFn = jQuery.fn[ name ];\n\tjQuery.fn[ name ] = function( speed, easing, callback ) {\n\t\treturn speed == null || typeof speed === \"boolean\" ?\n\t\t\tcssFn.apply( this, arguments ) :\n\t\t\tthis.animate( genFx( name, true ), speed, easing, callback );\n\t};\n} );\n\n// Generate shortcuts for custom animations\njQuery.each( {\n\tslideDown: genFx( \"show\" ),\n\tslideUp: genFx( \"hide\" ),\n\tslideToggle: genFx( \"toggle\" ),\n\tfadeIn: { opacity: \"show\" },\n\tfadeOut: { opacity: \"hide\" },\n\tfadeToggle: { opacity: \"toggle\" }\n}, function( name, props ) {\n\tjQuery.fn[ name ] = function( speed, easing, callback ) {\n\t\treturn this.animate( props, speed, easing, callback );\n\t};\n} );\n\njQuery.timers = [];\njQuery.fx.tick = function() {\n\tvar timer,\n\t\ti = 0,\n\t\ttimers = jQuery.timers;\n\n\tfxNow = Date.now();\n\n\tfor ( ; i < timers.length; i++ ) {\n\t\ttimer = timers[ i ];\n\n\t\t// Run the timer and safely remove it when done (allowing for external removal)\n\t\tif ( !timer() && timers[ i ] === timer ) {\n\t\t\ttimers.splice( i--, 1 );\n\t\t}\n\t}\n\n\tif ( !timers.length ) {\n\t\tjQuery.fx.stop();\n\t}\n\tfxNow = undefined;\n};\n\njQuery.fx.timer = function( timer ) {\n\tjQuery.timers.push( timer );\n\tjQuery.fx.start();\n};\n\njQuery.fx.interval = 13;\njQuery.fx.start = function() {\n\tif ( inProgress ) {\n\t\treturn;\n\t}\n\n\tinProgress = true;\n\tschedule();\n};\n\njQuery.fx.stop = function() {\n\tinProgress = null;\n};\n\njQuery.fx.speeds = {\n\tslow: 600,\n\tfast: 200,\n\n\t// Default speed\n\t_default: 400\n};\n\n\n// Based off of the plugin by Clint Helfers, with permission.\n// https://web.archive.org/web/20100324014747/http://blindsignals.com/index.php/2009/07/jquery-delay/\njQuery.fn.delay = function( time, type ) {\n\ttime = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time;\n\ttype = type || \"fx\";\n\n\treturn this.queue( type, function( next, hooks ) {\n\t\tvar timeout = window.setTimeout( next, time );\n\t\thooks.stop = function() {\n\t\t\twindow.clearTimeout( timeout );\n\t\t};\n\t} );\n};\n\n\n( function() {\n\tvar input = document.createElement( \"input\" ),\n\t\tselect = document.createElement( \"select\" ),\n\t\topt = select.appendChild( document.createElement( \"option\" ) );\n\n\tinput.type = \"checkbox\";\n\n\t// Support: Android <=4.3 only\n\t// Default value for a checkbox should be \"on\"\n\tsupport.checkOn = input.value !== \"\";\n\n\t// Support: IE <=11 only\n\t// Must access selectedIndex to make default options select\n\tsupport.optSelected = opt.selected;\n\n\t// Support: IE <=11 only\n\t// An input loses its value after becoming a radio\n\tinput = document.createElement( \"input\" );\n\tinput.value = \"t\";\n\tinput.type = \"radio\";\n\tsupport.radioValue = input.value === \"t\";\n} )();\n\n\nvar boolHook,\n\tattrHandle = jQuery.expr.attrHandle;\n\njQuery.fn.extend( {\n\tattr: function( name, value ) {\n\t\treturn access( this, jQuery.attr, name, value, arguments.length > 1 );\n\t},\n\n\tremoveAttr: function( name ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.removeAttr( this, name );\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tattr: function( elem, name, value ) {\n\t\tvar ret, hooks,\n\t\t\tnType = elem.nodeType;\n\n\t\t// Don't get/set attributes on text, comment and attribute nodes\n\t\tif ( nType === 3 || nType === 8 || nType === 2 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Fallback to prop when attributes are not supported\n\t\tif ( typeof elem.getAttribute === \"undefined\" ) {\n\t\t\treturn jQuery.prop( elem, name, value );\n\t\t}\n\n\t\t// Attribute hooks are determined by the lowercase version\n\t\t// Grab necessary hook if one is defined\n\t\tif ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {\n\t\t\thooks = jQuery.attrHooks[ name.toLowerCase() ] ||\n\t\t\t\t( jQuery.expr.match.bool.test( name ) ? boolHook : undefined );\n\t\t}\n\n\t\tif ( value !== undefined ) {\n\t\t\tif ( value === null ) {\n\t\t\t\tjQuery.removeAttr( elem, name );\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif ( hooks && \"set\" in hooks &&\n\t\t\t\t( ret = hooks.set( elem, value, name ) ) !== undefined ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\telem.setAttribute( name, value + \"\" );\n\t\t\treturn value;\n\t\t}\n\n\t\tif ( hooks && \"get\" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {\n\t\t\treturn ret;\n\t\t}\n\n\t\tret = jQuery.find.attr( elem, name );\n\n\t\t// Non-existent attributes return null, we normalize to undefined\n\t\treturn ret == null ? undefined : ret;\n\t},\n\n\tattrHooks: {\n\t\ttype: {\n\t\t\tset: function( elem, value ) {\n\t\t\t\tif ( !support.radioValue && value === \"radio\" &&\n\t\t\t\t\tnodeName( elem, \"input\" ) ) {\n\t\t\t\t\tvar val = elem.value;\n\t\t\t\t\telem.setAttribute( \"type\", value );\n\t\t\t\t\tif ( val ) {\n\t\t\t\t\t\telem.value = val;\n\t\t\t\t\t}\n\t\t\t\t\treturn value;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t},\n\n\tremoveAttr: function( elem, value ) {\n\t\tvar name,\n\t\t\ti = 0,\n\n\t\t\t// Attribute names can contain non-HTML whitespace characters\n\t\t\t// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2\n\t\t\tattrNames = value && value.match( rnothtmlwhite );\n\n\t\tif ( attrNames && elem.nodeType === 1 ) {\n\t\t\twhile ( ( name = attrNames[ i++ ] ) ) {\n\t\t\t\telem.removeAttribute( name );\n\t\t\t}\n\t\t}\n\t}\n} );\n\n// Hooks for boolean attributes\nboolHook = {\n\tset: function( elem, value, name ) {\n\t\tif ( value === false ) {\n\n\t\t\t// Remove boolean attributes when set to false\n\t\t\tjQuery.removeAttr( elem, name );\n\t\t} else {\n\t\t\telem.setAttribute( name, name );\n\t\t}\n\t\treturn name;\n\t}\n};\n\njQuery.each( jQuery.expr.match.bool.source.match( /\\w+/g ), function( _i, name ) {\n\tvar getter = attrHandle[ name ] || jQuery.find.attr;\n\n\tattrHandle[ name ] = function( elem, name, isXML ) {\n\t\tvar ret, handle,\n\t\t\tlowercaseName = name.toLowerCase();\n\n\t\tif ( !isXML ) {\n\n\t\t\t// Avoid an infinite loop by temporarily removing this function from the getter\n\t\t\thandle = attrHandle[ lowercaseName ];\n\t\t\tattrHandle[ lowercaseName ] = ret;\n\t\t\tret = getter( elem, name, isXML ) != null ?\n\t\t\t\tlowercaseName :\n\t\t\t\tnull;\n\t\t\tattrHandle[ lowercaseName ] = handle;\n\t\t}\n\t\treturn ret;\n\t};\n} );\n\n\n\n\nvar rfocusable = /^(?:input|select|textarea|button)$/i,\n\trclickable = /^(?:a|area)$/i;\n\njQuery.fn.extend( {\n\tprop: function( name, value ) {\n\t\treturn access( this, jQuery.prop, name, value, arguments.length > 1 );\n\t},\n\n\tremoveProp: function( name ) {\n\t\treturn this.each( function() {\n\t\t\tdelete this[ jQuery.propFix[ name ] || name ];\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tprop: function( elem, name, value ) {\n\t\tvar ret, hooks,\n\t\t\tnType = elem.nodeType;\n\n\t\t// Don't get/set properties on text, comment and attribute nodes\n\t\tif ( nType === 3 || nType === 8 || nType === 2 ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) {\n\n\t\t\t// Fix name and attach hooks\n\t\t\tname = jQuery.propFix[ name ] || name;\n\t\t\thooks = jQuery.propHooks[ name ];\n\t\t}\n\n\t\tif ( value !== undefined ) {\n\t\t\tif ( hooks && \"set\" in hooks &&\n\t\t\t\t( ret = hooks.set( elem, value, name ) ) !== undefined ) {\n\t\t\t\treturn ret;\n\t\t\t}\n\n\t\t\treturn ( elem[ name ] = value );\n\t\t}\n\n\t\tif ( hooks && \"get\" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) {\n\t\t\treturn ret;\n\t\t}\n\n\t\treturn elem[ name ];\n\t},\n\n\tpropHooks: {\n\t\ttabIndex: {\n\t\t\tget: function( elem ) {\n\n\t\t\t\t// Support: IE <=9 - 11 only\n\t\t\t\t// elem.tabIndex doesn't always return the\n\t\t\t\t// correct value when it hasn't been explicitly set\n\t\t\t\t// https://web.archive.org/web/20141116233347/http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/\n\t\t\t\t// Use proper attribute retrieval(#12072)\n\t\t\t\tvar tabindex = jQuery.find.attr( elem, \"tabindex\" );\n\n\t\t\t\tif ( tabindex ) {\n\t\t\t\t\treturn parseInt( tabindex, 10 );\n\t\t\t\t}\n\n\t\t\t\tif (\n\t\t\t\t\trfocusable.test( elem.nodeName ) ||\n\t\t\t\t\trclickable.test( elem.nodeName ) &&\n\t\t\t\t\telem.href\n\t\t\t\t) {\n\t\t\t\t\treturn 0;\n\t\t\t\t}\n\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t}\n\t},\n\n\tpropFix: {\n\t\t\"for\": \"htmlFor\",\n\t\t\"class\": \"className\"\n\t}\n} );\n\n// Support: IE <=11 only\n// Accessing the selectedIndex property\n// forces the browser to respect setting selected\n// on the option\n// The getter ensures a default option is selected\n// when in an optgroup\n// eslint rule \"no-unused-expressions\" is disabled for this code\n// since it considers such accessions noop\nif ( !support.optSelected ) {\n\tjQuery.propHooks.selected = {\n\t\tget: function( elem ) {\n\n\t\t\t/* eslint no-unused-expressions: \"off\" */\n\n\t\t\tvar parent = elem.parentNode;\n\t\t\tif ( parent && parent.parentNode ) {\n\t\t\t\tparent.parentNode.selectedIndex;\n\t\t\t}\n\t\t\treturn null;\n\t\t},\n\t\tset: function( elem ) {\n\n\t\t\t/* eslint no-unused-expressions: \"off\" */\n\n\t\t\tvar parent = elem.parentNode;\n\t\t\tif ( parent ) {\n\t\t\t\tparent.selectedIndex;\n\n\t\t\t\tif ( parent.parentNode ) {\n\t\t\t\t\tparent.parentNode.selectedIndex;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n}\n\njQuery.each( [\n\t\"tabIndex\",\n\t\"readOnly\",\n\t\"maxLength\",\n\t\"cellSpacing\",\n\t\"cellPadding\",\n\t\"rowSpan\",\n\t\"colSpan\",\n\t\"useMap\",\n\t\"frameBorder\",\n\t\"contentEditable\"\n], function() {\n\tjQuery.propFix[ this.toLowerCase() ] = this;\n} );\n\n\n\n\n\t// Strip and collapse whitespace according to HTML spec\n\t// https://infra.spec.whatwg.org/#strip-and-collapse-ascii-whitespace\n\tfunction stripAndCollapse( value ) {\n\t\tvar tokens = value.match( rnothtmlwhite ) || [];\n\t\treturn tokens.join( \" \" );\n\t}\n\n\nfunction getClass( elem ) {\n\treturn elem.getAttribute && elem.getAttribute( \"class\" ) || \"\";\n}\n\nfunction classesToArray( value ) {\n\tif ( Array.isArray( value ) ) {\n\t\treturn value;\n\t}\n\tif ( typeof value === \"string\" ) {\n\t\treturn value.match( rnothtmlwhite ) || [];\n\t}\n\treturn [];\n}\n\njQuery.fn.extend( {\n\taddClass: function( value ) {\n\t\tvar classes, elem, cur, curValue, clazz, j, finalValue,\n\t\t\ti = 0;\n\n\t\tif ( isFunction( value ) ) {\n\t\t\treturn this.each( function( j ) {\n\t\t\t\tjQuery( this ).addClass( value.call( this, j, getClass( this ) ) );\n\t\t\t} );\n\t\t}\n\n\t\tclasses = classesToArray( value );\n\n\t\tif ( classes.length ) {\n\t\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\t\tcurValue = getClass( elem );\n\t\t\t\tcur = elem.nodeType === 1 && ( \" \" + stripAndCollapse( curValue ) + \" \" );\n\n\t\t\t\tif ( cur ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\twhile ( ( clazz = classes[ j++ ] ) ) {\n\t\t\t\t\t\tif ( cur.indexOf( \" \" + clazz + \" \" ) < 0 ) {\n\t\t\t\t\t\t\tcur += clazz + \" \";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Only assign if different to avoid unneeded rendering.\n\t\t\t\t\tfinalValue = stripAndCollapse( cur );\n\t\t\t\t\tif ( curValue !== finalValue ) {\n\t\t\t\t\t\telem.setAttribute( \"class\", finalValue );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\tremoveClass: function( value ) {\n\t\tvar classes, elem, cur, curValue, clazz, j, finalValue,\n\t\t\ti = 0;\n\n\t\tif ( isFunction( value ) ) {\n\t\t\treturn this.each( function( j ) {\n\t\t\t\tjQuery( this ).removeClass( value.call( this, j, getClass( this ) ) );\n\t\t\t} );\n\t\t}\n\n\t\tif ( !arguments.length ) {\n\t\t\treturn this.attr( \"class\", \"\" );\n\t\t}\n\n\t\tclasses = classesToArray( value );\n\n\t\tif ( classes.length ) {\n\t\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\t\tcurValue = getClass( elem );\n\n\t\t\t\t// This expression is here for better compressibility (see addClass)\n\t\t\t\tcur = elem.nodeType === 1 && ( \" \" + stripAndCollapse( curValue ) + \" \" );\n\n\t\t\t\tif ( cur ) {\n\t\t\t\t\tj = 0;\n\t\t\t\t\twhile ( ( clazz = classes[ j++ ] ) ) {\n\n\t\t\t\t\t\t// Remove *all* instances\n\t\t\t\t\t\twhile ( cur.indexOf( \" \" + clazz + \" \" ) > -1 ) {\n\t\t\t\t\t\t\tcur = cur.replace( \" \" + clazz + \" \", \" \" );\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Only assign if different to avoid unneeded rendering.\n\t\t\t\t\tfinalValue = stripAndCollapse( cur );\n\t\t\t\t\tif ( curValue !== finalValue ) {\n\t\t\t\t\t\telem.setAttribute( \"class\", finalValue );\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn this;\n\t},\n\n\ttoggleClass: function( value, stateVal ) {\n\t\tvar type = typeof value,\n\t\t\tisValidValue = type === \"string\" || Array.isArray( value );\n\n\t\tif ( typeof stateVal === \"boolean\" && isValidValue ) {\n\t\t\treturn stateVal ? this.addClass( value ) : this.removeClass( value );\n\t\t}\n\n\t\tif ( isFunction( value ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).toggleClass(\n\t\t\t\t\tvalue.call( this, i, getClass( this ), stateVal ),\n\t\t\t\t\tstateVal\n\t\t\t\t);\n\t\t\t} );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar className, i, self, classNames;\n\n\t\t\tif ( isValidValue ) {\n\n\t\t\t\t// Toggle individual class names\n\t\t\t\ti = 0;\n\t\t\t\tself = jQuery( this );\n\t\t\t\tclassNames = classesToArray( value );\n\n\t\t\t\twhile ( ( className = classNames[ i++ ] ) ) {\n\n\t\t\t\t\t// Check each className given, space separated list\n\t\t\t\t\tif ( self.hasClass( className ) ) {\n\t\t\t\t\t\tself.removeClass( className );\n\t\t\t\t\t} else {\n\t\t\t\t\t\tself.addClass( className );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t// Toggle whole class name\n\t\t\t} else if ( value === undefined || type === \"boolean\" ) {\n\t\t\t\tclassName = getClass( this );\n\t\t\t\tif ( className ) {\n\n\t\t\t\t\t// Store className if set\n\t\t\t\t\tdataPriv.set( this, \"__className__\", className );\n\t\t\t\t}\n\n\t\t\t\t// If the element has a class name or if we're passed `false`,\n\t\t\t\t// then remove the whole classname (if there was one, the above saved it).\n\t\t\t\t// Otherwise bring back whatever was previously saved (if anything),\n\t\t\t\t// falling back to the empty string if nothing was stored.\n\t\t\t\tif ( this.setAttribute ) {\n\t\t\t\t\tthis.setAttribute( \"class\",\n\t\t\t\t\t\tclassName || value === false ?\n\t\t\t\t\t\t\"\" :\n\t\t\t\t\t\tdataPriv.get( this, \"__className__\" ) || \"\"\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t} );\n\t},\n\n\thasClass: function( selector ) {\n\t\tvar className, elem,\n\t\t\ti = 0;\n\n\t\tclassName = \" \" + selector + \" \";\n\t\twhile ( ( elem = this[ i++ ] ) ) {\n\t\t\tif ( elem.nodeType === 1 &&\n\t\t\t\t( \" \" + stripAndCollapse( getClass( elem ) ) + \" \" ).indexOf( className ) > -1 ) {\n\t\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n} );\n\n\n\n\nvar rreturn = /\\r/g;\n\njQuery.fn.extend( {\n\tval: function( value ) {\n\t\tvar hooks, ret, valueIsFunction,\n\t\t\telem = this[ 0 ];\n\n\t\tif ( !arguments.length ) {\n\t\t\tif ( elem ) {\n\t\t\t\thooks = jQuery.valHooks[ elem.type ] ||\n\t\t\t\t\tjQuery.valHooks[ elem.nodeName.toLowerCase() ];\n\n\t\t\t\tif ( hooks &&\n\t\t\t\t\t\"get\" in hooks &&\n\t\t\t\t\t( ret = hooks.get( elem, \"value\" ) ) !== undefined\n\t\t\t\t) {\n\t\t\t\t\treturn ret;\n\t\t\t\t}\n\n\t\t\t\tret = elem.value;\n\n\t\t\t\t// Handle most common string cases\n\t\t\t\tif ( typeof ret === \"string\" ) {\n\t\t\t\t\treturn ret.replace( rreturn, \"\" );\n\t\t\t\t}\n\n\t\t\t\t// Handle cases where value is null/undef or number\n\t\t\t\treturn ret == null ? \"\" : ret;\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tvalueIsFunction = isFunction( value );\n\n\t\treturn this.each( function( i ) {\n\t\t\tvar val;\n\n\t\t\tif ( this.nodeType !== 1 ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tif ( valueIsFunction ) {\n\t\t\t\tval = value.call( this, i, jQuery( this ).val() );\n\t\t\t} else {\n\t\t\t\tval = value;\n\t\t\t}\n\n\t\t\t// Treat null/undefined as \"\"; convert numbers to string\n\t\t\tif ( val == null ) {\n\t\t\t\tval = \"\";\n\n\t\t\t} else if ( typeof val === \"number\" ) {\n\t\t\t\tval += \"\";\n\n\t\t\t} else if ( Array.isArray( val ) ) {\n\t\t\t\tval = jQuery.map( val, function( value ) {\n\t\t\t\t\treturn value == null ? \"\" : value + \"\";\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\thooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ];\n\n\t\t\t// If set returns undefined, fall back to normal setting\n\t\t\tif ( !hooks || !( \"set\" in hooks ) || hooks.set( this, val, \"value\" ) === undefined ) {\n\t\t\t\tthis.value = val;\n\t\t\t}\n\t\t} );\n\t}\n} );\n\njQuery.extend( {\n\tvalHooks: {\n\t\toption: {\n\t\t\tget: function( elem ) {\n\n\t\t\t\tvar val = jQuery.find.attr( elem, \"value\" );\n\t\t\t\treturn val != null ?\n\t\t\t\t\tval :\n\n\t\t\t\t\t// Support: IE <=10 - 11 only\n\t\t\t\t\t// option.text throws exceptions (#14686, #14858)\n\t\t\t\t\t// Strip and collapse whitespace\n\t\t\t\t\t// https://html.spec.whatwg.org/#strip-and-collapse-whitespace\n\t\t\t\t\tstripAndCollapse( jQuery.text( elem ) );\n\t\t\t}\n\t\t},\n\t\tselect: {\n\t\t\tget: function( elem ) {\n\t\t\t\tvar value, option, i,\n\t\t\t\t\toptions = elem.options,\n\t\t\t\t\tindex = elem.selectedIndex,\n\t\t\t\t\tone = elem.type === \"select-one\",\n\t\t\t\t\tvalues = one ? null : [],\n\t\t\t\t\tmax = one ? index + 1 : options.length;\n\n\t\t\t\tif ( index < 0 ) {\n\t\t\t\t\ti = max;\n\n\t\t\t\t} else {\n\t\t\t\t\ti = one ? index : 0;\n\t\t\t\t}\n\n\t\t\t\t// Loop through all the selected options\n\t\t\t\tfor ( ; i < max; i++ ) {\n\t\t\t\t\toption = options[ i ];\n\n\t\t\t\t\t// Support: IE <=9 only\n\t\t\t\t\t// IE8-9 doesn't update selected after form reset (#2551)\n\t\t\t\t\tif ( ( option.selected || i === index ) &&\n\n\t\t\t\t\t\t\t// Don't return options that are disabled or in a disabled optgroup\n\t\t\t\t\t\t\t!option.disabled &&\n\t\t\t\t\t\t\t( !option.parentNode.disabled ||\n\t\t\t\t\t\t\t\t!nodeName( option.parentNode, \"optgroup\" ) ) ) {\n\n\t\t\t\t\t\t// Get the specific value for the option\n\t\t\t\t\t\tvalue = jQuery( option ).val();\n\n\t\t\t\t\t\t// We don't need an array for one selects\n\t\t\t\t\t\tif ( one ) {\n\t\t\t\t\t\t\treturn value;\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Multi-Selects return an array\n\t\t\t\t\t\tvalues.push( value );\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn values;\n\t\t\t},\n\n\t\t\tset: function( elem, value ) {\n\t\t\t\tvar optionSet, option,\n\t\t\t\t\toptions = elem.options,\n\t\t\t\t\tvalues = jQuery.makeArray( value ),\n\t\t\t\t\ti = options.length;\n\n\t\t\t\twhile ( i-- ) {\n\t\t\t\t\toption = options[ i ];\n\n\t\t\t\t\t/* eslint-disable no-cond-assign */\n\n\t\t\t\t\tif ( option.selected =\n\t\t\t\t\t\tjQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -1\n\t\t\t\t\t) {\n\t\t\t\t\t\toptionSet = true;\n\t\t\t\t\t}\n\n\t\t\t\t\t/* eslint-enable no-cond-assign */\n\t\t\t\t}\n\n\t\t\t\t// Force browsers to behave consistently when non-matching value is set\n\t\t\t\tif ( !optionSet ) {\n\t\t\t\t\telem.selectedIndex = -1;\n\t\t\t\t}\n\t\t\t\treturn values;\n\t\t\t}\n\t\t}\n\t}\n} );\n\n// Radios and checkboxes getter/setter\njQuery.each( [ \"radio\", \"checkbox\" ], function() {\n\tjQuery.valHooks[ this ] = {\n\t\tset: function( elem, value ) {\n\t\t\tif ( Array.isArray( value ) ) {\n\t\t\t\treturn ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) > -1 );\n\t\t\t}\n\t\t}\n\t};\n\tif ( !support.checkOn ) {\n\t\tjQuery.valHooks[ this ].get = function( elem ) {\n\t\t\treturn elem.getAttribute( \"value\" ) === null ? \"on\" : elem.value;\n\t\t};\n\t}\n} );\n\n\n\n\n// Return jQuery for attributes-only inclusion\n\n\nsupport.focusin = \"onfocusin\" in window;\n\n\nvar rfocusMorph = /^(?:focusinfocus|focusoutblur)$/,\n\tstopPropagationCallback = function( e ) {\n\t\te.stopPropagation();\n\t};\n\njQuery.extend( jQuery.event, {\n\n\ttrigger: function( event, data, elem, onlyHandlers ) {\n\n\t\tvar i, cur, tmp, bubbleType, ontype, handle, special, lastElement,\n\t\t\teventPath = [ elem || document ],\n\t\t\ttype = hasOwn.call( event, \"type\" ) ? event.type : event,\n\t\t\tnamespaces = hasOwn.call( event, \"namespace\" ) ? event.namespace.split( \".\" ) : [];\n\n\t\tcur = lastElement = tmp = elem = elem || document;\n\n\t\t// Don't do events on text and comment nodes\n\t\tif ( elem.nodeType === 3 || elem.nodeType === 8 ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// focus/blur morphs to focusin/out; ensure we're not firing them right now\n\t\tif ( rfocusMorph.test( type + jQuery.event.triggered ) ) {\n\t\t\treturn;\n\t\t}\n\n\t\tif ( type.indexOf( \".\" ) > -1 ) {\n\n\t\t\t// Namespaced trigger; create a regexp to match event type in handle()\n\t\t\tnamespaces = type.split( \".\" );\n\t\t\ttype = namespaces.shift();\n\t\t\tnamespaces.sort();\n\t\t}\n\t\tontype = type.indexOf( \":\" ) < 0 && \"on\" + type;\n\n\t\t// Caller can pass in a jQuery.Event object, Object, or just an event type string\n\t\tevent = event[ jQuery.expando ] ?\n\t\t\tevent :\n\t\t\tnew jQuery.Event( type, typeof event === \"object\" && event );\n\n\t\t// Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true)\n\t\tevent.isTrigger = onlyHandlers ? 2 : 3;\n\t\tevent.namespace = namespaces.join( \".\" );\n\t\tevent.rnamespace = event.namespace ?\n\t\t\tnew RegExp( \"(^|\\\\.)\" + namespaces.join( \"\\\\.(?:.*\\\\.|)\" ) + \"(\\\\.|$)\" ) :\n\t\t\tnull;\n\n\t\t// Clean up the event in case it is being reused\n\t\tevent.result = undefined;\n\t\tif ( !event.target ) {\n\t\t\tevent.target = elem;\n\t\t}\n\n\t\t// Clone any incoming data and prepend the event, creating the handler arg list\n\t\tdata = data == null ?\n\t\t\t[ event ] :\n\t\t\tjQuery.makeArray( data, [ event ] );\n\n\t\t// Allow special events to draw outside the lines\n\t\tspecial = jQuery.event.special[ type ] || {};\n\t\tif ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Determine event propagation path in advance, per W3C events spec (#9951)\n\t\t// Bubble up to document, then to window; watch for a global ownerDocument var (#9724)\n\t\tif ( !onlyHandlers && !special.noBubble && !isWindow( elem ) ) {\n\n\t\t\tbubbleType = special.delegateType || type;\n\t\t\tif ( !rfocusMorph.test( bubbleType + type ) ) {\n\t\t\t\tcur = cur.parentNode;\n\t\t\t}\n\t\t\tfor ( ; cur; cur = cur.parentNode ) {\n\t\t\t\teventPath.push( cur );\n\t\t\t\ttmp = cur;\n\t\t\t}\n\n\t\t\t// Only add window if we got to document (e.g., not plain obj or detached DOM)\n\t\t\tif ( tmp === ( elem.ownerDocument || document ) ) {\n\t\t\t\teventPath.push( tmp.defaultView || tmp.parentWindow || window );\n\t\t\t}\n\t\t}\n\n\t\t// Fire handlers on the event path\n\t\ti = 0;\n\t\twhile ( ( cur = eventPath[ i++ ] ) && !event.isPropagationStopped() ) {\n\t\t\tlastElement = cur;\n\t\t\tevent.type = i > 1 ?\n\t\t\t\tbubbleType :\n\t\t\t\tspecial.bindType || type;\n\n\t\t\t// jQuery handler\n\t\t\thandle = (\n\t\t\t\t\tdataPriv.get( cur, \"events\" ) || Object.create( null )\n\t\t\t\t)[ event.type ] &&\n\t\t\t\tdataPriv.get( cur, \"handle\" );\n\t\t\tif ( handle ) {\n\t\t\t\thandle.apply( cur, data );\n\t\t\t}\n\n\t\t\t// Native handler\n\t\t\thandle = ontype && cur[ ontype ];\n\t\t\tif ( handle && handle.apply && acceptData( cur ) ) {\n\t\t\t\tevent.result = handle.apply( cur, data );\n\t\t\t\tif ( event.result === false ) {\n\t\t\t\t\tevent.preventDefault();\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tevent.type = type;\n\n\t\t// If nobody prevented the default action, do it now\n\t\tif ( !onlyHandlers && !event.isDefaultPrevented() ) {\n\n\t\t\tif ( ( !special._default ||\n\t\t\t\tspecial._default.apply( eventPath.pop(), data ) === false ) &&\n\t\t\t\tacceptData( elem ) ) {\n\n\t\t\t\t// Call a native DOM method on the target with the same name as the event.\n\t\t\t\t// Don't do default actions on window, that's where global variables be (#6170)\n\t\t\t\tif ( ontype && isFunction( elem[ type ] ) && !isWindow( elem ) ) {\n\n\t\t\t\t\t// Don't re-trigger an onFOO event when we call its FOO() method\n\t\t\t\t\ttmp = elem[ ontype ];\n\n\t\t\t\t\tif ( tmp ) {\n\t\t\t\t\t\telem[ ontype ] = null;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Prevent re-triggering of the same event, since we already bubbled it above\n\t\t\t\t\tjQuery.event.triggered = type;\n\n\t\t\t\t\tif ( event.isPropagationStopped() ) {\n\t\t\t\t\t\tlastElement.addEventListener( type, stopPropagationCallback );\n\t\t\t\t\t}\n\n\t\t\t\t\telem[ type ]();\n\n\t\t\t\t\tif ( event.isPropagationStopped() ) {\n\t\t\t\t\t\tlastElement.removeEventListener( type, stopPropagationCallback );\n\t\t\t\t\t}\n\n\t\t\t\t\tjQuery.event.triggered = undefined;\n\n\t\t\t\t\tif ( tmp ) {\n\t\t\t\t\t\telem[ ontype ] = tmp;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn event.result;\n\t},\n\n\t// Piggyback on a donor event to simulate a different one\n\t// Used only for `focus(in | out)` events\n\tsimulate: function( type, elem, event ) {\n\t\tvar e = jQuery.extend(\n\t\t\tnew jQuery.Event(),\n\t\t\tevent,\n\t\t\t{\n\t\t\t\ttype: type,\n\t\t\t\tisSimulated: true\n\t\t\t}\n\t\t);\n\n\t\tjQuery.event.trigger( e, null, elem );\n\t}\n\n} );\n\njQuery.fn.extend( {\n\n\ttrigger: function( type, data ) {\n\t\treturn this.each( function() {\n\t\t\tjQuery.event.trigger( type, data, this );\n\t\t} );\n\t},\n\ttriggerHandler: function( type, data ) {\n\t\tvar elem = this[ 0 ];\n\t\tif ( elem ) {\n\t\t\treturn jQuery.event.trigger( type, data, elem, true );\n\t\t}\n\t}\n} );\n\n\n// Support: Firefox <=44\n// Firefox doesn't have focus(in | out) events\n// Related ticket - https://bugzilla.mozilla.org/show_bug.cgi?id=687787\n//\n// Support: Chrome <=48 - 49, Safari <=9.0 - 9.1\n// focus(in | out) events fire after focus & blur events,\n// which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order\n// Related ticket - https://bugs.chromium.org/p/chromium/issues/detail?id=449857\nif ( !support.focusin ) {\n\tjQuery.each( { focus: \"focusin\", blur: \"focusout\" }, function( orig, fix ) {\n\n\t\t// Attach a single capturing handler on the document while someone wants focusin/focusout\n\t\tvar handler = function( event ) {\n\t\t\tjQuery.event.simulate( fix, event.target, jQuery.event.fix( event ) );\n\t\t};\n\n\t\tjQuery.event.special[ fix ] = {\n\t\t\tsetup: function() {\n\n\t\t\t\t// Handle: regular nodes (via `this.ownerDocument`), window\n\t\t\t\t// (via `this.document`) & document (via `this`).\n\t\t\t\tvar doc = this.ownerDocument || this.document || this,\n\t\t\t\t\tattaches = dataPriv.access( doc, fix );\n\n\t\t\t\tif ( !attaches ) {\n\t\t\t\t\tdoc.addEventListener( orig, handler, true );\n\t\t\t\t}\n\t\t\t\tdataPriv.access( doc, fix, ( attaches || 0 ) + 1 );\n\t\t\t},\n\t\t\tteardown: function() {\n\t\t\t\tvar doc = this.ownerDocument || this.document || this,\n\t\t\t\t\tattaches = dataPriv.access( doc, fix ) - 1;\n\n\t\t\t\tif ( !attaches ) {\n\t\t\t\t\tdoc.removeEventListener( orig, handler, true );\n\t\t\t\t\tdataPriv.remove( doc, fix );\n\n\t\t\t\t} else {\n\t\t\t\t\tdataPriv.access( doc, fix, attaches );\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t} );\n}\nvar location = window.location;\n\nvar nonce = { guid: Date.now() };\n\nvar rquery = ( /\\?/ );\n\n\n\n// Cross-browser xml parsing\njQuery.parseXML = function( data ) {\n\tvar xml;\n\tif ( !data || typeof data !== \"string\" ) {\n\t\treturn null;\n\t}\n\n\t// Support: IE 9 - 11 only\n\t// IE throws on parseFromString with invalid input.\n\ttry {\n\t\txml = ( new window.DOMParser() ).parseFromString( data, \"text/xml\" );\n\t} catch ( e ) {\n\t\txml = undefined;\n\t}\n\n\tif ( !xml || xml.getElementsByTagName( \"parsererror\" ).length ) {\n\t\tjQuery.error( \"Invalid XML: \" + data );\n\t}\n\treturn xml;\n};\n\n\nvar\n\trbracket = /\\[\\]$/,\n\trCRLF = /\\r?\\n/g,\n\trsubmitterTypes = /^(?:submit|button|image|reset|file)$/i,\n\trsubmittable = /^(?:input|select|textarea|keygen)/i;\n\nfunction buildParams( prefix, obj, traditional, add ) {\n\tvar name;\n\n\tif ( Array.isArray( obj ) ) {\n\n\t\t// Serialize array item.\n\t\tjQuery.each( obj, function( i, v ) {\n\t\t\tif ( traditional || rbracket.test( prefix ) ) {\n\n\t\t\t\t// Treat each array item as a scalar.\n\t\t\t\tadd( prefix, v );\n\n\t\t\t} else {\n\n\t\t\t\t// Item is non-scalar (array or object), encode its numeric index.\n\t\t\t\tbuildParams(\n\t\t\t\t\tprefix + \"[\" + ( typeof v === \"object\" && v != null ? i : \"\" ) + \"]\",\n\t\t\t\t\tv,\n\t\t\t\t\ttraditional,\n\t\t\t\t\tadd\n\t\t\t\t);\n\t\t\t}\n\t\t} );\n\n\t} else if ( !traditional && toType( obj ) === \"object\" ) {\n\n\t\t// Serialize object item.\n\t\tfor ( name in obj ) {\n\t\t\tbuildParams( prefix + \"[\" + name + \"]\", obj[ name ], traditional, add );\n\t\t}\n\n\t} else {\n\n\t\t// Serialize scalar item.\n\t\tadd( prefix, obj );\n\t}\n}\n\n// Serialize an array of form elements or a set of\n// key/values into a query string\njQuery.param = function( a, traditional ) {\n\tvar prefix,\n\t\ts = [],\n\t\tadd = function( key, valueOrFunction ) {\n\n\t\t\t// If value is a function, invoke it and use its return value\n\t\t\tvar value = isFunction( valueOrFunction ) ?\n\t\t\t\tvalueOrFunction() :\n\t\t\t\tvalueOrFunction;\n\n\t\t\ts[ s.length ] = encodeURIComponent( key ) + \"=\" +\n\t\t\t\tencodeURIComponent( value == null ? \"\" : value );\n\t\t};\n\n\tif ( a == null ) {\n\t\treturn \"\";\n\t}\n\n\t// If an array was passed in, assume that it is an array of form elements.\n\tif ( Array.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) {\n\n\t\t// Serialize the form elements\n\t\tjQuery.each( a, function() {\n\t\t\tadd( this.name, this.value );\n\t\t} );\n\n\t} else {\n\n\t\t// If traditional, encode the \"old\" way (the way 1.3.2 or older\n\t\t// did it), otherwise encode params recursively.\n\t\tfor ( prefix in a ) {\n\t\t\tbuildParams( prefix, a[ prefix ], traditional, add );\n\t\t}\n\t}\n\n\t// Return the resulting serialization\n\treturn s.join( \"&\" );\n};\n\njQuery.fn.extend( {\n\tserialize: function() {\n\t\treturn jQuery.param( this.serializeArray() );\n\t},\n\tserializeArray: function() {\n\t\treturn this.map( function() {\n\n\t\t\t// Can add propHook for \"elements\" to filter or add form elements\n\t\t\tvar elements = jQuery.prop( this, \"elements\" );\n\t\t\treturn elements ? jQuery.makeArray( elements ) : this;\n\t\t} )\n\t\t.filter( function() {\n\t\t\tvar type = this.type;\n\n\t\t\t// Use .is( \":disabled\" ) so that fieldset[disabled] works\n\t\t\treturn this.name && !jQuery( this ).is( \":disabled\" ) &&\n\t\t\t\trsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&\n\t\t\t\t( this.checked || !rcheckableType.test( type ) );\n\t\t} )\n\t\t.map( function( _i, elem ) {\n\t\t\tvar val = jQuery( this ).val();\n\n\t\t\tif ( val == null ) {\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\tif ( Array.isArray( val ) ) {\n\t\t\t\treturn jQuery.map( val, function( val ) {\n\t\t\t\t\treturn { name: elem.name, value: val.replace( rCRLF, \"\\r\\n\" ) };\n\t\t\t\t} );\n\t\t\t}\n\n\t\t\treturn { name: elem.name, value: val.replace( rCRLF, \"\\r\\n\" ) };\n\t\t} ).get();\n\t}\n} );\n\n\nvar\n\tr20 = /%20/g,\n\trhash = /#.*$/,\n\trantiCache = /([?&])_=[^&]*/,\n\trheaders = /^(.*?):[ \\t]*([^\\r\\n]*)$/mg,\n\n\t// #7653, #8125, #8152: local protocol detection\n\trlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,\n\trnoContent = /^(?:GET|HEAD)$/,\n\trprotocol = /^\\/\\//,\n\n\t/* Prefilters\n\t * 1) They are useful to introduce custom dataTypes (see ajax/jsonp.js for an example)\n\t * 2) These are called:\n\t * - BEFORE asking for a transport\n\t * - AFTER param serialization (s.data is a string if s.processData is true)\n\t * 3) key is the dataType\n\t * 4) the catchall symbol \"*\" can be used\n\t * 5) execution will start with transport dataType and THEN continue down to \"*\" if needed\n\t */\n\tprefilters = {},\n\n\t/* Transports bindings\n\t * 1) key is the dataType\n\t * 2) the catchall symbol \"*\" can be used\n\t * 3) selection will start with transport dataType and THEN go to \"*\" if needed\n\t */\n\ttransports = {},\n\n\t// Avoid comment-prolog char sequence (#10098); must appease lint and evade compression\n\tallTypes = \"*/\".concat( \"*\" ),\n\n\t// Anchor tag for parsing the document origin\n\toriginAnchor = document.createElement( \"a\" );\n\toriginAnchor.href = location.href;\n\n// Base \"constructor\" for jQuery.ajaxPrefilter and jQuery.ajaxTransport\nfunction addToPrefiltersOrTransports( structure ) {\n\n\t// dataTypeExpression is optional and defaults to \"*\"\n\treturn function( dataTypeExpression, func ) {\n\n\t\tif ( typeof dataTypeExpression !== \"string\" ) {\n\t\t\tfunc = dataTypeExpression;\n\t\t\tdataTypeExpression = \"*\";\n\t\t}\n\n\t\tvar dataType,\n\t\t\ti = 0,\n\t\t\tdataTypes = dataTypeExpression.toLowerCase().match( rnothtmlwhite ) || [];\n\n\t\tif ( isFunction( func ) ) {\n\n\t\t\t// For each dataType in the dataTypeExpression\n\t\t\twhile ( ( dataType = dataTypes[ i++ ] ) ) {\n\n\t\t\t\t// Prepend if requested\n\t\t\t\tif ( dataType[ 0 ] === \"+\" ) {\n\t\t\t\t\tdataType = dataType.slice( 1 ) || \"*\";\n\t\t\t\t\t( structure[ dataType ] = structure[ dataType ] || [] ).unshift( func );\n\n\t\t\t\t// Otherwise append\n\t\t\t\t} else {\n\t\t\t\t\t( structure[ dataType ] = structure[ dataType ] || [] ).push( func );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t};\n}\n\n// Base inspection function for prefilters and transports\nfunction inspectPrefiltersOrTransports( structure, options, originalOptions, jqXHR ) {\n\n\tvar inspected = {},\n\t\tseekingTransport = ( structure === transports );\n\n\tfunction inspect( dataType ) {\n\t\tvar selected;\n\t\tinspected[ dataType ] = true;\n\t\tjQuery.each( structure[ dataType ] || [], function( _, prefilterOrFactory ) {\n\t\t\tvar dataTypeOrTransport = prefilterOrFactory( options, originalOptions, jqXHR );\n\t\t\tif ( typeof dataTypeOrTransport === \"string\" &&\n\t\t\t\t!seekingTransport && !inspected[ dataTypeOrTransport ] ) {\n\n\t\t\t\toptions.dataTypes.unshift( dataTypeOrTransport );\n\t\t\t\tinspect( dataTypeOrTransport );\n\t\t\t\treturn false;\n\t\t\t} else if ( seekingTransport ) {\n\t\t\t\treturn !( selected = dataTypeOrTransport );\n\t\t\t}\n\t\t} );\n\t\treturn selected;\n\t}\n\n\treturn inspect( options.dataTypes[ 0 ] ) || !inspected[ \"*\" ] && inspect( \"*\" );\n}\n\n// A special extend for ajax options\n// that takes \"flat\" options (not to be deep extended)\n// Fixes #9887\nfunction ajaxExtend( target, src ) {\n\tvar key, deep,\n\t\tflatOptions = jQuery.ajaxSettings.flatOptions || {};\n\n\tfor ( key in src ) {\n\t\tif ( src[ key ] !== undefined ) {\n\t\t\t( flatOptions[ key ] ? target : ( deep || ( deep = {} ) ) )[ key ] = src[ key ];\n\t\t}\n\t}\n\tif ( deep ) {\n\t\tjQuery.extend( true, target, deep );\n\t}\n\n\treturn target;\n}\n\n/* Handles responses to an ajax request:\n * - finds the right dataType (mediates between content-type and expected dataType)\n * - returns the corresponding response\n */\nfunction ajaxHandleResponses( s, jqXHR, responses ) {\n\n\tvar ct, type, finalDataType, firstDataType,\n\t\tcontents = s.contents,\n\t\tdataTypes = s.dataTypes;\n\n\t// Remove auto dataType and get content-type in the process\n\twhile ( dataTypes[ 0 ] === \"*\" ) {\n\t\tdataTypes.shift();\n\t\tif ( ct === undefined ) {\n\t\t\tct = s.mimeType || jqXHR.getResponseHeader( \"Content-Type\" );\n\t\t}\n\t}\n\n\t// Check if we're dealing with a known content-type\n\tif ( ct ) {\n\t\tfor ( type in contents ) {\n\t\t\tif ( contents[ type ] && contents[ type ].test( ct ) ) {\n\t\t\t\tdataTypes.unshift( type );\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\t// Check to see if we have a response for the expected dataType\n\tif ( dataTypes[ 0 ] in responses ) {\n\t\tfinalDataType = dataTypes[ 0 ];\n\t} else {\n\n\t\t// Try convertible dataTypes\n\t\tfor ( type in responses ) {\n\t\t\tif ( !dataTypes[ 0 ] || s.converters[ type + \" \" + dataTypes[ 0 ] ] ) {\n\t\t\t\tfinalDataType = type;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif ( !firstDataType ) {\n\t\t\t\tfirstDataType = type;\n\t\t\t}\n\t\t}\n\n\t\t// Or just use first one\n\t\tfinalDataType = finalDataType || firstDataType;\n\t}\n\n\t// If we found a dataType\n\t// We add the dataType to the list if needed\n\t// and return the corresponding response\n\tif ( finalDataType ) {\n\t\tif ( finalDataType !== dataTypes[ 0 ] ) {\n\t\t\tdataTypes.unshift( finalDataType );\n\t\t}\n\t\treturn responses[ finalDataType ];\n\t}\n}\n\n/* Chain conversions given the request and the original response\n * Also sets the responseXXX fields on the jqXHR instance\n */\nfunction ajaxConvert( s, response, jqXHR, isSuccess ) {\n\tvar conv2, current, conv, tmp, prev,\n\t\tconverters = {},\n\n\t\t// Work with a copy of dataTypes in case we need to modify it for conversion\n\t\tdataTypes = s.dataTypes.slice();\n\n\t// Create converters map with lowercased keys\n\tif ( dataTypes[ 1 ] ) {\n\t\tfor ( conv in s.converters ) {\n\t\t\tconverters[ conv.toLowerCase() ] = s.converters[ conv ];\n\t\t}\n\t}\n\n\tcurrent = dataTypes.shift();\n\n\t// Convert to each sequential dataType\n\twhile ( current ) {\n\n\t\tif ( s.responseFields[ current ] ) {\n\t\t\tjqXHR[ s.responseFields[ current ] ] = response;\n\t\t}\n\n\t\t// Apply the dataFilter if provided\n\t\tif ( !prev && isSuccess && s.dataFilter ) {\n\t\t\tresponse = s.dataFilter( response, s.dataType );\n\t\t}\n\n\t\tprev = current;\n\t\tcurrent = dataTypes.shift();\n\n\t\tif ( current ) {\n\n\t\t\t// There's only work to do if current dataType is non-auto\n\t\t\tif ( current === \"*\" ) {\n\n\t\t\t\tcurrent = prev;\n\n\t\t\t// Convert response if prev dataType is non-auto and differs from current\n\t\t\t} else if ( prev !== \"*\" && prev !== current ) {\n\n\t\t\t\t// Seek a direct converter\n\t\t\t\tconv = converters[ prev + \" \" + current ] || converters[ \"* \" + current ];\n\n\t\t\t\t// If none found, seek a pair\n\t\t\t\tif ( !conv ) {\n\t\t\t\t\tfor ( conv2 in converters ) {\n\n\t\t\t\t\t\t// If conv2 outputs current\n\t\t\t\t\t\ttmp = conv2.split( \" \" );\n\t\t\t\t\t\tif ( tmp[ 1 ] === current ) {\n\n\t\t\t\t\t\t\t// If prev can be converted to accepted input\n\t\t\t\t\t\t\tconv = converters[ prev + \" \" + tmp[ 0 ] ] ||\n\t\t\t\t\t\t\t\tconverters[ \"* \" + tmp[ 0 ] ];\n\t\t\t\t\t\t\tif ( conv ) {\n\n\t\t\t\t\t\t\t\t// Condense equivalence converters\n\t\t\t\t\t\t\t\tif ( conv === true ) {\n\t\t\t\t\t\t\t\t\tconv = converters[ conv2 ];\n\n\t\t\t\t\t\t\t\t// Otherwise, insert the intermediate dataType\n\t\t\t\t\t\t\t\t} else if ( converters[ conv2 ] !== true ) {\n\t\t\t\t\t\t\t\t\tcurrent = tmp[ 0 ];\n\t\t\t\t\t\t\t\t\tdataTypes.unshift( tmp[ 1 ] );\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Apply converter (if not an equivalence)\n\t\t\t\tif ( conv !== true ) {\n\n\t\t\t\t\t// Unless errors are allowed to bubble, catch and return them\n\t\t\t\t\tif ( conv && s.throws ) {\n\t\t\t\t\t\tresponse = conv( response );\n\t\t\t\t\t} else {\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tresponse = conv( response );\n\t\t\t\t\t\t} catch ( e ) {\n\t\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\t\tstate: \"parsererror\",\n\t\t\t\t\t\t\t\terror: conv ? e : \"No conversion from \" + prev + \" to \" + current\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn { state: \"success\", data: response };\n}\n\njQuery.extend( {\n\n\t// Counter for holding the number of active queries\n\tactive: 0,\n\n\t// Last-Modified header cache for next request\n\tlastModified: {},\n\tetag: {},\n\n\tajaxSettings: {\n\t\turl: location.href,\n\t\ttype: \"GET\",\n\t\tisLocal: rlocalProtocol.test( location.protocol ),\n\t\tglobal: true,\n\t\tprocessData: true,\n\t\tasync: true,\n\t\tcontentType: \"application/x-www-form-urlencoded; charset=UTF-8\",\n\n\t\t/*\n\t\ttimeout: 0,\n\t\tdata: null,\n\t\tdataType: null,\n\t\tusername: null,\n\t\tpassword: null,\n\t\tcache: null,\n\t\tthrows: false,\n\t\ttraditional: false,\n\t\theaders: {},\n\t\t*/\n\n\t\taccepts: {\n\t\t\t\"*\": allTypes,\n\t\t\ttext: \"text/plain\",\n\t\t\thtml: \"text/html\",\n\t\t\txml: \"application/xml, text/xml\",\n\t\t\tjson: \"application/json, text/javascript\"\n\t\t},\n\n\t\tcontents: {\n\t\t\txml: /\\bxml\\b/,\n\t\t\thtml: /\\bhtml/,\n\t\t\tjson: /\\bjson\\b/\n\t\t},\n\n\t\tresponseFields: {\n\t\t\txml: \"responseXML\",\n\t\t\ttext: \"responseText\",\n\t\t\tjson: \"responseJSON\"\n\t\t},\n\n\t\t// Data converters\n\t\t// Keys separate source (or catchall \"*\") and destination types with a single space\n\t\tconverters: {\n\n\t\t\t// Convert anything to text\n\t\t\t\"* text\": String,\n\n\t\t\t// Text to html (true = no transformation)\n\t\t\t\"text html\": true,\n\n\t\t\t// Evaluate text as a json expression\n\t\t\t\"text json\": JSON.parse,\n\n\t\t\t// Parse text as xml\n\t\t\t\"text xml\": jQuery.parseXML\n\t\t},\n\n\t\t// For options that shouldn't be deep extended:\n\t\t// you can add your own custom options here if\n\t\t// and when you create one that shouldn't be\n\t\t// deep extended (see ajaxExtend)\n\t\tflatOptions: {\n\t\t\turl: true,\n\t\t\tcontext: true\n\t\t}\n\t},\n\n\t// Creates a full fledged settings object into target\n\t// with both ajaxSettings and settings fields.\n\t// If target is omitted, writes into ajaxSettings.\n\tajaxSetup: function( target, settings ) {\n\t\treturn settings ?\n\n\t\t\t// Building a settings object\n\t\t\tajaxExtend( ajaxExtend( target, jQuery.ajaxSettings ), settings ) :\n\n\t\t\t// Extending ajaxSettings\n\t\t\tajaxExtend( jQuery.ajaxSettings, target );\n\t},\n\n\tajaxPrefilter: addToPrefiltersOrTransports( prefilters ),\n\tajaxTransport: addToPrefiltersOrTransports( transports ),\n\n\t// Main method\n\tajax: function( url, options ) {\n\n\t\t// If url is an object, simulate pre-1.5 signature\n\t\tif ( typeof url === \"object\" ) {\n\t\t\toptions = url;\n\t\t\turl = undefined;\n\t\t}\n\n\t\t// Force options to be an object\n\t\toptions = options || {};\n\n\t\tvar transport,\n\n\t\t\t// URL without anti-cache param\n\t\t\tcacheURL,\n\n\t\t\t// Response headers\n\t\t\tresponseHeadersString,\n\t\t\tresponseHeaders,\n\n\t\t\t// timeout handle\n\t\t\ttimeoutTimer,\n\n\t\t\t// Url cleanup var\n\t\t\turlAnchor,\n\n\t\t\t// Request state (becomes false upon send and true upon completion)\n\t\t\tcompleted,\n\n\t\t\t// To know if global events are to be dispatched\n\t\t\tfireGlobals,\n\n\t\t\t// Loop variable\n\t\t\ti,\n\n\t\t\t// uncached part of the url\n\t\t\tuncached,\n\n\t\t\t// Create the final options object\n\t\t\ts = jQuery.ajaxSetup( {}, options ),\n\n\t\t\t// Callbacks context\n\t\t\tcallbackContext = s.context || s,\n\n\t\t\t// Context for global events is callbackContext if it is a DOM node or jQuery collection\n\t\t\tglobalEventContext = s.context &&\n\t\t\t\t( callbackContext.nodeType || callbackContext.jquery ) ?\n\t\t\t\t\tjQuery( callbackContext ) :\n\t\t\t\t\tjQuery.event,\n\n\t\t\t// Deferreds\n\t\t\tdeferred = jQuery.Deferred(),\n\t\t\tcompleteDeferred = jQuery.Callbacks( \"once memory\" ),\n\n\t\t\t// Status-dependent callbacks\n\t\t\tstatusCode = s.statusCode || {},\n\n\t\t\t// Headers (they are sent all at once)\n\t\t\trequestHeaders = {},\n\t\t\trequestHeadersNames = {},\n\n\t\t\t// Default abort message\n\t\t\tstrAbort = \"canceled\",\n\n\t\t\t// Fake xhr\n\t\t\tjqXHR = {\n\t\t\t\treadyState: 0,\n\n\t\t\t\t// Builds headers hashtable if needed\n\t\t\t\tgetResponseHeader: function( key ) {\n\t\t\t\t\tvar match;\n\t\t\t\t\tif ( completed ) {\n\t\t\t\t\t\tif ( !responseHeaders ) {\n\t\t\t\t\t\t\tresponseHeaders = {};\n\t\t\t\t\t\t\twhile ( ( match = rheaders.exec( responseHeadersString ) ) ) {\n\t\t\t\t\t\t\t\tresponseHeaders[ match[ 1 ].toLowerCase() + \" \" ] =\n\t\t\t\t\t\t\t\t\t( responseHeaders[ match[ 1 ].toLowerCase() + \" \" ] || [] )\n\t\t\t\t\t\t\t\t\t\t.concat( match[ 2 ] );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tmatch = responseHeaders[ key.toLowerCase() + \" \" ];\n\t\t\t\t\t}\n\t\t\t\t\treturn match == null ? null : match.join( \", \" );\n\t\t\t\t},\n\n\t\t\t\t// Raw string\n\t\t\t\tgetAllResponseHeaders: function() {\n\t\t\t\t\treturn completed ? responseHeadersString : null;\n\t\t\t\t},\n\n\t\t\t\t// Caches the header\n\t\t\t\tsetRequestHeader: function( name, value ) {\n\t\t\t\t\tif ( completed == null ) {\n\t\t\t\t\t\tname = requestHeadersNames[ name.toLowerCase() ] =\n\t\t\t\t\t\t\trequestHeadersNames[ name.toLowerCase() ] || name;\n\t\t\t\t\t\trequestHeaders[ name ] = value;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Overrides response content-type header\n\t\t\t\toverrideMimeType: function( type ) {\n\t\t\t\t\tif ( completed == null ) {\n\t\t\t\t\t\ts.mimeType = type;\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Status-dependent callbacks\n\t\t\t\tstatusCode: function( map ) {\n\t\t\t\t\tvar code;\n\t\t\t\t\tif ( map ) {\n\t\t\t\t\t\tif ( completed ) {\n\n\t\t\t\t\t\t\t// Execute the appropriate callbacks\n\t\t\t\t\t\t\tjqXHR.always( map[ jqXHR.status ] );\n\t\t\t\t\t\t} else {\n\n\t\t\t\t\t\t\t// Lazy-add the new callbacks in a way that preserves old ones\n\t\t\t\t\t\t\tfor ( code in map ) {\n\t\t\t\t\t\t\t\tstatusCode[ code ] = [ statusCode[ code ], map[ code ] ];\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\treturn this;\n\t\t\t\t},\n\n\t\t\t\t// Cancel the request\n\t\t\t\tabort: function( statusText ) {\n\t\t\t\t\tvar finalText = statusText || strAbort;\n\t\t\t\t\tif ( transport ) {\n\t\t\t\t\t\ttransport.abort( finalText );\n\t\t\t\t\t}\n\t\t\t\t\tdone( 0, finalText );\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t};\n\n\t\t// Attach deferreds\n\t\tdeferred.promise( jqXHR );\n\n\t\t// Add protocol if not provided (prefilters might expect it)\n\t\t// Handle falsy url in the settings object (#10093: consistency with old signature)\n\t\t// We also use the url parameter if available\n\t\ts.url = ( ( url || s.url || location.href ) + \"\" )\n\t\t\t.replace( rprotocol, location.protocol + \"//\" );\n\n\t\t// Alias method option to type as per ticket #12004\n\t\ts.type = options.method || options.type || s.method || s.type;\n\n\t\t// Extract dataTypes list\n\t\ts.dataTypes = ( s.dataType || \"*\" ).toLowerCase().match( rnothtmlwhite ) || [ \"\" ];\n\n\t\t// A cross-domain request is in order when the origin doesn't match the current origin.\n\t\tif ( s.crossDomain == null ) {\n\t\t\turlAnchor = document.createElement( \"a\" );\n\n\t\t\t// Support: IE <=8 - 11, Edge 12 - 15\n\t\t\t// IE throws exception on accessing the href property if url is malformed,\n\t\t\t// e.g. http://example.com:80x/\n\t\t\ttry {\n\t\t\t\turlAnchor.href = s.url;\n\n\t\t\t\t// Support: IE <=8 - 11 only\n\t\t\t\t// Anchor's host property isn't correctly set when s.url is relative\n\t\t\t\turlAnchor.href = urlAnchor.href;\n\t\t\t\ts.crossDomain = originAnchor.protocol + \"//\" + originAnchor.host !==\n\t\t\t\t\turlAnchor.protocol + \"//\" + urlAnchor.host;\n\t\t\t} catch ( e ) {\n\n\t\t\t\t// If there is an error parsing the URL, assume it is crossDomain,\n\t\t\t\t// it can be rejected by the transport if it is invalid\n\t\t\t\ts.crossDomain = true;\n\t\t\t}\n\t\t}\n\n\t\t// Convert data if not already a string\n\t\tif ( s.data && s.processData && typeof s.data !== \"string\" ) {\n\t\t\ts.data = jQuery.param( s.data, s.traditional );\n\t\t}\n\n\t\t// Apply prefilters\n\t\tinspectPrefiltersOrTransports( prefilters, s, options, jqXHR );\n\n\t\t// If request was aborted inside a prefilter, stop there\n\t\tif ( completed ) {\n\t\t\treturn jqXHR;\n\t\t}\n\n\t\t// We can fire global events as of now if asked to\n\t\t// Don't fire events if jQuery.event is undefined in an AMD-usage scenario (#15118)\n\t\tfireGlobals = jQuery.event && s.global;\n\n\t\t// Watch for a new set of requests\n\t\tif ( fireGlobals && jQuery.active++ === 0 ) {\n\t\t\tjQuery.event.trigger( \"ajaxStart\" );\n\t\t}\n\n\t\t// Uppercase the type\n\t\ts.type = s.type.toUpperCase();\n\n\t\t// Determine if request has content\n\t\ts.hasContent = !rnoContent.test( s.type );\n\n\t\t// Save the URL in case we're toying with the If-Modified-Since\n\t\t// and/or If-None-Match header later on\n\t\t// Remove hash to simplify url manipulation\n\t\tcacheURL = s.url.replace( rhash, \"\" );\n\n\t\t// More options handling for requests with no content\n\t\tif ( !s.hasContent ) {\n\n\t\t\t// Remember the hash so we can put it back\n\t\t\tuncached = s.url.slice( cacheURL.length );\n\n\t\t\t// If data is available and should be processed, append data to url\n\t\t\tif ( s.data && ( s.processData || typeof s.data === \"string\" ) ) {\n\t\t\t\tcacheURL += ( rquery.test( cacheURL ) ? \"&\" : \"?\" ) + s.data;\n\n\t\t\t\t// #9682: remove data so that it's not used in an eventual retry\n\t\t\t\tdelete s.data;\n\t\t\t}\n\n\t\t\t// Add or update anti-cache param if needed\n\t\t\tif ( s.cache === false ) {\n\t\t\t\tcacheURL = cacheURL.replace( rantiCache, \"$1\" );\n\t\t\t\tuncached = ( rquery.test( cacheURL ) ? \"&\" : \"?\" ) + \"_=\" + ( nonce.guid++ ) +\n\t\t\t\t\tuncached;\n\t\t\t}\n\n\t\t\t// Put hash and anti-cache on the URL that will be requested (gh-1732)\n\t\t\ts.url = cacheURL + uncached;\n\n\t\t// Change '%20' to '+' if this is encoded form body content (gh-2658)\n\t\t} else if ( s.data && s.processData &&\n\t\t\t( s.contentType || \"\" ).indexOf( \"application/x-www-form-urlencoded\" ) === 0 ) {\n\t\t\ts.data = s.data.replace( r20, \"+\" );\n\t\t}\n\n\t\t// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.\n\t\tif ( s.ifModified ) {\n\t\t\tif ( jQuery.lastModified[ cacheURL ] ) {\n\t\t\t\tjqXHR.setRequestHeader( \"If-Modified-Since\", jQuery.lastModified[ cacheURL ] );\n\t\t\t}\n\t\t\tif ( jQuery.etag[ cacheURL ] ) {\n\t\t\t\tjqXHR.setRequestHeader( \"If-None-Match\", jQuery.etag[ cacheURL ] );\n\t\t\t}\n\t\t}\n\n\t\t// Set the correct header, if data is being sent\n\t\tif ( s.data && s.hasContent && s.contentType !== false || options.contentType ) {\n\t\t\tjqXHR.setRequestHeader( \"Content-Type\", s.contentType );\n\t\t}\n\n\t\t// Set the Accepts header for the server, depending on the dataType\n\t\tjqXHR.setRequestHeader(\n\t\t\t\"Accept\",\n\t\t\ts.dataTypes[ 0 ] && s.accepts[ s.dataTypes[ 0 ] ] ?\n\t\t\t\ts.accepts[ s.dataTypes[ 0 ] ] +\n\t\t\t\t\t( s.dataTypes[ 0 ] !== \"*\" ? \", \" + allTypes + \"; q=0.01\" : \"\" ) :\n\t\t\t\ts.accepts[ \"*\" ]\n\t\t);\n\n\t\t// Check for headers option\n\t\tfor ( i in s.headers ) {\n\t\t\tjqXHR.setRequestHeader( i, s.headers[ i ] );\n\t\t}\n\n\t\t// Allow custom headers/mimetypes and early abort\n\t\tif ( s.beforeSend &&\n\t\t\t( s.beforeSend.call( callbackContext, jqXHR, s ) === false || completed ) ) {\n\n\t\t\t// Abort if not done already and return\n\t\t\treturn jqXHR.abort();\n\t\t}\n\n\t\t// Aborting is no longer a cancellation\n\t\tstrAbort = \"abort\";\n\n\t\t// Install callbacks on deferreds\n\t\tcompleteDeferred.add( s.complete );\n\t\tjqXHR.done( s.success );\n\t\tjqXHR.fail( s.error );\n\n\t\t// Get transport\n\t\ttransport = inspectPrefiltersOrTransports( transports, s, options, jqXHR );\n\n\t\t// If no transport, we auto-abort\n\t\tif ( !transport ) {\n\t\t\tdone( -1, \"No Transport\" );\n\t\t} else {\n\t\t\tjqXHR.readyState = 1;\n\n\t\t\t// Send global event\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( \"ajaxSend\", [ jqXHR, s ] );\n\t\t\t}\n\n\t\t\t// If request was aborted inside ajaxSend, stop there\n\t\t\tif ( completed ) {\n\t\t\t\treturn jqXHR;\n\t\t\t}\n\n\t\t\t// Timeout\n\t\t\tif ( s.async && s.timeout > 0 ) {\n\t\t\t\ttimeoutTimer = window.setTimeout( function() {\n\t\t\t\t\tjqXHR.abort( \"timeout\" );\n\t\t\t\t}, s.timeout );\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\tcompleted = false;\n\t\t\t\ttransport.send( requestHeaders, done );\n\t\t\t} catch ( e ) {\n\n\t\t\t\t// Rethrow post-completion exceptions\n\t\t\t\tif ( completed ) {\n\t\t\t\t\tthrow e;\n\t\t\t\t}\n\n\t\t\t\t// Propagate others as results\n\t\t\t\tdone( -1, e );\n\t\t\t}\n\t\t}\n\n\t\t// Callback for when everything is done\n\t\tfunction done( status, nativeStatusText, responses, headers ) {\n\t\t\tvar isSuccess, success, error, response, modified,\n\t\t\t\tstatusText = nativeStatusText;\n\n\t\t\t// Ignore repeat invocations\n\t\t\tif ( completed ) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tcompleted = true;\n\n\t\t\t// Clear timeout if it exists\n\t\t\tif ( timeoutTimer ) {\n\t\t\t\twindow.clearTimeout( timeoutTimer );\n\t\t\t}\n\n\t\t\t// Dereference transport for early garbage collection\n\t\t\t// (no matter how long the jqXHR object will be used)\n\t\t\ttransport = undefined;\n\n\t\t\t// Cache response headers\n\t\t\tresponseHeadersString = headers || \"\";\n\n\t\t\t// Set readyState\n\t\t\tjqXHR.readyState = status > 0 ? 4 : 0;\n\n\t\t\t// Determine if successful\n\t\t\tisSuccess = status >= 200 && status < 300 || status === 304;\n\n\t\t\t// Get response data\n\t\t\tif ( responses ) {\n\t\t\t\tresponse = ajaxHandleResponses( s, jqXHR, responses );\n\t\t\t}\n\n\t\t\t// Use a noop converter for missing script\n\t\t\tif ( !isSuccess && jQuery.inArray( \"script\", s.dataTypes ) > -1 ) {\n\t\t\t\ts.converters[ \"text script\" ] = function() {};\n\t\t\t}\n\n\t\t\t// Convert no matter what (that way responseXXX fields are always set)\n\t\t\tresponse = ajaxConvert( s, response, jqXHR, isSuccess );\n\n\t\t\t// If successful, handle type chaining\n\t\t\tif ( isSuccess ) {\n\n\t\t\t\t// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.\n\t\t\t\tif ( s.ifModified ) {\n\t\t\t\t\tmodified = jqXHR.getResponseHeader( \"Last-Modified\" );\n\t\t\t\t\tif ( modified ) {\n\t\t\t\t\t\tjQuery.lastModified[ cacheURL ] = modified;\n\t\t\t\t\t}\n\t\t\t\t\tmodified = jqXHR.getResponseHeader( \"etag\" );\n\t\t\t\t\tif ( modified ) {\n\t\t\t\t\t\tjQuery.etag[ cacheURL ] = modified;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// if no content\n\t\t\t\tif ( status === 204 || s.type === \"HEAD\" ) {\n\t\t\t\t\tstatusText = \"nocontent\";\n\n\t\t\t\t// if not modified\n\t\t\t\t} else if ( status === 304 ) {\n\t\t\t\t\tstatusText = \"notmodified\";\n\n\t\t\t\t// If we have data, let's convert it\n\t\t\t\t} else {\n\t\t\t\t\tstatusText = response.state;\n\t\t\t\t\tsuccess = response.data;\n\t\t\t\t\terror = response.error;\n\t\t\t\t\tisSuccess = !error;\n\t\t\t\t}\n\t\t\t} else {\n\n\t\t\t\t// Extract error from statusText and normalize for non-aborts\n\t\t\t\terror = statusText;\n\t\t\t\tif ( status || !statusText ) {\n\t\t\t\t\tstatusText = \"error\";\n\t\t\t\t\tif ( status < 0 ) {\n\t\t\t\t\t\tstatus = 0;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Set data for the fake xhr object\n\t\t\tjqXHR.status = status;\n\t\t\tjqXHR.statusText = ( nativeStatusText || statusText ) + \"\";\n\n\t\t\t// Success/Error\n\t\t\tif ( isSuccess ) {\n\t\t\t\tdeferred.resolveWith( callbackContext, [ success, statusText, jqXHR ] );\n\t\t\t} else {\n\t\t\t\tdeferred.rejectWith( callbackContext, [ jqXHR, statusText, error ] );\n\t\t\t}\n\n\t\t\t// Status-dependent callbacks\n\t\t\tjqXHR.statusCode( statusCode );\n\t\t\tstatusCode = undefined;\n\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( isSuccess ? \"ajaxSuccess\" : \"ajaxError\",\n\t\t\t\t\t[ jqXHR, s, isSuccess ? success : error ] );\n\t\t\t}\n\n\t\t\t// Complete\n\t\t\tcompleteDeferred.fireWith( callbackContext, [ jqXHR, statusText ] );\n\n\t\t\tif ( fireGlobals ) {\n\t\t\t\tglobalEventContext.trigger( \"ajaxComplete\", [ jqXHR, s ] );\n\n\t\t\t\t// Handle the global AJAX counter\n\t\t\t\tif ( !( --jQuery.active ) ) {\n\t\t\t\t\tjQuery.event.trigger( \"ajaxStop\" );\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn jqXHR;\n\t},\n\n\tgetJSON: function( url, data, callback ) {\n\t\treturn jQuery.get( url, data, callback, \"json\" );\n\t},\n\n\tgetScript: function( url, callback ) {\n\t\treturn jQuery.get( url, undefined, callback, \"script\" );\n\t}\n} );\n\njQuery.each( [ \"get\", \"post\" ], function( _i, method ) {\n\tjQuery[ method ] = function( url, data, callback, type ) {\n\n\t\t// Shift arguments if data argument was omitted\n\t\tif ( isFunction( data ) ) {\n\t\t\ttype = type || callback;\n\t\t\tcallback = data;\n\t\t\tdata = undefined;\n\t\t}\n\n\t\t// The url can be an options object (which then must have .url)\n\t\treturn jQuery.ajax( jQuery.extend( {\n\t\t\turl: url,\n\t\t\ttype: method,\n\t\t\tdataType: type,\n\t\t\tdata: data,\n\t\t\tsuccess: callback\n\t\t}, jQuery.isPlainObject( url ) && url ) );\n\t};\n} );\n\njQuery.ajaxPrefilter( function( s ) {\n\tvar i;\n\tfor ( i in s.headers ) {\n\t\tif ( i.toLowerCase() === \"content-type\" ) {\n\t\t\ts.contentType = s.headers[ i ] || \"\";\n\t\t}\n\t}\n} );\n\n\njQuery._evalUrl = function( url, options, doc ) {\n\treturn jQuery.ajax( {\n\t\turl: url,\n\n\t\t// Make this explicit, since user can override this through ajaxSetup (#11264)\n\t\ttype: \"GET\",\n\t\tdataType: \"script\",\n\t\tcache: true,\n\t\tasync: false,\n\t\tglobal: false,\n\n\t\t// Only evaluate the response if it is successful (gh-4126)\n\t\t// dataFilter is not invoked for failure responses, so using it instead\n\t\t// of the default converter is kludgy but it works.\n\t\tconverters: {\n\t\t\t\"text script\": function() {}\n\t\t},\n\t\tdataFilter: function( response ) {\n\t\t\tjQuery.globalEval( response, options, doc );\n\t\t}\n\t} );\n};\n\n\njQuery.fn.extend( {\n\twrapAll: function( html ) {\n\t\tvar wrap;\n\n\t\tif ( this[ 0 ] ) {\n\t\t\tif ( isFunction( html ) ) {\n\t\t\t\thtml = html.call( this[ 0 ] );\n\t\t\t}\n\n\t\t\t// The elements to wrap the target around\n\t\t\twrap = jQuery( html, this[ 0 ].ownerDocument ).eq( 0 ).clone( true );\n\n\t\t\tif ( this[ 0 ].parentNode ) {\n\t\t\t\twrap.insertBefore( this[ 0 ] );\n\t\t\t}\n\n\t\t\twrap.map( function() {\n\t\t\t\tvar elem = this;\n\n\t\t\t\twhile ( elem.firstElementChild ) {\n\t\t\t\t\telem = elem.firstElementChild;\n\t\t\t\t}\n\n\t\t\t\treturn elem;\n\t\t\t} ).append( this );\n\t\t}\n\n\t\treturn this;\n\t},\n\n\twrapInner: function( html ) {\n\t\tif ( isFunction( html ) ) {\n\t\t\treturn this.each( function( i ) {\n\t\t\t\tjQuery( this ).wrapInner( html.call( this, i ) );\n\t\t\t} );\n\t\t}\n\n\t\treturn this.each( function() {\n\t\t\tvar self = jQuery( this ),\n\t\t\t\tcontents = self.contents();\n\n\t\t\tif ( contents.length ) {\n\t\t\t\tcontents.wrapAll( html );\n\n\t\t\t} else {\n\t\t\t\tself.append( html );\n\t\t\t}\n\t\t} );\n\t},\n\n\twrap: function( html ) {\n\t\tvar htmlIsFunction = isFunction( html );\n\n\t\treturn this.each( function( i ) {\n\t\t\tjQuery( this ).wrapAll( htmlIsFunction ? html.call( this, i ) : html );\n\t\t} );\n\t},\n\n\tunwrap: function( selector ) {\n\t\tthis.parent( selector ).not( \"body\" ).each( function() {\n\t\t\tjQuery( this ).replaceWith( this.childNodes );\n\t\t} );\n\t\treturn this;\n\t}\n} );\n\n\njQuery.expr.pseudos.hidden = function( elem ) {\n\treturn !jQuery.expr.pseudos.visible( elem );\n};\njQuery.expr.pseudos.visible = function( elem ) {\n\treturn !!( elem.offsetWidth || elem.offsetHeight || elem.getClientRects().length );\n};\n\n\n\n\njQuery.ajaxSettings.xhr = function() {\n\ttry {\n\t\treturn new window.XMLHttpRequest();\n\t} catch ( e ) {}\n};\n\nvar xhrSuccessStatus = {\n\n\t\t// File protocol always yields status code 0, assume 200\n\t\t0: 200,\n\n\t\t// Support: IE <=9 only\n\t\t// #1450: sometimes IE returns 1223 when it should be 204\n\t\t1223: 204\n\t},\n\txhrSupported = jQuery.ajaxSettings.xhr();\n\nsupport.cors = !!xhrSupported && ( \"withCredentials\" in xhrSupported );\nsupport.ajax = xhrSupported = !!xhrSupported;\n\njQuery.ajaxTransport( function( options ) {\n\tvar callback, errorCallback;\n\n\t// Cross domain only allowed if supported through XMLHttpRequest\n\tif ( support.cors || xhrSupported && !options.crossDomain ) {\n\t\treturn {\n\t\t\tsend: function( headers, complete ) {\n\t\t\t\tvar i,\n\t\t\t\t\txhr = options.xhr();\n\n\t\t\t\txhr.open(\n\t\t\t\t\toptions.type,\n\t\t\t\t\toptions.url,\n\t\t\t\t\toptions.async,\n\t\t\t\t\toptions.username,\n\t\t\t\t\toptions.password\n\t\t\t\t);\n\n\t\t\t\t// Apply custom fields if provided\n\t\t\t\tif ( options.xhrFields ) {\n\t\t\t\t\tfor ( i in options.xhrFields ) {\n\t\t\t\t\t\txhr[ i ] = options.xhrFields[ i ];\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// Override mime type if needed\n\t\t\t\tif ( options.mimeType && xhr.overrideMimeType ) {\n\t\t\t\t\txhr.overrideMimeType( options.mimeType );\n\t\t\t\t}\n\n\t\t\t\t// X-Requested-With header\n\t\t\t\t// For cross-domain requests, seeing as conditions for a preflight are\n\t\t\t\t// akin to a jigsaw puzzle, we simply never set it to be sure.\n\t\t\t\t// (it can always be set on a per-request basis or even using ajaxSetup)\n\t\t\t\t// For same-domain requests, won't change header if already provided.\n\t\t\t\tif ( !options.crossDomain && !headers[ \"X-Requested-With\" ] ) {\n\t\t\t\t\theaders[ \"X-Requested-With\" ] = \"XMLHttpRequest\";\n\t\t\t\t}\n\n\t\t\t\t// Set headers\n\t\t\t\tfor ( i in headers ) {\n\t\t\t\t\txhr.setRequestHeader( i, headers[ i ] );\n\t\t\t\t}\n\n\t\t\t\t// Callback\n\t\t\t\tcallback = function( type ) {\n\t\t\t\t\treturn function() {\n\t\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\t\tcallback = errorCallback = xhr.onload =\n\t\t\t\t\t\t\t\txhr.onerror = xhr.onabort = xhr.ontimeout =\n\t\t\t\t\t\t\t\t\txhr.onreadystatechange = null;\n\n\t\t\t\t\t\t\tif ( type === \"abort\" ) {\n\t\t\t\t\t\t\t\txhr.abort();\n\t\t\t\t\t\t\t} else if ( type === \"error\" ) {\n\n\t\t\t\t\t\t\t\t// Support: IE <=9 only\n\t\t\t\t\t\t\t\t// On a manual native abort, IE9 throws\n\t\t\t\t\t\t\t\t// errors on any property access that is not readyState\n\t\t\t\t\t\t\t\tif ( typeof xhr.status !== \"number\" ) {\n\t\t\t\t\t\t\t\t\tcomplete( 0, \"error\" );\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tcomplete(\n\n\t\t\t\t\t\t\t\t\t\t// File: protocol always yields status 0; see #8605, #14207\n\t\t\t\t\t\t\t\t\t\txhr.status,\n\t\t\t\t\t\t\t\t\t\txhr.statusText\n\t\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tcomplete(\n\t\t\t\t\t\t\t\t\txhrSuccessStatus[ xhr.status ] || xhr.status,\n\t\t\t\t\t\t\t\t\txhr.statusText,\n\n\t\t\t\t\t\t\t\t\t// Support: IE <=9 only\n\t\t\t\t\t\t\t\t\t// IE9 has no XHR2 but throws on binary (trac-11426)\n\t\t\t\t\t\t\t\t\t// For XHR2 non-text, let the caller handle it (gh-2498)\n\t\t\t\t\t\t\t\t\t( xhr.responseType || \"text\" ) !== \"text\" ||\n\t\t\t\t\t\t\t\t\ttypeof xhr.responseText !== \"string\" ?\n\t\t\t\t\t\t\t\t\t\t{ binary: xhr.response } :\n\t\t\t\t\t\t\t\t\t\t{ text: xhr.responseText },\n\t\t\t\t\t\t\t\t\txhr.getAllResponseHeaders()\n\t\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t};\n\n\t\t\t\t// Listen to events\n\t\t\t\txhr.onload = callback();\n\t\t\t\terrorCallback = xhr.onerror = xhr.ontimeout = callback( \"error\" );\n\n\t\t\t\t// Support: IE 9 only\n\t\t\t\t// Use onreadystatechange to replace onabort\n\t\t\t\t// to handle uncaught aborts\n\t\t\t\tif ( xhr.onabort !== undefined ) {\n\t\t\t\t\txhr.onabort = errorCallback;\n\t\t\t\t} else {\n\t\t\t\t\txhr.onreadystatechange = function() {\n\n\t\t\t\t\t\t// Check readyState before timeout as it changes\n\t\t\t\t\t\tif ( xhr.readyState === 4 ) {\n\n\t\t\t\t\t\t\t// Allow onerror to be called first,\n\t\t\t\t\t\t\t// but that will not handle a native abort\n\t\t\t\t\t\t\t// Also, save errorCallback to a variable\n\t\t\t\t\t\t\t// as xhr.onerror cannot be accessed\n\t\t\t\t\t\t\twindow.setTimeout( function() {\n\t\t\t\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\t\t\t\terrorCallback();\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t}\n\n\t\t\t\t// Create the abort callback\n\t\t\t\tcallback = callback( \"abort\" );\n\n\t\t\t\ttry {\n\n\t\t\t\t\t// Do send the request (this may raise an exception)\n\t\t\t\t\txhr.send( options.hasContent && options.data || null );\n\t\t\t\t} catch ( e ) {\n\n\t\t\t\t\t// #14683: Only rethrow if this hasn't been notified as an error yet\n\t\t\t\t\tif ( callback ) {\n\t\t\t\t\t\tthrow e;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\n\t\t\tabort: function() {\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n} );\n\n\n\n\n// Prevent auto-execution of scripts when no explicit dataType was provided (See gh-2432)\njQuery.ajaxPrefilter( function( s ) {\n\tif ( s.crossDomain ) {\n\t\ts.contents.script = false;\n\t}\n} );\n\n// Install script dataType\njQuery.ajaxSetup( {\n\taccepts: {\n\t\tscript: \"text/javascript, application/javascript, \" +\n\t\t\t\"application/ecmascript, application/x-ecmascript\"\n\t},\n\tcontents: {\n\t\tscript: /\\b(?:java|ecma)script\\b/\n\t},\n\tconverters: {\n\t\t\"text script\": function( text ) {\n\t\t\tjQuery.globalEval( text );\n\t\t\treturn text;\n\t\t}\n\t}\n} );\n\n// Handle cache's special case and crossDomain\njQuery.ajaxPrefilter( \"script\", function( s ) {\n\tif ( s.cache === undefined ) {\n\t\ts.cache = false;\n\t}\n\tif ( s.crossDomain ) {\n\t\ts.type = \"GET\";\n\t}\n} );\n\n// Bind script tag hack transport\njQuery.ajaxTransport( \"script\", function( s ) {\n\n\t// This transport only deals with cross domain or forced-by-attrs requests\n\tif ( s.crossDomain || s.scriptAttrs ) {\n\t\tvar script, callback;\n\t\treturn {\n\t\t\tsend: function( _, complete ) {\n\t\t\t\tscript = jQuery( \"<script>\" )\n\t\t\t\t\t.attr( s.scriptAttrs || {} )\n\t\t\t\t\t.prop( { charset: s.scriptCharset, src: s.url } )\n\t\t\t\t\t.on( \"load error\", callback = function( evt ) {\n\t\t\t\t\t\tscript.remove();\n\t\t\t\t\t\tcallback = null;\n\t\t\t\t\t\tif ( evt ) {\n\t\t\t\t\t\t\tcomplete( evt.type === \"error\" ? 404 : 200, evt.type );\n\t\t\t\t\t\t}\n\t\t\t\t\t} );\n\n\t\t\t\t// Use native DOM manipulation to avoid our domManip AJAX trickery\n\t\t\t\tdocument.head.appendChild( script[ 0 ] );\n\t\t\t},\n\t\t\tabort: function() {\n\t\t\t\tif ( callback ) {\n\t\t\t\t\tcallback();\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\t}\n} );\n\n\n\n\nvar oldCallbacks = [],\n\trjsonp = /(=)\\?(?=&|$)|\\?\\?/;\n\n// Default jsonp settings\njQuery.ajaxSetup( {\n\tjsonp: \"callback\",\n\tjsonpCallback: function() {\n\t\tvar callback = oldCallbacks.pop() || ( jQuery.expando + \"_\" + ( nonce.guid++ ) );\n\t\tthis[ callback ] = true;\n\t\treturn callback;\n\t}\n} );\n\n// Detect, normalize options and install callbacks for jsonp requests\njQuery.ajaxPrefilter( \"json jsonp\", function( s, originalSettings, jqXHR ) {\n\n\tvar callbackName, overwritten, responseContainer,\n\t\tjsonProp = s.jsonp !== false && ( rjsonp.test( s.url ) ?\n\t\t\t\"url\" :\n\t\t\ttypeof s.data === \"string\" &&\n\t\t\t\t( s.contentType || \"\" )\n\t\t\t\t\t.indexOf( \"application/x-www-form-urlencoded\" ) === 0 &&\n\t\t\t\trjsonp.test( s.data ) && \"data\"\n\t\t);\n\n\t// Handle iff the expected data type is \"jsonp\" or we have a parameter to set\n\tif ( jsonProp || s.dataTypes[ 0 ] === \"jsonp\" ) {\n\n\t\t// Get callback name, remembering preexisting value associated with it\n\t\tcallbackName = s.jsonpCallback = isFunction( s.jsonpCallback ) ?\n\t\t\ts.jsonpCallback() :\n\t\t\ts.jsonpCallback;\n\n\t\t// Insert callback into url or form data\n\t\tif ( jsonProp ) {\n\t\t\ts[ jsonProp ] = s[ jsonProp ].replace( rjsonp, \"$1\" + callbackName );\n\t\t} else if ( s.jsonp !== false ) {\n\t\t\ts.url += ( rquery.test( s.url ) ? \"&\" : \"?\" ) + s.jsonp + \"=\" + callbackName;\n\t\t}\n\n\t\t// Use data converter to retrieve json after script execution\n\t\ts.converters[ \"script json\" ] = function() {\n\t\t\tif ( !responseContainer ) {\n\t\t\t\tjQuery.error( callbackName + \" was not called\" );\n\t\t\t}\n\t\t\treturn responseContainer[ 0 ];\n\t\t};\n\n\t\t// Force json dataType\n\t\ts.dataTypes[ 0 ] = \"json\";\n\n\t\t// Install callback\n\t\toverwritten = window[ callbackName ];\n\t\twindow[ callbackName ] = function() {\n\t\t\tresponseContainer = arguments;\n\t\t};\n\n\t\t// Clean-up function (fires after converters)\n\t\tjqXHR.always( function() {\n\n\t\t\t// If previous value didn't exist - remove it\n\t\t\tif ( overwritten === undefined ) {\n\t\t\t\tjQuery( window ).removeProp( callbackName );\n\n\t\t\t// Otherwise restore preexisting value\n\t\t\t} else {\n\t\t\t\twindow[ callbackName ] = overwritten;\n\t\t\t}\n\n\t\t\t// Save back as free\n\t\t\tif ( s[ callbackName ] ) {\n\n\t\t\t\t// Make sure that re-using the options doesn't screw things around\n\t\t\t\ts.jsonpCallback = originalSettings.jsonpCallback;\n\n\t\t\t\t// Save the callback name for future use\n\t\t\t\toldCallbacks.push( callbackName );\n\t\t\t}\n\n\t\t\t// Call if it was a function and we have a response\n\t\t\tif ( responseContainer && isFunction( overwritten ) ) {\n\t\t\t\toverwritten( responseContainer[ 0 ] );\n\t\t\t}\n\n\t\t\tresponseContainer = overwritten = undefined;\n\t\t} );\n\n\t\t// Delegate to script\n\t\treturn \"script\";\n\t}\n} );\n\n\n\n\n// Support: Safari 8 only\n// In Safari 8 documents created via document.implementation.createHTMLDocument\n// collapse sibling forms: the second one becomes a child of the first one.\n// Because of that, this security measure has to be disabled in Safari 8.\n// https://bugs.webkit.org/show_bug.cgi?id=137337\nsupport.createHTMLDocument = ( function() {\n\tvar body = document.implementation.createHTMLDocument( \"\" ).body;\n\tbody.innerHTML = \"<form></form><form></form>\";\n\treturn body.childNodes.length === 2;\n} )();\n\n\n// Argument \"data\" should be string of html\n// context (optional): If specified, the fragment will be created in this context,\n// defaults to document\n// keepScripts (optional): If true, will include scripts passed in the html string\njQuery.parseHTML = function( data, context, keepScripts ) {\n\tif ( typeof data !== \"string\" ) {\n\t\treturn [];\n\t}\n\tif ( typeof context === \"boolean\" ) {\n\t\tkeepScripts = context;\n\t\tcontext = false;\n\t}\n\n\tvar base, parsed, scripts;\n\n\tif ( !context ) {\n\n\t\t// Stop scripts or inline event handlers from being executed immediately\n\t\t// by using document.implementation\n\t\tif ( support.createHTMLDocument ) {\n\t\t\tcontext = document.implementation.createHTMLDocument( \"\" );\n\n\t\t\t// Set the base href for the created document\n\t\t\t// so any parsed elements with URLs\n\t\t\t// are based on the document's URL (gh-2965)\n\t\t\tbase = context.createElement( \"base\" );\n\t\t\tbase.href = document.location.href;\n\t\t\tcontext.head.appendChild( base );\n\t\t} else {\n\t\t\tcontext = document;\n\t\t}\n\t}\n\n\tparsed = rsingleTag.exec( data );\n\tscripts = !keepScripts && [];\n\n\t// Single tag\n\tif ( parsed ) {\n\t\treturn [ context.createElement( parsed[ 1 ] ) ];\n\t}\n\n\tparsed = buildFragment( [ data ], context, scripts );\n\n\tif ( scripts && scripts.length ) {\n\t\tjQuery( scripts ).remove();\n\t}\n\n\treturn jQuery.merge( [], parsed.childNodes );\n};\n\n\n/**\n * Load a url into a page\n */\njQuery.fn.load = function( url, params, callback ) {\n\tvar selector, type, response,\n\t\tself = this,\n\t\toff = url.indexOf( \" \" );\n\n\tif ( off > -1 ) {\n\t\tselector = stripAndCollapse( url.slice( off ) );\n\t\turl = url.slice( 0, off );\n\t}\n\n\t// If it's a function\n\tif ( isFunction( params ) ) {\n\n\t\t// We assume that it's the callback\n\t\tcallback = params;\n\t\tparams = undefined;\n\n\t// Otherwise, build a param string\n\t} else if ( params && typeof params === \"object\" ) {\n\t\ttype = \"POST\";\n\t}\n\n\t// If we have elements to modify, make the request\n\tif ( self.length > 0 ) {\n\t\tjQuery.ajax( {\n\t\t\turl: url,\n\n\t\t\t// If \"type\" variable is undefined, then \"GET\" method will be used.\n\t\t\t// Make value of this field explicit since\n\t\t\t// user can override it through ajaxSetup method\n\t\t\ttype: type || \"GET\",\n\t\t\tdataType: \"html\",\n\t\t\tdata: params\n\t\t} ).done( function( responseText ) {\n\n\t\t\t// Save response for use in complete callback\n\t\t\tresponse = arguments;\n\n\t\t\tself.html( selector ?\n\n\t\t\t\t// If a selector was specified, locate the right elements in a dummy div\n\t\t\t\t// Exclude scripts to avoid IE 'Permission Denied' errors\n\t\t\t\tjQuery( \"<div>\" ).append( jQuery.parseHTML( responseText ) ).find( selector ) :\n\n\t\t\t\t// Otherwise use the full result\n\t\t\t\tresponseText );\n\n\t\t// If the request succeeds, this function gets \"data\", \"status\", \"jqXHR\"\n\t\t// but they are ignored because response was set above.\n\t\t// If it fails, this function gets \"jqXHR\", \"status\", \"error\"\n\t\t} ).always( callback && function( jqXHR, status ) {\n\t\t\tself.each( function() {\n\t\t\t\tcallback.apply( this, response || [ jqXHR.responseText, status, jqXHR ] );\n\t\t\t} );\n\t\t} );\n\t}\n\n\treturn this;\n};\n\n\n\n\njQuery.expr.pseudos.animated = function( elem ) {\n\treturn jQuery.grep( jQuery.timers, function( fn ) {\n\t\treturn elem === fn.elem;\n\t} ).length;\n};\n\n\n\n\njQuery.offset = {\n\tsetOffset: function( elem, options, i ) {\n\t\tvar curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition,\n\t\t\tposition = jQuery.css( elem, \"position\" ),\n\t\t\tcurElem = jQuery( elem ),\n\t\t\tprops = {};\n\n\t\t// Set position first, in-case top/left are set even on static elem\n\t\tif ( position === \"static\" ) {\n\t\t\telem.style.position = \"relative\";\n\t\t}\n\n\t\tcurOffset = curElem.offset();\n\t\tcurCSSTop = jQuery.css( elem, \"top\" );\n\t\tcurCSSLeft = jQuery.css( elem, \"left\" );\n\t\tcalculatePosition = ( position === \"absolute\" || position === \"fixed\" ) &&\n\t\t\t( curCSSTop + curCSSLeft ).indexOf( \"auto\" ) > -1;\n\n\t\t// Need to be able to calculate position if either\n\t\t// top or left is auto and position is either absolute or fixed\n\t\tif ( calculatePosition ) {\n\t\t\tcurPosition = curElem.position();\n\t\t\tcurTop = curPosition.top;\n\t\t\tcurLeft = curPosition.left;\n\n\t\t} else {\n\t\t\tcurTop = parseFloat( curCSSTop ) || 0;\n\t\t\tcurLeft = parseFloat( curCSSLeft ) || 0;\n\t\t}\n\n\t\tif ( isFunction( options ) ) {\n\n\t\t\t// Use jQuery.extend here to allow modification of coordinates argument (gh-1848)\n\t\t\toptions = options.call( elem, i, jQuery.extend( {}, curOffset ) );\n\t\t}\n\n\t\tif ( options.top != null ) {\n\t\t\tprops.top = ( options.top - curOffset.top ) + curTop;\n\t\t}\n\t\tif ( options.left != null ) {\n\t\t\tprops.left = ( options.left - curOffset.left ) + curLeft;\n\t\t}\n\n\t\tif ( \"using\" in options ) {\n\t\t\toptions.using.call( elem, props );\n\n\t\t} else {\n\t\t\tif ( typeof props.top === \"number\" ) {\n\t\t\t\tprops.top += \"px\";\n\t\t\t}\n\t\t\tif ( typeof props.left === \"number\" ) {\n\t\t\t\tprops.left += \"px\";\n\t\t\t}\n\t\t\tcurElem.css( props );\n\t\t}\n\t}\n};\n\njQuery.fn.extend( {\n\n\t// offset() relates an element's border box to the document origin\n\toffset: function( options ) {\n\n\t\t// Preserve chaining for setter\n\t\tif ( arguments.length ) {\n\t\t\treturn options === undefined ?\n\t\t\t\tthis :\n\t\t\t\tthis.each( function( i ) {\n\t\t\t\t\tjQuery.offset.setOffset( this, options, i );\n\t\t\t\t} );\n\t\t}\n\n\t\tvar rect, win,\n\t\t\telem = this[ 0 ];\n\n\t\tif ( !elem ) {\n\t\t\treturn;\n\t\t}\n\n\t\t// Return zeros for disconnected and hidden (display: none) elements (gh-2310)\n\t\t// Support: IE <=11 only\n\t\t// Running getBoundingClientRect on a\n\t\t// disconnected node in IE throws an error\n\t\tif ( !elem.getClientRects().length ) {\n\t\t\treturn { top: 0, left: 0 };\n\t\t}\n\n\t\t// Get document-relative position by adding viewport scroll to viewport-relative gBCR\n\t\trect = elem.getBoundingClientRect();\n\t\twin = elem.ownerDocument.defaultView;\n\t\treturn {\n\t\t\ttop: rect.top + win.pageYOffset,\n\t\t\tleft: rect.left + win.pageXOffset\n\t\t};\n\t},\n\n\t// position() relates an element's margin box to its offset parent's padding box\n\t// This corresponds to the behavior of CSS absolute positioning\n\tposition: function() {\n\t\tif ( !this[ 0 ] ) {\n\t\t\treturn;\n\t\t}\n\n\t\tvar offsetParent, offset, doc,\n\t\t\telem = this[ 0 ],\n\t\t\tparentOffset = { top: 0, left: 0 };\n\n\t\t// position:fixed elements are offset from the viewport, which itself always has zero offset\n\t\tif ( jQuery.css( elem, \"position\" ) === \"fixed\" ) {\n\n\t\t\t// Assume position:fixed implies availability of getBoundingClientRect\n\t\t\toffset = elem.getBoundingClientRect();\n\n\t\t} else {\n\t\t\toffset = this.offset();\n\n\t\t\t// Account for the *real* offset parent, which can be the document or its root element\n\t\t\t// when a statically positioned element is identified\n\t\t\tdoc = elem.ownerDocument;\n\t\t\toffsetParent = elem.offsetParent || doc.documentElement;\n\t\t\twhile ( offsetParent &&\n\t\t\t\t( offsetParent === doc.body || offsetParent === doc.documentElement ) &&\n\t\t\t\tjQuery.css( offsetParent, \"position\" ) === \"static\" ) {\n\n\t\t\t\toffsetParent = offsetParent.parentNode;\n\t\t\t}\n\t\t\tif ( offsetParent && offsetParent !== elem && offsetParent.nodeType === 1 ) {\n\n\t\t\t\t// Incorporate borders into its offset, since they are outside its content origin\n\t\t\t\tparentOffset = jQuery( offsetParent ).offset();\n\t\t\t\tparentOffset.top += jQuery.css( offsetParent, \"borderTopWidth\", true );\n\t\t\t\tparentOffset.left += jQuery.css( offsetParent, \"borderLeftWidth\", true );\n\t\t\t}\n\t\t}\n\n\t\t// Subtract parent offsets and element margins\n\t\treturn {\n\t\t\ttop: offset.top - parentOffset.top - jQuery.css( elem, \"marginTop\", true ),\n\t\t\tleft: offset.left - parentOffset.left - jQuery.css( elem, \"marginLeft\", true )\n\t\t};\n\t},\n\n\t// This method will return documentElement in the following cases:\n\t// 1) For the element inside the iframe without offsetParent, this method will return\n\t// documentElement of the parent window\n\t// 2) For the hidden or detached element\n\t// 3) For body or html element, i.e. in case of the html node - it will return itself\n\t//\n\t// but those exceptions were never presented as a real life use-cases\n\t// and might be considered as more preferable results.\n\t//\n\t// This logic, however, is not guaranteed and can change at any point in the future\n\toffsetParent: function() {\n\t\treturn this.map( function() {\n\t\t\tvar offsetParent = this.offsetParent;\n\n\t\t\twhile ( offsetParent && jQuery.css( offsetParent, \"position\" ) === \"static\" ) {\n\t\t\t\toffsetParent = offsetParent.offsetParent;\n\t\t\t}\n\n\t\t\treturn offsetParent || documentElement;\n\t\t} );\n\t}\n} );\n\n// Create scrollLeft and scrollTop methods\njQuery.each( { scrollLeft: \"pageXOffset\", scrollTop: \"pageYOffset\" }, function( method, prop ) {\n\tvar top = \"pageYOffset\" === prop;\n\n\tjQuery.fn[ method ] = function( val ) {\n\t\treturn access( this, function( elem, method, val ) {\n\n\t\t\t// Coalesce documents and windows\n\t\t\tvar win;\n\t\t\tif ( isWindow( elem ) ) {\n\t\t\t\twin = elem;\n\t\t\t} else if ( elem.nodeType === 9 ) {\n\t\t\t\twin = elem.defaultView;\n\t\t\t}\n\n\t\t\tif ( val === undefined ) {\n\t\t\t\treturn win ? win[ prop ] : elem[ method ];\n\t\t\t}\n\n\t\t\tif ( win ) {\n\t\t\t\twin.scrollTo(\n\t\t\t\t\t!top ? val : win.pageXOffset,\n\t\t\t\t\ttop ? val : win.pageYOffset\n\t\t\t\t);\n\n\t\t\t} else {\n\t\t\t\telem[ method ] = val;\n\t\t\t}\n\t\t}, method, val, arguments.length );\n\t};\n} );\n\n// Support: Safari <=7 - 9.1, Chrome <=37 - 49\n// Add the top/left cssHooks using jQuery.fn.position\n// Webkit bug: https://bugs.webkit.org/show_bug.cgi?id=29084\n// Blink bug: https://bugs.chromium.org/p/chromium/issues/detail?id=589347\n// getComputedStyle returns percent when specified for top/left/bottom/right;\n// rather than make the css module depend on the offset module, just check for it here\njQuery.each( [ \"top\", \"left\" ], function( _i, prop ) {\n\tjQuery.cssHooks[ prop ] = addGetHookIf( support.pixelPosition,\n\t\tfunction( elem, computed ) {\n\t\t\tif ( computed ) {\n\t\t\t\tcomputed = curCSS( elem, prop );\n\n\t\t\t\t// If curCSS returns percentage, fallback to offset\n\t\t\t\treturn rnumnonpx.test( computed ) ?\n\t\t\t\t\tjQuery( elem ).position()[ prop ] + \"px\" :\n\t\t\t\t\tcomputed;\n\t\t\t}\n\t\t}\n\t);\n} );\n\n\n// Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods\njQuery.each( { Height: \"height\", Width: \"width\" }, function( name, type ) {\n\tjQuery.each( { padding: \"inner\" + name, content: type, \"\": \"outer\" + name },\n\t\tfunction( defaultExtra, funcName ) {\n\n\t\t// Margin is only for outerHeight, outerWidth\n\t\tjQuery.fn[ funcName ] = function( margin, value ) {\n\t\t\tvar chainable = arguments.length && ( defaultExtra || typeof margin !== \"boolean\" ),\n\t\t\t\textra = defaultExtra || ( margin === true || value === true ? \"margin\" : \"border\" );\n\n\t\t\treturn access( this, function( elem, type, value ) {\n\t\t\t\tvar doc;\n\n\t\t\t\tif ( isWindow( elem ) ) {\n\n\t\t\t\t\t// $( window ).outerWidth/Height return w/h including scrollbars (gh-1729)\n\t\t\t\t\treturn funcName.indexOf( \"outer\" ) === 0 ?\n\t\t\t\t\t\telem[ \"inner\" + name ] :\n\t\t\t\t\t\telem.document.documentElement[ \"client\" + name ];\n\t\t\t\t}\n\n\t\t\t\t// Get document width or height\n\t\t\t\tif ( elem.nodeType === 9 ) {\n\t\t\t\t\tdoc = elem.documentElement;\n\n\t\t\t\t\t// Either scroll[Width/Height] or offset[Width/Height] or client[Width/Height],\n\t\t\t\t\t// whichever is greatest\n\t\t\t\t\treturn Math.max(\n\t\t\t\t\t\telem.body[ \"scroll\" + name ], doc[ \"scroll\" + name ],\n\t\t\t\t\t\telem.body[ \"offset\" + name ], doc[ \"offset\" + name ],\n\t\t\t\t\t\tdoc[ \"client\" + name ]\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn value === undefined ?\n\n\t\t\t\t\t// Get width or height on the element, requesting but not forcing parseFloat\n\t\t\t\t\tjQuery.css( elem, type, extra ) :\n\n\t\t\t\t\t// Set width or height on the element\n\t\t\t\t\tjQuery.style( elem, type, value, extra );\n\t\t\t}, type, chainable ? margin : undefined, chainable );\n\t\t};\n\t} );\n} );\n\n\njQuery.each( [\n\t\"ajaxStart\",\n\t\"ajaxStop\",\n\t\"ajaxComplete\",\n\t\"ajaxError\",\n\t\"ajaxSuccess\",\n\t\"ajaxSend\"\n], function( _i, type ) {\n\tjQuery.fn[ type ] = function( fn ) {\n\t\treturn this.on( type, fn );\n\t};\n} );\n\n\n\n\njQuery.fn.extend( {\n\n\tbind: function( types, data, fn ) {\n\t\treturn this.on( types, null, data, fn );\n\t},\n\tunbind: function( types, fn ) {\n\t\treturn this.off( types, null, fn );\n\t},\n\n\tdelegate: function( selector, types, data, fn ) {\n\t\treturn this.on( types, selector, data, fn );\n\t},\n\tundelegate: function( selector, types, fn ) {\n\n\t\t// ( namespace ) or ( selector, types [, fn] )\n\t\treturn arguments.length === 1 ?\n\t\t\tthis.off( selector, \"**\" ) :\n\t\t\tthis.off( types, selector || \"**\", fn );\n\t},\n\n\thover: function( fnOver, fnOut ) {\n\t\treturn this.mouseenter( fnOver ).mouseleave( fnOut || fnOver );\n\t}\n} );\n\njQuery.each( ( \"blur focus focusin focusout resize scroll click dblclick \" +\n\t\"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave \" +\n\t\"change select submit keydown keypress keyup contextmenu\" ).split( \" \" ),\n\tfunction( _i, name ) {\n\n\t\t// Handle event binding\n\t\tjQuery.fn[ name ] = function( data, fn ) {\n\t\t\treturn arguments.length > 0 ?\n\t\t\t\tthis.on( name, null, data, fn ) :\n\t\t\t\tthis.trigger( name );\n\t\t};\n\t} );\n\n\n\n\n// Support: Android <=4.0 only\n// Make sure we trim BOM and NBSP\nvar rtrim = /^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g;\n\n// Bind a function to a context, optionally partially applying any\n// arguments.\n// jQuery.proxy is deprecated to promote standards (specifically Function#bind)\n// However, it is not slated for removal any time soon\njQuery.proxy = function( fn, context ) {\n\tvar tmp, args, proxy;\n\n\tif ( typeof context === \"string\" ) {\n\t\ttmp = fn[ context ];\n\t\tcontext = fn;\n\t\tfn = tmp;\n\t}\n\n\t// Quick check to determine if target is callable, in the spec\n\t// this throws a TypeError, but we will just return undefined.\n\tif ( !isFunction( fn ) ) {\n\t\treturn undefined;\n\t}\n\n\t// Simulated bind\n\targs = slice.call( arguments, 2 );\n\tproxy = function() {\n\t\treturn fn.apply( context || this, args.concat( slice.call( arguments ) ) );\n\t};\n\n\t// Set the guid of unique handler to the same of original handler, so it can be removed\n\tproxy.guid = fn.guid = fn.guid || jQuery.guid++;\n\n\treturn proxy;\n};\n\njQuery.holdReady = function( hold ) {\n\tif ( hold ) {\n\t\tjQuery.readyWait++;\n\t} else {\n\t\tjQuery.ready( true );\n\t}\n};\njQuery.isArray = Array.isArray;\njQuery.parseJSON = JSON.parse;\njQuery.nodeName = nodeName;\njQuery.isFunction = isFunction;\njQuery.isWindow = isWindow;\njQuery.camelCase = camelCase;\njQuery.type = toType;\n\njQuery.now = Date.now;\n\njQuery.isNumeric = function( obj ) {\n\n\t// As of jQuery 3.0, isNumeric is limited to\n\t// strings and numbers (primitives or objects)\n\t// that can be coerced to finite numbers (gh-2662)\n\tvar type = jQuery.type( obj );\n\treturn ( type === \"number\" || type === \"string\" ) &&\n\n\t\t// parseFloat NaNs numeric-cast false positives (\"\")\n\t\t// ...but misinterprets leading-number strings, particularly hex literals (\"0x...\")\n\t\t// subtraction forces infinities to NaN\n\t\t!isNaN( obj - parseFloat( obj ) );\n};\n\njQuery.trim = function( text ) {\n\treturn text == null ?\n\t\t\"\" :\n\t\t( text + \"\" ).replace( rtrim, \"\" );\n};\n\n\n\n// Register as a named AMD module, since jQuery can be concatenated with other\n// files that may use define, but not via a proper concatenation script that\n// understands anonymous AMD modules. A named AMD is safest and most robust\n// way to register. Lowercase jquery is used because AMD module names are\n// derived from file names, and jQuery is normally delivered in a lowercase\n// file name. Do this after creating the global so that if an AMD module wants\n// to call noConflict to hide this version of jQuery, it will work.\n\n// Note that for maximum portability, libraries that are not jQuery should\n// declare themselves as anonymous modules, and avoid setting a global if an\n// AMD loader is present. jQuery is a special case. For more information, see\n// https://github.com/jrburke/requirejs/wiki/Updating-existing-libraries#wiki-anon\n\nif ( typeof define === \"function\" && define.amd ) {\n\tdefine( \"jquery\", [], function() {\n\t\treturn jQuery;\n\t} );\n}\n\n\n\n\nvar\n\n\t// Map over jQuery in case of overwrite\n\t_jQuery = window.jQuery,\n\n\t// Map over the $ in case of overwrite\n\t_$ = window.$;\n\njQuery.noConflict = function( deep ) {\n\tif ( window.$ === jQuery ) {\n\t\twindow.$ = _$;\n\t}\n\n\tif ( deep && window.jQuery === jQuery ) {\n\t\twindow.jQuery = _jQuery;\n\t}\n\n\treturn jQuery;\n};\n\n// Expose jQuery and $ identifiers, even in AMD\n// (#7102#comment:10, https://github.com/jquery/jquery/pull/557)\n// and CommonJS for browser emulators (#13566)\nif ( typeof noGlobal === \"undefined\" ) {\n\twindow.jQuery = window.$ = jQuery;\n}\n\n\n\n\nreturn jQuery;\n} );\n","/**\n * Advanced Encryption Standard (AES) implementation.\n *\n * This implementation is based on the public domain library 'jscrypto' which\n * was written by:\n *\n * Emily Stark (estark@stanford.edu)\n * Mike Hamburg (mhamburg@stanford.edu)\n * Dan Boneh (dabo@cs.stanford.edu)\n *\n * Parts of this code are based on the OpenSSL implementation of AES:\n * http://www.openssl.org\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./cipher');\nrequire('./cipherModes');\nrequire('./util');\n\n/* AES API */\nmodule.exports = forge.aes = forge.aes || {};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('AES-<mode>', key);\n * cipher.start({iv: iv});\n *\n * Creates an AES cipher object to encrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as a string of bytes, an array of bytes,\n * a byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.startEncrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: false,\n mode: mode\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('AES-<mode>', key);\n *\n * Creates an AES cipher object to encrypt data using the given symmetric key.\n *\n * The key may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.createEncryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: false,\n mode: mode\n });\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('AES-<mode>', key);\n * decipher.start({iv: iv});\n *\n * Creates an AES cipher object to decrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as a string of bytes, an array of bytes,\n * a byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.startDecrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: true,\n mode: mode\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('AES-<mode>', key);\n *\n * Creates an AES cipher object to decrypt data using the given symmetric key.\n *\n * The key may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.createDecryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: true,\n mode: mode\n });\n};\n\n/**\n * Creates a new AES cipher algorithm object.\n *\n * @param name the name of the algorithm.\n * @param mode the mode factory function.\n *\n * @return the AES algorithm object.\n */\nforge.aes.Algorithm = function(name, mode) {\n if(!init) {\n initialize();\n }\n var self = this;\n self.name = name;\n self.mode = new mode({\n blockSize: 16,\n cipher: {\n encrypt: function(inBlock, outBlock) {\n return _updateBlock(self._w, inBlock, outBlock, false);\n },\n decrypt: function(inBlock, outBlock) {\n return _updateBlock(self._w, inBlock, outBlock, true);\n }\n }\n });\n self._init = false;\n};\n\n/**\n * Initializes this AES algorithm by expanding its key.\n *\n * @param options the options to use.\n * key the key to use with this algorithm.\n * decrypt true if the algorithm should be initialized for decryption,\n * false for encryption.\n */\nforge.aes.Algorithm.prototype.initialize = function(options) {\n if(this._init) {\n return;\n }\n\n var key = options.key;\n var tmp;\n\n /* Note: The key may be a string of bytes, an array of bytes, a byte\n buffer, or an array of 32-bit integers. If the key is in bytes, then\n it must be 16, 24, or 32 bytes in length. If it is in 32-bit\n integers, it must be 4, 6, or 8 integers long. */\n\n if(typeof key === 'string' &&\n (key.length === 16 || key.length === 24 || key.length === 32)) {\n // convert key string into byte buffer\n key = forge.util.createBuffer(key);\n } else if(forge.util.isArray(key) &&\n (key.length === 16 || key.length === 24 || key.length === 32)) {\n // convert key integer array into byte buffer\n tmp = key;\n key = forge.util.createBuffer();\n for(var i = 0; i < tmp.length; ++i) {\n key.putByte(tmp[i]);\n }\n }\n\n // convert key byte buffer into 32-bit integer array\n if(!forge.util.isArray(key)) {\n tmp = key;\n key = [];\n\n // key lengths of 16, 24, 32 bytes allowed\n var len = tmp.length();\n if(len === 16 || len === 24 || len === 32) {\n len = len >>> 2;\n for(var i = 0; i < len; ++i) {\n key.push(tmp.getInt32());\n }\n }\n }\n\n // key must be an array of 32-bit integers by now\n if(!forge.util.isArray(key) ||\n !(key.length === 4 || key.length === 6 || key.length === 8)) {\n throw new Error('Invalid key parameter.');\n }\n\n // encryption operation is always used for these modes\n var mode = this.mode.name;\n var encryptOp = (['CFB', 'OFB', 'CTR', 'GCM'].indexOf(mode) !== -1);\n\n // do key expansion\n this._w = _expandKey(key, options.decrypt && !encryptOp);\n this._init = true;\n};\n\n/**\n * Expands a key. Typically only used for testing.\n *\n * @param key the symmetric key to expand, as an array of 32-bit words.\n * @param decrypt true to expand for decryption, false for encryption.\n *\n * @return the expanded key.\n */\nforge.aes._expandKey = function(key, decrypt) {\n if(!init) {\n initialize();\n }\n return _expandKey(key, decrypt);\n};\n\n/**\n * Updates a single block. Typically only used for testing.\n *\n * @param w the expanded key to use.\n * @param input an array of block-size 32-bit words.\n * @param output an array of block-size 32-bit words.\n * @param decrypt true to decrypt, false to encrypt.\n */\nforge.aes._updateBlock = _updateBlock;\n\n/** Register AES algorithms **/\n\nregisterAlgorithm('AES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('AES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('AES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('AES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('AES-CTR', forge.cipher.modes.ctr);\nregisterAlgorithm('AES-GCM', forge.cipher.modes.gcm);\n\nfunction registerAlgorithm(name, mode) {\n var factory = function() {\n return new forge.aes.Algorithm(name, mode);\n };\n forge.cipher.registerAlgorithm(name, factory);\n}\n\n/** AES implementation **/\n\nvar init = false; // not yet initialized\nvar Nb = 4; // number of words comprising the state (AES = 4)\nvar sbox; // non-linear substitution table used in key expansion\nvar isbox; // inversion of sbox\nvar rcon; // round constant word array\nvar mix; // mix-columns table\nvar imix; // inverse mix-columns table\n\n/**\n * Performs initialization, ie: precomputes tables to optimize for speed.\n *\n * One way to understand how AES works is to imagine that 'addition' and\n * 'multiplication' are interfaces that require certain mathematical\n * properties to hold true (ie: they are associative) but they might have\n * different implementations and produce different kinds of results ...\n * provided that their mathematical properties remain true. AES defines\n * its own methods of addition and multiplication but keeps some important\n * properties the same, ie: associativity and distributivity. The\n * explanation below tries to shed some light on how AES defines addition\n * and multiplication of bytes and 32-bit words in order to perform its\n * encryption and decryption algorithms.\n *\n * The basics:\n *\n * The AES algorithm views bytes as binary representations of polynomials\n * that have either 1 or 0 as the coefficients. It defines the addition\n * or subtraction of two bytes as the XOR operation. It also defines the\n * multiplication of two bytes as a finite field referred to as GF(2^8)\n * (Note: 'GF' means \"Galois Field\" which is a field that contains a finite\n * number of elements so GF(2^8) has 256 elements).\n *\n * This means that any two bytes can be represented as binary polynomials;\n * when they multiplied together and modularly reduced by an irreducible\n * polynomial of the 8th degree, the results are the field GF(2^8). The\n * specific irreducible polynomial that AES uses in hexadecimal is 0x11b.\n * This multiplication is associative with 0x01 as the identity:\n *\n * (b * 0x01 = GF(b, 0x01) = b).\n *\n * The operation GF(b, 0x02) can be performed at the byte level by left\n * shifting b once and then XOR'ing it (to perform the modular reduction)\n * with 0x11b if b is >= 128. Repeated application of the multiplication\n * of 0x02 can be used to implement the multiplication of any two bytes.\n *\n * For instance, multiplying 0x57 and 0x13, denoted as GF(0x57, 0x13), can\n * be performed by factoring 0x13 into 0x01, 0x02, and 0x10. Then these\n * factors can each be multiplied by 0x57 and then added together. To do\n * the multiplication, values for 0x57 multiplied by each of these 3 factors\n * can be precomputed and stored in a table. To add them, the values from\n * the table are XOR'd together.\n *\n * AES also defines addition and multiplication of words, that is 4-byte\n * numbers represented as polynomials of 3 degrees where the coefficients\n * are the values of the bytes.\n *\n * The word [a0, a1, a2, a3] is a polynomial a3x^3 + a2x^2 + a1x + a0.\n *\n * Addition is performed by XOR'ing like powers of x. Multiplication\n * is performed in two steps, the first is an algebriac expansion as\n * you would do normally (where addition is XOR). But the result is\n * a polynomial larger than 3 degrees and thus it cannot fit in a word. So\n * next the result is modularly reduced by an AES-specific polynomial of\n * degree 4 which will always produce a polynomial of less than 4 degrees\n * such that it will fit in a word. In AES, this polynomial is x^4 + 1.\n *\n * The modular product of two polynomials 'a' and 'b' is thus:\n *\n * d(x) = d3x^3 + d2x^2 + d1x + d0\n * with\n * d0 = GF(a0, b0) ^ GF(a3, b1) ^ GF(a2, b2) ^ GF(a1, b3)\n * d1 = GF(a1, b0) ^ GF(a0, b1) ^ GF(a3, b2) ^ GF(a2, b3)\n * d2 = GF(a2, b0) ^ GF(a1, b1) ^ GF(a0, b2) ^ GF(a3, b3)\n * d3 = GF(a3, b0) ^ GF(a2, b1) ^ GF(a1, b2) ^ GF(a0, b3)\n *\n * As a matrix:\n *\n * [d0] = [a0 a3 a2 a1][b0]\n * [d1] [a1 a0 a3 a2][b1]\n * [d2] [a2 a1 a0 a3][b2]\n * [d3] [a3 a2 a1 a0][b3]\n *\n * Special polynomials defined by AES (0x02 == {02}):\n * a(x) = {03}x^3 + {01}x^2 + {01}x + {02}\n * a^-1(x) = {0b}x^3 + {0d}x^2 + {09}x + {0e}.\n *\n * These polynomials are used in the MixColumns() and InverseMixColumns()\n * operations, respectively, to cause each element in the state to affect\n * the output (referred to as diffusing).\n *\n * RotWord() uses: a0 = a1 = a2 = {00} and a3 = {01}, which is the\n * polynomial x3.\n *\n * The ShiftRows() method modifies the last 3 rows in the state (where\n * the state is 4 words with 4 bytes per word) by shifting bytes cyclically.\n * The 1st byte in the second row is moved to the end of the row. The 1st\n * and 2nd bytes in the third row are moved to the end of the row. The 1st,\n * 2nd, and 3rd bytes are moved in the fourth row.\n *\n * More details on how AES arithmetic works:\n *\n * In the polynomial representation of binary numbers, XOR performs addition\n * and subtraction and multiplication in GF(2^8) denoted as GF(a, b)\n * corresponds with the multiplication of polynomials modulo an irreducible\n * polynomial of degree 8. In other words, for AES, GF(a, b) will multiply\n * polynomial 'a' with polynomial 'b' and then do a modular reduction by\n * an AES-specific irreducible polynomial of degree 8.\n *\n * A polynomial is irreducible if its only divisors are one and itself. For\n * the AES algorithm, this irreducible polynomial is:\n *\n * m(x) = x^8 + x^4 + x^3 + x + 1,\n *\n * or {01}{1b} in hexadecimal notation, where each coefficient is a bit:\n * 100011011 = 283 = 0x11b.\n *\n * For example, GF(0x57, 0x83) = 0xc1 because\n *\n * 0x57 = 87 = 01010111 = x^6 + x^4 + x^2 + x + 1\n * 0x85 = 131 = 10000101 = x^7 + x + 1\n *\n * (x^6 + x^4 + x^2 + x + 1) * (x^7 + x + 1)\n * = x^13 + x^11 + x^9 + x^8 + x^7 +\n * x^7 + x^5 + x^3 + x^2 + x +\n * x^6 + x^4 + x^2 + x + 1\n * = x^13 + x^11 + x^9 + x^8 + x^6 + x^5 + x^4 + x^3 + 1 = y\n * y modulo (x^8 + x^4 + x^3 + x + 1)\n * = x^7 + x^6 + 1.\n *\n * The modular reduction by m(x) guarantees the result will be a binary\n * polynomial of less than degree 8, so that it can fit in a byte.\n *\n * The operation to multiply a binary polynomial b with x (the polynomial\n * x in binary representation is 00000010) is:\n *\n * b_7x^8 + b_6x^7 + b_5x^6 + b_4x^5 + b_3x^4 + b_2x^3 + b_1x^2 + b_0x^1\n *\n * To get GF(b, x) we must reduce that by m(x). If b_7 is 0 (that is the\n * most significant bit is 0 in b) then the result is already reduced. If\n * it is 1, then we can reduce it by subtracting m(x) via an XOR.\n *\n * It follows that multiplication by x (00000010 or 0x02) can be implemented\n * by performing a left shift followed by a conditional bitwise XOR with\n * 0x1b. This operation on bytes is denoted by xtime(). Multiplication by\n * higher powers of x can be implemented by repeated application of xtime().\n *\n * By adding intermediate results, multiplication by any constant can be\n * implemented. For instance:\n *\n * GF(0x57, 0x13) = 0xfe because:\n *\n * xtime(b) = (b & 128) ? (b << 1 ^ 0x11b) : (b << 1)\n *\n * Note: We XOR with 0x11b instead of 0x1b because in javascript our\n * datatype for b can be larger than 1 byte, so a left shift will not\n * automatically eliminate bits that overflow a byte ... by XOR'ing the\n * overflow bit with 1 (the extra one from 0x11b) we zero it out.\n *\n * GF(0x57, 0x02) = xtime(0x57) = 0xae\n * GF(0x57, 0x04) = xtime(0xae) = 0x47\n * GF(0x57, 0x08) = xtime(0x47) = 0x8e\n * GF(0x57, 0x10) = xtime(0x8e) = 0x07\n *\n * GF(0x57, 0x13) = GF(0x57, (0x01 ^ 0x02 ^ 0x10))\n *\n * And by the distributive property (since XOR is addition and GF() is\n * multiplication):\n *\n * = GF(0x57, 0x01) ^ GF(0x57, 0x02) ^ GF(0x57, 0x10)\n * = 0x57 ^ 0xae ^ 0x07\n * = 0xfe.\n */\nfunction initialize() {\n init = true;\n\n /* Populate the Rcon table. These are the values given by\n [x^(i-1),{00},{00},{00}] where x^(i-1) are powers of x (and x = 0x02)\n in the field of GF(2^8), where i starts at 1.\n\n rcon[0] = [0x00, 0x00, 0x00, 0x00]\n rcon[1] = [0x01, 0x00, 0x00, 0x00] 2^(1-1) = 2^0 = 1\n rcon[2] = [0x02, 0x00, 0x00, 0x00] 2^(2-1) = 2^1 = 2\n ...\n rcon[9] = [0x1B, 0x00, 0x00, 0x00] 2^(9-1) = 2^8 = 0x1B\n rcon[10] = [0x36, 0x00, 0x00, 0x00] 2^(10-1) = 2^9 = 0x36\n\n We only store the first byte because it is the only one used.\n */\n rcon = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1B, 0x36];\n\n // compute xtime table which maps i onto GF(i, 0x02)\n var xtime = new Array(256);\n for(var i = 0; i < 128; ++i) {\n xtime[i] = i << 1;\n xtime[i + 128] = (i + 128) << 1 ^ 0x11B;\n }\n\n // compute all other tables\n sbox = new Array(256);\n isbox = new Array(256);\n mix = new Array(4);\n imix = new Array(4);\n for(var i = 0; i < 4; ++i) {\n mix[i] = new Array(256);\n imix[i] = new Array(256);\n }\n var e = 0, ei = 0, e2, e4, e8, sx, sx2, me, ime;\n for(var i = 0; i < 256; ++i) {\n /* We need to generate the SubBytes() sbox and isbox tables so that\n we can perform byte substitutions. This requires us to traverse\n all of the elements in GF, find their multiplicative inverses,\n and apply to each the following affine transformation:\n\n bi' = bi ^ b(i + 4) mod 8 ^ b(i + 5) mod 8 ^ b(i + 6) mod 8 ^\n b(i + 7) mod 8 ^ ci\n for 0 <= i < 8, where bi is the ith bit of the byte, and ci is the\n ith bit of a byte c with the value {63} or {01100011}.\n\n It is possible to traverse every possible value in a Galois field\n using what is referred to as a 'generator'. There are many\n generators (128 out of 256): 3,5,6,9,11,82 to name a few. To fully\n traverse GF we iterate 255 times, multiplying by our generator\n each time.\n\n On each iteration we can determine the multiplicative inverse for\n the current element.\n\n Suppose there is an element in GF 'e'. For a given generator 'g',\n e = g^x. The multiplicative inverse of e is g^(255 - x). It turns\n out that if use the inverse of a generator as another generator\n it will produce all of the corresponding multiplicative inverses\n at the same time. For this reason, we choose 5 as our inverse\n generator because it only requires 2 multiplies and 1 add and its\n inverse, 82, requires relatively few operations as well.\n\n In order to apply the affine transformation, the multiplicative\n inverse 'ei' of 'e' can be repeatedly XOR'd (4 times) with a\n bit-cycling of 'ei'. To do this 'ei' is first stored in 's' and\n 'x'. Then 's' is left shifted and the high bit of 's' is made the\n low bit. The resulting value is stored in 's'. Then 'x' is XOR'd\n with 's' and stored in 'x'. On each subsequent iteration the same\n operation is performed. When 4 iterations are complete, 'x' is\n XOR'd with 'c' (0x63) and the transformed value is stored in 'x'.\n For example:\n\n s = 01000001\n x = 01000001\n\n iteration 1: s = 10000010, x ^= s\n iteration 2: s = 00000101, x ^= s\n iteration 3: s = 00001010, x ^= s\n iteration 4: s = 00010100, x ^= s\n x ^= 0x63\n\n This can be done with a loop where s = (s << 1) | (s >> 7). However,\n it can also be done by using a single 16-bit (in this case 32-bit)\n number 'sx'. Since XOR is an associative operation, we can set 'sx'\n to 'ei' and then XOR it with 'sx' left-shifted 1,2,3, and 4 times.\n The most significant bits will flow into the high 8 bit positions\n and be correctly XOR'd with one another. All that remains will be\n to cycle the high 8 bits by XOR'ing them all with the lower 8 bits\n afterwards.\n\n At the same time we're populating sbox and isbox we can precompute\n the multiplication we'll need to do to do MixColumns() later.\n */\n\n // apply affine transformation\n sx = ei ^ (ei << 1) ^ (ei << 2) ^ (ei << 3) ^ (ei << 4);\n sx = (sx >> 8) ^ (sx & 255) ^ 0x63;\n\n // update tables\n sbox[e] = sx;\n isbox[sx] = e;\n\n /* Mixing columns is done using matrix multiplication. The columns\n that are to be mixed are each a single word in the current state.\n The state has Nb columns (4 columns). Therefore each column is a\n 4 byte word. So to mix the columns in a single column 'c' where\n its rows are r0, r1, r2, and r3, we use the following matrix\n multiplication:\n\n [2 3 1 1]*[r0,c]=[r'0,c]\n [1 2 3 1] [r1,c] [r'1,c]\n [1 1 2 3] [r2,c] [r'2,c]\n [3 1 1 2] [r3,c] [r'3,c]\n\n r0, r1, r2, and r3 are each 1 byte of one of the words in the\n state (a column). To do matrix multiplication for each mixed\n column c' we multiply the corresponding row from the left matrix\n with the corresponding column from the right matrix. In total, we\n get 4 equations:\n\n r0,c' = 2*r0,c + 3*r1,c + 1*r2,c + 1*r3,c\n r1,c' = 1*r0,c + 2*r1,c + 3*r2,c + 1*r3,c\n r2,c' = 1*r0,c + 1*r1,c + 2*r2,c + 3*r3,c\n r3,c' = 3*r0,c + 1*r1,c + 1*r2,c + 2*r3,c\n\n As usual, the multiplication is as previously defined and the\n addition is XOR. In order to optimize mixing columns we can store\n the multiplication results in tables. If you think of the whole\n column as a word (it might help to visualize by mentally rotating\n the equations above by counterclockwise 90 degrees) then you can\n see that it would be useful to map the multiplications performed on\n each byte (r0, r1, r2, r3) onto a word as well. For instance, we\n could map 2*r0,1*r0,1*r0,3*r0 onto a word by storing 2*r0 in the\n highest 8 bits and 3*r0 in the lowest 8 bits (with the other two\n respectively in the middle). This means that a table can be\n constructed that uses r0 as an index to the word. We can do the\n same with r1, r2, and r3, creating a total of 4 tables.\n\n To construct a full c', we can just look up each byte of c in\n their respective tables and XOR the results together.\n\n Also, to build each table we only have to calculate the word\n for 2,1,1,3 for every byte ... which we can do on each iteration\n of this loop since we will iterate over every byte. After we have\n calculated 2,1,1,3 we can get the results for the other tables\n by cycling the byte at the end to the beginning. For instance\n we can take the result of table 2,1,1,3 and produce table 3,2,1,1\n by moving the right most byte to the left most position just like\n how you can imagine the 3 moved out of 2,1,1,3 and to the front\n to produce 3,2,1,1.\n\n There is another optimization in that the same multiples of\n the current element we need in order to advance our generator\n to the next iteration can be reused in performing the 2,1,1,3\n calculation. We also calculate the inverse mix column tables,\n with e,9,d,b being the inverse of 2,1,1,3.\n\n When we're done, and we need to actually mix columns, the first\n byte of each state word should be put through mix[0] (2,1,1,3),\n the second through mix[1] (3,2,1,1) and so forth. Then they should\n be XOR'd together to produce the fully mixed column.\n */\n\n // calculate mix and imix table values\n sx2 = xtime[sx];\n e2 = xtime[e];\n e4 = xtime[e2];\n e8 = xtime[e4];\n me =\n (sx2 << 24) ^ // 2\n (sx << 16) ^ // 1\n (sx << 8) ^ // 1\n (sx ^ sx2); // 3\n ime =\n (e2 ^ e4 ^ e8) << 24 ^ // E (14)\n (e ^ e8) << 16 ^ // 9\n (e ^ e4 ^ e8) << 8 ^ // D (13)\n (e ^ e2 ^ e8); // B (11)\n // produce each of the mix tables by rotating the 2,1,1,3 value\n for(var n = 0; n < 4; ++n) {\n mix[n][e] = me;\n imix[n][sx] = ime;\n // cycle the right most byte to the left most position\n // ie: 2,1,1,3 becomes 3,2,1,1\n me = me << 24 | me >>> 8;\n ime = ime << 24 | ime >>> 8;\n }\n\n // get next element and inverse\n if(e === 0) {\n // 1 is the inverse of 1\n e = ei = 1;\n } else {\n // e = 2e + 2*2*2*(10e)) = multiply e by 82 (chosen generator)\n // ei = ei + 2*2*ei = multiply ei by 5 (inverse generator)\n e = e2 ^ xtime[xtime[xtime[e2 ^ e8]]];\n ei ^= xtime[xtime[ei]];\n }\n }\n}\n\n/**\n * Generates a key schedule using the AES key expansion algorithm.\n *\n * The AES algorithm takes the Cipher Key, K, and performs a Key Expansion\n * routine to generate a key schedule. The Key Expansion generates a total\n * of Nb*(Nr + 1) words: the algorithm requires an initial set of Nb words,\n * and each of the Nr rounds requires Nb words of key data. The resulting\n * key schedule consists of a linear array of 4-byte words, denoted [wi ],\n * with i in the range 0 <= i < Nb(Nr + 1).\n *\n * KeyExpansion(byte key[4*Nk], word w[Nb*(Nr+1)], Nk)\n * AES-128 (Nb=4, Nk=4, Nr=10)\n * AES-192 (Nb=4, Nk=6, Nr=12)\n * AES-256 (Nb=4, Nk=8, Nr=14)\n * Note: Nr=Nk+6.\n *\n * Nb is the number of columns (32-bit words) comprising the State (or\n * number of bytes in a block). For AES, Nb=4.\n *\n * @param key the key to schedule (as an array of 32-bit words).\n * @param decrypt true to modify the key schedule to decrypt, false not to.\n *\n * @return the generated key schedule.\n */\nfunction _expandKey(key, decrypt) {\n // copy the key's words to initialize the key schedule\n var w = key.slice(0);\n\n /* RotWord() will rotate a word, moving the first byte to the last\n byte's position (shifting the other bytes left).\n\n We will be getting the value of Rcon at i / Nk. 'i' will iterate\n from Nk to (Nb * Nr+1). Nk = 4 (4 byte key), Nb = 4 (4 words in\n a block), Nr = Nk + 6 (10). Therefore 'i' will iterate from\n 4 to 44 (exclusive). Each time we iterate 4 times, i / Nk will\n increase by 1. We use a counter iNk to keep track of this.\n */\n\n // go through the rounds expanding the key\n var temp, iNk = 1;\n var Nk = w.length;\n var Nr1 = Nk + 6 + 1;\n var end = Nb * Nr1;\n for(var i = Nk; i < end; ++i) {\n temp = w[i - 1];\n if(i % Nk === 0) {\n // temp = SubWord(RotWord(temp)) ^ Rcon[i / Nk]\n temp =\n sbox[temp >>> 16 & 255] << 24 ^\n sbox[temp >>> 8 & 255] << 16 ^\n sbox[temp & 255] << 8 ^\n sbox[temp >>> 24] ^ (rcon[iNk] << 24);\n iNk++;\n } else if(Nk > 6 && (i % Nk === 4)) {\n // temp = SubWord(temp)\n temp =\n sbox[temp >>> 24] << 24 ^\n sbox[temp >>> 16 & 255] << 16 ^\n sbox[temp >>> 8 & 255] << 8 ^\n sbox[temp & 255];\n }\n w[i] = w[i - Nk] ^ temp;\n }\n\n /* When we are updating a cipher block we always use the code path for\n encryption whether we are decrypting or not (to shorten code and\n simplify the generation of look up tables). However, because there\n are differences in the decryption algorithm, other than just swapping\n in different look up tables, we must transform our key schedule to\n account for these changes:\n\n 1. The decryption algorithm gets its key rounds in reverse order.\n 2. The decryption algorithm adds the round key before mixing columns\n instead of afterwards.\n\n We don't need to modify our key schedule to handle the first case,\n we can just traverse the key schedule in reverse order when decrypting.\n\n The second case requires a little work.\n\n The tables we built for performing rounds will take an input and then\n perform SubBytes() and MixColumns() or, for the decrypt version,\n InvSubBytes() and InvMixColumns(). But the decrypt algorithm requires\n us to AddRoundKey() before InvMixColumns(). This means we'll need to\n apply some transformations to the round key to inverse-mix its columns\n so they'll be correct for moving AddRoundKey() to after the state has\n had its columns inverse-mixed.\n\n To inverse-mix the columns of the state when we're decrypting we use a\n lookup table that will apply InvSubBytes() and InvMixColumns() at the\n same time. However, the round key's bytes are not inverse-substituted\n in the decryption algorithm. To get around this problem, we can first\n substitute the bytes in the round key so that when we apply the\n transformation via the InvSubBytes()+InvMixColumns() table, it will\n undo our substitution leaving us with the original value that we\n want -- and then inverse-mix that value.\n\n This change will correctly alter our key schedule so that we can XOR\n each round key with our already transformed decryption state. This\n allows us to use the same code path as the encryption algorithm.\n\n We make one more change to the decryption key. Since the decryption\n algorithm runs in reverse from the encryption algorithm, we reverse\n the order of the round keys to avoid having to iterate over the key\n schedule backwards when running the encryption algorithm later in\n decryption mode. In addition to reversing the order of the round keys,\n we also swap each round key's 2nd and 4th rows. See the comments\n section where rounds are performed for more details about why this is\n done. These changes are done inline with the other substitution\n described above.\n */\n if(decrypt) {\n var tmp;\n var m0 = imix[0];\n var m1 = imix[1];\n var m2 = imix[2];\n var m3 = imix[3];\n var wnew = w.slice(0);\n end = w.length;\n for(var i = 0, wi = end - Nb; i < end; i += Nb, wi -= Nb) {\n // do not sub the first or last round key (round keys are Nb\n // words) as no column mixing is performed before they are added,\n // but do change the key order\n if(i === 0 || i === (end - Nb)) {\n wnew[i] = w[wi];\n wnew[i + 1] = w[wi + 3];\n wnew[i + 2] = w[wi + 2];\n wnew[i + 3] = w[wi + 1];\n } else {\n // substitute each round key byte because the inverse-mix\n // table will inverse-substitute it (effectively cancel the\n // substitution because round key bytes aren't sub'd in\n // decryption mode) and swap indexes 3 and 1\n for(var n = 0; n < Nb; ++n) {\n tmp = w[wi + n];\n wnew[i + (3&-n)] =\n m0[sbox[tmp >>> 24]] ^\n m1[sbox[tmp >>> 16 & 255]] ^\n m2[sbox[tmp >>> 8 & 255]] ^\n m3[sbox[tmp & 255]];\n }\n }\n }\n w = wnew;\n }\n\n return w;\n}\n\n/**\n * Updates a single block (16 bytes) using AES. The update will either\n * encrypt or decrypt the block.\n *\n * @param w the key schedule.\n * @param input the input block (an array of 32-bit words).\n * @param output the updated output block.\n * @param decrypt true to decrypt the block, false to encrypt it.\n */\nfunction _updateBlock(w, input, output, decrypt) {\n /*\n Cipher(byte in[4*Nb], byte out[4*Nb], word w[Nb*(Nr+1)])\n begin\n byte state[4,Nb]\n state = in\n AddRoundKey(state, w[0, Nb-1])\n for round = 1 step 1 to Nr-1\n SubBytes(state)\n ShiftRows(state)\n MixColumns(state)\n AddRoundKey(state, w[round*Nb, (round+1)*Nb-1])\n end for\n SubBytes(state)\n ShiftRows(state)\n AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n out = state\n end\n\n InvCipher(byte in[4*Nb], byte out[4*Nb], word w[Nb*(Nr+1)])\n begin\n byte state[4,Nb]\n state = in\n AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n for round = Nr-1 step -1 downto 1\n InvShiftRows(state)\n InvSubBytes(state)\n AddRoundKey(state, w[round*Nb, (round+1)*Nb-1])\n InvMixColumns(state)\n end for\n InvShiftRows(state)\n InvSubBytes(state)\n AddRoundKey(state, w[0, Nb-1])\n out = state\n end\n */\n\n // Encrypt: AddRoundKey(state, w[0, Nb-1])\n // Decrypt: AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n var Nr = w.length / 4 - 1;\n var m0, m1, m2, m3, sub;\n if(decrypt) {\n m0 = imix[0];\n m1 = imix[1];\n m2 = imix[2];\n m3 = imix[3];\n sub = isbox;\n } else {\n m0 = mix[0];\n m1 = mix[1];\n m2 = mix[2];\n m3 = mix[3];\n sub = sbox;\n }\n var a, b, c, d, a2, b2, c2;\n a = input[0] ^ w[0];\n b = input[decrypt ? 3 : 1] ^ w[1];\n c = input[2] ^ w[2];\n d = input[decrypt ? 1 : 3] ^ w[3];\n var i = 3;\n\n /* In order to share code we follow the encryption algorithm when both\n encrypting and decrypting. To account for the changes required in the\n decryption algorithm, we use different lookup tables when decrypting\n and use a modified key schedule to account for the difference in the\n order of transformations applied when performing rounds. We also get\n key rounds in reverse order (relative to encryption). */\n for(var round = 1; round < Nr; ++round) {\n /* As described above, we'll be using table lookups to perform the\n column mixing. Each column is stored as a word in the state (the\n array 'input' has one column as a word at each index). In order to\n mix a column, we perform these transformations on each row in c,\n which is 1 byte in each word. The new column for c0 is c'0:\n\n m0 m1 m2 m3\n r0,c'0 = 2*r0,c0 + 3*r1,c0 + 1*r2,c0 + 1*r3,c0\n r1,c'0 = 1*r0,c0 + 2*r1,c0 + 3*r2,c0 + 1*r3,c0\n r2,c'0 = 1*r0,c0 + 1*r1,c0 + 2*r2,c0 + 3*r3,c0\n r3,c'0 = 3*r0,c0 + 1*r1,c0 + 1*r2,c0 + 2*r3,c0\n\n So using mix tables where c0 is a word with r0 being its upper\n 8 bits and r3 being its lower 8 bits:\n\n m0[c0 >> 24] will yield this word: [2*r0,1*r0,1*r0,3*r0]\n ...\n m3[c0 & 255] will yield this word: [1*r3,1*r3,3*r3,2*r3]\n\n Therefore to mix the columns in each word in the state we\n do the following (& 255 omitted for brevity):\n c'0,r0 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n c'0,r1 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n c'0,r2 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n c'0,r3 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n\n However, before mixing, the algorithm requires us to perform\n ShiftRows(). The ShiftRows() transformation cyclically shifts the\n last 3 rows of the state over different offsets. The first row\n (r = 0) is not shifted.\n\n s'_r,c = s_r,(c + shift(r, Nb) mod Nb\n for 0 < r < 4 and 0 <= c < Nb and\n shift(1, 4) = 1\n shift(2, 4) = 2\n shift(3, 4) = 3.\n\n This causes the first byte in r = 1 to be moved to the end of\n the row, the first 2 bytes in r = 2 to be moved to the end of\n the row, the first 3 bytes in r = 3 to be moved to the end of\n the row:\n\n r1: [c0 c1 c2 c3] => [c1 c2 c3 c0]\n r2: [c0 c1 c2 c3] [c2 c3 c0 c1]\n r3: [c0 c1 c2 c3] [c3 c0 c1 c2]\n\n We can make these substitutions inline with our column mixing to\n generate an updated set of equations to produce each word in the\n state (note the columns have changed positions):\n\n c0 c1 c2 c3 => c0 c1 c2 c3\n c0 c1 c2 c3 c1 c2 c3 c0 (cycled 1 byte)\n c0 c1 c2 c3 c2 c3 c0 c1 (cycled 2 bytes)\n c0 c1 c2 c3 c3 c0 c1 c2 (cycled 3 bytes)\n\n Therefore:\n\n c'0 = 2*r0,c0 + 3*r1,c1 + 1*r2,c2 + 1*r3,c3\n c'0 = 1*r0,c0 + 2*r1,c1 + 3*r2,c2 + 1*r3,c3\n c'0 = 1*r0,c0 + 1*r1,c1 + 2*r2,c2 + 3*r3,c3\n c'0 = 3*r0,c0 + 1*r1,c1 + 1*r2,c2 + 2*r3,c3\n\n c'1 = 2*r0,c1 + 3*r1,c2 + 1*r2,c3 + 1*r3,c0\n c'1 = 1*r0,c1 + 2*r1,c2 + 3*r2,c3 + 1*r3,c0\n c'1 = 1*r0,c1 + 1*r1,c2 + 2*r2,c3 + 3*r3,c0\n c'1 = 3*r0,c1 + 1*r1,c2 + 1*r2,c3 + 2*r3,c0\n\n ... and so forth for c'2 and c'3. The important distinction is\n that the columns are cycling, with c0 being used with the m0\n map when calculating c0, but c1 being used with the m0 map when\n calculating c1 ... and so forth.\n\n When performing the inverse we transform the mirror image and\n skip the bottom row, instead of the top one, and move upwards:\n\n c3 c2 c1 c0 => c0 c3 c2 c1 (cycled 3 bytes) *same as encryption\n c3 c2 c1 c0 c1 c0 c3 c2 (cycled 2 bytes)\n c3 c2 c1 c0 c2 c1 c0 c3 (cycled 1 byte) *same as encryption\n c3 c2 c1 c0 c3 c2 c1 c0\n\n If you compare the resulting matrices for ShiftRows()+MixColumns()\n and for InvShiftRows()+InvMixColumns() the 2nd and 4th columns are\n different (in encrypt mode vs. decrypt mode). So in order to use\n the same code to handle both encryption and decryption, we will\n need to do some mapping.\n\n If in encryption mode we let a=c0, b=c1, c=c2, d=c3, and r<N> be\n a row number in the state, then the resulting matrix in encryption\n mode for applying the above transformations would be:\n\n r1: a b c d\n r2: b c d a\n r3: c d a b\n r4: d a b c\n\n If we did the same in decryption mode we would get:\n\n r1: a d c b\n r2: b a d c\n r3: c b a d\n r4: d c b a\n\n If instead we swap d and b (set b=c3 and d=c1), then we get:\n\n r1: a b c d\n r2: d a b c\n r3: c d a b\n r4: b c d a\n\n Now the 1st and 3rd rows are the same as the encryption matrix. All\n we need to do then to make the mapping exactly the same is to swap\n the 2nd and 4th rows when in decryption mode. To do this without\n having to do it on each iteration, we swapped the 2nd and 4th rows\n in the decryption key schedule. We also have to do the swap above\n when we first pull in the input and when we set the final output. */\n a2 =\n m0[a >>> 24] ^\n m1[b >>> 16 & 255] ^\n m2[c >>> 8 & 255] ^\n m3[d & 255] ^ w[++i];\n b2 =\n m0[b >>> 24] ^\n m1[c >>> 16 & 255] ^\n m2[d >>> 8 & 255] ^\n m3[a & 255] ^ w[++i];\n c2 =\n m0[c >>> 24] ^\n m1[d >>> 16 & 255] ^\n m2[a >>> 8 & 255] ^\n m3[b & 255] ^ w[++i];\n d =\n m0[d >>> 24] ^\n m1[a >>> 16 & 255] ^\n m2[b >>> 8 & 255] ^\n m3[c & 255] ^ w[++i];\n a = a2;\n b = b2;\n c = c2;\n }\n\n /*\n Encrypt:\n SubBytes(state)\n ShiftRows(state)\n AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n\n Decrypt:\n InvShiftRows(state)\n InvSubBytes(state)\n AddRoundKey(state, w[0, Nb-1])\n */\n // Note: rows are shifted inline\n output[0] =\n (sub[a >>> 24] << 24) ^\n (sub[b >>> 16 & 255] << 16) ^\n (sub[c >>> 8 & 255] << 8) ^\n (sub[d & 255]) ^ w[++i];\n output[decrypt ? 3 : 1] =\n (sub[b >>> 24] << 24) ^\n (sub[c >>> 16 & 255] << 16) ^\n (sub[d >>> 8 & 255] << 8) ^\n (sub[a & 255]) ^ w[++i];\n output[2] =\n (sub[c >>> 24] << 24) ^\n (sub[d >>> 16 & 255] << 16) ^\n (sub[a >>> 8 & 255] << 8) ^\n (sub[b & 255]) ^ w[++i];\n output[decrypt ? 1 : 3] =\n (sub[d >>> 24] << 24) ^\n (sub[a >>> 16 & 255] << 16) ^\n (sub[b >>> 8 & 255] << 8) ^\n (sub[c & 255]) ^ w[++i];\n}\n\n/**\n * Deprecated. Instead, use:\n *\n * forge.cipher.createCipher('AES-<mode>', key);\n * forge.cipher.createDecipher('AES-<mode>', key);\n *\n * Creates a deprecated AES cipher object. This object's mode will default to\n * CBC (cipher-block-chaining).\n *\n * The key and iv may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param options the options to use.\n * key the symmetric key to use.\n * output the buffer to write to.\n * decrypt true for decryption, false for encryption.\n * mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nfunction _createCipher(options) {\n options = options || {};\n var mode = (options.mode || 'CBC').toUpperCase();\n var algorithm = 'AES-' + mode;\n\n var cipher;\n if(options.decrypt) {\n cipher = forge.cipher.createDecipher(algorithm, options.key);\n } else {\n cipher = forge.cipher.createCipher(algorithm, options.key);\n }\n\n // backwards compatible start API\n var start = cipher.start;\n cipher.start = function(iv, options) {\n // backwards compatibility: support second arg as output buffer\n var output = null;\n if(options instanceof forge.util.ByteBuffer) {\n output = options;\n options = {};\n }\n options = options || {};\n options.output = output;\n options.iv = iv;\n start.call(cipher, options);\n };\n\n return cipher;\n}\n","/**\n * Object IDs for ASN.1.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\n\nforge.pki = forge.pki || {};\nvar oids = module.exports = forge.pki.oids = forge.oids = forge.oids || {};\n\n// set id to name mapping and name to id mapping\nfunction _IN(id, name) {\n oids[id] = name;\n oids[name] = id;\n}\n// set id to name mapping only\nfunction _I_(id, name) {\n oids[id] = name;\n}\n\n// algorithm OIDs\n_IN('1.2.840.113549.1.1.1', 'rsaEncryption');\n// Note: md2 & md4 not implemented\n//_IN('1.2.840.113549.1.1.2', 'md2WithRSAEncryption');\n//_IN('1.2.840.113549.1.1.3', 'md4WithRSAEncryption');\n_IN('1.2.840.113549.1.1.4', 'md5WithRSAEncryption');\n_IN('1.2.840.113549.1.1.5', 'sha1WithRSAEncryption');\n_IN('1.2.840.113549.1.1.7', 'RSAES-OAEP');\n_IN('1.2.840.113549.1.1.8', 'mgf1');\n_IN('1.2.840.113549.1.1.9', 'pSpecified');\n_IN('1.2.840.113549.1.1.10', 'RSASSA-PSS');\n_IN('1.2.840.113549.1.1.11', 'sha256WithRSAEncryption');\n_IN('1.2.840.113549.1.1.12', 'sha384WithRSAEncryption');\n_IN('1.2.840.113549.1.1.13', 'sha512WithRSAEncryption');\n// Edwards-curve Digital Signature Algorithm (EdDSA) Ed25519\n_IN('1.3.101.112', 'EdDSA25519');\n\n_IN('1.2.840.10040.4.3', 'dsa-with-sha1');\n\n_IN('1.3.14.3.2.7', 'desCBC');\n\n_IN('1.3.14.3.2.26', 'sha1');\n_IN('2.16.840.1.101.3.4.2.1', 'sha256');\n_IN('2.16.840.1.101.3.4.2.2', 'sha384');\n_IN('2.16.840.1.101.3.4.2.3', 'sha512');\n_IN('1.2.840.113549.2.5', 'md5');\n\n// pkcs#7 content types\n_IN('1.2.840.113549.1.7.1', 'data');\n_IN('1.2.840.113549.1.7.2', 'signedData');\n_IN('1.2.840.113549.1.7.3', 'envelopedData');\n_IN('1.2.840.113549.1.7.4', 'signedAndEnvelopedData');\n_IN('1.2.840.113549.1.7.5', 'digestedData');\n_IN('1.2.840.113549.1.7.6', 'encryptedData');\n\n// pkcs#9 oids\n_IN('1.2.840.113549.1.9.1', 'emailAddress');\n_IN('1.2.840.113549.1.9.2', 'unstructuredName');\n_IN('1.2.840.113549.1.9.3', 'contentType');\n_IN('1.2.840.113549.1.9.4', 'messageDigest');\n_IN('1.2.840.113549.1.9.5', 'signingTime');\n_IN('1.2.840.113549.1.9.6', 'counterSignature');\n_IN('1.2.840.113549.1.9.7', 'challengePassword');\n_IN('1.2.840.113549.1.9.8', 'unstructuredAddress');\n_IN('1.2.840.113549.1.9.14', 'extensionRequest');\n\n_IN('1.2.840.113549.1.9.20', 'friendlyName');\n_IN('1.2.840.113549.1.9.21', 'localKeyId');\n_IN('1.2.840.113549.1.9.22.1', 'x509Certificate');\n\n// pkcs#12 safe bags\n_IN('1.2.840.113549.1.12.10.1.1', 'keyBag');\n_IN('1.2.840.113549.1.12.10.1.2', 'pkcs8ShroudedKeyBag');\n_IN('1.2.840.113549.1.12.10.1.3', 'certBag');\n_IN('1.2.840.113549.1.12.10.1.4', 'crlBag');\n_IN('1.2.840.113549.1.12.10.1.5', 'secretBag');\n_IN('1.2.840.113549.1.12.10.1.6', 'safeContentsBag');\n\n// password-based-encryption for pkcs#12\n_IN('1.2.840.113549.1.5.13', 'pkcs5PBES2');\n_IN('1.2.840.113549.1.5.12', 'pkcs5PBKDF2');\n\n_IN('1.2.840.113549.1.12.1.1', 'pbeWithSHAAnd128BitRC4');\n_IN('1.2.840.113549.1.12.1.2', 'pbeWithSHAAnd40BitRC4');\n_IN('1.2.840.113549.1.12.1.3', 'pbeWithSHAAnd3-KeyTripleDES-CBC');\n_IN('1.2.840.113549.1.12.1.4', 'pbeWithSHAAnd2-KeyTripleDES-CBC');\n_IN('1.2.840.113549.1.12.1.5', 'pbeWithSHAAnd128BitRC2-CBC');\n_IN('1.2.840.113549.1.12.1.6', 'pbewithSHAAnd40BitRC2-CBC');\n\n// hmac OIDs\n_IN('1.2.840.113549.2.7', 'hmacWithSHA1');\n_IN('1.2.840.113549.2.8', 'hmacWithSHA224');\n_IN('1.2.840.113549.2.9', 'hmacWithSHA256');\n_IN('1.2.840.113549.2.10', 'hmacWithSHA384');\n_IN('1.2.840.113549.2.11', 'hmacWithSHA512');\n\n// symmetric key algorithm oids\n_IN('1.2.840.113549.3.7', 'des-EDE3-CBC');\n_IN('2.16.840.1.101.3.4.1.2', 'aes128-CBC');\n_IN('2.16.840.1.101.3.4.1.22', 'aes192-CBC');\n_IN('2.16.840.1.101.3.4.1.42', 'aes256-CBC');\n\n// certificate issuer/subject OIDs\n_IN('2.5.4.3', 'commonName');\n_IN('2.5.4.5', 'serialName');\n_IN('2.5.4.6', 'countryName');\n_IN('2.5.4.7', 'localityName');\n_IN('2.5.4.8', 'stateOrProvinceName');\n_IN('2.5.4.9', 'streetAddress');\n_IN('2.5.4.10', 'organizationName');\n_IN('2.5.4.11', 'organizationalUnitName');\n_IN('2.5.4.13', 'description');\n_IN('2.5.4.15', 'businessCategory');\n_IN('2.5.4.17', 'postalCode');\n_IN('1.3.6.1.4.1.311.60.2.1.2', 'jurisdictionOfIncorporationStateOrProvinceName');\n_IN('1.3.6.1.4.1.311.60.2.1.3', 'jurisdictionOfIncorporationCountryName');\n\n// X.509 extension OIDs\n_IN('2.16.840.1.113730.1.1', 'nsCertType');\n_IN('2.16.840.1.113730.1.13', 'nsComment'); // deprecated in theory; still widely used\n_I_('2.5.29.1', 'authorityKeyIdentifier'); // deprecated, use .35\n_I_('2.5.29.2', 'keyAttributes'); // obsolete use .37 or .15\n_I_('2.5.29.3', 'certificatePolicies'); // deprecated, use .32\n_I_('2.5.29.4', 'keyUsageRestriction'); // obsolete use .37 or .15\n_I_('2.5.29.5', 'policyMapping'); // deprecated use .33\n_I_('2.5.29.6', 'subtreesConstraint'); // obsolete use .30\n_I_('2.5.29.7', 'subjectAltName'); // deprecated use .17\n_I_('2.5.29.8', 'issuerAltName'); // deprecated use .18\n_I_('2.5.29.9', 'subjectDirectoryAttributes');\n_I_('2.5.29.10', 'basicConstraints'); // deprecated use .19\n_I_('2.5.29.11', 'nameConstraints'); // deprecated use .30\n_I_('2.5.29.12', 'policyConstraints'); // deprecated use .36\n_I_('2.5.29.13', 'basicConstraints'); // deprecated use .19\n_IN('2.5.29.14', 'subjectKeyIdentifier');\n_IN('2.5.29.15', 'keyUsage');\n_I_('2.5.29.16', 'privateKeyUsagePeriod');\n_IN('2.5.29.17', 'subjectAltName');\n_IN('2.5.29.18', 'issuerAltName');\n_IN('2.5.29.19', 'basicConstraints');\n_I_('2.5.29.20', 'cRLNumber');\n_I_('2.5.29.21', 'cRLReason');\n_I_('2.5.29.22', 'expirationDate');\n_I_('2.5.29.23', 'instructionCode');\n_I_('2.5.29.24', 'invalidityDate');\n_I_('2.5.29.25', 'cRLDistributionPoints'); // deprecated use .31\n_I_('2.5.29.26', 'issuingDistributionPoint'); // deprecated use .28\n_I_('2.5.29.27', 'deltaCRLIndicator');\n_I_('2.5.29.28', 'issuingDistributionPoint');\n_I_('2.5.29.29', 'certificateIssuer');\n_I_('2.5.29.30', 'nameConstraints');\n_IN('2.5.29.31', 'cRLDistributionPoints');\n_IN('2.5.29.32', 'certificatePolicies');\n_I_('2.5.29.33', 'policyMappings');\n_I_('2.5.29.34', 'policyConstraints'); // deprecated use .36\n_IN('2.5.29.35', 'authorityKeyIdentifier');\n_I_('2.5.29.36', 'policyConstraints');\n_IN('2.5.29.37', 'extKeyUsage');\n_I_('2.5.29.46', 'freshestCRL');\n_I_('2.5.29.54', 'inhibitAnyPolicy');\n\n// extKeyUsage purposes\n_IN('1.3.6.1.4.1.11129.2.4.2', 'timestampList');\n_IN('1.3.6.1.5.5.7.1.1', 'authorityInfoAccess');\n_IN('1.3.6.1.5.5.7.3.1', 'serverAuth');\n_IN('1.3.6.1.5.5.7.3.2', 'clientAuth');\n_IN('1.3.6.1.5.5.7.3.3', 'codeSigning');\n_IN('1.3.6.1.5.5.7.3.4', 'emailProtection');\n_IN('1.3.6.1.5.5.7.3.8', 'timeStamping');\n","/**\n * Javascript implementation of basic PEM (Privacy Enhanced Mail) algorithms.\n *\n * See: RFC 1421.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2013-2014 Digital Bazaar, Inc.\n *\n * A Forge PEM object has the following fields:\n *\n * type: identifies the type of message (eg: \"RSA PRIVATE KEY\").\n *\n * procType: identifies the type of processing performed on the message,\n * it has two subfields: version and type, eg: 4,ENCRYPTED.\n *\n * contentDomain: identifies the type of content in the message, typically\n * only uses the value: \"RFC822\".\n *\n * dekInfo: identifies the message encryption algorithm and mode and includes\n * any parameters for the algorithm, it has two subfields: algorithm and\n * parameters, eg: DES-CBC,F8143EDE5960C597.\n *\n * headers: contains all other PEM encapsulated headers -- where order is\n * significant (for pairing data like recipient ID + key info).\n *\n * body: the binary-encoded body.\n */\nvar forge = require('./forge');\nrequire('./util');\n\n// shortcut for pem API\nvar pem = module.exports = forge.pem = forge.pem || {};\n\n/**\n * Encodes (serializes) the given PEM object.\n *\n * @param msg the PEM message object to encode.\n * @param options the options to use:\n * maxline the maximum characters per line for the body, (default: 64).\n *\n * @return the PEM-formatted string.\n */\npem.encode = function(msg, options) {\n options = options || {};\n var rval = '-----BEGIN ' + msg.type + '-----\\r\\n';\n\n // encode special headers\n var header;\n if(msg.procType) {\n header = {\n name: 'Proc-Type',\n values: [String(msg.procType.version), msg.procType.type]\n };\n rval += foldHeader(header);\n }\n if(msg.contentDomain) {\n header = {name: 'Content-Domain', values: [msg.contentDomain]};\n rval += foldHeader(header);\n }\n if(msg.dekInfo) {\n header = {name: 'DEK-Info', values: [msg.dekInfo.algorithm]};\n if(msg.dekInfo.parameters) {\n header.values.push(msg.dekInfo.parameters);\n }\n rval += foldHeader(header);\n }\n\n if(msg.headers) {\n // encode all other headers\n for(var i = 0; i < msg.headers.length; ++i) {\n rval += foldHeader(msg.headers[i]);\n }\n }\n\n // terminate header\n if(msg.procType) {\n rval += '\\r\\n';\n }\n\n // add body\n rval += forge.util.encode64(msg.body, options.maxline || 64) + '\\r\\n';\n\n rval += '-----END ' + msg.type + '-----\\r\\n';\n return rval;\n};\n\n/**\n * Decodes (deserializes) all PEM messages found in the given string.\n *\n * @param str the PEM-formatted string to decode.\n *\n * @return the PEM message objects in an array.\n */\npem.decode = function(str) {\n var rval = [];\n\n // split string into PEM messages (be lenient w/EOF on BEGIN line)\n var rMessage = /\\s*-----BEGIN ([A-Z0-9- ]+)-----\\r?\\n?([\\x21-\\x7e\\s]+?(?:\\r?\\n\\r?\\n))?([:A-Za-z0-9+\\/=\\s]+?)-----END \\1-----/g;\n var rHeader = /([\\x21-\\x7e]+):\\s*([\\x21-\\x7e\\s^:]+)/;\n var rCRLF = /\\r?\\n/;\n var match;\n while(true) {\n match = rMessage.exec(str);\n if(!match) {\n break;\n }\n\n var msg = {\n type: match[1],\n procType: null,\n contentDomain: null,\n dekInfo: null,\n headers: [],\n body: forge.util.decode64(match[3])\n };\n rval.push(msg);\n\n // no headers\n if(!match[2]) {\n continue;\n }\n\n // parse headers\n var lines = match[2].split(rCRLF);\n var li = 0;\n while(match && li < lines.length) {\n // get line, trim any rhs whitespace\n var line = lines[li].replace(/\\s+$/, '');\n\n // RFC2822 unfold any following folded lines\n for(var nl = li + 1; nl < lines.length; ++nl) {\n var next = lines[nl];\n if(!/\\s/.test(next[0])) {\n break;\n }\n line += next;\n li = nl;\n }\n\n // parse header\n match = line.match(rHeader);\n if(match) {\n var header = {name: match[1], values: []};\n var values = match[2].split(',');\n for(var vi = 0; vi < values.length; ++vi) {\n header.values.push(ltrim(values[vi]));\n }\n\n // Proc-Type must be the first header\n if(!msg.procType) {\n if(header.name !== 'Proc-Type') {\n throw new Error('Invalid PEM formatted message. The first ' +\n 'encapsulated header must be \"Proc-Type\".');\n } else if(header.values.length !== 2) {\n throw new Error('Invalid PEM formatted message. The \"Proc-Type\" ' +\n 'header must have two subfields.');\n }\n msg.procType = {version: values[0], type: values[1]};\n } else if(!msg.contentDomain && header.name === 'Content-Domain') {\n // special-case Content-Domain\n msg.contentDomain = values[0] || '';\n } else if(!msg.dekInfo && header.name === 'DEK-Info') {\n // special-case DEK-Info\n if(header.values.length === 0) {\n throw new Error('Invalid PEM formatted message. The \"DEK-Info\" ' +\n 'header must have at least one subfield.');\n }\n msg.dekInfo = {algorithm: values[0], parameters: values[1] || null};\n } else {\n msg.headers.push(header);\n }\n }\n\n ++li;\n }\n\n if(msg.procType === 'ENCRYPTED' && !msg.dekInfo) {\n throw new Error('Invalid PEM formatted message. The \"DEK-Info\" ' +\n 'header must be present if \"Proc-Type\" is \"ENCRYPTED\".');\n }\n }\n\n if(rval.length === 0) {\n throw new Error('Invalid PEM formatted message.');\n }\n\n return rval;\n};\n\nfunction foldHeader(header) {\n var rval = header.name + ': ';\n\n // ensure values with CRLF are folded\n var values = [];\n var insertSpace = function(match, $1) {\n return ' ' + $1;\n };\n for(var i = 0; i < header.values.length; ++i) {\n values.push(header.values[i].replace(/^(\\S+\\r\\n)/, insertSpace));\n }\n rval += values.join(',') + '\\r\\n';\n\n // do folding\n var length = 0;\n var candidate = -1;\n for(var i = 0; i < rval.length; ++i, ++length) {\n if(length > 65 && candidate !== -1) {\n var insert = rval[candidate];\n if(insert === ',') {\n ++candidate;\n rval = rval.substr(0, candidate) + '\\r\\n ' + rval.substr(candidate);\n } else {\n rval = rval.substr(0, candidate) +\n '\\r\\n' + insert + rval.substr(candidate + 1);\n }\n length = (i - candidate - 1);\n candidate = -1;\n ++i;\n } else if(rval[i] === ' ' || rval[i] === '\\t' || rval[i] === ',') {\n candidate = i;\n }\n }\n\n return rval;\n}\n\nfunction ltrim(str) {\n return str.replace(/^\\s+/, '');\n}\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","/**\n * Hash-based Message Authentication Code implementation. Requires a message\n * digest object that can be obtained, for example, from forge.md.sha1 or\n * forge.md.md5.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2012 Digital Bazaar, Inc. All rights reserved.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\n/* HMAC API */\nvar hmac = module.exports = forge.hmac = forge.hmac || {};\n\n/**\n * Creates an HMAC object that uses the given message digest object.\n *\n * @return an HMAC object.\n */\nhmac.create = function() {\n // the hmac key to use\n var _key = null;\n\n // the message digest to use\n var _md = null;\n\n // the inner padding\n var _ipadding = null;\n\n // the outer padding\n var _opadding = null;\n\n // hmac context\n var ctx = {};\n\n /**\n * Starts or restarts the HMAC with the given key and message digest.\n *\n * @param md the message digest to use, null to reuse the previous one,\n * a string to use builtin 'sha1', 'md5', 'sha256'.\n * @param key the key to use as a string, array of bytes, byte buffer,\n * or null to reuse the previous key.\n */\n ctx.start = function(md, key) {\n if(md !== null) {\n if(typeof md === 'string') {\n // create builtin message digest\n md = md.toLowerCase();\n if(md in forge.md.algorithms) {\n _md = forge.md.algorithms[md].create();\n } else {\n throw new Error('Unknown hash algorithm \"' + md + '\"');\n }\n } else {\n // store message digest\n _md = md;\n }\n }\n\n if(key === null) {\n // reuse previous key\n key = _key;\n } else {\n if(typeof key === 'string') {\n // convert string into byte buffer\n key = forge.util.createBuffer(key);\n } else if(forge.util.isArray(key)) {\n // convert byte array into byte buffer\n var tmp = key;\n key = forge.util.createBuffer();\n for(var i = 0; i < tmp.length; ++i) {\n key.putByte(tmp[i]);\n }\n }\n\n // if key is longer than blocksize, hash it\n var keylen = key.length();\n if(keylen > _md.blockLength) {\n _md.start();\n _md.update(key.bytes());\n key = _md.digest();\n }\n\n // mix key into inner and outer padding\n // ipadding = [0x36 * blocksize] ^ key\n // opadding = [0x5C * blocksize] ^ key\n _ipadding = forge.util.createBuffer();\n _opadding = forge.util.createBuffer();\n keylen = key.length();\n for(var i = 0; i < keylen; ++i) {\n var tmp = key.at(i);\n _ipadding.putByte(0x36 ^ tmp);\n _opadding.putByte(0x5C ^ tmp);\n }\n\n // if key is shorter than blocksize, add additional padding\n if(keylen < _md.blockLength) {\n var tmp = _md.blockLength - keylen;\n for(var i = 0; i < tmp; ++i) {\n _ipadding.putByte(0x36);\n _opadding.putByte(0x5C);\n }\n }\n _key = key;\n _ipadding = _ipadding.bytes();\n _opadding = _opadding.bytes();\n }\n\n // digest is done like so: hash(opadding | hash(ipadding | message))\n\n // prepare to do inner hash\n // hash(ipadding | message)\n _md.start();\n _md.update(_ipadding);\n };\n\n /**\n * Updates the HMAC with the given message bytes.\n *\n * @param bytes the bytes to update with.\n */\n ctx.update = function(bytes) {\n _md.update(bytes);\n };\n\n /**\n * Produces the Message Authentication Code (MAC).\n *\n * @return a byte buffer containing the digest value.\n */\n ctx.getMac = function() {\n // digest is done like so: hash(opadding | hash(ipadding | message))\n // here we do the outer hashing\n var inner = _md.digest().bytes();\n _md.start();\n _md.update(_opadding);\n _md.update(inner);\n return _md.digest();\n };\n // alias for getMac\n ctx.digest = ctx.getMac;\n\n return ctx;\n};\n","/**\n * Secure Hash Algorithm with 160-bit digest (SHA-1) implementation.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha1 = module.exports = forge.sha1 = forge.sha1 || {};\nforge.md.sha1 = forge.md.algorithms.sha1 = sha1;\n\n/**\n * Creates a SHA-1 message digest object.\n *\n * @return a message digest object.\n */\nsha1.create = function() {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n // SHA-1 state contains five 32-bit integers\n var _state = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for word storage\n var _w = new Array(80);\n\n // message digest object\n var md = {\n algorithm: 'sha1',\n blockLength: 64,\n digestLength: 20,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 8\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength64 for backwards-compatibility)\n md.fullMessageLength = md.messageLength64 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _state = {\n h0: 0x67452301,\n h1: 0xEFCDAB89,\n h2: 0x98BADCFE,\n h3: 0x10325476,\n h4: 0xC3D2E1F0\n };\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = ((len[1] / 0x100000000) >>> 0);\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_state, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate SHA-1 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 448 mod 512. In other words,\n the data to be digested must be a multiple of 512 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 8 bytes (64\n bits), that means that the last segment of the data must have 56 bytes\n (448 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 448 mod 512 because\n 512 - 128 = 448.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 448 mod 512, then 512 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in big-endian order; since length\n // is stored in bytes we multiply by 8 and add carry from next int\n var next, carry;\n var bits = md.fullMessageLength[0] * 8;\n for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n next = md.fullMessageLength[i + 1] * 8;\n carry = (next / 0x100000000) >>> 0;\n bits += carry;\n finalBlock.putInt32(bits >>> 0);\n bits = next >>> 0;\n }\n finalBlock.putInt32(bits);\n\n var s2 = {\n h0: _state.h0,\n h1: _state.h1,\n h2: _state.h2,\n h3: _state.h3,\n h4: _state.h4\n };\n _update(s2, _w, finalBlock);\n var rval = forge.util.createBuffer();\n rval.putInt32(s2.h0);\n rval.putInt32(s2.h1);\n rval.putInt32(s2.h2);\n rval.putInt32(s2.h3);\n rval.putInt32(s2.h4);\n return rval;\n };\n\n return md;\n};\n\n// sha-1 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 64);\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates a SHA-1 state with the given byte buffer.\n *\n * @param s the SHA-1 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (64 byte) chunks\n var t, a, b, c, d, e, f, i;\n var len = bytes.length();\n while(len >= 64) {\n // the w array will be populated with sixteen 32-bit big-endian words\n // and then extended into 80 32-bit words according to SHA-1 algorithm\n // and for 32-79 using Max Locktyukhin's optimization\n\n // initialize hash value for this chunk\n a = s.h0;\n b = s.h1;\n c = s.h2;\n d = s.h3;\n e = s.h4;\n\n // round 1\n for(i = 0; i < 16; ++i) {\n t = bytes.getInt32();\n w[i] = t;\n f = d ^ (b & (c ^ d));\n t = ((a << 5) | (a >>> 27)) + f + e + 0x5A827999 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n for(; i < 20; ++i) {\n t = (w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16]);\n t = (t << 1) | (t >>> 31);\n w[i] = t;\n f = d ^ (b & (c ^ d));\n t = ((a << 5) | (a >>> 27)) + f + e + 0x5A827999 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n // round 2\n for(; i < 32; ++i) {\n t = (w[i - 3] ^ w[i - 8] ^ w[i - 14] ^ w[i - 16]);\n t = (t << 1) | (t >>> 31);\n w[i] = t;\n f = b ^ c ^ d;\n t = ((a << 5) | (a >>> 27)) + f + e + 0x6ED9EBA1 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n for(; i < 40; ++i) {\n t = (w[i - 6] ^ w[i - 16] ^ w[i - 28] ^ w[i - 32]);\n t = (t << 2) | (t >>> 30);\n w[i] = t;\n f = b ^ c ^ d;\n t = ((a << 5) | (a >>> 27)) + f + e + 0x6ED9EBA1 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n // round 3\n for(; i < 60; ++i) {\n t = (w[i - 6] ^ w[i - 16] ^ w[i - 28] ^ w[i - 32]);\n t = (t << 2) | (t >>> 30);\n w[i] = t;\n f = (b & c) | (d & (b ^ c));\n t = ((a << 5) | (a >>> 27)) + f + e + 0x8F1BBCDC + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n // round 4\n for(; i < 80; ++i) {\n t = (w[i - 6] ^ w[i - 16] ^ w[i - 28] ^ w[i - 32]);\n t = (t << 2) | (t >>> 30);\n w[i] = t;\n f = b ^ c ^ d;\n t = ((a << 5) | (a >>> 27)) + f + e + 0xCA62C1D6 + t;\n e = d;\n d = c;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n c = ((b << 30) | (b >>> 2)) >>> 0;\n b = a;\n a = t;\n }\n\n // update hash state\n s.h0 = (s.h0 + a) | 0;\n s.h1 = (s.h1 + b) | 0;\n s.h2 = (s.h2 + c) | 0;\n s.h3 = (s.h3 + d) | 0;\n s.h4 = (s.h4 + e) | 0;\n\n len -= 64;\n }\n}\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh <http://feross.org>\n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('isarray')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n * incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n ? global.TYPED_ARRAY_SUPPORT\n : typedArraySupport()\n\n/*\n * Export kMaxLength after typed array support is determined.\n */\nexports.kMaxLength = kMaxLength()\n\nfunction typedArraySupport () {\n try {\n var arr = new Uint8Array(1)\n arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n return arr.foo() === 42 && // typed array instances can be augmented\n typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n } catch (e) {\n return false\n }\n}\n\nfunction kMaxLength () {\n return Buffer.TYPED_ARRAY_SUPPORT\n ? 0x7fffffff\n : 0x3fffffff\n}\n\nfunction createBuffer (that, length) {\n if (kMaxLength() < length) {\n throw new RangeError('Invalid typed array length')\n }\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = new Uint8Array(length)\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n if (that === null) {\n that = new Buffer(length)\n }\n that.length = length\n }\n\n return that\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n if (!Buffer.TYPED_ARRAY_SUPPORT && !(this instanceof Buffer)) {\n return new Buffer(arg, encodingOrOffset, length)\n }\n\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new Error(\n 'If encoding is specified then the first argument must be a string'\n )\n }\n return allocUnsafe(this, arg)\n }\n return from(this, arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n arr.__proto__ = Buffer.prototype\n return arr\n}\n\nfunction from (that, value, encodingOrOffset, length) {\n if (typeof value === 'number') {\n throw new TypeError('\"value\" argument must not be a number')\n }\n\n if (typeof ArrayBuffer !== 'undefined' && value instanceof ArrayBuffer) {\n return fromArrayBuffer(that, value, encodingOrOffset, length)\n }\n\n if (typeof value === 'string') {\n return fromString(that, value, encodingOrOffset)\n }\n\n return fromObject(that, value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(null, value, encodingOrOffset, length)\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n Buffer.prototype.__proto__ = Uint8Array.prototype\n Buffer.__proto__ = Uint8Array\n if (typeof Symbol !== 'undefined' && Symbol.species &&\n Buffer[Symbol.species] === Buffer) {\n // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n Object.defineProperty(Buffer, Symbol.species, {\n value: null,\n configurable: true\n })\n }\n}\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be a number')\n } else if (size < 0) {\n throw new RangeError('\"size\" argument must not be negative')\n }\n}\n\nfunction alloc (that, size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(that, size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpretted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(that, size).fill(fill, encoding)\n : createBuffer(that, size).fill(fill)\n }\n return createBuffer(that, size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(null, size, fill, encoding)\n}\n\nfunction allocUnsafe (that, size) {\n assertSize(size)\n that = createBuffer(that, size < 0 ? 0 : checked(size) | 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) {\n for (var i = 0; i < size; ++i) {\n that[i] = 0\n }\n }\n return that\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(null, size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(null, size)\n}\n\nfunction fromString (that, string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('\"encoding\" must be a valid string encoding')\n }\n\n var length = byteLength(string, encoding) | 0\n that = createBuffer(that, length)\n\n var actual = that.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n that = that.slice(0, actual)\n }\n\n return that\n}\n\nfunction fromArrayLike (that, array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n that = createBuffer(that, length)\n for (var i = 0; i < length; i += 1) {\n that[i] = array[i] & 255\n }\n return that\n}\n\nfunction fromArrayBuffer (that, array, byteOffset, length) {\n array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\\'offset\\' is out of bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\\'length\\' is out of bounds')\n }\n\n if (byteOffset === undefined && length === undefined) {\n array = new Uint8Array(array)\n } else if (length === undefined) {\n array = new Uint8Array(array, byteOffset)\n } else {\n array = new Uint8Array(array, byteOffset, length)\n }\n\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n // Return an augmented `Uint8Array` instance, for best performance\n that = array\n that.__proto__ = Buffer.prototype\n } else {\n // Fallback: Return an object instance of the Buffer class\n that = fromArrayLike(that, array)\n }\n return that\n}\n\nfunction fromObject (that, obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n that = createBuffer(that, len)\n\n if (that.length === 0) {\n return that\n }\n\n obj.copy(that, 0, 0, len)\n return that\n }\n\n if (obj) {\n if ((typeof ArrayBuffer !== 'undefined' &&\n obj.buffer instanceof ArrayBuffer) || 'length' in obj) {\n if (typeof obj.length !== 'number' || isnan(obj.length)) {\n return createBuffer(that, 0)\n }\n return fromArrayLike(that, obj)\n }\n\n if (obj.type === 'Buffer' && isArray(obj.data)) {\n return fromArrayLike(that, obj.data)\n }\n }\n\n throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n // Note: cannot use `length < kMaxLength()` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= kMaxLength()) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + kMaxLength().toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError('Arguments must be Buffers')\n }\n\n if (a === b) return 0\n\n var x = a.length\n var y = b.length\n\n for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n var i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n var buffer = Buffer.allocUnsafe(length)\n var pos = 0\n for (i = 0; i < list.length; ++i) {\n var buf = list[i]\n if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n buf.copy(buffer, pos)\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (typeof ArrayBuffer !== 'undefined' && typeof ArrayBuffer.isView === 'function' &&\n (ArrayBuffer.isView(string) || string instanceof ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n string = '' + string\n }\n\n var len = string.length\n if (len === 0) return 0\n\n // Use a for loop to avoid recursion\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n case undefined:\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) return utf8ToBytes(string).length // assume utf8\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n var loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n var i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n var len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (var i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n var len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (var i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n var len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (var i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n var length = this.length | 0\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n var str = ''\n var max = exports.INSPECT_MAX_BYTES\n if (this.length > 0) {\n str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n if (this.length > max) str += ' ... '\n }\n return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (!Buffer.isBuffer(target)) {\n throw new TypeError('Argument must be a Buffer')\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n var x = thisEnd - thisStart\n var y = end - start\n var len = Math.min(x, y)\n\n var thisCopy = this.slice(thisStart, thisEnd)\n var targetCopy = target.slice(start, end)\n\n for (var i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (isNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (Buffer.TYPED_ARRAY_SUPPORT &&\n typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n var indexSize = 1\n var arrLength = arr.length\n var valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n var i\n if (dir) {\n var foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n var found = true\n for (var j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n var remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n // must be an even number of digits\n var strLen = string.length\n if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n for (var i = 0; i < length; ++i) {\n var parsed = parseInt(string.substr(i * 2, 2), 16)\n if (isNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset | 0\n if (isFinite(length)) {\n length = length | 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n // legacy write(string, encoding, offset, length) - remove in v0.13\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n var remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n var loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n return asciiWrite(this, string, offset, length)\n\n case 'latin1':\n case 'binary':\n return latin1Write(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n var res = []\n\n var i = start\n while (i < end) {\n var firstByte = buf[i]\n var codePoint = null\n var bytesPerSequence = (firstByte > 0xEF) ? 4\n : (firstByte > 0xDF) ? 3\n : (firstByte > 0xBF) ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n var secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n var len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n var res = ''\n var i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n var ret = ''\n end = Math.min(buf.length, end)\n\n for (var i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n var len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n var out = ''\n for (var i = start; i < end; ++i) {\n out += toHex(buf[i])\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n for (var i = 0; i < bytes.length; i += 2) {\n res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n var len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n var newBuf\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n newBuf = this.subarray(start, end)\n newBuf.__proto__ = Buffer.prototype\n } else {\n var sliceLen = end - start\n newBuf = new Buffer(sliceLen, undefined)\n for (var i = 0; i < sliceLen; ++i) {\n newBuf[i] = this[i + start]\n }\n }\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n var val = this[offset + --byteLength]\n var mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var val = this[offset]\n var mul = 1\n var i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n var i = byteLength\n var mul = 1\n var val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 2, this.length)\n var val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var mul = 1\n var i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n byteLength = byteLength | 0\n if (!noAssert) {\n var maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n var i = byteLength - 1\n var mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; ++i) {\n buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n (littleEndian ? i : 1 - i) * 8\n }\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n if (value < 0) value = 0xffffffff + value + 1\n for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; ++i) {\n buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n }\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = 0\n var mul = 1\n var sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) {\n var limit = Math.pow(2, 8 * byteLength - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n var i = byteLength - 1\n var mul = 1\n var sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n } else {\n objectWriteUInt16(this, value, offset, true)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n } else {\n objectWriteUInt16(this, value, offset, false)\n }\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n } else {\n objectWriteUInt32(this, value, offset, true)\n }\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset | 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n if (Buffer.TYPED_ARRAY_SUPPORT) {\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n } else {\n objectWriteUInt32(this, value, offset, false)\n }\n return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n var len = end - start\n var i\n\n if (this === target && start < targetStart && targetStart < end) {\n // descending copy from end\n for (i = len - 1; i >= 0; --i) {\n target[i + targetStart] = this[i + start]\n }\n } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n // ascending copy from start\n for (i = 0; i < len; ++i) {\n target[i + targetStart] = this[i + start]\n }\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, start + len),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (val.length === 1) {\n var code = val.charCodeAt(0)\n if (code < 256) {\n val = code\n }\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n } else if (typeof val === 'number') {\n val = val & 255\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n var i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n var bytes = Buffer.isBuffer(val)\n ? val\n : utf8ToBytes(new Buffer(val, encoding).toString())\n var len = bytes.length\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction stringtrim (str) {\n if (str.trim) return str.trim()\n return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n if (n < 16) return '0' + n.toString(16)\n return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n var codePoint\n var length = string.length\n var leadSurrogate = null\n var bytes = []\n\n for (var i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n var c, hi, lo\n var byteArray = []\n for (var i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n for (var i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\nfunction isnan (val) {\n return val !== val // eslint-disable-line no-self-compare\n}\n","/**\n * DES (Data Encryption Standard) implementation.\n *\n * This implementation supports DES as well as 3DES-EDE in ECB and CBC mode.\n * It is based on the BSD-licensed implementation by Paul Tero:\n *\n * Paul Tero, July 2001\n * http://www.tero.co.uk/des/\n *\n * Optimised for performance with large blocks by\n * Michael Hayworth, November 2001\n * http://www.netdealing.com\n *\n * THIS SOFTWARE IS PROVIDED \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT\n * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY\n * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF\n * SUCH DAMAGE.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2012-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./cipher');\nrequire('./cipherModes');\nrequire('./util');\n\n/* DES API */\nmodule.exports = forge.des = forge.des || {};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('DES-<mode>', key);\n * cipher.start({iv: iv});\n *\n * Creates an DES cipher object to encrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as binary-encoded strings of bytes or\n * byte buffers.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC' if IV is\n * given, 'ECB' if null).\n *\n * @return the cipher.\n */\nforge.des.startEncrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: false,\n mode: mode || (iv === null ? 'ECB' : 'CBC')\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('DES-<mode>', key);\n *\n * Creates an DES cipher object to encrypt data using the given symmetric key.\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.des.createEncryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: false,\n mode: mode\n });\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('DES-<mode>', key);\n * decipher.start({iv: iv});\n *\n * Creates an DES cipher object to decrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as binary-encoded strings of bytes or\n * byte buffers.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC' if IV is\n * given, 'ECB' if null).\n *\n * @return the cipher.\n */\nforge.des.startDecrypting = function(key, iv, output, mode) {\n var cipher = _createCipher({\n key: key,\n output: output,\n decrypt: true,\n mode: mode || (iv === null ? 'ECB' : 'CBC')\n });\n cipher.start(iv);\n return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('DES-<mode>', key);\n *\n * Creates an DES cipher object to decrypt data using the given symmetric key.\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.des.createDecryptionCipher = function(key, mode) {\n return _createCipher({\n key: key,\n output: null,\n decrypt: true,\n mode: mode\n });\n};\n\n/**\n * Creates a new DES cipher algorithm object.\n *\n * @param name the name of the algorithm.\n * @param mode the mode factory function.\n *\n * @return the DES algorithm object.\n */\nforge.des.Algorithm = function(name, mode) {\n var self = this;\n self.name = name;\n self.mode = new mode({\n blockSize: 8,\n cipher: {\n encrypt: function(inBlock, outBlock) {\n return _updateBlock(self._keys, inBlock, outBlock, false);\n },\n decrypt: function(inBlock, outBlock) {\n return _updateBlock(self._keys, inBlock, outBlock, true);\n }\n }\n });\n self._init = false;\n};\n\n/**\n * Initializes this DES algorithm by expanding its key.\n *\n * @param options the options to use.\n * key the key to use with this algorithm.\n * decrypt true if the algorithm should be initialized for decryption,\n * false for encryption.\n */\nforge.des.Algorithm.prototype.initialize = function(options) {\n if(this._init) {\n return;\n }\n\n var key = forge.util.createBuffer(options.key);\n if(this.name.indexOf('3DES') === 0) {\n if(key.length() !== 24) {\n throw new Error('Invalid Triple-DES key size: ' + key.length() * 8);\n }\n }\n\n // do key expansion to 16 or 48 subkeys (single or triple DES)\n this._keys = _createKeys(key);\n this._init = true;\n};\n\n/** Register DES algorithms **/\n\nregisterAlgorithm('DES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('DES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('DES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('DES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('DES-CTR', forge.cipher.modes.ctr);\n\nregisterAlgorithm('3DES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('3DES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('3DES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('3DES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('3DES-CTR', forge.cipher.modes.ctr);\n\nfunction registerAlgorithm(name, mode) {\n var factory = function() {\n return new forge.des.Algorithm(name, mode);\n };\n forge.cipher.registerAlgorithm(name, factory);\n}\n\n/** DES implementation **/\n\nvar spfunction1 = [0x1010400,0,0x10000,0x1010404,0x1010004,0x10404,0x4,0x10000,0x400,0x1010400,0x1010404,0x400,0x1000404,0x1010004,0x1000000,0x4,0x404,0x1000400,0x1000400,0x10400,0x10400,0x1010000,0x1010000,0x1000404,0x10004,0x1000004,0x1000004,0x10004,0,0x404,0x10404,0x1000000,0x10000,0x1010404,0x4,0x1010000,0x1010400,0x1000000,0x1000000,0x400,0x1010004,0x10000,0x10400,0x1000004,0x400,0x4,0x1000404,0x10404,0x1010404,0x10004,0x1010000,0x1000404,0x1000004,0x404,0x10404,0x1010400,0x404,0x1000400,0x1000400,0,0x10004,0x10400,0,0x1010004];\nvar spfunction2 = [-0x7fef7fe0,-0x7fff8000,0x8000,0x108020,0x100000,0x20,-0x7fefffe0,-0x7fff7fe0,-0x7fffffe0,-0x7fef7fe0,-0x7fef8000,-0x80000000,-0x7fff8000,0x100000,0x20,-0x7fefffe0,0x108000,0x100020,-0x7fff7fe0,0,-0x80000000,0x8000,0x108020,-0x7ff00000,0x100020,-0x7fffffe0,0,0x108000,0x8020,-0x7fef8000,-0x7ff00000,0x8020,0,0x108020,-0x7fefffe0,0x100000,-0x7fff7fe0,-0x7ff00000,-0x7fef8000,0x8000,-0x7ff00000,-0x7fff8000,0x20,-0x7fef7fe0,0x108020,0x20,0x8000,-0x80000000,0x8020,-0x7fef8000,0x100000,-0x7fffffe0,0x100020,-0x7fff7fe0,-0x7fffffe0,0x100020,0x108000,0,-0x7fff8000,0x8020,-0x80000000,-0x7fefffe0,-0x7fef7fe0,0x108000];\nvar spfunction3 = [0x208,0x8020200,0,0x8020008,0x8000200,0,0x20208,0x8000200,0x20008,0x8000008,0x8000008,0x20000,0x8020208,0x20008,0x8020000,0x208,0x8000000,0x8,0x8020200,0x200,0x20200,0x8020000,0x8020008,0x20208,0x8000208,0x20200,0x20000,0x8000208,0x8,0x8020208,0x200,0x8000000,0x8020200,0x8000000,0x20008,0x208,0x20000,0x8020200,0x8000200,0,0x200,0x20008,0x8020208,0x8000200,0x8000008,0x200,0,0x8020008,0x8000208,0x20000,0x8000000,0x8020208,0x8,0x20208,0x20200,0x8000008,0x8020000,0x8000208,0x208,0x8020000,0x20208,0x8,0x8020008,0x20200];\nvar spfunction4 = [0x802001,0x2081,0x2081,0x80,0x802080,0x800081,0x800001,0x2001,0,0x802000,0x802000,0x802081,0x81,0,0x800080,0x800001,0x1,0x2000,0x800000,0x802001,0x80,0x800000,0x2001,0x2080,0x800081,0x1,0x2080,0x800080,0x2000,0x802080,0x802081,0x81,0x800080,0x800001,0x802000,0x802081,0x81,0,0,0x802000,0x2080,0x800080,0x800081,0x1,0x802001,0x2081,0x2081,0x80,0x802081,0x81,0x1,0x2000,0x800001,0x2001,0x802080,0x800081,0x2001,0x2080,0x800000,0x802001,0x80,0x800000,0x2000,0x802080];\nvar spfunction5 = [0x100,0x2080100,0x2080000,0x42000100,0x80000,0x100,0x40000000,0x2080000,0x40080100,0x80000,0x2000100,0x40080100,0x42000100,0x42080000,0x80100,0x40000000,0x2000000,0x40080000,0x40080000,0,0x40000100,0x42080100,0x42080100,0x2000100,0x42080000,0x40000100,0,0x42000000,0x2080100,0x2000000,0x42000000,0x80100,0x80000,0x42000100,0x100,0x2000000,0x40000000,0x2080000,0x42000100,0x40080100,0x2000100,0x40000000,0x42080000,0x2080100,0x40080100,0x100,0x2000000,0x42080000,0x42080100,0x80100,0x42000000,0x42080100,0x2080000,0,0x40080000,0x42000000,0x80100,0x2000100,0x40000100,0x80000,0,0x40080000,0x2080100,0x40000100];\nvar spfunction6 = [0x20000010,0x20400000,0x4000,0x20404010,0x20400000,0x10,0x20404010,0x400000,0x20004000,0x404010,0x400000,0x20000010,0x400010,0x20004000,0x20000000,0x4010,0,0x400010,0x20004010,0x4000,0x404000,0x20004010,0x10,0x20400010,0x20400010,0,0x404010,0x20404000,0x4010,0x404000,0x20404000,0x20000000,0x20004000,0x10,0x20400010,0x404000,0x20404010,0x400000,0x4010,0x20000010,0x400000,0x20004000,0x20000000,0x4010,0x20000010,0x20404010,0x404000,0x20400000,0x404010,0x20404000,0,0x20400010,0x10,0x4000,0x20400000,0x404010,0x4000,0x400010,0x20004010,0,0x20404000,0x20000000,0x400010,0x20004010];\nvar spfunction7 = [0x200000,0x4200002,0x4000802,0,0x800,0x4000802,0x200802,0x4200800,0x4200802,0x200000,0,0x4000002,0x2,0x4000000,0x4200002,0x802,0x4000800,0x200802,0x200002,0x4000800,0x4000002,0x4200000,0x4200800,0x200002,0x4200000,0x800,0x802,0x4200802,0x200800,0x2,0x4000000,0x200800,0x4000000,0x200800,0x200000,0x4000802,0x4000802,0x4200002,0x4200002,0x2,0x200002,0x4000000,0x4000800,0x200000,0x4200800,0x802,0x200802,0x4200800,0x802,0x4000002,0x4200802,0x4200000,0x200800,0,0x2,0x4200802,0,0x200802,0x4200000,0x800,0x4000002,0x4000800,0x800,0x200002];\nvar spfunction8 = [0x10001040,0x1000,0x40000,0x10041040,0x10000000,0x10001040,0x40,0x10000000,0x40040,0x10040000,0x10041040,0x41000,0x10041000,0x41040,0x1000,0x40,0x10040000,0x10000040,0x10001000,0x1040,0x41000,0x40040,0x10040040,0x10041000,0x1040,0,0,0x10040040,0x10000040,0x10001000,0x41040,0x40000,0x41040,0x40000,0x10041000,0x1000,0x40,0x10040040,0x1000,0x41040,0x10001000,0x40,0x10000040,0x10040000,0x10040040,0x10000000,0x40000,0x10001040,0,0x10041040,0x40040,0x10000040,0x10040000,0x10001000,0x10001040,0,0x10041040,0x41000,0x41000,0x1040,0x1040,0x40040,0x10000000,0x10041000];\n\n/**\n * Create necessary sub keys.\n *\n * @param key the 64-bit or 192-bit key.\n *\n * @return the expanded keys.\n */\nfunction _createKeys(key) {\n var pc2bytes0 = [0,0x4,0x20000000,0x20000004,0x10000,0x10004,0x20010000,0x20010004,0x200,0x204,0x20000200,0x20000204,0x10200,0x10204,0x20010200,0x20010204],\n pc2bytes1 = [0,0x1,0x100000,0x100001,0x4000000,0x4000001,0x4100000,0x4100001,0x100,0x101,0x100100,0x100101,0x4000100,0x4000101,0x4100100,0x4100101],\n pc2bytes2 = [0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808,0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808],\n pc2bytes3 = [0,0x200000,0x8000000,0x8200000,0x2000,0x202000,0x8002000,0x8202000,0x20000,0x220000,0x8020000,0x8220000,0x22000,0x222000,0x8022000,0x8222000],\n pc2bytes4 = [0,0x40000,0x10,0x40010,0,0x40000,0x10,0x40010,0x1000,0x41000,0x1010,0x41010,0x1000,0x41000,0x1010,0x41010],\n pc2bytes5 = [0,0x400,0x20,0x420,0,0x400,0x20,0x420,0x2000000,0x2000400,0x2000020,0x2000420,0x2000000,0x2000400,0x2000020,0x2000420],\n pc2bytes6 = [0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002,0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002],\n pc2bytes7 = [0,0x10000,0x800,0x10800,0x20000000,0x20010000,0x20000800,0x20010800,0x20000,0x30000,0x20800,0x30800,0x20020000,0x20030000,0x20020800,0x20030800],\n pc2bytes8 = [0,0x40000,0,0x40000,0x2,0x40002,0x2,0x40002,0x2000000,0x2040000,0x2000000,0x2040000,0x2000002,0x2040002,0x2000002,0x2040002],\n pc2bytes9 = [0,0x10000000,0x8,0x10000008,0,0x10000000,0x8,0x10000008,0x400,0x10000400,0x408,0x10000408,0x400,0x10000400,0x408,0x10000408],\n pc2bytes10 = [0,0x20,0,0x20,0x100000,0x100020,0x100000,0x100020,0x2000,0x2020,0x2000,0x2020,0x102000,0x102020,0x102000,0x102020],\n pc2bytes11 = [0,0x1000000,0x200,0x1000200,0x200000,0x1200000,0x200200,0x1200200,0x4000000,0x5000000,0x4000200,0x5000200,0x4200000,0x5200000,0x4200200,0x5200200],\n pc2bytes12 = [0,0x1000,0x8000000,0x8001000,0x80000,0x81000,0x8080000,0x8081000,0x10,0x1010,0x8000010,0x8001010,0x80010,0x81010,0x8080010,0x8081010],\n pc2bytes13 = [0,0x4,0x100,0x104,0,0x4,0x100,0x104,0x1,0x5,0x101,0x105,0x1,0x5,0x101,0x105];\n\n // how many iterations (1 for des, 3 for triple des)\n // changed by Paul 16/6/2007 to use Triple DES for 9+ byte keys\n var iterations = key.length() > 8 ? 3 : 1;\n\n // stores the return keys\n var keys = [];\n\n // now define the left shifts which need to be done\n var shifts = [0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0];\n\n var n = 0, tmp;\n for(var j = 0; j < iterations; j++) {\n var left = key.getInt32();\n var right = key.getInt32();\n\n tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n right ^= tmp;\n left ^= (tmp << 4);\n\n tmp = ((right >>> -16) ^ left) & 0x0000ffff;\n left ^= tmp;\n right ^= (tmp << -16);\n\n tmp = ((left >>> 2) ^ right) & 0x33333333;\n right ^= tmp;\n left ^= (tmp << 2);\n\n tmp = ((right >>> -16) ^ left) & 0x0000ffff;\n left ^= tmp;\n right ^= (tmp << -16);\n\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n left ^= tmp;\n right ^= (tmp << 8);\n\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n // right needs to be shifted and OR'd with last four bits of left\n tmp = (left << 8) | ((right >>> 20) & 0x000000f0);\n\n // left needs to be put upside down\n left = ((right << 24) | ((right << 8) & 0xff0000) |\n ((right >>> 8) & 0xff00) | ((right >>> 24) & 0xf0));\n right = tmp;\n\n // now go through and perform these shifts on the left and right keys\n for(var i = 0; i < shifts.length; ++i) {\n //shift the keys either one or two bits to the left\n if(shifts[i]) {\n left = (left << 2) | (left >>> 26);\n right = (right << 2) | (right >>> 26);\n } else {\n left = (left << 1) | (left >>> 27);\n right = (right << 1) | (right >>> 27);\n }\n left &= -0xf;\n right &= -0xf;\n\n // now apply PC-2, in such a way that E is easier when encrypting or\n // decrypting this conversion will look like PC-2 except only the last 6\n // bits of each byte are used rather than 48 consecutive bits and the\n // order of lines will be according to how the S selection functions will\n // be applied: S2, S4, S6, S8, S1, S3, S5, S7\n var lefttmp = (\n pc2bytes0[left >>> 28] | pc2bytes1[(left >>> 24) & 0xf] |\n pc2bytes2[(left >>> 20) & 0xf] | pc2bytes3[(left >>> 16) & 0xf] |\n pc2bytes4[(left >>> 12) & 0xf] | pc2bytes5[(left >>> 8) & 0xf] |\n pc2bytes6[(left >>> 4) & 0xf]);\n var righttmp = (\n pc2bytes7[right >>> 28] | pc2bytes8[(right >>> 24) & 0xf] |\n pc2bytes9[(right >>> 20) & 0xf] | pc2bytes10[(right >>> 16) & 0xf] |\n pc2bytes11[(right >>> 12) & 0xf] | pc2bytes12[(right >>> 8) & 0xf] |\n pc2bytes13[(right >>> 4) & 0xf]);\n tmp = ((righttmp >>> 16) ^ lefttmp) & 0x0000ffff;\n keys[n++] = lefttmp ^ tmp;\n keys[n++] = righttmp ^ (tmp << 16);\n }\n }\n\n return keys;\n}\n\n/**\n * Updates a single block (1 byte) using DES. The update will either\n * encrypt or decrypt the block.\n *\n * @param keys the expanded keys.\n * @param input the input block (an array of 32-bit words).\n * @param output the updated output block.\n * @param decrypt true to decrypt the block, false to encrypt it.\n */\nfunction _updateBlock(keys, input, output, decrypt) {\n // set up loops for single or triple DES\n var iterations = keys.length === 32 ? 3 : 9;\n var looping;\n if(iterations === 3) {\n looping = decrypt ? [30, -2, -2] : [0, 32, 2];\n } else {\n looping = (decrypt ?\n [94, 62, -2, 32, 64, 2, 30, -2, -2] :\n [0, 32, 2, 62, 30, -2, 64, 96, 2]);\n }\n\n var tmp;\n\n var left = input[0];\n var right = input[1];\n\n // first each 64 bit chunk of the message must be permuted according to IP\n tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n right ^= tmp;\n left ^= (tmp << 4);\n\n tmp = ((left >>> 16) ^ right) & 0x0000ffff;\n right ^= tmp;\n left ^= (tmp << 16);\n\n tmp = ((right >>> 2) ^ left) & 0x33333333;\n left ^= tmp;\n right ^= (tmp << 2);\n\n tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n left ^= tmp;\n right ^= (tmp << 8);\n\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n // rotate left 1 bit\n left = ((left << 1) | (left >>> 31));\n right = ((right << 1) | (right >>> 31));\n\n for(var j = 0; j < iterations; j += 3) {\n var endloop = looping[j + 1];\n var loopinc = looping[j + 2];\n\n // now go through and perform the encryption or decryption\n for(var i = looping[j]; i != endloop; i += loopinc) {\n var right1 = right ^ keys[i];\n var right2 = ((right >>> 4) | (right << 28)) ^ keys[i + 1];\n\n // passing these bytes through the S selection functions\n tmp = left;\n left = right;\n right = tmp ^ (\n spfunction2[(right1 >>> 24) & 0x3f] |\n spfunction4[(right1 >>> 16) & 0x3f] |\n spfunction6[(right1 >>> 8) & 0x3f] |\n spfunction8[right1 & 0x3f] |\n spfunction1[(right2 >>> 24) & 0x3f] |\n spfunction3[(right2 >>> 16) & 0x3f] |\n spfunction5[(right2 >>> 8) & 0x3f] |\n spfunction7[right2 & 0x3f]);\n }\n // unreverse left and right\n tmp = left;\n left = right;\n right = tmp;\n }\n\n // rotate right 1 bit\n left = ((left >>> 1) | (left << 31));\n right = ((right >>> 1) | (right << 31));\n\n // now perform IP-1, which is IP in the opposite direction\n tmp = ((left >>> 1) ^ right) & 0x55555555;\n right ^= tmp;\n left ^= (tmp << 1);\n\n tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n left ^= tmp;\n right ^= (tmp << 8);\n\n tmp = ((right >>> 2) ^ left) & 0x33333333;\n left ^= tmp;\n right ^= (tmp << 2);\n\n tmp = ((left >>> 16) ^ right) & 0x0000ffff;\n right ^= tmp;\n left ^= (tmp << 16);\n\n tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n right ^= tmp;\n left ^= (tmp << 4);\n\n output[0] = left;\n output[1] = right;\n}\n\n/**\n * Deprecated. Instead, use:\n *\n * forge.cipher.createCipher('DES-<mode>', key);\n * forge.cipher.createDecipher('DES-<mode>', key);\n *\n * Creates a deprecated DES cipher object. This object's mode will default to\n * CBC (cipher-block-chaining).\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param options the options to use.\n * key the symmetric key to use (64 or 192 bits).\n * output the buffer to write to.\n * decrypt true for decryption, false for encryption.\n * mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nfunction _createCipher(options) {\n options = options || {};\n var mode = (options.mode || 'CBC').toUpperCase();\n var algorithm = 'DES-' + mode;\n\n var cipher;\n if(options.decrypt) {\n cipher = forge.cipher.createDecipher(algorithm, options.key);\n } else {\n cipher = forge.cipher.createCipher(algorithm, options.key);\n }\n\n // backwards compatible start API\n var start = cipher.start;\n cipher.start = function(iv, options) {\n // backwards compatibility: support second arg as output buffer\n var output = null;\n if(options instanceof forge.util.ByteBuffer) {\n output = options;\n options = {};\n }\n options = options || {};\n options.output = output;\n options.iv = iv;\n start.call(cipher, options);\n };\n\n return cipher;\n}\n","/**\n * Javascript implementation of basic RSA algorithms.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n *\n * The only algorithm currently supported for PKI is RSA.\n *\n * An RSA key is often stored in ASN.1 DER format. The SubjectPublicKeyInfo\n * ASN.1 structure is composed of an algorithm of type AlgorithmIdentifier\n * and a subjectPublicKey of type bit string.\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of RSA, there aren't any.\n *\n * SubjectPublicKeyInfo ::= SEQUENCE {\n * algorithm AlgorithmIdentifier,\n * subjectPublicKey BIT STRING\n * }\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * For an RSA public key, the subjectPublicKey is:\n *\n * RSAPublicKey ::= SEQUENCE {\n * modulus INTEGER, -- n\n * publicExponent INTEGER -- e\n * }\n *\n * PrivateKeyInfo ::= SEQUENCE {\n * version Version,\n * privateKeyAlgorithm PrivateKeyAlgorithmIdentifier,\n * privateKey PrivateKey,\n * attributes [0] IMPLICIT Attributes OPTIONAL\n * }\n *\n * Version ::= INTEGER\n * PrivateKeyAlgorithmIdentifier ::= AlgorithmIdentifier\n * PrivateKey ::= OCTET STRING\n * Attributes ::= SET OF Attribute\n *\n * An RSA private key as the following structure:\n *\n * RSAPrivateKey ::= SEQUENCE {\n * version Version,\n * modulus INTEGER, -- n\n * publicExponent INTEGER, -- e\n * privateExponent INTEGER, -- d\n * prime1 INTEGER, -- p\n * prime2 INTEGER, -- q\n * exponent1 INTEGER, -- d mod (p-1)\n * exponent2 INTEGER, -- d mod (q-1)\n * coefficient INTEGER -- (inverse of q) mod p\n * }\n *\n * Version ::= INTEGER\n *\n * The OID for the RSA key algorithm is: 1.2.840.113549.1.1.1\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./jsbn');\nrequire('./oids');\nrequire('./pkcs1');\nrequire('./prime');\nrequire('./random');\nrequire('./util');\n\nif(typeof BigInteger === 'undefined') {\n var BigInteger = forge.jsbn.BigInteger;\n}\n\nvar _crypto = forge.util.isNodejs ? require('crypto') : null;\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for util API\nvar util = forge.util;\n\n/*\n * RSA encryption and decryption, see RFC 2313.\n */\nforge.pki = forge.pki || {};\nmodule.exports = forge.pki.rsa = forge.rsa = forge.rsa || {};\nvar pki = forge.pki;\n\n// for finding primes, which are 30k+i for i = 1, 7, 11, 13, 17, 19, 23, 29\nvar GCD_30_DELTA = [6, 4, 2, 4, 2, 4, 6, 2];\n\n// validator for a PrivateKeyInfo structure\nvar privateKeyValidator = {\n // PrivateKeyInfo\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // Version (INTEGER)\n name: 'PrivateKeyInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyVersion'\n }, {\n // privateKeyAlgorithm\n name: 'PrivateKeyInfo.privateKeyAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'privateKeyOid'\n }]\n }, {\n // PrivateKey\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'privateKey'\n }]\n};\n\n// validator for an RSA private key\nvar rsaPrivateKeyValidator = {\n // RSAPrivateKey\n name: 'RSAPrivateKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // Version (INTEGER)\n name: 'RSAPrivateKey.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyVersion'\n }, {\n // modulus (n)\n name: 'RSAPrivateKey.modulus',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyModulus'\n }, {\n // publicExponent (e)\n name: 'RSAPrivateKey.publicExponent',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPublicExponent'\n }, {\n // privateExponent (d)\n name: 'RSAPrivateKey.privateExponent',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPrivateExponent'\n }, {\n // prime1 (p)\n name: 'RSAPrivateKey.prime1',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPrime1'\n }, {\n // prime2 (q)\n name: 'RSAPrivateKey.prime2',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyPrime2'\n }, {\n // exponent1 (d mod (p-1))\n name: 'RSAPrivateKey.exponent1',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyExponent1'\n }, {\n // exponent2 (d mod (q-1))\n name: 'RSAPrivateKey.exponent2',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyExponent2'\n }, {\n // coefficient ((inverse of q) mod p)\n name: 'RSAPrivateKey.coefficient',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyCoefficient'\n }]\n};\n\n// validator for an RSA public key\nvar rsaPublicKeyValidator = {\n // RSAPublicKey\n name: 'RSAPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // modulus (n)\n name: 'RSAPublicKey.modulus',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'publicKeyModulus'\n }, {\n // publicExponent (e)\n name: 'RSAPublicKey.exponent',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'publicKeyExponent'\n }]\n};\n\n// validator for an SubjectPublicKeyInfo structure\n// Note: Currently only works with an RSA public key\nvar publicKeyValidator = forge.pki.rsa.publicKeyValidator = {\n name: 'SubjectPublicKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'subjectPublicKeyInfo',\n value: [{\n name: 'SubjectPublicKeyInfo.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'publicKeyOid'\n }]\n }, {\n // subjectPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n value: [{\n // RSAPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n captureAsn1: 'rsaPublicKey'\n }]\n }]\n};\n\n/**\n * Wrap digest in DigestInfo object.\n *\n * This function implements EMSA-PKCS1-v1_5-ENCODE as per RFC 3447.\n *\n * DigestInfo ::= SEQUENCE {\n * digestAlgorithm DigestAlgorithmIdentifier,\n * digest Digest\n * }\n *\n * DigestAlgorithmIdentifier ::= AlgorithmIdentifier\n * Digest ::= OCTET STRING\n *\n * @param md the message digest object with the hash to sign.\n *\n * @return the encoded message (ready for RSA encrytion)\n */\nvar emsaPkcs1v15encode = function(md) {\n // get the oid for the algorithm\n var oid;\n if(md.algorithm in pki.oids) {\n oid = pki.oids[md.algorithm];\n } else {\n var error = new Error('Unknown message digest algorithm.');\n error.algorithm = md.algorithm;\n throw error;\n }\n var oidBytes = asn1.oidToDer(oid).getBytes();\n\n // create the digest info\n var digestInfo = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var digestAlgorithm = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n digestAlgorithm.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OID, false, oidBytes));\n digestAlgorithm.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.NULL, false, ''));\n var digest = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING,\n false, md.digest().getBytes());\n digestInfo.value.push(digestAlgorithm);\n digestInfo.value.push(digest);\n\n // encode digest info\n return asn1.toDer(digestInfo).getBytes();\n};\n\n/**\n * Performs x^c mod n (RSA encryption or decryption operation).\n *\n * @param x the number to raise and mod.\n * @param key the key to use.\n * @param pub true if the key is public, false if private.\n *\n * @return the result of x^c mod n.\n */\nvar _modPow = function(x, key, pub) {\n if(pub) {\n return x.modPow(key.e, key.n);\n }\n\n if(!key.p || !key.q) {\n // allow calculation without CRT params (slow)\n return x.modPow(key.d, key.n);\n }\n\n // pre-compute dP, dQ, and qInv if necessary\n if(!key.dP) {\n key.dP = key.d.mod(key.p.subtract(BigInteger.ONE));\n }\n if(!key.dQ) {\n key.dQ = key.d.mod(key.q.subtract(BigInteger.ONE));\n }\n if(!key.qInv) {\n key.qInv = key.q.modInverse(key.p);\n }\n\n /* Chinese remainder theorem (CRT) states:\n\n Suppose n1, n2, ..., nk are positive integers which are pairwise\n coprime (n1 and n2 have no common factors other than 1). For any\n integers x1, x2, ..., xk there exists an integer x solving the\n system of simultaneous congruences (where ~= means modularly\n congruent so a ~= b mod n means a mod n = b mod n):\n\n x ~= x1 mod n1\n x ~= x2 mod n2\n ...\n x ~= xk mod nk\n\n This system of congruences has a single simultaneous solution x\n between 0 and n - 1. Furthermore, each xk solution and x itself\n is congruent modulo the product n = n1*n2*...*nk.\n So x1 mod n = x2 mod n = xk mod n = x mod n.\n\n The single simultaneous solution x can be solved with the following\n equation:\n\n x = sum(xi*ri*si) mod n where ri = n/ni and si = ri^-1 mod ni.\n\n Where x is less than n, xi = x mod ni.\n\n For RSA we are only concerned with k = 2. The modulus n = pq, where\n p and q are coprime. The RSA decryption algorithm is:\n\n y = x^d mod n\n\n Given the above:\n\n x1 = x^d mod p\n r1 = n/p = q\n s1 = q^-1 mod p\n x2 = x^d mod q\n r2 = n/q = p\n s2 = p^-1 mod q\n\n So y = (x1r1s1 + x2r2s2) mod n\n = ((x^d mod p)q(q^-1 mod p) + (x^d mod q)p(p^-1 mod q)) mod n\n\n According to Fermat's Little Theorem, if the modulus P is prime,\n for any integer A not evenly divisible by P, A^(P-1) ~= 1 mod P.\n Since A is not divisible by P it follows that if:\n N ~= M mod (P - 1), then A^N mod P = A^M mod P. Therefore:\n\n A^N mod P = A^(M mod (P - 1)) mod P. (The latter takes less effort\n to calculate). In order to calculate x^d mod p more quickly the\n exponent d mod (p - 1) is stored in the RSA private key (the same\n is done for x^d mod q). These values are referred to as dP and dQ\n respectively. Therefore we now have:\n\n y = ((x^dP mod p)q(q^-1 mod p) + (x^dQ mod q)p(p^-1 mod q)) mod n\n\n Since we'll be reducing x^dP by modulo p (same for q) we can also\n reduce x by p (and q respectively) before hand. Therefore, let\n\n xp = ((x mod p)^dP mod p), and\n xq = ((x mod q)^dQ mod q), yielding:\n\n y = (xp*q*(q^-1 mod p) + xq*p*(p^-1 mod q)) mod n\n\n This can be further reduced to a simple algorithm that only\n requires 1 inverse (the q inverse is used) to be used and stored.\n The algorithm is called Garner's algorithm. If qInv is the\n inverse of q, we simply calculate:\n\n y = (qInv*(xp - xq) mod p) * q + xq\n\n However, there are two further complications. First, we need to\n ensure that xp > xq to prevent signed BigIntegers from being used\n so we add p until this is true (since we will be mod'ing with\n p anyway). Then, there is a known timing attack on algorithms\n using the CRT. To mitigate this risk, \"cryptographic blinding\"\n should be used. This requires simply generating a random number r\n between 0 and n-1 and its inverse and multiplying x by r^e before\n calculating y and then multiplying y by r^-1 afterwards. Note that\n r must be coprime with n (gcd(r, n) === 1) in order to have an\n inverse.\n */\n\n // cryptographic blinding\n var r;\n do {\n r = new BigInteger(\n forge.util.bytesToHex(forge.random.getBytes(key.n.bitLength() / 8)),\n 16);\n } while(r.compareTo(key.n) >= 0 || !r.gcd(key.n).equals(BigInteger.ONE));\n x = x.multiply(r.modPow(key.e, key.n)).mod(key.n);\n\n // calculate xp and xq\n var xp = x.mod(key.p).modPow(key.dP, key.p);\n var xq = x.mod(key.q).modPow(key.dQ, key.q);\n\n // xp must be larger than xq to avoid signed bit usage\n while(xp.compareTo(xq) < 0) {\n xp = xp.add(key.p);\n }\n\n // do last step\n var y = xp.subtract(xq)\n .multiply(key.qInv).mod(key.p)\n .multiply(key.q).add(xq);\n\n // remove effect of random for cryptographic blinding\n y = y.multiply(r.modInverse(key.n)).mod(key.n);\n\n return y;\n};\n\n/**\n * NOTE: THIS METHOD IS DEPRECATED, use 'sign' on a private key object or\n * 'encrypt' on a public key object instead.\n *\n * Performs RSA encryption.\n *\n * The parameter bt controls whether to put padding bytes before the\n * message passed in. Set bt to either true or false to disable padding\n * completely (in order to handle e.g. EMSA-PSS encoding seperately before),\n * signaling whether the encryption operation is a public key operation\n * (i.e. encrypting data) or not, i.e. private key operation (data signing).\n *\n * For PKCS#1 v1.5 padding pass in the block type to use, i.e. either 0x01\n * (for signing) or 0x02 (for encryption). The key operation mode (private\n * or public) is derived from this flag in that case).\n *\n * @param m the message to encrypt as a byte string.\n * @param key the RSA key to use.\n * @param bt for PKCS#1 v1.5 padding, the block type to use\n * (0x01 for private key, 0x02 for public),\n * to disable padding: true = public key, false = private key.\n *\n * @return the encrypted bytes as a string.\n */\npki.rsa.encrypt = function(m, key, bt) {\n var pub = bt;\n var eb;\n\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n if(bt !== false && bt !== true) {\n // legacy, default to PKCS#1 v1.5 padding\n pub = (bt === 0x02);\n eb = _encodePkcs1_v1_5(m, key, bt);\n } else {\n eb = forge.util.createBuffer();\n eb.putBytes(m);\n }\n\n // load encryption block as big integer 'x'\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var x = new BigInteger(eb.toHex(), 16);\n\n // do RSA encryption\n var y = _modPow(x, key, pub);\n\n // convert y into the encrypted data byte string, if y is shorter in\n // bytes than k, then prepend zero bytes to fill up ed\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var yhex = y.toString(16);\n var ed = forge.util.createBuffer();\n var zeros = k - Math.ceil(yhex.length / 2);\n while(zeros > 0) {\n ed.putByte(0x00);\n --zeros;\n }\n ed.putBytes(forge.util.hexToBytes(yhex));\n return ed.getBytes();\n};\n\n/**\n * NOTE: THIS METHOD IS DEPRECATED, use 'decrypt' on a private key object or\n * 'verify' on a public key object instead.\n *\n * Performs RSA decryption.\n *\n * The parameter ml controls whether to apply PKCS#1 v1.5 padding\n * or not. Set ml = false to disable padding removal completely\n * (in order to handle e.g. EMSA-PSS later on) and simply pass back\n * the RSA encryption block.\n *\n * @param ed the encrypted data to decrypt in as a byte string.\n * @param key the RSA key to use.\n * @param pub true for a public key operation, false for private.\n * @param ml the message length, if known, false to disable padding.\n *\n * @return the decrypted message as a byte string.\n */\npki.rsa.decrypt = function(ed, key, pub, ml) {\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n // error if the length of the encrypted data ED is not k\n if(ed.length !== k) {\n var error = new Error('Encrypted message length is invalid.');\n error.length = ed.length;\n error.expected = k;\n throw error;\n }\n\n // convert encrypted data into a big integer\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var y = new BigInteger(forge.util.createBuffer(ed).toHex(), 16);\n\n // y must be less than the modulus or it wasn't the result of\n // a previous mod operation (encryption) using that modulus\n if(y.compareTo(key.n) >= 0) {\n throw new Error('Encrypted message is invalid.');\n }\n\n // do RSA decryption\n var x = _modPow(y, key, pub);\n\n // create the encryption block, if x is shorter in bytes than k, then\n // prepend zero bytes to fill up eb\n // FIXME: hex conversion inefficient, get BigInteger w/byte strings\n var xhex = x.toString(16);\n var eb = forge.util.createBuffer();\n var zeros = k - Math.ceil(xhex.length / 2);\n while(zeros > 0) {\n eb.putByte(0x00);\n --zeros;\n }\n eb.putBytes(forge.util.hexToBytes(xhex));\n\n if(ml !== false) {\n // legacy, default to PKCS#1 v1.5 padding\n return _decodePkcs1_v1_5(eb.getBytes(), key, pub);\n }\n\n // return message\n return eb.getBytes();\n};\n\n/**\n * Creates an RSA key-pair generation state object. It is used to allow\n * key-generation to be performed in steps. It also allows for a UI to\n * display progress updates.\n *\n * @param bits the size for the private key in bits, defaults to 2048.\n * @param e the public exponent to use, defaults to 65537 (0x10001).\n * @param [options] the options to use.\n * prng a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\".\n * algorithm the algorithm to use (default: 'PRIMEINC').\n *\n * @return the state object to use to generate the key-pair.\n */\npki.rsa.createKeyPairGenerationState = function(bits, e, options) {\n // TODO: migrate step-based prime generation code to forge.prime\n\n // set default bits\n if(typeof(bits) === 'string') {\n bits = parseInt(bits, 10);\n }\n bits = bits || 2048;\n\n // create prng with api that matches BigInteger secure random\n options = options || {};\n var prng = options.prng || forge.random;\n var rng = {\n // x is an array to fill with bytes\n nextBytes: function(x) {\n var b = prng.getBytesSync(x.length);\n for(var i = 0; i < x.length; ++i) {\n x[i] = b.charCodeAt(i);\n }\n }\n };\n\n var algorithm = options.algorithm || 'PRIMEINC';\n\n // create PRIMEINC algorithm state\n var rval;\n if(algorithm === 'PRIMEINC') {\n rval = {\n algorithm: algorithm,\n state: 0,\n bits: bits,\n rng: rng,\n eInt: e || 65537,\n e: new BigInteger(null),\n p: null,\n q: null,\n qBits: bits >> 1,\n pBits: bits - (bits >> 1),\n pqState: 0,\n num: null,\n keys: null\n };\n rval.e.fromInt(rval.eInt);\n } else {\n throw new Error('Invalid key generation algorithm: ' + algorithm);\n }\n\n return rval;\n};\n\n/**\n * Attempts to runs the key-generation algorithm for at most n seconds\n * (approximately) using the given state. When key-generation has completed,\n * the keys will be stored in state.keys.\n *\n * To use this function to update a UI while generating a key or to prevent\n * causing browser lockups/warnings, set \"n\" to a value other than 0. A\n * simple pattern for generating a key and showing a progress indicator is:\n *\n * var state = pki.rsa.createKeyPairGenerationState(2048);\n * var step = function() {\n * // step key-generation, run algorithm for 100 ms, repeat\n * if(!forge.pki.rsa.stepKeyPairGenerationState(state, 100)) {\n * setTimeout(step, 1);\n * } else {\n * // key-generation complete\n * // TODO: turn off progress indicator here\n * // TODO: use the generated key-pair in \"state.keys\"\n * }\n * };\n * // TODO: turn on progress indicator here\n * setTimeout(step, 0);\n *\n * @param state the state to use.\n * @param n the maximum number of milliseconds to run the algorithm for, 0\n * to run the algorithm to completion.\n *\n * @return true if the key-generation completed, false if not.\n */\npki.rsa.stepKeyPairGenerationState = function(state, n) {\n // set default algorithm if not set\n if(!('algorithm' in state)) {\n state.algorithm = 'PRIMEINC';\n }\n\n // TODO: migrate step-based prime generation code to forge.prime\n // TODO: abstract as PRIMEINC algorithm\n\n // do key generation (based on Tom Wu's rsa.js, see jsbn.js license)\n // with some minor optimizations and designed to run in steps\n\n // local state vars\n var THIRTY = new BigInteger(null);\n THIRTY.fromInt(30);\n var deltaIdx = 0;\n var op_or = function(x, y) {return x | y;};\n\n // keep stepping until time limit is reached or done\n var t1 = +new Date();\n var t2;\n var total = 0;\n while(state.keys === null && (n <= 0 || total < n)) {\n // generate p or q\n if(state.state === 0) {\n /* Note: All primes are of the form:\n\n 30k+i, for i < 30 and gcd(30, i)=1, where there are 8 values for i\n\n When we generate a random number, we always align it at 30k + 1. Each\n time the number is determined not to be prime we add to get to the\n next 'i', eg: if the number was at 30k + 1 we add 6. */\n var bits = (state.p === null) ? state.pBits : state.qBits;\n var bits1 = bits - 1;\n\n // get a random number\n if(state.pqState === 0) {\n state.num = new BigInteger(bits, state.rng);\n // force MSB set\n if(!state.num.testBit(bits1)) {\n state.num.bitwiseTo(\n BigInteger.ONE.shiftLeft(bits1), op_or, state.num);\n }\n // align number on 30k+1 boundary\n state.num.dAddOffset(31 - state.num.mod(THIRTY).byteValue(), 0);\n deltaIdx = 0;\n\n ++state.pqState;\n } else if(state.pqState === 1) {\n // try to make the number a prime\n if(state.num.bitLength() > bits) {\n // overflow, try again\n state.pqState = 0;\n // do primality test\n } else if(state.num.isProbablePrime(\n _getMillerRabinTests(state.num.bitLength()))) {\n ++state.pqState;\n } else {\n // get next potential prime\n state.num.dAddOffset(GCD_30_DELTA[deltaIdx++ % 8], 0);\n }\n } else if(state.pqState === 2) {\n // ensure number is coprime with e\n state.pqState =\n (state.num.subtract(BigInteger.ONE).gcd(state.e)\n .compareTo(BigInteger.ONE) === 0) ? 3 : 0;\n } else if(state.pqState === 3) {\n // store p or q\n state.pqState = 0;\n if(state.p === null) {\n state.p = state.num;\n } else {\n state.q = state.num;\n }\n\n // advance state if both p and q are ready\n if(state.p !== null && state.q !== null) {\n ++state.state;\n }\n state.num = null;\n }\n } else if(state.state === 1) {\n // ensure p is larger than q (swap them if not)\n if(state.p.compareTo(state.q) < 0) {\n state.num = state.p;\n state.p = state.q;\n state.q = state.num;\n }\n ++state.state;\n } else if(state.state === 2) {\n // compute phi: (p - 1)(q - 1) (Euler's totient function)\n state.p1 = state.p.subtract(BigInteger.ONE);\n state.q1 = state.q.subtract(BigInteger.ONE);\n state.phi = state.p1.multiply(state.q1);\n ++state.state;\n } else if(state.state === 3) {\n // ensure e and phi are coprime\n if(state.phi.gcd(state.e).compareTo(BigInteger.ONE) === 0) {\n // phi and e are coprime, advance\n ++state.state;\n } else {\n // phi and e aren't coprime, so generate a new p and q\n state.p = null;\n state.q = null;\n state.state = 0;\n }\n } else if(state.state === 4) {\n // create n, ensure n is has the right number of bits\n state.n = state.p.multiply(state.q);\n\n // ensure n is right number of bits\n if(state.n.bitLength() === state.bits) {\n // success, advance\n ++state.state;\n } else {\n // failed, get new q\n state.q = null;\n state.state = 0;\n }\n } else if(state.state === 5) {\n // set keys\n var d = state.e.modInverse(state.phi);\n state.keys = {\n privateKey: pki.rsa.setPrivateKey(\n state.n, state.e, d, state.p, state.q,\n d.mod(state.p1), d.mod(state.q1),\n state.q.modInverse(state.p)),\n publicKey: pki.rsa.setPublicKey(state.n, state.e)\n };\n }\n\n // update timing\n t2 = +new Date();\n total += t2 - t1;\n t1 = t2;\n }\n\n return state.keys !== null;\n};\n\n/**\n * Generates an RSA public-private key pair in a single call.\n *\n * To generate a key-pair in steps (to allow for progress updates and to\n * prevent blocking or warnings in slow browsers) then use the key-pair\n * generation state functions.\n *\n * To generate a key-pair asynchronously (either through web-workers, if\n * available, or by breaking up the work on the main thread), pass a\n * callback function.\n *\n * @param [bits] the size for the private key in bits, defaults to 2048.\n * @param [e] the public exponent to use, defaults to 65537.\n * @param [options] options for key-pair generation, if given then 'bits'\n * and 'e' must *not* be given:\n * bits the size for the private key in bits, (default: 2048).\n * e the public exponent to use, (default: 65537 (0x10001)).\n * workerScript the worker script URL.\n * workers the number of web workers (if supported) to use,\n * (default: 2).\n * workLoad the size of the work load, ie: number of possible prime\n * numbers for each web worker to check per work assignment,\n * (default: 100).\n * prng a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\". Disables use of native APIs.\n * algorithm the algorithm to use (default: 'PRIMEINC').\n * @param [callback(err, keypair)] called once the operation completes.\n *\n * @return an object with privateKey and publicKey properties.\n */\npki.rsa.generateKeyPair = function(bits, e, options, callback) {\n // (bits), (options), (callback)\n if(arguments.length === 1) {\n if(typeof bits === 'object') {\n options = bits;\n bits = undefined;\n } else if(typeof bits === 'function') {\n callback = bits;\n bits = undefined;\n }\n } else if(arguments.length === 2) {\n // (bits, e), (bits, options), (bits, callback), (options, callback)\n if(typeof bits === 'number') {\n if(typeof e === 'function') {\n callback = e;\n e = undefined;\n } else if(typeof e !== 'number') {\n options = e;\n e = undefined;\n }\n } else {\n options = bits;\n callback = e;\n bits = undefined;\n e = undefined;\n }\n } else if(arguments.length === 3) {\n // (bits, e, options), (bits, e, callback), (bits, options, callback)\n if(typeof e === 'number') {\n if(typeof options === 'function') {\n callback = options;\n options = undefined;\n }\n } else {\n callback = options;\n options = e;\n e = undefined;\n }\n }\n options = options || {};\n if(bits === undefined) {\n bits = options.bits || 2048;\n }\n if(e === undefined) {\n e = options.e || 0x10001;\n }\n\n // use native code if permitted, available, and parameters are acceptable\n if(!forge.options.usePureJavaScript && !options.prng &&\n bits >= 256 && bits <= 16384 && (e === 0x10001 || e === 3)) {\n if(callback) {\n // try native async\n if(_detectNodeCrypto('generateKeyPair')) {\n return _crypto.generateKeyPair('rsa', {\n modulusLength: bits,\n publicExponent: e,\n publicKeyEncoding: {\n type: 'spki',\n format: 'pem'\n },\n privateKeyEncoding: {\n type: 'pkcs8',\n format: 'pem'\n }\n }, function(err, pub, priv) {\n if(err) {\n return callback(err);\n }\n callback(null, {\n privateKey: pki.privateKeyFromPem(priv),\n publicKey: pki.publicKeyFromPem(pub)\n });\n });\n }\n if(_detectSubtleCrypto('generateKey') &&\n _detectSubtleCrypto('exportKey')) {\n // use standard native generateKey\n return util.globalScope.crypto.subtle.generateKey({\n name: 'RSASSA-PKCS1-v1_5',\n modulusLength: bits,\n publicExponent: _intToUint8Array(e),\n hash: {name: 'SHA-256'}\n }, true /* key can be exported*/, ['sign', 'verify'])\n .then(function(pair) {\n return util.globalScope.crypto.subtle.exportKey(\n 'pkcs8', pair.privateKey);\n // avoiding catch(function(err) {...}) to support IE <= 8\n }).then(undefined, function(err) {\n callback(err);\n }).then(function(pkcs8) {\n if(pkcs8) {\n var privateKey = pki.privateKeyFromAsn1(\n asn1.fromDer(forge.util.createBuffer(pkcs8)));\n callback(null, {\n privateKey: privateKey,\n publicKey: pki.setRsaPublicKey(privateKey.n, privateKey.e)\n });\n }\n });\n }\n if(_detectSubtleMsCrypto('generateKey') &&\n _detectSubtleMsCrypto('exportKey')) {\n var genOp = util.globalScope.msCrypto.subtle.generateKey({\n name: 'RSASSA-PKCS1-v1_5',\n modulusLength: bits,\n publicExponent: _intToUint8Array(e),\n hash: {name: 'SHA-256'}\n }, true /* key can be exported*/, ['sign', 'verify']);\n genOp.oncomplete = function(e) {\n var pair = e.target.result;\n var exportOp = util.globalScope.msCrypto.subtle.exportKey(\n 'pkcs8', pair.privateKey);\n exportOp.oncomplete = function(e) {\n var pkcs8 = e.target.result;\n var privateKey = pki.privateKeyFromAsn1(\n asn1.fromDer(forge.util.createBuffer(pkcs8)));\n callback(null, {\n privateKey: privateKey,\n publicKey: pki.setRsaPublicKey(privateKey.n, privateKey.e)\n });\n };\n exportOp.onerror = function(err) {\n callback(err);\n };\n };\n genOp.onerror = function(err) {\n callback(err);\n };\n return;\n }\n } else {\n // try native sync\n if(_detectNodeCrypto('generateKeyPairSync')) {\n var keypair = _crypto.generateKeyPairSync('rsa', {\n modulusLength: bits,\n publicExponent: e,\n publicKeyEncoding: {\n type: 'spki',\n format: 'pem'\n },\n privateKeyEncoding: {\n type: 'pkcs8',\n format: 'pem'\n }\n });\n return {\n privateKey: pki.privateKeyFromPem(keypair.privateKey),\n publicKey: pki.publicKeyFromPem(keypair.publicKey)\n };\n }\n }\n }\n\n // use JavaScript implementation\n var state = pki.rsa.createKeyPairGenerationState(bits, e, options);\n if(!callback) {\n pki.rsa.stepKeyPairGenerationState(state, 0);\n return state.keys;\n }\n _generateKeyPair(state, options, callback);\n};\n\n/**\n * Sets an RSA public key from BigIntegers modulus and exponent.\n *\n * @param n the modulus.\n * @param e the exponent.\n *\n * @return the public key.\n */\npki.setRsaPublicKey = pki.rsa.setPublicKey = function(n, e) {\n var key = {\n n: n,\n e: e\n };\n\n /**\n * Encrypts the given data with this public key. Newer applications\n * should use the 'RSA-OAEP' decryption scheme, 'RSAES-PKCS1-V1_5' is for\n * legacy applications.\n *\n * @param data the byte string to encrypt.\n * @param scheme the encryption scheme to use:\n * 'RSAES-PKCS1-V1_5' (default),\n * 'RSA-OAEP',\n * 'RAW', 'NONE', or null to perform raw RSA encryption,\n * an object with an 'encode' property set to a function\n * with the signature 'function(data, key)' that returns\n * a binary-encoded string representing the encoded data.\n * @param schemeOptions any scheme-specific options.\n *\n * @return the encrypted byte string.\n */\n key.encrypt = function(data, scheme, schemeOptions) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSAES-PKCS1-V1_5';\n }\n\n if(scheme === 'RSAES-PKCS1-V1_5') {\n scheme = {\n encode: function(m, key, pub) {\n return _encodePkcs1_v1_5(m, key, 0x02).getBytes();\n }\n };\n } else if(scheme === 'RSA-OAEP' || scheme === 'RSAES-OAEP') {\n scheme = {\n encode: function(m, key) {\n return forge.pkcs1.encode_rsa_oaep(key, m, schemeOptions);\n }\n };\n } else if(['RAW', 'NONE', 'NULL', null].indexOf(scheme) !== -1) {\n scheme = {encode: function(e) {return e;}};\n } else if(typeof scheme === 'string') {\n throw new Error('Unsupported encryption scheme: \"' + scheme + '\".');\n }\n\n // do scheme-based encoding then rsa encryption\n var e = scheme.encode(data, key, true);\n return pki.rsa.encrypt(e, key, true);\n };\n\n /**\n * Verifies the given signature against the given digest.\n *\n * PKCS#1 supports multiple (currently two) signature schemes:\n * RSASSA-PKCS1-V1_5 and RSASSA-PSS.\n *\n * By default this implementation uses the \"old scheme\", i.e.\n * RSASSA-PKCS1-V1_5, in which case once RSA-decrypted, the\n * signature is an OCTET STRING that holds a DigestInfo.\n *\n * DigestInfo ::= SEQUENCE {\n * digestAlgorithm DigestAlgorithmIdentifier,\n * digest Digest\n * }\n * DigestAlgorithmIdentifier ::= AlgorithmIdentifier\n * Digest ::= OCTET STRING\n *\n * To perform PSS signature verification, provide an instance\n * of Forge PSS object as the scheme parameter.\n *\n * @param digest the message digest hash to compare against the signature,\n * as a binary-encoded string.\n * @param signature the signature to verify, as a binary-encoded string.\n * @param scheme signature verification scheme to use:\n * 'RSASSA-PKCS1-V1_5' or undefined for RSASSA PKCS#1 v1.5,\n * a Forge PSS object for RSASSA-PSS,\n * 'NONE' or null for none, DigestInfo will not be expected, but\n * PKCS#1 v1.5 padding will still be used.\n *\n * @return true if the signature was verified, false if not.\n */\n key.verify = function(digest, signature, scheme) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSASSA-PKCS1-V1_5';\n }\n\n if(scheme === 'RSASSA-PKCS1-V1_5') {\n scheme = {\n verify: function(digest, d) {\n // remove padding\n d = _decodePkcs1_v1_5(d, key, true);\n // d is ASN.1 BER-encoded DigestInfo\n var obj = asn1.fromDer(d);\n // compare the given digest to the decrypted one\n return digest === obj.value[1].value;\n }\n };\n } else if(scheme === 'NONE' || scheme === 'NULL' || scheme === null) {\n scheme = {\n verify: function(digest, d) {\n // remove padding\n d = _decodePkcs1_v1_5(d, key, true);\n return digest === d;\n }\n };\n }\n\n // do rsa decryption w/o any decoding, then verify -- which does decoding\n var d = pki.rsa.decrypt(signature, key, true, false);\n return scheme.verify(digest, d, key.n.bitLength());\n };\n\n return key;\n};\n\n/**\n * Sets an RSA private key from BigIntegers modulus, exponent, primes,\n * prime exponents, and modular multiplicative inverse.\n *\n * @param n the modulus.\n * @param e the public exponent.\n * @param d the private exponent ((inverse of e) mod n).\n * @param p the first prime.\n * @param q the second prime.\n * @param dP exponent1 (d mod (p-1)).\n * @param dQ exponent2 (d mod (q-1)).\n * @param qInv ((inverse of q) mod p)\n *\n * @return the private key.\n */\npki.setRsaPrivateKey = pki.rsa.setPrivateKey = function(\n n, e, d, p, q, dP, dQ, qInv) {\n var key = {\n n: n,\n e: e,\n d: d,\n p: p,\n q: q,\n dP: dP,\n dQ: dQ,\n qInv: qInv\n };\n\n /**\n * Decrypts the given data with this private key. The decryption scheme\n * must match the one used to encrypt the data.\n *\n * @param data the byte string to decrypt.\n * @param scheme the decryption scheme to use:\n * 'RSAES-PKCS1-V1_5' (default),\n * 'RSA-OAEP',\n * 'RAW', 'NONE', or null to perform raw RSA decryption.\n * @param schemeOptions any scheme-specific options.\n *\n * @return the decrypted byte string.\n */\n key.decrypt = function(data, scheme, schemeOptions) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSAES-PKCS1-V1_5';\n }\n\n // do rsa decryption w/o any decoding\n var d = pki.rsa.decrypt(data, key, false, false);\n\n if(scheme === 'RSAES-PKCS1-V1_5') {\n scheme = {decode: _decodePkcs1_v1_5};\n } else if(scheme === 'RSA-OAEP' || scheme === 'RSAES-OAEP') {\n scheme = {\n decode: function(d, key) {\n return forge.pkcs1.decode_rsa_oaep(key, d, schemeOptions);\n }\n };\n } else if(['RAW', 'NONE', 'NULL', null].indexOf(scheme) !== -1) {\n scheme = {decode: function(d) {return d;}};\n } else {\n throw new Error('Unsupported encryption scheme: \"' + scheme + '\".');\n }\n\n // decode according to scheme\n return scheme.decode(d, key, false);\n };\n\n /**\n * Signs the given digest, producing a signature.\n *\n * PKCS#1 supports multiple (currently two) signature schemes:\n * RSASSA-PKCS1-V1_5 and RSASSA-PSS.\n *\n * By default this implementation uses the \"old scheme\", i.e.\n * RSASSA-PKCS1-V1_5. In order to generate a PSS signature, provide\n * an instance of Forge PSS object as the scheme parameter.\n *\n * @param md the message digest object with the hash to sign.\n * @param scheme the signature scheme to use:\n * 'RSASSA-PKCS1-V1_5' or undefined for RSASSA PKCS#1 v1.5,\n * a Forge PSS object for RSASSA-PSS,\n * 'NONE' or null for none, DigestInfo will not be used but\n * PKCS#1 v1.5 padding will still be used.\n *\n * @return the signature as a byte string.\n */\n key.sign = function(md, scheme) {\n /* Note: The internal implementation of RSA operations is being\n transitioned away from a PKCS#1 v1.5 hard-coded scheme. Some legacy\n code like the use of an encoding block identifier 'bt' will eventually\n be removed. */\n\n // private key operation\n var bt = false;\n\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n }\n\n if(scheme === undefined || scheme === 'RSASSA-PKCS1-V1_5') {\n scheme = {encode: emsaPkcs1v15encode};\n bt = 0x01;\n } else if(scheme === 'NONE' || scheme === 'NULL' || scheme === null) {\n scheme = {encode: function() {return md;}};\n bt = 0x01;\n }\n\n // encode and then encrypt\n var d = scheme.encode(md, key.n.bitLength());\n return pki.rsa.encrypt(d, key, bt);\n };\n\n return key;\n};\n\n/**\n * Wraps an RSAPrivateKey ASN.1 object in an ASN.1 PrivateKeyInfo object.\n *\n * @param rsaKey the ASN.1 RSAPrivateKey.\n *\n * @return the ASN.1 PrivateKeyInfo.\n */\npki.wrapRsaPrivateKey = function(rsaKey) {\n // PrivateKeyInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version (0)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(0).getBytes()),\n // privateKeyAlgorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.rsaEncryption).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // PrivateKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n asn1.toDer(rsaKey).getBytes())\n ]);\n};\n\n/**\n * Converts a private key from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a PrivateKeyInfo containing an\n * RSAPrivateKey or an RSAPrivateKey.\n *\n * @return the private key.\n */\npki.privateKeyFromAsn1 = function(obj) {\n // get PrivateKeyInfo\n var capture = {};\n var errors = [];\n if(asn1.validate(obj, privateKeyValidator, capture, errors)) {\n obj = asn1.fromDer(forge.util.createBuffer(capture.privateKey));\n }\n\n // get RSAPrivateKey\n capture = {};\n errors = [];\n if(!asn1.validate(obj, rsaPrivateKeyValidator, capture, errors)) {\n var error = new Error('Cannot read private key. ' +\n 'ASN.1 object does not contain an RSAPrivateKey.');\n error.errors = errors;\n throw error;\n }\n\n // Note: Version is currently ignored.\n // capture.privateKeyVersion\n // FIXME: inefficient, get a BigInteger that uses byte strings\n var n, e, d, p, q, dP, dQ, qInv;\n n = forge.util.createBuffer(capture.privateKeyModulus).toHex();\n e = forge.util.createBuffer(capture.privateKeyPublicExponent).toHex();\n d = forge.util.createBuffer(capture.privateKeyPrivateExponent).toHex();\n p = forge.util.createBuffer(capture.privateKeyPrime1).toHex();\n q = forge.util.createBuffer(capture.privateKeyPrime2).toHex();\n dP = forge.util.createBuffer(capture.privateKeyExponent1).toHex();\n dQ = forge.util.createBuffer(capture.privateKeyExponent2).toHex();\n qInv = forge.util.createBuffer(capture.privateKeyCoefficient).toHex();\n\n // set private key\n return pki.setRsaPrivateKey(\n new BigInteger(n, 16),\n new BigInteger(e, 16),\n new BigInteger(d, 16),\n new BigInteger(p, 16),\n new BigInteger(q, 16),\n new BigInteger(dP, 16),\n new BigInteger(dQ, 16),\n new BigInteger(qInv, 16));\n};\n\n/**\n * Converts a private key to an ASN.1 RSAPrivateKey.\n *\n * @param key the private key.\n *\n * @return the ASN.1 representation of an RSAPrivateKey.\n */\npki.privateKeyToAsn1 = pki.privateKeyToRSAPrivateKey = function(key) {\n // RSAPrivateKey\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version (0 = only 2 primes, 1 multiple primes)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(0).getBytes()),\n // modulus (n)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.n)),\n // publicExponent (e)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.e)),\n // privateExponent (d)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.d)),\n // privateKeyPrime1 (p)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.p)),\n // privateKeyPrime2 (q)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.q)),\n // privateKeyExponent1 (dP)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.dP)),\n // privateKeyExponent2 (dQ)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.dQ)),\n // coefficient (qInv)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.qInv))\n ]);\n};\n\n/**\n * Converts a public key from an ASN.1 SubjectPublicKeyInfo or RSAPublicKey.\n *\n * @param obj the asn1 representation of a SubjectPublicKeyInfo or RSAPublicKey.\n *\n * @return the public key.\n */\npki.publicKeyFromAsn1 = function(obj) {\n // get SubjectPublicKeyInfo\n var capture = {};\n var errors = [];\n if(asn1.validate(obj, publicKeyValidator, capture, errors)) {\n // get oid\n var oid = asn1.derToOid(capture.publicKeyOid);\n if(oid !== pki.oids.rsaEncryption) {\n var error = new Error('Cannot read public key. Unknown OID.');\n error.oid = oid;\n throw error;\n }\n obj = capture.rsaPublicKey;\n }\n\n // get RSA params\n errors = [];\n if(!asn1.validate(obj, rsaPublicKeyValidator, capture, errors)) {\n var error = new Error('Cannot read public key. ' +\n 'ASN.1 object does not contain an RSAPublicKey.');\n error.errors = errors;\n throw error;\n }\n\n // FIXME: inefficient, get a BigInteger that uses byte strings\n var n = forge.util.createBuffer(capture.publicKeyModulus).toHex();\n var e = forge.util.createBuffer(capture.publicKeyExponent).toHex();\n\n // set public key\n return pki.setRsaPublicKey(\n new BigInteger(n, 16),\n new BigInteger(e, 16));\n};\n\n/**\n * Converts a public key to an ASN.1 SubjectPublicKeyInfo.\n *\n * @param key the public key.\n *\n * @return the asn1 representation of a SubjectPublicKeyInfo.\n */\npki.publicKeyToAsn1 = pki.publicKeyToSubjectPublicKeyInfo = function(key) {\n // SubjectPublicKeyInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.rsaEncryption).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // subjectPublicKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false, [\n pki.publicKeyToRSAPublicKey(key)\n ])\n ]);\n};\n\n/**\n * Converts a public key to an ASN.1 RSAPublicKey.\n *\n * @param key the public key.\n *\n * @return the asn1 representation of a RSAPublicKey.\n */\npki.publicKeyToRSAPublicKey = function(key) {\n // RSAPublicKey\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // modulus (n)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.n)),\n // publicExponent (e)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n _bnToBytes(key.e))\n ]);\n};\n\n/**\n * Encodes a message using PKCS#1 v1.5 padding.\n *\n * @param m the message to encode.\n * @param key the RSA key to use.\n * @param bt the block type to use, i.e. either 0x01 (for signing) or 0x02\n * (for encryption).\n *\n * @return the padded byte buffer.\n */\nfunction _encodePkcs1_v1_5(m, key, bt) {\n var eb = forge.util.createBuffer();\n\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n /* use PKCS#1 v1.5 padding */\n if(m.length > (k - 11)) {\n var error = new Error('Message is too long for PKCS#1 v1.5 padding.');\n error.length = m.length;\n error.max = k - 11;\n throw error;\n }\n\n /* A block type BT, a padding string PS, and the data D shall be\n formatted into an octet string EB, the encryption block:\n\n EB = 00 || BT || PS || 00 || D\n\n The block type BT shall be a single octet indicating the structure of\n the encryption block. For this version of the document it shall have\n value 00, 01, or 02. For a private-key operation, the block type\n shall be 00 or 01. For a public-key operation, it shall be 02.\n\n The padding string PS shall consist of k-3-||D|| octets. For block\n type 00, the octets shall have value 00; for block type 01, they\n shall have value FF; and for block type 02, they shall be\n pseudorandomly generated and nonzero. This makes the length of the\n encryption block EB equal to k. */\n\n // build the encryption block\n eb.putByte(0x00);\n eb.putByte(bt);\n\n // create the padding\n var padNum = k - 3 - m.length;\n var padByte;\n // private key op\n if(bt === 0x00 || bt === 0x01) {\n padByte = (bt === 0x00) ? 0x00 : 0xFF;\n for(var i = 0; i < padNum; ++i) {\n eb.putByte(padByte);\n }\n } else {\n // public key op\n // pad with random non-zero values\n while(padNum > 0) {\n var numZeros = 0;\n var padBytes = forge.random.getBytes(padNum);\n for(var i = 0; i < padNum; ++i) {\n padByte = padBytes.charCodeAt(i);\n if(padByte === 0) {\n ++numZeros;\n } else {\n eb.putByte(padByte);\n }\n }\n padNum = numZeros;\n }\n }\n\n // zero followed by message\n eb.putByte(0x00);\n eb.putBytes(m);\n\n return eb;\n}\n\n/**\n * Decodes a message using PKCS#1 v1.5 padding.\n *\n * @param em the message to decode.\n * @param key the RSA key to use.\n * @param pub true if the key is a public key, false if it is private.\n * @param ml the message length, if specified.\n *\n * @return the decoded bytes.\n */\nfunction _decodePkcs1_v1_5(em, key, pub, ml) {\n // get the length of the modulus in bytes\n var k = Math.ceil(key.n.bitLength() / 8);\n\n /* It is an error if any of the following conditions occurs:\n\n 1. The encryption block EB cannot be parsed unambiguously.\n 2. The padding string PS consists of fewer than eight octets\n or is inconsisent with the block type BT.\n 3. The decryption process is a public-key operation and the block\n type BT is not 00 or 01, or the decryption process is a\n private-key operation and the block type is not 02.\n */\n\n // parse the encryption block\n var eb = forge.util.createBuffer(em);\n var first = eb.getByte();\n var bt = eb.getByte();\n if(first !== 0x00 ||\n (pub && bt !== 0x00 && bt !== 0x01) ||\n (!pub && bt != 0x02) ||\n (pub && bt === 0x00 && typeof(ml) === 'undefined')) {\n throw new Error('Encryption block is invalid.');\n }\n\n var padNum = 0;\n if(bt === 0x00) {\n // check all padding bytes for 0x00\n padNum = k - 3 - ml;\n for(var i = 0; i < padNum; ++i) {\n if(eb.getByte() !== 0x00) {\n throw new Error('Encryption block is invalid.');\n }\n }\n } else if(bt === 0x01) {\n // find the first byte that isn't 0xFF, should be after all padding\n padNum = 0;\n while(eb.length() > 1) {\n if(eb.getByte() !== 0xFF) {\n --eb.read;\n break;\n }\n ++padNum;\n }\n } else if(bt === 0x02) {\n // look for 0x00 byte\n padNum = 0;\n while(eb.length() > 1) {\n if(eb.getByte() === 0x00) {\n --eb.read;\n break;\n }\n ++padNum;\n }\n }\n\n // zero must be 0x00 and padNum must be (k - 3 - message length)\n var zero = eb.getByte();\n if(zero !== 0x00 || padNum !== (k - 3 - eb.length())) {\n throw new Error('Encryption block is invalid.');\n }\n\n return eb.getBytes();\n}\n\n/**\n * Runs the key-generation algorithm asynchronously, either in the background\n * via Web Workers, or using the main thread and setImmediate.\n *\n * @param state the key-pair generation state.\n * @param [options] options for key-pair generation:\n * workerScript the worker script URL.\n * workers the number of web workers (if supported) to use,\n * (default: 2, -1 to use estimated cores minus one).\n * workLoad the size of the work load, ie: number of possible prime\n * numbers for each web worker to check per work assignment,\n * (default: 100).\n * @param callback(err, keypair) called once the operation completes.\n */\nfunction _generateKeyPair(state, options, callback) {\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n\n var opts = {\n algorithm: {\n name: options.algorithm || 'PRIMEINC',\n options: {\n workers: options.workers || 2,\n workLoad: options.workLoad || 100,\n workerScript: options.workerScript\n }\n }\n };\n if('prng' in options) {\n opts.prng = options.prng;\n }\n\n generate();\n\n function generate() {\n // find p and then q (done in series to simplify)\n getPrime(state.pBits, function(err, num) {\n if(err) {\n return callback(err);\n }\n state.p = num;\n if(state.q !== null) {\n return finish(err, state.q);\n }\n getPrime(state.qBits, finish);\n });\n }\n\n function getPrime(bits, callback) {\n forge.prime.generateProbablePrime(bits, opts, callback);\n }\n\n function finish(err, num) {\n if(err) {\n return callback(err);\n }\n\n // set q\n state.q = num;\n\n // ensure p is larger than q (swap them if not)\n if(state.p.compareTo(state.q) < 0) {\n var tmp = state.p;\n state.p = state.q;\n state.q = tmp;\n }\n\n // ensure p is coprime with e\n if(state.p.subtract(BigInteger.ONE).gcd(state.e)\n .compareTo(BigInteger.ONE) !== 0) {\n state.p = null;\n generate();\n return;\n }\n\n // ensure q is coprime with e\n if(state.q.subtract(BigInteger.ONE).gcd(state.e)\n .compareTo(BigInteger.ONE) !== 0) {\n state.q = null;\n getPrime(state.qBits, finish);\n return;\n }\n\n // compute phi: (p - 1)(q - 1) (Euler's totient function)\n state.p1 = state.p.subtract(BigInteger.ONE);\n state.q1 = state.q.subtract(BigInteger.ONE);\n state.phi = state.p1.multiply(state.q1);\n\n // ensure e and phi are coprime\n if(state.phi.gcd(state.e).compareTo(BigInteger.ONE) !== 0) {\n // phi and e aren't coprime, so generate a new p and q\n state.p = state.q = null;\n generate();\n return;\n }\n\n // create n, ensure n is has the right number of bits\n state.n = state.p.multiply(state.q);\n if(state.n.bitLength() !== state.bits) {\n // failed, get new q\n state.q = null;\n getPrime(state.qBits, finish);\n return;\n }\n\n // set keys\n var d = state.e.modInverse(state.phi);\n state.keys = {\n privateKey: pki.rsa.setPrivateKey(\n state.n, state.e, d, state.p, state.q,\n d.mod(state.p1), d.mod(state.q1),\n state.q.modInverse(state.p)),\n publicKey: pki.rsa.setPublicKey(state.n, state.e)\n };\n\n callback(null, state.keys);\n }\n}\n\n/**\n * Converts a positive BigInteger into 2's-complement big-endian bytes.\n *\n * @param b the big integer to convert.\n *\n * @return the bytes.\n */\nfunction _bnToBytes(b) {\n // prepend 0x00 if first byte >= 0x80\n var hex = b.toString(16);\n if(hex[0] >= '8') {\n hex = '00' + hex;\n }\n var bytes = forge.util.hexToBytes(hex);\n\n // ensure integer is minimally-encoded\n if(bytes.length > 1 &&\n // leading 0x00 for positive integer\n ((bytes.charCodeAt(0) === 0 &&\n (bytes.charCodeAt(1) & 0x80) === 0) ||\n // leading 0xFF for negative integer\n (bytes.charCodeAt(0) === 0xFF &&\n (bytes.charCodeAt(1) & 0x80) === 0x80))) {\n return bytes.substr(1);\n }\n return bytes;\n}\n\n/**\n * Returns the required number of Miller-Rabin tests to generate a\n * prime with an error probability of (1/2)^80.\n *\n * See Handbook of Applied Cryptography Chapter 4, Table 4.4.\n *\n * @param bits the bit size.\n *\n * @return the required number of iterations.\n */\nfunction _getMillerRabinTests(bits) {\n if(bits <= 100) return 27;\n if(bits <= 150) return 18;\n if(bits <= 200) return 15;\n if(bits <= 250) return 12;\n if(bits <= 300) return 9;\n if(bits <= 350) return 8;\n if(bits <= 400) return 7;\n if(bits <= 500) return 6;\n if(bits <= 600) return 5;\n if(bits <= 800) return 4;\n if(bits <= 1250) return 3;\n return 2;\n}\n\n/**\n * Performs feature detection on the Node crypto interface.\n *\n * @param fn the feature (function) to detect.\n *\n * @return true if detected, false if not.\n */\nfunction _detectNodeCrypto(fn) {\n return forge.util.isNodejs && typeof _crypto[fn] === 'function';\n}\n\n/**\n * Performs feature detection on the SubtleCrypto interface.\n *\n * @param fn the feature (function) to detect.\n *\n * @return true if detected, false if not.\n */\nfunction _detectSubtleCrypto(fn) {\n return (typeof util.globalScope !== 'undefined' &&\n typeof util.globalScope.crypto === 'object' &&\n typeof util.globalScope.crypto.subtle === 'object' &&\n typeof util.globalScope.crypto.subtle[fn] === 'function');\n}\n\n/**\n * Performs feature detection on the deprecated Microsoft Internet Explorer\n * outdated SubtleCrypto interface. This function should only be used after\n * checking for the modern, standard SubtleCrypto interface.\n *\n * @param fn the feature (function) to detect.\n *\n * @return true if detected, false if not.\n */\nfunction _detectSubtleMsCrypto(fn) {\n return (typeof util.globalScope !== 'undefined' &&\n typeof util.globalScope.msCrypto === 'object' &&\n typeof util.globalScope.msCrypto.subtle === 'object' &&\n typeof util.globalScope.msCrypto.subtle[fn] === 'function');\n}\n\nfunction _intToUint8Array(x) {\n var bytes = forge.util.hexToBytes(x.toString(16));\n var buffer = new Uint8Array(bytes.length);\n for(var i = 0; i < bytes.length; ++i) {\n buffer[i] = bytes.charCodeAt(i);\n }\n return buffer;\n}\n\nfunction _privateKeyFromJwk(jwk) {\n if(jwk.kty !== 'RSA') {\n throw new Error(\n 'Unsupported key algorithm \"' + jwk.kty + '\"; algorithm must be \"RSA\".');\n }\n return pki.setRsaPrivateKey(\n _base64ToBigInt(jwk.n),\n _base64ToBigInt(jwk.e),\n _base64ToBigInt(jwk.d),\n _base64ToBigInt(jwk.p),\n _base64ToBigInt(jwk.q),\n _base64ToBigInt(jwk.dp),\n _base64ToBigInt(jwk.dq),\n _base64ToBigInt(jwk.qi));\n}\n\nfunction _publicKeyFromJwk(jwk) {\n if(jwk.kty !== 'RSA') {\n throw new Error('Key algorithm must be \"RSA\".');\n }\n return pki.setRsaPublicKey(\n _base64ToBigInt(jwk.n),\n _base64ToBigInt(jwk.e));\n}\n\nfunction _base64ToBigInt(b64) {\n return new BigInteger(forge.util.bytesToHex(forge.util.decode64(b64)), 16);\n}\n","// Copyright (c) 2005 Tom Wu\n// All Rights Reserved.\n// See \"LICENSE\" for details.\n\n// Basic JavaScript BN library - subset useful for RSA encryption.\n\n/*\nLicensing (LICENSE)\n-------------------\n\nThis software is covered under the following copyright:\n*/\n/*\n * Copyright (c) 2003-2005 Tom Wu\n * All Rights Reserved.\n *\n * Permission is hereby granted, free of charge, to any person obtaining\n * a copy of this software and associated documentation files (the\n * \"Software\"), to deal in the Software without restriction, including\n * without limitation the rights to use, copy, modify, merge, publish,\n * distribute, sublicense, and/or sell copies of the Software, and to\n * permit persons to whom the Software is furnished to do so, subject to\n * the following conditions:\n *\n * The above copyright notice and this permission notice shall be\n * included in all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS-IS\" AND WITHOUT WARRANTY OF ANY KIND,\n * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY\n * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.\n *\n * IN NO EVENT SHALL TOM WU BE LIABLE FOR ANY SPECIAL, INCIDENTAL,\n * INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, OR ANY DAMAGES WHATSOEVER\n * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER OR NOT ADVISED OF\n * THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF LIABILITY, ARISING OUT\n * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n *\n * In addition, the following condition applies:\n *\n * All redistributions must retain an intact copy of this copyright notice\n * and disclaimer.\n */\n/*\nAddress all questions regarding this license to:\n\n Tom Wu\n tjw@cs.Stanford.EDU\n*/\nvar forge = require('./forge');\n\nmodule.exports = forge.jsbn = forge.jsbn || {};\n\n// Bits per digit\nvar dbits;\n\n// JavaScript engine analysis\nvar canary = 0xdeadbeefcafe;\nvar j_lm = ((canary&0xffffff)==0xefcafe);\n\n// (public) Constructor\nfunction BigInteger(a,b,c) {\n this.data = [];\n if(a != null)\n if(\"number\" == typeof a) this.fromNumber(a,b,c);\n else if(b == null && \"string\" != typeof a) this.fromString(a,256);\n else this.fromString(a,b);\n}\nforge.jsbn.BigInteger = BigInteger;\n\n// return new, unset BigInteger\nfunction nbi() { return new BigInteger(null); }\n\n// am: Compute w_j += (x*this_i), propagate carries,\n// c is initial carry, returns final carry.\n// c < 3*dvalue, x < 2*dvalue, this_i < dvalue\n// We need to select the fastest one that works in this environment.\n\n// am1: use a single mult and divide to get the high bits,\n// max digit bits should be 26 because\n// max internal value = 2*dvalue^2-2*dvalue (< 2^53)\nfunction am1(i,x,w,j,c,n) {\n while(--n >= 0) {\n var v = x*this.data[i++]+w.data[j]+c;\n c = Math.floor(v/0x4000000);\n w.data[j++] = v&0x3ffffff;\n }\n return c;\n}\n// am2 avoids a big mult-and-extract completely.\n// Max digit bits should be <= 30 because we do bitwise ops\n// on values up to 2*hdvalue^2-hdvalue-1 (< 2^31)\nfunction am2(i,x,w,j,c,n) {\n var xl = x&0x7fff, xh = x>>15;\n while(--n >= 0) {\n var l = this.data[i]&0x7fff;\n var h = this.data[i++]>>15;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x7fff)<<15)+w.data[j]+(c&0x3fffffff);\n c = (l>>>30)+(m>>>15)+xh*h+(c>>>30);\n w.data[j++] = l&0x3fffffff;\n }\n return c;\n}\n// Alternately, set max digit bits to 28 since some\n// browsers slow down when dealing with 32-bit numbers.\nfunction am3(i,x,w,j,c,n) {\n var xl = x&0x3fff, xh = x>>14;\n while(--n >= 0) {\n var l = this.data[i]&0x3fff;\n var h = this.data[i++]>>14;\n var m = xh*l+h*xl;\n l = xl*l+((m&0x3fff)<<14)+w.data[j]+c;\n c = (l>>28)+(m>>14)+xh*h;\n w.data[j++] = l&0xfffffff;\n }\n return c;\n}\n\n// node.js (no browser)\nif(typeof(navigator) === 'undefined')\n{\n BigInteger.prototype.am = am3;\n dbits = 28;\n} else if(j_lm && (navigator.appName == \"Microsoft Internet Explorer\")) {\n BigInteger.prototype.am = am2;\n dbits = 30;\n} else if(j_lm && (navigator.appName != \"Netscape\")) {\n BigInteger.prototype.am = am1;\n dbits = 26;\n} else { // Mozilla/Netscape seems to prefer am3\n BigInteger.prototype.am = am3;\n dbits = 28;\n}\n\nBigInteger.prototype.DB = dbits;\nBigInteger.prototype.DM = ((1<<dbits)-1);\nBigInteger.prototype.DV = (1<<dbits);\n\nvar BI_FP = 52;\nBigInteger.prototype.FV = Math.pow(2,BI_FP);\nBigInteger.prototype.F1 = BI_FP-dbits;\nBigInteger.prototype.F2 = 2*dbits-BI_FP;\n\n// Digit conversions\nvar BI_RM = \"0123456789abcdefghijklmnopqrstuvwxyz\";\nvar BI_RC = new Array();\nvar rr,vv;\nrr = \"0\".charCodeAt(0);\nfor(vv = 0; vv <= 9; ++vv) BI_RC[rr++] = vv;\nrr = \"a\".charCodeAt(0);\nfor(vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv;\nrr = \"A\".charCodeAt(0);\nfor(vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv;\n\nfunction int2char(n) { return BI_RM.charAt(n); }\nfunction intAt(s,i) {\n var c = BI_RC[s.charCodeAt(i)];\n return (c==null)?-1:c;\n}\n\n// (protected) copy this to r\nfunction bnpCopyTo(r) {\n for(var i = this.t-1; i >= 0; --i) r.data[i] = this.data[i];\n r.t = this.t;\n r.s = this.s;\n}\n\n// (protected) set from integer value x, -DV <= x < DV\nfunction bnpFromInt(x) {\n this.t = 1;\n this.s = (x<0)?-1:0;\n if(x > 0) this.data[0] = x;\n else if(x < -1) this.data[0] = x+this.DV;\n else this.t = 0;\n}\n\n// return bigint initialized to value\nfunction nbv(i) { var r = nbi(); r.fromInt(i); return r; }\n\n// (protected) set from string and radix\nfunction bnpFromString(s,b) {\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 256) k = 8; // byte array\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else { this.fromRadix(s,b); return; }\n this.t = 0;\n this.s = 0;\n var i = s.length, mi = false, sh = 0;\n while(--i >= 0) {\n var x = (k==8)?s[i]&0xff:intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\") mi = true;\n continue;\n }\n mi = false;\n if(sh == 0)\n this.data[this.t++] = x;\n else if(sh+k > this.DB) {\n this.data[this.t-1] |= (x&((1<<(this.DB-sh))-1))<<sh;\n this.data[this.t++] = (x>>(this.DB-sh));\n } else\n this.data[this.t-1] |= x<<sh;\n sh += k;\n if(sh >= this.DB) sh -= this.DB;\n }\n if(k == 8 && (s[0]&0x80) != 0) {\n this.s = -1;\n if(sh > 0) this.data[this.t-1] |= ((1<<(this.DB-sh))-1)<<sh;\n }\n this.clamp();\n if(mi) BigInteger.ZERO.subTo(this,this);\n}\n\n// (protected) clamp off excess high words\nfunction bnpClamp() {\n var c = this.s&this.DM;\n while(this.t > 0 && this.data[this.t-1] == c) --this.t;\n}\n\n// (public) return string representation in given radix\nfunction bnToString(b) {\n if(this.s < 0) return \"-\"+this.negate().toString(b);\n var k;\n if(b == 16) k = 4;\n else if(b == 8) k = 3;\n else if(b == 2) k = 1;\n else if(b == 32) k = 5;\n else if(b == 4) k = 2;\n else return this.toRadix(b);\n var km = (1<<k)-1, d, m = false, r = \"\", i = this.t;\n var p = this.DB-(i*this.DB)%k;\n if(i-- > 0) {\n if(p < this.DB && (d = this.data[i]>>p) > 0) { m = true; r = int2char(d); }\n while(i >= 0) {\n if(p < k) {\n d = (this.data[i]&((1<<p)-1))<<(k-p);\n d |= this.data[--i]>>(p+=this.DB-k);\n } else {\n d = (this.data[i]>>(p-=k))&km;\n if(p <= 0) { p += this.DB; --i; }\n }\n if(d > 0) m = true;\n if(m) r += int2char(d);\n }\n }\n return m?r:\"0\";\n}\n\n// (public) -this\nfunction bnNegate() { var r = nbi(); BigInteger.ZERO.subTo(this,r); return r; }\n\n// (public) |this|\nfunction bnAbs() { return (this.s<0)?this.negate():this; }\n\n// (public) return + if this > a, - if this < a, 0 if equal\nfunction bnCompareTo(a) {\n var r = this.s-a.s;\n if(r != 0) return r;\n var i = this.t;\n r = i-a.t;\n if(r != 0) return (this.s<0)?-r:r;\n while(--i >= 0) if((r=this.data[i]-a.data[i]) != 0) return r;\n return 0;\n}\n\n// returns bit length of the integer x\nfunction nbits(x) {\n var r = 1, t;\n if((t=x>>>16) != 0) { x = t; r += 16; }\n if((t=x>>8) != 0) { x = t; r += 8; }\n if((t=x>>4) != 0) { x = t; r += 4; }\n if((t=x>>2) != 0) { x = t; r += 2; }\n if((t=x>>1) != 0) { x = t; r += 1; }\n return r;\n}\n\n// (public) return the number of bits in \"this\"\nfunction bnBitLength() {\n if(this.t <= 0) return 0;\n return this.DB*(this.t-1)+nbits(this.data[this.t-1]^(this.s&this.DM));\n}\n\n// (protected) r = this << n*DB\nfunction bnpDLShiftTo(n,r) {\n var i;\n for(i = this.t-1; i >= 0; --i) r.data[i+n] = this.data[i];\n for(i = n-1; i >= 0; --i) r.data[i] = 0;\n r.t = this.t+n;\n r.s = this.s;\n}\n\n// (protected) r = this >> n*DB\nfunction bnpDRShiftTo(n,r) {\n for(var i = n; i < this.t; ++i) r.data[i-n] = this.data[i];\n r.t = Math.max(this.t-n,0);\n r.s = this.s;\n}\n\n// (protected) r = this << n\nfunction bnpLShiftTo(n,r) {\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<<cbs)-1;\n var ds = Math.floor(n/this.DB), c = (this.s<<bs)&this.DM, i;\n for(i = this.t-1; i >= 0; --i) {\n r.data[i+ds+1] = (this.data[i]>>cbs)|c;\n c = (this.data[i]&bm)<<bs;\n }\n for(i = ds-1; i >= 0; --i) r.data[i] = 0;\n r.data[ds] = c;\n r.t = this.t+ds+1;\n r.s = this.s;\n r.clamp();\n}\n\n// (protected) r = this >> n\nfunction bnpRShiftTo(n,r) {\n r.s = this.s;\n var ds = Math.floor(n/this.DB);\n if(ds >= this.t) { r.t = 0; return; }\n var bs = n%this.DB;\n var cbs = this.DB-bs;\n var bm = (1<<bs)-1;\n r.data[0] = this.data[ds]>>bs;\n for(var i = ds+1; i < this.t; ++i) {\n r.data[i-ds-1] |= (this.data[i]&bm)<<cbs;\n r.data[i-ds] = this.data[i]>>bs;\n }\n if(bs > 0) r.data[this.t-ds-1] |= (this.s&bm)<<cbs;\n r.t = this.t-ds;\n r.clamp();\n}\n\n// (protected) r = this - a\nfunction bnpSubTo(a,r) {\n var i = 0, c = 0, m = Math.min(a.t,this.t);\n while(i < m) {\n c += this.data[i]-a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n if(a.t < this.t) {\n c -= a.s;\n while(i < this.t) {\n c += this.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n } else {\n c += this.s;\n while(i < a.t) {\n c -= a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c -= a.s;\n }\n r.s = (c<0)?-1:0;\n if(c < -1) r.data[i++] = this.DV+c;\n else if(c > 0) r.data[i++] = c;\n r.t = i;\n r.clamp();\n}\n\n// (protected) r = this * a, r != this,a (HAC 14.12)\n// \"this\" should be the larger one if appropriate.\nfunction bnpMultiplyTo(a,r) {\n var x = this.abs(), y = a.abs();\n var i = x.t;\n r.t = i+y.t;\n while(--i >= 0) r.data[i] = 0;\n for(i = 0; i < y.t; ++i) r.data[i+x.t] = x.am(0,y.data[i],r,i,0,x.t);\n r.s = 0;\n r.clamp();\n if(this.s != a.s) BigInteger.ZERO.subTo(r,r);\n}\n\n// (protected) r = this^2, r != this (HAC 14.16)\nfunction bnpSquareTo(r) {\n var x = this.abs();\n var i = r.t = 2*x.t;\n while(--i >= 0) r.data[i] = 0;\n for(i = 0; i < x.t-1; ++i) {\n var c = x.am(i,x.data[i],r,2*i,0,1);\n if((r.data[i+x.t]+=x.am(i+1,2*x.data[i],r,2*i+1,c,x.t-i-1)) >= x.DV) {\n r.data[i+x.t] -= x.DV;\n r.data[i+x.t+1] = 1;\n }\n }\n if(r.t > 0) r.data[r.t-1] += x.am(i,x.data[i],r,2*i,0,1);\n r.s = 0;\n r.clamp();\n}\n\n// (protected) divide this by m, quotient and remainder to q, r (HAC 14.20)\n// r != q, this != m. q or r may be null.\nfunction bnpDivRemTo(m,q,r) {\n var pm = m.abs();\n if(pm.t <= 0) return;\n var pt = this.abs();\n if(pt.t < pm.t) {\n if(q != null) q.fromInt(0);\n if(r != null) this.copyTo(r);\n return;\n }\n if(r == null) r = nbi();\n var y = nbi(), ts = this.s, ms = m.s;\n var nsh = this.DB-nbits(pm.data[pm.t-1]);\t// normalize modulus\n if(nsh > 0) { pm.lShiftTo(nsh,y); pt.lShiftTo(nsh,r); } else { pm.copyTo(y); pt.copyTo(r); }\n var ys = y.t;\n var y0 = y.data[ys-1];\n if(y0 == 0) return;\n var yt = y0*(1<<this.F1)+((ys>1)?y.data[ys-2]>>this.F2:0);\n var d1 = this.FV/yt, d2 = (1<<this.F1)/yt, e = 1<<this.F2;\n var i = r.t, j = i-ys, t = (q==null)?nbi():q;\n y.dlShiftTo(j,t);\n if(r.compareTo(t) >= 0) {\n r.data[r.t++] = 1;\n r.subTo(t,r);\n }\n BigInteger.ONE.dlShiftTo(ys,t);\n t.subTo(y,y);\t// \"negative\" y so we can replace sub with am later\n while(y.t < ys) y.data[y.t++] = 0;\n while(--j >= 0) {\n // Estimate quotient digit\n var qd = (r.data[--i]==y0)?this.DM:Math.floor(r.data[i]*d1+(r.data[i-1]+e)*d2);\n if((r.data[i]+=y.am(0,qd,r,j,0,ys)) < qd) {\t// Try it out\n y.dlShiftTo(j,t);\n r.subTo(t,r);\n while(r.data[i] < --qd) r.subTo(t,r);\n }\n }\n if(q != null) {\n r.drShiftTo(ys,q);\n if(ts != ms) BigInteger.ZERO.subTo(q,q);\n }\n r.t = ys;\n r.clamp();\n if(nsh > 0) r.rShiftTo(nsh,r);\t// Denormalize remainder\n if(ts < 0) BigInteger.ZERO.subTo(r,r);\n}\n\n// (public) this mod a\nfunction bnMod(a) {\n var r = nbi();\n this.abs().divRemTo(a,null,r);\n if(this.s < 0 && r.compareTo(BigInteger.ZERO) > 0) a.subTo(r,r);\n return r;\n}\n\n// Modular reduction using \"classic\" algorithm\nfunction Classic(m) { this.m = m; }\nfunction cConvert(x) {\n if(x.s < 0 || x.compareTo(this.m) >= 0) return x.mod(this.m);\n else return x;\n}\nfunction cRevert(x) { return x; }\nfunction cReduce(x) { x.divRemTo(this.m,null,x); }\nfunction cMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\nfunction cSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\nClassic.prototype.convert = cConvert;\nClassic.prototype.revert = cRevert;\nClassic.prototype.reduce = cReduce;\nClassic.prototype.mulTo = cMulTo;\nClassic.prototype.sqrTo = cSqrTo;\n\n// (protected) return \"-1/this % 2^DB\"; useful for Mont. reduction\n// justification:\n// xy == 1 (mod m)\n// xy = 1+km\n// xy(2-xy) = (1+km)(1-km)\n// x[y(2-xy)] = 1-k^2m^2\n// x[y(2-xy)] == 1 (mod m^2)\n// if y is 1/x mod m, then y(2-xy) is 1/x mod m^2\n// should reduce x and y(2-xy) by m^2 at each step to keep size bounded.\n// JS multiply \"overflows\" differently from C/C++, so care is needed here.\nfunction bnpInvDigit() {\n if(this.t < 1) return 0;\n var x = this.data[0];\n if((x&1) == 0) return 0;\n var y = x&3;\t\t// y == 1/x mod 2^2\n y = (y*(2-(x&0xf)*y))&0xf;\t// y == 1/x mod 2^4\n y = (y*(2-(x&0xff)*y))&0xff;\t// y == 1/x mod 2^8\n y = (y*(2-(((x&0xffff)*y)&0xffff)))&0xffff;\t// y == 1/x mod 2^16\n // last step - calculate inverse mod DV directly;\n // assumes 16 < DB <= 32 and assumes ability to handle 48-bit ints\n y = (y*(2-x*y%this.DV))%this.DV;\t\t// y == 1/x mod 2^dbits\n // we really want the negative inverse, and -DV < y < DV\n return (y>0)?this.DV-y:-y;\n}\n\n// Montgomery reduction\nfunction Montgomery(m) {\n this.m = m;\n this.mp = m.invDigit();\n this.mpl = this.mp&0x7fff;\n this.mph = this.mp>>15;\n this.um = (1<<(m.DB-15))-1;\n this.mt2 = 2*m.t;\n}\n\n// xR mod m\nfunction montConvert(x) {\n var r = nbi();\n x.abs().dlShiftTo(this.m.t,r);\n r.divRemTo(this.m,null,r);\n if(x.s < 0 && r.compareTo(BigInteger.ZERO) > 0) this.m.subTo(r,r);\n return r;\n}\n\n// x/R mod m\nfunction montRevert(x) {\n var r = nbi();\n x.copyTo(r);\n this.reduce(r);\n return r;\n}\n\n// x = x/R mod m (HAC 14.32)\nfunction montReduce(x) {\n while(x.t <= this.mt2)\t// pad x so am has enough room later\n x.data[x.t++] = 0;\n for(var i = 0; i < this.m.t; ++i) {\n // faster way of calculating u0 = x.data[i]*mp mod DV\n var j = x.data[i]&0x7fff;\n var u0 = (j*this.mpl+(((j*this.mph+(x.data[i]>>15)*this.mpl)&this.um)<<15))&x.DM;\n // use am to combine the multiply-shift-add into one call\n j = i+this.m.t;\n x.data[j] += this.m.am(0,u0,x,i,0,this.m.t);\n // propagate carry\n while(x.data[j] >= x.DV) { x.data[j] -= x.DV; x.data[++j]++; }\n }\n x.clamp();\n x.drShiftTo(this.m.t,x);\n if(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n}\n\n// r = \"x^2/R mod m\"; x != r\nfunction montSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n// r = \"xy/R mod m\"; x,y != r\nfunction montMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\nMontgomery.prototype.convert = montConvert;\nMontgomery.prototype.revert = montRevert;\nMontgomery.prototype.reduce = montReduce;\nMontgomery.prototype.mulTo = montMulTo;\nMontgomery.prototype.sqrTo = montSqrTo;\n\n// (protected) true iff this is even\nfunction bnpIsEven() { return ((this.t>0)?(this.data[0]&1):this.s) == 0; }\n\n// (protected) this^e, e < 2^32, doing sqr and mul with \"r\" (HAC 14.79)\nfunction bnpExp(e,z) {\n if(e > 0xffffffff || e < 1) return BigInteger.ONE;\n var r = nbi(), r2 = nbi(), g = z.convert(this), i = nbits(e)-1;\n g.copyTo(r);\n while(--i >= 0) {\n z.sqrTo(r,r2);\n if((e&(1<<i)) > 0) z.mulTo(r2,g,r);\n else { var t = r; r = r2; r2 = t; }\n }\n return z.revert(r);\n}\n\n// (public) this^e % m, 0 <= e < 2^32\nfunction bnModPowInt(e,m) {\n var z;\n if(e < 256 || m.isEven()) z = new Classic(m); else z = new Montgomery(m);\n return this.exp(e,z);\n}\n\n// protected\nBigInteger.prototype.copyTo = bnpCopyTo;\nBigInteger.prototype.fromInt = bnpFromInt;\nBigInteger.prototype.fromString = bnpFromString;\nBigInteger.prototype.clamp = bnpClamp;\nBigInteger.prototype.dlShiftTo = bnpDLShiftTo;\nBigInteger.prototype.drShiftTo = bnpDRShiftTo;\nBigInteger.prototype.lShiftTo = bnpLShiftTo;\nBigInteger.prototype.rShiftTo = bnpRShiftTo;\nBigInteger.prototype.subTo = bnpSubTo;\nBigInteger.prototype.multiplyTo = bnpMultiplyTo;\nBigInteger.prototype.squareTo = bnpSquareTo;\nBigInteger.prototype.divRemTo = bnpDivRemTo;\nBigInteger.prototype.invDigit = bnpInvDigit;\nBigInteger.prototype.isEven = bnpIsEven;\nBigInteger.prototype.exp = bnpExp;\n\n// public\nBigInteger.prototype.toString = bnToString;\nBigInteger.prototype.negate = bnNegate;\nBigInteger.prototype.abs = bnAbs;\nBigInteger.prototype.compareTo = bnCompareTo;\nBigInteger.prototype.bitLength = bnBitLength;\nBigInteger.prototype.mod = bnMod;\nBigInteger.prototype.modPowInt = bnModPowInt;\n\n// \"constants\"\nBigInteger.ZERO = nbv(0);\nBigInteger.ONE = nbv(1);\n\n// jsbn2 lib\n\n//Copyright (c) 2005-2009 Tom Wu\n//All Rights Reserved.\n//See \"LICENSE\" for details (See jsbn.js for LICENSE).\n\n//Extended JavaScript BN functions, required for RSA private ops.\n\n//Version 1.1: new BigInteger(\"0\", 10) returns \"proper\" zero\n\n//(public)\nfunction bnClone() { var r = nbi(); this.copyTo(r); return r; }\n\n//(public) return value as integer\nfunction bnIntValue() {\nif(this.s < 0) {\n if(this.t == 1) return this.data[0]-this.DV;\n else if(this.t == 0) return -1;\n} else if(this.t == 1) return this.data[0];\nelse if(this.t == 0) return 0;\n// assumes 16 < DB < 32\nreturn ((this.data[1]&((1<<(32-this.DB))-1))<<this.DB)|this.data[0];\n}\n\n//(public) return value as byte\nfunction bnByteValue() { return (this.t==0)?this.s:(this.data[0]<<24)>>24; }\n\n//(public) return value as short (assumes DB>=16)\nfunction bnShortValue() { return (this.t==0)?this.s:(this.data[0]<<16)>>16; }\n\n//(protected) return x s.t. r^x < DV\nfunction bnpChunkSize(r) { return Math.floor(Math.LN2*this.DB/Math.log(r)); }\n\n//(public) 0 if this == 0, 1 if this > 0\nfunction bnSigNum() {\nif(this.s < 0) return -1;\nelse if(this.t <= 0 || (this.t == 1 && this.data[0] <= 0)) return 0;\nelse return 1;\n}\n\n//(protected) convert to radix string\nfunction bnpToRadix(b) {\nif(b == null) b = 10;\nif(this.signum() == 0 || b < 2 || b > 36) return \"0\";\nvar cs = this.chunkSize(b);\nvar a = Math.pow(b,cs);\nvar d = nbv(a), y = nbi(), z = nbi(), r = \"\";\nthis.divRemTo(d,y,z);\nwhile(y.signum() > 0) {\n r = (a+z.intValue()).toString(b).substr(1) + r;\n y.divRemTo(d,y,z);\n}\nreturn z.intValue().toString(b) + r;\n}\n\n//(protected) convert from radix string\nfunction bnpFromRadix(s,b) {\nthis.fromInt(0);\nif(b == null) b = 10;\nvar cs = this.chunkSize(b);\nvar d = Math.pow(b,cs), mi = false, j = 0, w = 0;\nfor(var i = 0; i < s.length; ++i) {\n var x = intAt(s,i);\n if(x < 0) {\n if(s.charAt(i) == \"-\" && this.signum() == 0) mi = true;\n continue;\n }\n w = b*w+x;\n if(++j >= cs) {\n this.dMultiply(d);\n this.dAddOffset(w,0);\n j = 0;\n w = 0;\n }\n}\nif(j > 0) {\n this.dMultiply(Math.pow(b,j));\n this.dAddOffset(w,0);\n}\nif(mi) BigInteger.ZERO.subTo(this,this);\n}\n\n//(protected) alternate constructor\nfunction bnpFromNumber(a,b,c) {\nif(\"number\" == typeof b) {\n // new BigInteger(int,int,RNG)\n if(a < 2) this.fromInt(1);\n else {\n this.fromNumber(a,c);\n if(!this.testBit(a-1)) // force MSB set\n this.bitwiseTo(BigInteger.ONE.shiftLeft(a-1),op_or,this);\n if(this.isEven()) this.dAddOffset(1,0); // force odd\n while(!this.isProbablePrime(b)) {\n this.dAddOffset(2,0);\n if(this.bitLength() > a) this.subTo(BigInteger.ONE.shiftLeft(a-1),this);\n }\n }\n} else {\n // new BigInteger(int,RNG)\n var x = new Array(), t = a&7;\n x.length = (a>>3)+1;\n b.nextBytes(x);\n if(t > 0) x[0] &= ((1<<t)-1); else x[0] = 0;\n this.fromString(x,256);\n}\n}\n\n//(public) convert to bigendian byte array\nfunction bnToByteArray() {\nvar i = this.t, r = new Array();\nr[0] = this.s;\nvar p = this.DB-(i*this.DB)%8, d, k = 0;\nif(i-- > 0) {\n if(p < this.DB && (d = this.data[i]>>p) != (this.s&this.DM)>>p)\n r[k++] = d|(this.s<<(this.DB-p));\n while(i >= 0) {\n if(p < 8) {\n d = (this.data[i]&((1<<p)-1))<<(8-p);\n d |= this.data[--i]>>(p+=this.DB-8);\n } else {\n d = (this.data[i]>>(p-=8))&0xff;\n if(p <= 0) { p += this.DB; --i; }\n }\n if((d&0x80) != 0) d |= -256;\n if(k == 0 && (this.s&0x80) != (d&0x80)) ++k;\n if(k > 0 || d != this.s) r[k++] = d;\n }\n}\nreturn r;\n}\n\nfunction bnEquals(a) { return(this.compareTo(a)==0); }\nfunction bnMin(a) { return(this.compareTo(a)<0)?this:a; }\nfunction bnMax(a) { return(this.compareTo(a)>0)?this:a; }\n\n//(protected) r = this op a (bitwise)\nfunction bnpBitwiseTo(a,op,r) {\nvar i, f, m = Math.min(a.t,this.t);\nfor(i = 0; i < m; ++i) r.data[i] = op(this.data[i],a.data[i]);\nif(a.t < this.t) {\n f = a.s&this.DM;\n for(i = m; i < this.t; ++i) r.data[i] = op(this.data[i],f);\n r.t = this.t;\n} else {\n f = this.s&this.DM;\n for(i = m; i < a.t; ++i) r.data[i] = op(f,a.data[i]);\n r.t = a.t;\n}\nr.s = op(this.s,a.s);\nr.clamp();\n}\n\n//(public) this & a\nfunction op_and(x,y) { return x&y; }\nfunction bnAnd(a) { var r = nbi(); this.bitwiseTo(a,op_and,r); return r; }\n\n//(public) this | a\nfunction op_or(x,y) { return x|y; }\nfunction bnOr(a) { var r = nbi(); this.bitwiseTo(a,op_or,r); return r; }\n\n//(public) this ^ a\nfunction op_xor(x,y) { return x^y; }\nfunction bnXor(a) { var r = nbi(); this.bitwiseTo(a,op_xor,r); return r; }\n\n//(public) this & ~a\nfunction op_andnot(x,y) { return x&~y; }\nfunction bnAndNot(a) { var r = nbi(); this.bitwiseTo(a,op_andnot,r); return r; }\n\n//(public) ~this\nfunction bnNot() {\nvar r = nbi();\nfor(var i = 0; i < this.t; ++i) r.data[i] = this.DM&~this.data[i];\nr.t = this.t;\nr.s = ~this.s;\nreturn r;\n}\n\n//(public) this << n\nfunction bnShiftLeft(n) {\nvar r = nbi();\nif(n < 0) this.rShiftTo(-n,r); else this.lShiftTo(n,r);\nreturn r;\n}\n\n//(public) this >> n\nfunction bnShiftRight(n) {\nvar r = nbi();\nif(n < 0) this.lShiftTo(-n,r); else this.rShiftTo(n,r);\nreturn r;\n}\n\n//return index of lowest 1-bit in x, x < 2^31\nfunction lbit(x) {\nif(x == 0) return -1;\nvar r = 0;\nif((x&0xffff) == 0) { x >>= 16; r += 16; }\nif((x&0xff) == 0) { x >>= 8; r += 8; }\nif((x&0xf) == 0) { x >>= 4; r += 4; }\nif((x&3) == 0) { x >>= 2; r += 2; }\nif((x&1) == 0) ++r;\nreturn r;\n}\n\n//(public) returns index of lowest 1-bit (or -1 if none)\nfunction bnGetLowestSetBit() {\nfor(var i = 0; i < this.t; ++i)\n if(this.data[i] != 0) return i*this.DB+lbit(this.data[i]);\nif(this.s < 0) return this.t*this.DB;\nreturn -1;\n}\n\n//return number of 1 bits in x\nfunction cbit(x) {\nvar r = 0;\nwhile(x != 0) { x &= x-1; ++r; }\nreturn r;\n}\n\n//(public) return number of set bits\nfunction bnBitCount() {\nvar r = 0, x = this.s&this.DM;\nfor(var i = 0; i < this.t; ++i) r += cbit(this.data[i]^x);\nreturn r;\n}\n\n//(public) true iff nth bit is set\nfunction bnTestBit(n) {\nvar j = Math.floor(n/this.DB);\nif(j >= this.t) return(this.s!=0);\nreturn((this.data[j]&(1<<(n%this.DB)))!=0);\n}\n\n//(protected) this op (1<<n)\nfunction bnpChangeBit(n,op) {\nvar r = BigInteger.ONE.shiftLeft(n);\nthis.bitwiseTo(r,op,r);\nreturn r;\n}\n\n//(public) this | (1<<n)\nfunction bnSetBit(n) { return this.changeBit(n,op_or); }\n\n//(public) this & ~(1<<n)\nfunction bnClearBit(n) { return this.changeBit(n,op_andnot); }\n\n//(public) this ^ (1<<n)\nfunction bnFlipBit(n) { return this.changeBit(n,op_xor); }\n\n//(protected) r = this + a\nfunction bnpAddTo(a,r) {\nvar i = 0, c = 0, m = Math.min(a.t,this.t);\nwhile(i < m) {\n c += this.data[i]+a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n}\nif(a.t < this.t) {\n c += a.s;\n while(i < this.t) {\n c += this.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += this.s;\n} else {\n c += this.s;\n while(i < a.t) {\n c += a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n }\n c += a.s;\n}\nr.s = (c<0)?-1:0;\nif(c > 0) r.data[i++] = c;\nelse if(c < -1) r.data[i++] = this.DV+c;\nr.t = i;\nr.clamp();\n}\n\n//(public) this + a\nfunction bnAdd(a) { var r = nbi(); this.addTo(a,r); return r; }\n\n//(public) this - a\nfunction bnSubtract(a) { var r = nbi(); this.subTo(a,r); return r; }\n\n//(public) this * a\nfunction bnMultiply(a) { var r = nbi(); this.multiplyTo(a,r); return r; }\n\n//(public) this / a\nfunction bnDivide(a) { var r = nbi(); this.divRemTo(a,r,null); return r; }\n\n//(public) this % a\nfunction bnRemainder(a) { var r = nbi(); this.divRemTo(a,null,r); return r; }\n\n//(public) [this/a,this%a]\nfunction bnDivideAndRemainder(a) {\nvar q = nbi(), r = nbi();\nthis.divRemTo(a,q,r);\nreturn new Array(q,r);\n}\n\n//(protected) this *= n, this >= 0, 1 < n < DV\nfunction bnpDMultiply(n) {\nthis.data[this.t] = this.am(0,n-1,this,0,0,this.t);\n++this.t;\nthis.clamp();\n}\n\n//(protected) this += n << w words, this >= 0\nfunction bnpDAddOffset(n,w) {\nif(n == 0) return;\nwhile(this.t <= w) this.data[this.t++] = 0;\nthis.data[w] += n;\nwhile(this.data[w] >= this.DV) {\n this.data[w] -= this.DV;\n if(++w >= this.t) this.data[this.t++] = 0;\n ++this.data[w];\n}\n}\n\n//A \"null\" reducer\nfunction NullExp() {}\nfunction nNop(x) { return x; }\nfunction nMulTo(x,y,r) { x.multiplyTo(y,r); }\nfunction nSqrTo(x,r) { x.squareTo(r); }\n\nNullExp.prototype.convert = nNop;\nNullExp.prototype.revert = nNop;\nNullExp.prototype.mulTo = nMulTo;\nNullExp.prototype.sqrTo = nSqrTo;\n\n//(public) this^e\nfunction bnPow(e) { return this.exp(e,new NullExp()); }\n\n//(protected) r = lower n words of \"this * a\", a.t <= n\n//\"this\" should be the larger one if appropriate.\nfunction bnpMultiplyLowerTo(a,n,r) {\nvar i = Math.min(this.t+a.t,n);\nr.s = 0; // assumes a,this >= 0\nr.t = i;\nwhile(i > 0) r.data[--i] = 0;\nvar j;\nfor(j = r.t-this.t; i < j; ++i) r.data[i+this.t] = this.am(0,a.data[i],r,i,0,this.t);\nfor(j = Math.min(a.t,n); i < j; ++i) this.am(0,a.data[i],r,i,0,n-i);\nr.clamp();\n}\n\n//(protected) r = \"this * a\" without lower n words, n > 0\n//\"this\" should be the larger one if appropriate.\nfunction bnpMultiplyUpperTo(a,n,r) {\n--n;\nvar i = r.t = this.t+a.t-n;\nr.s = 0; // assumes a,this >= 0\nwhile(--i >= 0) r.data[i] = 0;\nfor(i = Math.max(n-this.t,0); i < a.t; ++i)\n r.data[this.t+i-n] = this.am(n-i,a.data[i],r,0,0,this.t+i-n);\nr.clamp();\nr.drShiftTo(1,r);\n}\n\n//Barrett modular reduction\nfunction Barrett(m) {\n// setup Barrett\nthis.r2 = nbi();\nthis.q3 = nbi();\nBigInteger.ONE.dlShiftTo(2*m.t,this.r2);\nthis.mu = this.r2.divide(m);\nthis.m = m;\n}\n\nfunction barrettConvert(x) {\nif(x.s < 0 || x.t > 2*this.m.t) return x.mod(this.m);\nelse if(x.compareTo(this.m) < 0) return x;\nelse { var r = nbi(); x.copyTo(r); this.reduce(r); return r; }\n}\n\nfunction barrettRevert(x) { return x; }\n\n//x = x mod m (HAC 14.42)\nfunction barrettReduce(x) {\nx.drShiftTo(this.m.t-1,this.r2);\nif(x.t > this.m.t+1) { x.t = this.m.t+1; x.clamp(); }\nthis.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3);\nthis.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);\nwhile(x.compareTo(this.r2) < 0) x.dAddOffset(1,this.m.t+1);\nx.subTo(this.r2,x);\nwhile(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n}\n\n//r = x^2 mod m; x != r\nfunction barrettSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n//r = x*y mod m; x,y != r\nfunction barrettMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\nBarrett.prototype.convert = barrettConvert;\nBarrett.prototype.revert = barrettRevert;\nBarrett.prototype.reduce = barrettReduce;\nBarrett.prototype.mulTo = barrettMulTo;\nBarrett.prototype.sqrTo = barrettSqrTo;\n\n//(public) this^e % m (HAC 14.85)\nfunction bnModPow(e,m) {\nvar i = e.bitLength(), k, r = nbv(1), z;\nif(i <= 0) return r;\nelse if(i < 18) k = 1;\nelse if(i < 48) k = 3;\nelse if(i < 144) k = 4;\nelse if(i < 768) k = 5;\nelse k = 6;\nif(i < 8)\n z = new Classic(m);\nelse if(m.isEven())\n z = new Barrett(m);\nelse\n z = new Montgomery(m);\n\n// precomputation\nvar g = new Array(), n = 3, k1 = k-1, km = (1<<k)-1;\ng[1] = z.convert(this);\nif(k > 1) {\n var g2 = nbi();\n z.sqrTo(g[1],g2);\n while(n <= km) {\n g[n] = nbi();\n z.mulTo(g2,g[n-2],g[n]);\n n += 2;\n }\n}\n\nvar j = e.t-1, w, is1 = true, r2 = nbi(), t;\ni = nbits(e.data[j])-1;\nwhile(j >= 0) {\n if(i >= k1) w = (e.data[j]>>(i-k1))&km;\n else {\n w = (e.data[j]&((1<<(i+1))-1))<<(k1-i);\n if(j > 0) w |= e.data[j-1]>>(this.DB+i-k1);\n }\n\n n = k;\n while((w&1) == 0) { w >>= 1; --n; }\n if((i -= n) < 0) { i += this.DB; --j; }\n if(is1) { // ret == 1, don't bother squaring or multiplying it\n g[w].copyTo(r);\n is1 = false;\n } else {\n while(n > 1) { z.sqrTo(r,r2); z.sqrTo(r2,r); n -= 2; }\n if(n > 0) z.sqrTo(r,r2); else { t = r; r = r2; r2 = t; }\n z.mulTo(r2,g[w],r);\n }\n\n while(j >= 0 && (e.data[j]&(1<<i)) == 0) {\n z.sqrTo(r,r2); t = r; r = r2; r2 = t;\n if(--i < 0) { i = this.DB-1; --j; }\n }\n}\nreturn z.revert(r);\n}\n\n//(public) gcd(this,a) (HAC 14.54)\nfunction bnGCD(a) {\nvar x = (this.s<0)?this.negate():this.clone();\nvar y = (a.s<0)?a.negate():a.clone();\nif(x.compareTo(y) < 0) { var t = x; x = y; y = t; }\nvar i = x.getLowestSetBit(), g = y.getLowestSetBit();\nif(g < 0) return x;\nif(i < g) g = i;\nif(g > 0) {\n x.rShiftTo(g,x);\n y.rShiftTo(g,y);\n}\nwhile(x.signum() > 0) {\n if((i = x.getLowestSetBit()) > 0) x.rShiftTo(i,x);\n if((i = y.getLowestSetBit()) > 0) y.rShiftTo(i,y);\n if(x.compareTo(y) >= 0) {\n x.subTo(y,x);\n x.rShiftTo(1,x);\n } else {\n y.subTo(x,y);\n y.rShiftTo(1,y);\n }\n}\nif(g > 0) y.lShiftTo(g,y);\nreturn y;\n}\n\n//(protected) this % n, n < 2^26\nfunction bnpModInt(n) {\nif(n <= 0) return 0;\nvar d = this.DV%n, r = (this.s<0)?n-1:0;\nif(this.t > 0)\n if(d == 0) r = this.data[0]%n;\n else for(var i = this.t-1; i >= 0; --i) r = (d*r+this.data[i])%n;\nreturn r;\n}\n\n//(public) 1/this % m (HAC 14.61)\nfunction bnModInverse(m) {\nvar ac = m.isEven();\nif((this.isEven() && ac) || m.signum() == 0) return BigInteger.ZERO;\nvar u = m.clone(), v = this.clone();\nvar a = nbv(1), b = nbv(0), c = nbv(0), d = nbv(1);\nwhile(u.signum() != 0) {\n while(u.isEven()) {\n u.rShiftTo(1,u);\n if(ac) {\n if(!a.isEven() || !b.isEven()) { a.addTo(this,a); b.subTo(m,b); }\n a.rShiftTo(1,a);\n } else if(!b.isEven()) b.subTo(m,b);\n b.rShiftTo(1,b);\n }\n while(v.isEven()) {\n v.rShiftTo(1,v);\n if(ac) {\n if(!c.isEven() || !d.isEven()) { c.addTo(this,c); d.subTo(m,d); }\n c.rShiftTo(1,c);\n } else if(!d.isEven()) d.subTo(m,d);\n d.rShiftTo(1,d);\n }\n if(u.compareTo(v) >= 0) {\n u.subTo(v,u);\n if(ac) a.subTo(c,a);\n b.subTo(d,b);\n } else {\n v.subTo(u,v);\n if(ac) c.subTo(a,c);\n d.subTo(b,d);\n }\n}\nif(v.compareTo(BigInteger.ONE) != 0) return BigInteger.ZERO;\nif(d.compareTo(m) >= 0) return d.subtract(m);\nif(d.signum() < 0) d.addTo(m,d); else return d;\nif(d.signum() < 0) return d.add(m); else return d;\n}\n\nvar lowprimes = [2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509];\nvar lplim = (1<<26)/lowprimes[lowprimes.length-1];\n\n//(public) test primality with certainty >= 1-.5^t\nfunction bnIsProbablePrime(t) {\nvar i, x = this.abs();\nif(x.t == 1 && x.data[0] <= lowprimes[lowprimes.length-1]) {\n for(i = 0; i < lowprimes.length; ++i)\n if(x.data[0] == lowprimes[i]) return true;\n return false;\n}\nif(x.isEven()) return false;\ni = 1;\nwhile(i < lowprimes.length) {\n var m = lowprimes[i], j = i+1;\n while(j < lowprimes.length && m < lplim) m *= lowprimes[j++];\n m = x.modInt(m);\n while(i < j) if(m%lowprimes[i++] == 0) return false;\n}\nreturn x.millerRabin(t);\n}\n\n//(protected) true if probably prime (HAC 4.24, Miller-Rabin)\nfunction bnpMillerRabin(t) {\nvar n1 = this.subtract(BigInteger.ONE);\nvar k = n1.getLowestSetBit();\nif(k <= 0) return false;\nvar r = n1.shiftRight(k);\nvar prng = bnGetPrng();\nvar a;\nfor(var i = 0; i < t; ++i) {\n // select witness 'a' at random from between 1 and n1\n do {\n a = new BigInteger(this.bitLength(), prng);\n }\n while(a.compareTo(BigInteger.ONE) <= 0 || a.compareTo(n1) >= 0);\n var y = a.modPow(r,this);\n if(y.compareTo(BigInteger.ONE) != 0 && y.compareTo(n1) != 0) {\n var j = 1;\n while(j++ < k && y.compareTo(n1) != 0) {\n y = y.modPowInt(2,this);\n if(y.compareTo(BigInteger.ONE) == 0) return false;\n }\n if(y.compareTo(n1) != 0) return false;\n }\n}\nreturn true;\n}\n\n// get pseudo random number generator\nfunction bnGetPrng() {\n // create prng with api that matches BigInteger secure random\n return {\n // x is an array to fill with bytes\n nextBytes: function(x) {\n for(var i = 0; i < x.length; ++i) {\n x[i] = Math.floor(Math.random() * 0x0100);\n }\n }\n };\n}\n\n//protected\nBigInteger.prototype.chunkSize = bnpChunkSize;\nBigInteger.prototype.toRadix = bnpToRadix;\nBigInteger.prototype.fromRadix = bnpFromRadix;\nBigInteger.prototype.fromNumber = bnpFromNumber;\nBigInteger.prototype.bitwiseTo = bnpBitwiseTo;\nBigInteger.prototype.changeBit = bnpChangeBit;\nBigInteger.prototype.addTo = bnpAddTo;\nBigInteger.prototype.dMultiply = bnpDMultiply;\nBigInteger.prototype.dAddOffset = bnpDAddOffset;\nBigInteger.prototype.multiplyLowerTo = bnpMultiplyLowerTo;\nBigInteger.prototype.multiplyUpperTo = bnpMultiplyUpperTo;\nBigInteger.prototype.modInt = bnpModInt;\nBigInteger.prototype.millerRabin = bnpMillerRabin;\n\n//public\nBigInteger.prototype.clone = bnClone;\nBigInteger.prototype.intValue = bnIntValue;\nBigInteger.prototype.byteValue = bnByteValue;\nBigInteger.prototype.shortValue = bnShortValue;\nBigInteger.prototype.signum = bnSigNum;\nBigInteger.prototype.toByteArray = bnToByteArray;\nBigInteger.prototype.equals = bnEquals;\nBigInteger.prototype.min = bnMin;\nBigInteger.prototype.max = bnMax;\nBigInteger.prototype.and = bnAnd;\nBigInteger.prototype.or = bnOr;\nBigInteger.prototype.xor = bnXor;\nBigInteger.prototype.andNot = bnAndNot;\nBigInteger.prototype.not = bnNot;\nBigInteger.prototype.shiftLeft = bnShiftLeft;\nBigInteger.prototype.shiftRight = bnShiftRight;\nBigInteger.prototype.getLowestSetBit = bnGetLowestSetBit;\nBigInteger.prototype.bitCount = bnBitCount;\nBigInteger.prototype.testBit = bnTestBit;\nBigInteger.prototype.setBit = bnSetBit;\nBigInteger.prototype.clearBit = bnClearBit;\nBigInteger.prototype.flipBit = bnFlipBit;\nBigInteger.prototype.add = bnAdd;\nBigInteger.prototype.subtract = bnSubtract;\nBigInteger.prototype.multiply = bnMultiply;\nBigInteger.prototype.divide = bnDivide;\nBigInteger.prototype.remainder = bnRemainder;\nBigInteger.prototype.divideAndRemainder = bnDivideAndRemainder;\nBigInteger.prototype.modPow = bnModPow;\nBigInteger.prototype.modInverse = bnModInverse;\nBigInteger.prototype.pow = bnPow;\nBigInteger.prototype.gcd = bnGCD;\nBigInteger.prototype.isProbablePrime = bnIsProbablePrime;\n\n//BigInteger interfaces not implemented in jsbn:\n\n//BigInteger(int signum, byte[] magnitude)\n//double doubleValue()\n//float floatValue()\n//int hashCode()\n//long longValue()\n//static BigInteger valueOf(long val)\n","/**\n * Cipher base API.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nmodule.exports = forge.cipher = forge.cipher || {};\n\n// registered algorithms\nforge.cipher.algorithms = forge.cipher.algorithms || {};\n\n/**\n * Creates a cipher object that can be used to encrypt data using the given\n * algorithm and key. The algorithm may be provided as a string value for a\n * previously registered algorithm or it may be given as a cipher algorithm\n * API object.\n *\n * @param algorithm the algorithm to use, either a string or an algorithm API\n * object.\n * @param key the key to use, as a binary-encoded string of bytes or a\n * byte buffer.\n *\n * @return the cipher.\n */\nforge.cipher.createCipher = function(algorithm, key) {\n var api = algorithm;\n if(typeof api === 'string') {\n api = forge.cipher.getAlgorithm(api);\n if(api) {\n api = api();\n }\n }\n if(!api) {\n throw new Error('Unsupported algorithm: ' + algorithm);\n }\n\n // assume block cipher\n return new forge.cipher.BlockCipher({\n algorithm: api,\n key: key,\n decrypt: false\n });\n};\n\n/**\n * Creates a decipher object that can be used to decrypt data using the given\n * algorithm and key. The algorithm may be provided as a string value for a\n * previously registered algorithm or it may be given as a cipher algorithm\n * API object.\n *\n * @param algorithm the algorithm to use, either a string or an algorithm API\n * object.\n * @param key the key to use, as a binary-encoded string of bytes or a\n * byte buffer.\n *\n * @return the cipher.\n */\nforge.cipher.createDecipher = function(algorithm, key) {\n var api = algorithm;\n if(typeof api === 'string') {\n api = forge.cipher.getAlgorithm(api);\n if(api) {\n api = api();\n }\n }\n if(!api) {\n throw new Error('Unsupported algorithm: ' + algorithm);\n }\n\n // assume block cipher\n return new forge.cipher.BlockCipher({\n algorithm: api,\n key: key,\n decrypt: true\n });\n};\n\n/**\n * Registers an algorithm by name. If the name was already registered, the\n * algorithm API object will be overwritten.\n *\n * @param name the name of the algorithm.\n * @param algorithm the algorithm API object.\n */\nforge.cipher.registerAlgorithm = function(name, algorithm) {\n name = name.toUpperCase();\n forge.cipher.algorithms[name] = algorithm;\n};\n\n/**\n * Gets a registered algorithm by name.\n *\n * @param name the name of the algorithm.\n *\n * @return the algorithm, if found, null if not.\n */\nforge.cipher.getAlgorithm = function(name) {\n name = name.toUpperCase();\n if(name in forge.cipher.algorithms) {\n return forge.cipher.algorithms[name];\n }\n return null;\n};\n\nvar BlockCipher = forge.cipher.BlockCipher = function(options) {\n this.algorithm = options.algorithm;\n this.mode = this.algorithm.mode;\n this.blockSize = this.mode.blockSize;\n this._finish = false;\n this._input = null;\n this.output = null;\n this._op = options.decrypt ? this.mode.decrypt : this.mode.encrypt;\n this._decrypt = options.decrypt;\n this.algorithm.initialize(options);\n};\n\n/**\n * Starts or restarts the encryption or decryption process, whichever\n * was previously configured.\n *\n * For non-GCM mode, the IV may be a binary-encoded string of bytes, an array\n * of bytes, a byte buffer, or an array of 32-bit integers. If the IV is in\n * bytes, then it must be Nb (16) bytes in length. If the IV is given in as\n * 32-bit integers, then it must be 4 integers long.\n *\n * Note: an IV is not required or used in ECB mode.\n *\n * For GCM-mode, the IV must be given as a binary-encoded string of bytes or\n * a byte buffer. The number of bytes should be 12 (96 bits) as recommended\n * by NIST SP-800-38D but another length may be given.\n *\n * @param options the options to use:\n * iv the initialization vector to use as a binary-encoded string of\n * bytes, null to reuse the last ciphered block from a previous\n * update() (this \"residue\" method is for legacy support only).\n * additionalData additional authentication data as a binary-encoded\n * string of bytes, for 'GCM' mode, (default: none).\n * tagLength desired length of authentication tag, in bits, for\n * 'GCM' mode (0-128, default: 128).\n * tag the authentication tag to check if decrypting, as a\n * binary-encoded string of bytes.\n * output the output the buffer to write to, null to create one.\n */\nBlockCipher.prototype.start = function(options) {\n options = options || {};\n var opts = {};\n for(var key in options) {\n opts[key] = options[key];\n }\n opts.decrypt = this._decrypt;\n this._finish = false;\n this._input = forge.util.createBuffer();\n this.output = options.output || forge.util.createBuffer();\n this.mode.start(opts);\n};\n\n/**\n * Updates the next block according to the cipher mode.\n *\n * @param input the buffer to read from.\n */\nBlockCipher.prototype.update = function(input) {\n if(input) {\n // input given, so empty it into the input buffer\n this._input.putBuffer(input);\n }\n\n // do cipher operation until it needs more input and not finished\n while(!this._op.call(this.mode, this._input, this.output, this._finish) &&\n !this._finish) {}\n\n // free consumed memory from input buffer\n this._input.compact();\n};\n\n/**\n * Finishes encrypting or decrypting.\n *\n * @param pad a padding function to use in CBC mode, null for default,\n * signature(blockSize, buffer, decrypt).\n *\n * @return true if successful, false on error.\n */\nBlockCipher.prototype.finish = function(pad) {\n // backwards-compatibility w/deprecated padding API\n // Note: will overwrite padding functions even after another start() call\n if(pad && (this.mode.name === 'ECB' || this.mode.name === 'CBC')) {\n this.mode.pad = function(input) {\n return pad(this.blockSize, input, false);\n };\n this.mode.unpad = function(output) {\n return pad(this.blockSize, output, true);\n };\n }\n\n // build options for padding and afterFinish functions\n var options = {};\n options.decrypt = this._decrypt;\n\n // get # of bytes that won't fill a block\n options.overflow = this._input.length() % this.blockSize;\n\n if(!this._decrypt && this.mode.pad) {\n if(!this.mode.pad(this._input, options)) {\n return false;\n }\n }\n\n // do final update\n this._finish = true;\n this.update();\n\n if(this._decrypt && this.mode.unpad) {\n if(!this.mode.unpad(this.output, options)) {\n return false;\n }\n }\n\n if(this.mode.afterFinish) {\n if(!this.mode.afterFinish(this.output, options)) {\n return false;\n }\n }\n\n return true;\n};\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things. But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals. It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n throw new Error('clearTimeout has not been defined');\n}\n(function () {\n try {\n if (typeof setTimeout === 'function') {\n cachedSetTimeout = setTimeout;\n } else {\n cachedSetTimeout = defaultSetTimout;\n }\n } catch (e) {\n cachedSetTimeout = defaultSetTimout;\n }\n try {\n if (typeof clearTimeout === 'function') {\n cachedClearTimeout = clearTimeout;\n } else {\n cachedClearTimeout = defaultClearTimeout;\n }\n } catch (e) {\n cachedClearTimeout = defaultClearTimeout;\n }\n} ())\nfunction runTimeout(fun) {\n if (cachedSetTimeout === setTimeout) {\n //normal enviroments in sane situations\n return setTimeout(fun, 0);\n }\n // if setTimeout wasn't available but was latter defined\n if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n cachedSetTimeout = setTimeout;\n return setTimeout(fun, 0);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedSetTimeout(fun, 0);\n } catch(e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedSetTimeout.call(null, fun, 0);\n } catch(e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n return cachedSetTimeout.call(this, fun, 0);\n }\n }\n\n\n}\nfunction runClearTimeout(marker) {\n if (cachedClearTimeout === clearTimeout) {\n //normal enviroments in sane situations\n return clearTimeout(marker);\n }\n // if clearTimeout wasn't available but was latter defined\n if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n cachedClearTimeout = clearTimeout;\n return clearTimeout(marker);\n }\n try {\n // when when somebody has screwed with setTimeout but no I.E. maddness\n return cachedClearTimeout(marker);\n } catch (e){\n try {\n // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n return cachedClearTimeout.call(null, marker);\n } catch (e){\n // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n return cachedClearTimeout.call(this, marker);\n }\n }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = runTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n runTimeout(drainQueue);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","/**\n * Message Digest Algorithm 5 with 128-bit digest (MD5) implementation.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar md5 = module.exports = forge.md5 = forge.md5 || {};\nforge.md.md5 = forge.md.algorithms.md5 = md5;\n\n/**\n * Creates an MD5 message digest object.\n *\n * @return a message digest object.\n */\nmd5.create = function() {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n // MD5 state contains four 32-bit integers\n var _state = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for word storage\n var _w = new Array(16);\n\n // message digest object\n var md = {\n algorithm: 'md5',\n blockLength: 64,\n digestLength: 16,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 8\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength64 for backwards-compatibility)\n md.fullMessageLength = md.messageLength64 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _state = {\n h0: 0x67452301,\n h1: 0xEFCDAB89,\n h2: 0x98BADCFE,\n h3: 0x10325476\n };\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = (len[1] / 0x100000000) >>> 0;\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_state, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate MD5 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 448 mod 512. In other words,\n the data to be digested must be a multiple of 512 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 8 bytes (64\n bits), that means that the last segment of the data must have 56 bytes\n (448 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 448 mod 512 because\n 512 - 128 = 448.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 448 mod 512, then 512 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in little-endian order; since length\n // is stored in bytes we multiply by 8 and add carry\n var bits, carry = 0;\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n bits = md.fullMessageLength[i] * 8 + carry;\n carry = (bits / 0x100000000) >>> 0;\n finalBlock.putInt32Le(bits >>> 0);\n }\n\n var s2 = {\n h0: _state.h0,\n h1: _state.h1,\n h2: _state.h2,\n h3: _state.h3\n };\n _update(s2, _w, finalBlock);\n var rval = forge.util.createBuffer();\n rval.putInt32Le(s2.h0);\n rval.putInt32Le(s2.h1);\n rval.putInt32Le(s2.h2);\n rval.putInt32Le(s2.h3);\n return rval;\n };\n\n return md;\n};\n\n// padding, constant tables for calculating md5\nvar _padding = null;\nvar _g = null;\nvar _r = null;\nvar _k = null;\nvar _initialized = false;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 64);\n\n // g values\n _g = [\n 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n 1, 6, 11, 0, 5, 10, 15, 4, 9, 14, 3, 8, 13, 2, 7, 12,\n 5, 8, 11, 14, 1, 4, 7, 10, 13, 0, 3, 6, 9, 12, 15, 2,\n 0, 7, 14, 5, 12, 3, 10, 1, 8, 15, 6, 13, 4, 11, 2, 9];\n\n // rounds table\n _r = [\n 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22, 7, 12, 17, 22,\n 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20, 5, 9, 14, 20,\n 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23, 4, 11, 16, 23,\n 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21, 6, 10, 15, 21];\n\n // get the result of abs(sin(i + 1)) as a 32-bit integer\n _k = new Array(64);\n for(var i = 0; i < 64; ++i) {\n _k[i] = Math.floor(Math.abs(Math.sin(i + 1)) * 0x100000000);\n }\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates an MD5 state with the given byte buffer.\n *\n * @param s the MD5 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (64 byte) chunks\n var t, a, b, c, d, f, r, i;\n var len = bytes.length();\n while(len >= 64) {\n // initialize hash value for this chunk\n a = s.h0;\n b = s.h1;\n c = s.h2;\n d = s.h3;\n\n // round 1\n for(i = 0; i < 16; ++i) {\n w[i] = bytes.getInt32Le();\n f = d ^ (b & (c ^ d));\n t = (a + f + _k[i] + w[i]);\n r = _r[i];\n a = d;\n d = c;\n c = b;\n b += (t << r) | (t >>> (32 - r));\n }\n // round 2\n for(; i < 32; ++i) {\n f = c ^ (d & (b ^ c));\n t = (a + f + _k[i] + w[_g[i]]);\n r = _r[i];\n a = d;\n d = c;\n c = b;\n b += (t << r) | (t >>> (32 - r));\n }\n // round 3\n for(; i < 48; ++i) {\n f = b ^ c ^ d;\n t = (a + f + _k[i] + w[_g[i]]);\n r = _r[i];\n a = d;\n d = c;\n c = b;\n b += (t << r) | (t >>> (32 - r));\n }\n // round 4\n for(; i < 64; ++i) {\n f = c ^ (b | ~d);\n t = (a + f + _k[i] + w[_g[i]]);\n r = _r[i];\n a = d;\n d = c;\n c = b;\n b += (t << r) | (t >>> (32 - r));\n }\n\n // update hash state\n s.h0 = (s.h0 + a) | 0;\n s.h1 = (s.h1 + b) | 0;\n s.h2 = (s.h2 + c) | 0;\n s.h3 = (s.h3 + d) | 0;\n\n len -= 64;\n }\n}\n","/**\n * Javascript implementation of a basic Public Key Infrastructure, including\n * support for RSA public and private keys.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./oids');\nrequire('./pbe');\nrequire('./pem');\nrequire('./pbkdf2');\nrequire('./pkcs12');\nrequire('./pss');\nrequire('./rsa');\nrequire('./util');\nrequire('./x509');\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n/* Public Key Infrastructure (PKI) implementation. */\nvar pki = module.exports = forge.pki = forge.pki || {};\n\n/**\n * NOTE: THIS METHOD IS DEPRECATED. Use pem.decode() instead.\n *\n * Converts PEM-formatted data to DER.\n *\n * @param pem the PEM-formatted data.\n *\n * @return the DER-formatted data.\n */\npki.pemToDer = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert PEM to DER; PEM is encrypted.');\n }\n return forge.util.createBuffer(msg.body);\n};\n\n/**\n * Converts an RSA private key from PEM format.\n *\n * @param pem the PEM-formatted private key.\n *\n * @return the private key.\n */\npki.privateKeyFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'PRIVATE KEY' && msg.type !== 'RSA PRIVATE KEY') {\n var error = new Error('Could not convert private key from PEM; PEM ' +\n 'header type is not \"PRIVATE KEY\" or \"RSA PRIVATE KEY\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert private key from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body);\n\n return pki.privateKeyFromAsn1(obj);\n};\n\n/**\n * Converts an RSA private key to PEM format.\n *\n * @param key the private key.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted private key.\n */\npki.privateKeyToPem = function(key, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'RSA PRIVATE KEY',\n body: asn1.toDer(pki.privateKeyToAsn1(key)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts a PrivateKeyInfo to PEM format.\n *\n * @param pki the PrivateKeyInfo.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted private key.\n */\npki.privateKeyInfoToPem = function(pki, maxline) {\n // convert to DER, then PEM-encode\n var msg = {\n type: 'PRIVATE KEY',\n body: asn1.toDer(pki).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n","/**\n * Password-Based Key-Derivation Function #2 implementation.\n *\n * See RFC 2898 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./hmac');\nrequire('./md');\nrequire('./util');\n\nvar pkcs5 = forge.pkcs5 = forge.pkcs5 || {};\n\nvar crypto;\nif(forge.util.isNodejs && !forge.options.usePureJavaScript) {\n crypto = require('crypto');\n}\n\n/**\n * Derives a key from a password.\n *\n * @param p the password as a binary-encoded string of bytes.\n * @param s the salt as a binary-encoded string of bytes.\n * @param c the iteration count, a positive integer.\n * @param dkLen the intended length, in bytes, of the derived key,\n * (max: 2^32 - 1) * hash length of the PRF.\n * @param [md] the message digest (or algorithm identifier as a string) to use\n * in the PRF, defaults to SHA-1.\n * @param [callback(err, key)] presence triggers asynchronous version, called\n * once the operation completes.\n *\n * @return the derived key, as a binary-encoded string of bytes, for the\n * synchronous version (if no callback is specified).\n */\nmodule.exports = forge.pbkdf2 = pkcs5.pbkdf2 = function(\n p, s, c, dkLen, md, callback) {\n if(typeof md === 'function') {\n callback = md;\n md = null;\n }\n\n // use native implementation if possible and not disabled, note that\n // some node versions only support SHA-1, others allow digest to be changed\n if(forge.util.isNodejs && !forge.options.usePureJavaScript &&\n crypto.pbkdf2 && (md === null || typeof md !== 'object') &&\n (crypto.pbkdf2Sync.length > 4 || (!md || md === 'sha1'))) {\n if(typeof md !== 'string') {\n // default prf to SHA-1\n md = 'sha1';\n }\n p = Buffer.from(p, 'binary');\n s = Buffer.from(s, 'binary');\n if(!callback) {\n if(crypto.pbkdf2Sync.length === 4) {\n return crypto.pbkdf2Sync(p, s, c, dkLen).toString('binary');\n }\n return crypto.pbkdf2Sync(p, s, c, dkLen, md).toString('binary');\n }\n if(crypto.pbkdf2Sync.length === 4) {\n return crypto.pbkdf2(p, s, c, dkLen, function(err, key) {\n if(err) {\n return callback(err);\n }\n callback(null, key.toString('binary'));\n });\n }\n return crypto.pbkdf2(p, s, c, dkLen, md, function(err, key) {\n if(err) {\n return callback(err);\n }\n callback(null, key.toString('binary'));\n });\n }\n\n if(typeof md === 'undefined' || md === null) {\n // default prf to SHA-1\n md = 'sha1';\n }\n if(typeof md === 'string') {\n if(!(md in forge.md.algorithms)) {\n throw new Error('Unknown hash algorithm: ' + md);\n }\n md = forge.md[md].create();\n }\n\n var hLen = md.digestLength;\n\n /* 1. If dkLen > (2^32 - 1) * hLen, output \"derived key too long\" and\n stop. */\n if(dkLen > (0xFFFFFFFF * hLen)) {\n var err = new Error('Derived key is too long.');\n if(callback) {\n return callback(err);\n }\n throw err;\n }\n\n /* 2. Let len be the number of hLen-octet blocks in the derived key,\n rounding up, and let r be the number of octets in the last\n block:\n\n len = CEIL(dkLen / hLen),\n r = dkLen - (len - 1) * hLen. */\n var len = Math.ceil(dkLen / hLen);\n var r = dkLen - (len - 1) * hLen;\n\n /* 3. For each block of the derived key apply the function F defined\n below to the password P, the salt S, the iteration count c, and\n the block index to compute the block:\n\n T_1 = F(P, S, c, 1),\n T_2 = F(P, S, c, 2),\n ...\n T_len = F(P, S, c, len),\n\n where the function F is defined as the exclusive-or sum of the\n first c iterates of the underlying pseudorandom function PRF\n applied to the password P and the concatenation of the salt S\n and the block index i:\n\n F(P, S, c, i) = u_1 XOR u_2 XOR ... XOR u_c\n\n where\n\n u_1 = PRF(P, S || INT(i)),\n u_2 = PRF(P, u_1),\n ...\n u_c = PRF(P, u_{c-1}).\n\n Here, INT(i) is a four-octet encoding of the integer i, most\n significant octet first. */\n var prf = forge.hmac.create();\n prf.start(md, p);\n var dk = '';\n var xor, u_c, u_c1;\n\n // sync version\n if(!callback) {\n for(var i = 1; i <= len; ++i) {\n // PRF(P, S || INT(i)) (first iteration)\n prf.start(null, null);\n prf.update(s);\n prf.update(forge.util.int32ToBytes(i));\n xor = u_c1 = prf.digest().getBytes();\n\n // PRF(P, u_{c-1}) (other iterations)\n for(var j = 2; j <= c; ++j) {\n prf.start(null, null);\n prf.update(u_c1);\n u_c = prf.digest().getBytes();\n // F(p, s, c, i)\n xor = forge.util.xorBytes(xor, u_c, hLen);\n u_c1 = u_c;\n }\n\n /* 4. Concatenate the blocks and extract the first dkLen octets to\n produce a derived key DK:\n\n DK = T_1 || T_2 || ... || T_len<0..r-1> */\n dk += (i < len) ? xor : xor.substr(0, r);\n }\n /* 5. Output the derived key DK. */\n return dk;\n }\n\n // async version\n var i = 1, j;\n function outer() {\n if(i > len) {\n // done\n return callback(null, dk);\n }\n\n // PRF(P, S || INT(i)) (first iteration)\n prf.start(null, null);\n prf.update(s);\n prf.update(forge.util.int32ToBytes(i));\n xor = u_c1 = prf.digest().getBytes();\n\n // PRF(P, u_{c-1}) (other iterations)\n j = 2;\n inner();\n }\n\n function inner() {\n if(j <= c) {\n prf.start(null, null);\n prf.update(u_c1);\n u_c = prf.digest().getBytes();\n // F(p, s, c, i)\n xor = forge.util.xorBytes(xor, u_c, hLen);\n u_c1 = u_c;\n ++j;\n return forge.util.setImmediate(inner);\n }\n\n /* 4. Concatenate the blocks and extract the first dkLen octets to\n produce a derived key DK:\n\n DK = T_1 || T_2 || ... || T_len<0..r-1> */\n dk += (i < len) ? xor : xor.substr(0, r);\n\n ++i;\n outer();\n }\n\n outer();\n};\n","/**\n * Javascript implementation of PKCS#12.\n *\n * @author Dave Longley\n * @author Stefan Siegl <stesie@brokenpipe.de>\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * The ASN.1 representation of PKCS#12 is as follows\n * (see ftp://ftp.rsasecurity.com/pub/pkcs/pkcs-12/pkcs-12-tc1.pdf for details)\n *\n * PFX ::= SEQUENCE {\n * version INTEGER {v3(3)}(v3,...),\n * authSafe ContentInfo,\n * macData MacData OPTIONAL\n * }\n *\n * MacData ::= SEQUENCE {\n * mac DigestInfo,\n * macSalt OCTET STRING,\n * iterations INTEGER DEFAULT 1\n * }\n * Note: The iterations default is for historical reasons and its use is\n * deprecated. A higher value, like 1024, is recommended.\n *\n * DigestInfo is defined in PKCS#7 as follows:\n *\n * DigestInfo ::= SEQUENCE {\n * digestAlgorithm DigestAlgorithmIdentifier,\n * digest Digest\n * }\n *\n * DigestAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of SHA1 there is none.\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * Digest ::= OCTET STRING\n *\n *\n * ContentInfo ::= SEQUENCE {\n * contentType ContentType,\n * content [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL\n * }\n *\n * ContentType ::= OBJECT IDENTIFIER\n *\n * AuthenticatedSafe ::= SEQUENCE OF ContentInfo\n * -- Data if unencrypted\n * -- EncryptedData if password-encrypted\n * -- EnvelopedData if public key-encrypted\n *\n *\n * SafeContents ::= SEQUENCE OF SafeBag\n *\n * SafeBag ::= SEQUENCE {\n * bagId BAG-TYPE.&id ({PKCS12BagSet})\n * bagValue [0] EXPLICIT BAG-TYPE.&Type({PKCS12BagSet}{@bagId}),\n * bagAttributes SET OF PKCS12Attribute OPTIONAL\n * }\n *\n * PKCS12Attribute ::= SEQUENCE {\n * attrId ATTRIBUTE.&id ({PKCS12AttrSet}),\n * attrValues SET OF ATTRIBUTE.&Type ({PKCS12AttrSet}{@attrId})\n * } -- This type is compatible with the X.500 type 'Attribute'\n *\n * PKCS12AttrSet ATTRIBUTE ::= {\n * friendlyName | -- from PKCS #9\n * localKeyId, -- from PKCS #9\n * ... -- Other attributes are allowed\n * }\n *\n * CertBag ::= SEQUENCE {\n * certId BAG-TYPE.&id ({CertTypes}),\n * certValue [0] EXPLICIT BAG-TYPE.&Type ({CertTypes}{@certId})\n * }\n *\n * x509Certificate BAG-TYPE ::= {OCTET STRING IDENTIFIED BY {certTypes 1}}\n * -- DER-encoded X.509 certificate stored in OCTET STRING\n *\n * sdsiCertificate BAG-TYPE ::= {IA5String IDENTIFIED BY {certTypes 2}}\n * -- Base64-encoded SDSI certificate stored in IA5String\n *\n * CertTypes BAG-TYPE ::= {\n * x509Certificate |\n * sdsiCertificate,\n * ... -- For future extensions\n * }\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./hmac');\nrequire('./oids');\nrequire('./pkcs7asn1');\nrequire('./pbe');\nrequire('./random');\nrequire('./rsa');\nrequire('./sha1');\nrequire('./util');\nrequire('./x509');\n\n// shortcut for asn.1 & PKI API\nvar asn1 = forge.asn1;\nvar pki = forge.pki;\n\n// shortcut for PKCS#12 API\nvar p12 = module.exports = forge.pkcs12 = forge.pkcs12 || {};\n\nvar contentInfoValidator = {\n name: 'ContentInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE, // a ContentInfo\n constructed: true,\n value: [{\n name: 'ContentInfo.contentType',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'contentType'\n }, {\n name: 'ContentInfo.content',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n constructed: true,\n captureAsn1: 'content'\n }]\n};\n\nvar pfxValidator = {\n name: 'PFX',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PFX.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n },\n contentInfoValidator, {\n name: 'PFX.macData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n captureAsn1: 'mac',\n value: [{\n name: 'PFX.macData.mac',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE, // DigestInfo\n constructed: true,\n value: [{\n name: 'PFX.macData.mac.digestAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE, // DigestAlgorithmIdentifier\n constructed: true,\n value: [{\n name: 'PFX.macData.mac.digestAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'macAlgorithm'\n }, {\n name: 'PFX.macData.mac.digestAlgorithm.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n captureAsn1: 'macAlgorithmParameters'\n }]\n }, {\n name: 'PFX.macData.mac.digest',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'macDigest'\n }]\n }, {\n name: 'PFX.macData.macSalt',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'macSalt'\n }, {\n name: 'PFX.macData.iterations',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n optional: true,\n capture: 'macIterations'\n }]\n }]\n};\n\nvar safeBagValidator = {\n name: 'SafeBag',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SafeBag.bagId',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'bagId'\n }, {\n name: 'SafeBag.bagValue',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n constructed: true,\n captureAsn1: 'bagValue'\n }, {\n name: 'SafeBag.bagAttributes',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n optional: true,\n capture: 'bagAttributes'\n }]\n};\n\nvar attributeValidator = {\n name: 'Attribute',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'Attribute.attrId',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'oid'\n }, {\n name: 'Attribute.attrValues',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n capture: 'values'\n }]\n};\n\nvar certBagValidator = {\n name: 'CertBag',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'CertBag.certId',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'certId'\n }, {\n name: 'CertBag.certValue',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n constructed: true,\n /* So far we only support X.509 certificates (which are wrapped in\n an OCTET STRING, hence hard code that here). */\n value: [{\n name: 'CertBag.certValue[0]',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.OCTETSTRING,\n constructed: false,\n capture: 'cert'\n }]\n }]\n};\n\n/**\n * Search SafeContents structure for bags with matching attributes.\n *\n * The search can optionally be narrowed by a certain bag type.\n *\n * @param safeContents the SafeContents structure to search in.\n * @param attrName the name of the attribute to compare against.\n * @param attrValue the attribute value to search for.\n * @param [bagType] bag type to narrow search by.\n *\n * @return an array of matching bags.\n */\nfunction _getBagsByAttribute(safeContents, attrName, attrValue, bagType) {\n var result = [];\n\n for(var i = 0; i < safeContents.length; i++) {\n for(var j = 0; j < safeContents[i].safeBags.length; j++) {\n var bag = safeContents[i].safeBags[j];\n if(bagType !== undefined && bag.type !== bagType) {\n continue;\n }\n // only filter by bag type, no attribute specified\n if(attrName === null) {\n result.push(bag);\n continue;\n }\n if(bag.attributes[attrName] !== undefined &&\n bag.attributes[attrName].indexOf(attrValue) >= 0) {\n result.push(bag);\n }\n }\n }\n\n return result;\n}\n\n/**\n * Converts a PKCS#12 PFX in ASN.1 notation into a PFX object.\n *\n * @param obj The PKCS#12 PFX in ASN.1 notation.\n * @param strict true to use strict DER decoding, false not to (default: true).\n * @param {String} password Password to decrypt with (optional).\n *\n * @return PKCS#12 PFX object.\n */\np12.pkcs12FromAsn1 = function(obj, strict, password) {\n // handle args\n if(typeof strict === 'string') {\n password = strict;\n strict = true;\n } else if(strict === undefined) {\n strict = true;\n }\n\n // validate PFX and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, pfxValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#12 PFX. ' +\n 'ASN.1 object is not an PKCS#12 PFX.');\n error.errors = error;\n throw error;\n }\n\n var pfx = {\n version: capture.version.charCodeAt(0),\n safeContents: [],\n\n /**\n * Gets bags with matching attributes.\n *\n * @param filter the attributes to filter by:\n * [localKeyId] the localKeyId to search for.\n * [localKeyIdHex] the localKeyId in hex to search for.\n * [friendlyName] the friendly name to search for.\n * [bagType] bag type to narrow each attribute search by.\n *\n * @return a map of attribute type to an array of matching bags or, if no\n * attribute was given but a bag type, the map key will be the\n * bag type.\n */\n getBags: function(filter) {\n var rval = {};\n\n var localKeyId;\n if('localKeyId' in filter) {\n localKeyId = filter.localKeyId;\n } else if('localKeyIdHex' in filter) {\n localKeyId = forge.util.hexToBytes(filter.localKeyIdHex);\n }\n\n // filter on bagType only\n if(localKeyId === undefined && !('friendlyName' in filter) &&\n 'bagType' in filter) {\n rval[filter.bagType] = _getBagsByAttribute(\n pfx.safeContents, null, null, filter.bagType);\n }\n\n if(localKeyId !== undefined) {\n rval.localKeyId = _getBagsByAttribute(\n pfx.safeContents, 'localKeyId',\n localKeyId, filter.bagType);\n }\n if('friendlyName' in filter) {\n rval.friendlyName = _getBagsByAttribute(\n pfx.safeContents, 'friendlyName',\n filter.friendlyName, filter.bagType);\n }\n\n return rval;\n },\n\n /**\n * DEPRECATED: use getBags() instead.\n *\n * Get bags with matching friendlyName attribute.\n *\n * @param friendlyName the friendly name to search for.\n * @param [bagType] bag type to narrow search by.\n *\n * @return an array of bags with matching friendlyName attribute.\n */\n getBagsByFriendlyName: function(friendlyName, bagType) {\n return _getBagsByAttribute(\n pfx.safeContents, 'friendlyName', friendlyName, bagType);\n },\n\n /**\n * DEPRECATED: use getBags() instead.\n *\n * Get bags with matching localKeyId attribute.\n *\n * @param localKeyId the localKeyId to search for.\n * @param [bagType] bag type to narrow search by.\n *\n * @return an array of bags with matching localKeyId attribute.\n */\n getBagsByLocalKeyId: function(localKeyId, bagType) {\n return _getBagsByAttribute(\n pfx.safeContents, 'localKeyId', localKeyId, bagType);\n }\n };\n\n if(capture.version.charCodeAt(0) !== 3) {\n var error = new Error('PKCS#12 PFX of version other than 3 not supported.');\n error.version = capture.version.charCodeAt(0);\n throw error;\n }\n\n if(asn1.derToOid(capture.contentType) !== pki.oids.data) {\n var error = new Error('Only PKCS#12 PFX in password integrity mode supported.');\n error.oid = asn1.derToOid(capture.contentType);\n throw error;\n }\n\n var data = capture.content.value[0];\n if(data.tagClass !== asn1.Class.UNIVERSAL ||\n data.type !== asn1.Type.OCTETSTRING) {\n throw new Error('PKCS#12 authSafe content data is not an OCTET STRING.');\n }\n data = _decodePkcs7Data(data);\n\n // check for MAC\n if(capture.mac) {\n var md = null;\n var macKeyBytes = 0;\n var macAlgorithm = asn1.derToOid(capture.macAlgorithm);\n switch(macAlgorithm) {\n case pki.oids.sha1:\n md = forge.md.sha1.create();\n macKeyBytes = 20;\n break;\n case pki.oids.sha256:\n md = forge.md.sha256.create();\n macKeyBytes = 32;\n break;\n case pki.oids.sha384:\n md = forge.md.sha384.create();\n macKeyBytes = 48;\n break;\n case pki.oids.sha512:\n md = forge.md.sha512.create();\n macKeyBytes = 64;\n break;\n case pki.oids.md5:\n md = forge.md.md5.create();\n macKeyBytes = 16;\n break;\n }\n if(md === null) {\n throw new Error('PKCS#12 uses unsupported MAC algorithm: ' + macAlgorithm);\n }\n\n // verify MAC (iterations default to 1)\n var macSalt = new forge.util.ByteBuffer(capture.macSalt);\n var macIterations = (('macIterations' in capture) ?\n parseInt(forge.util.bytesToHex(capture.macIterations), 16) : 1);\n var macKey = p12.generateKey(\n password, macSalt, 3, macIterations, macKeyBytes, md);\n var mac = forge.hmac.create();\n mac.start(md, macKey);\n mac.update(data.value);\n var macValue = mac.getMac();\n if(macValue.getBytes() !== capture.macDigest) {\n throw new Error('PKCS#12 MAC could not be verified. Invalid password?');\n }\n }\n\n _decodeAuthenticatedSafe(pfx, data.value, strict, password);\n return pfx;\n};\n\n/**\n * Decodes PKCS#7 Data. PKCS#7 (RFC 2315) defines \"Data\" as an OCTET STRING,\n * but it is sometimes an OCTET STRING that is composed/constructed of chunks,\n * each its own OCTET STRING. This is BER-encoding vs. DER-encoding. This\n * function transforms this corner-case into the usual simple,\n * non-composed/constructed OCTET STRING.\n *\n * This function may be moved to ASN.1 at some point to better deal with\n * more BER-encoding issues, should they arise.\n *\n * @param data the ASN.1 Data object to transform.\n */\nfunction _decodePkcs7Data(data) {\n // handle special case of \"chunked\" data content: an octet string composed\n // of other octet strings\n if(data.composed || data.constructed) {\n var value = forge.util.createBuffer();\n for(var i = 0; i < data.value.length; ++i) {\n value.putBytes(data.value[i].value);\n }\n data.composed = data.constructed = false;\n data.value = value.getBytes();\n }\n return data;\n}\n\n/**\n * Decode PKCS#12 AuthenticatedSafe (BER encoded) into PFX object.\n *\n * The AuthenticatedSafe is a BER-encoded SEQUENCE OF ContentInfo.\n *\n * @param pfx The PKCS#12 PFX object to fill.\n * @param {String} authSafe BER-encoded AuthenticatedSafe.\n * @param strict true to use strict DER decoding, false not to.\n * @param {String} password Password to decrypt with (optional).\n */\nfunction _decodeAuthenticatedSafe(pfx, authSafe, strict, password) {\n authSafe = asn1.fromDer(authSafe, strict); /* actually it's BER encoded */\n\n if(authSafe.tagClass !== asn1.Class.UNIVERSAL ||\n authSafe.type !== asn1.Type.SEQUENCE ||\n authSafe.constructed !== true) {\n throw new Error('PKCS#12 AuthenticatedSafe expected to be a ' +\n 'SEQUENCE OF ContentInfo');\n }\n\n for(var i = 0; i < authSafe.value.length; i++) {\n var contentInfo = authSafe.value[i];\n\n // validate contentInfo and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(contentInfo, contentInfoValidator, capture, errors)) {\n var error = new Error('Cannot read ContentInfo.');\n error.errors = errors;\n throw error;\n }\n\n var obj = {\n encrypted: false\n };\n var safeContents = null;\n var data = capture.content.value[0];\n switch(asn1.derToOid(capture.contentType)) {\n case pki.oids.data:\n if(data.tagClass !== asn1.Class.UNIVERSAL ||\n data.type !== asn1.Type.OCTETSTRING) {\n throw new Error('PKCS#12 SafeContents Data is not an OCTET STRING.');\n }\n safeContents = _decodePkcs7Data(data).value;\n break;\n case pki.oids.encryptedData:\n safeContents = _decryptSafeContents(data, password);\n obj.encrypted = true;\n break;\n default:\n var error = new Error('Unsupported PKCS#12 contentType.');\n error.contentType = asn1.derToOid(capture.contentType);\n throw error;\n }\n\n obj.safeBags = _decodeSafeContents(safeContents, strict, password);\n pfx.safeContents.push(obj);\n }\n}\n\n/**\n * Decrypt PKCS#7 EncryptedData structure.\n *\n * @param data ASN.1 encoded EncryptedContentInfo object.\n * @param password The user-provided password.\n *\n * @return The decrypted SafeContents (ASN.1 object).\n */\nfunction _decryptSafeContents(data, password) {\n var capture = {};\n var errors = [];\n if(!asn1.validate(\n data, forge.pkcs7.asn1.encryptedDataValidator, capture, errors)) {\n var error = new Error('Cannot read EncryptedContentInfo.');\n error.errors = errors;\n throw error;\n }\n\n var oid = asn1.derToOid(capture.contentType);\n if(oid !== pki.oids.data) {\n var error = new Error(\n 'PKCS#12 EncryptedContentInfo ContentType is not Data.');\n error.oid = oid;\n throw error;\n }\n\n // get cipher\n oid = asn1.derToOid(capture.encAlgorithm);\n var cipher = pki.pbe.getCipher(oid, capture.encParameter, password);\n\n // get encrypted data\n var encryptedContentAsn1 = _decodePkcs7Data(capture.encryptedContentAsn1);\n var encrypted = forge.util.createBuffer(encryptedContentAsn1.value);\n\n cipher.update(encrypted);\n if(!cipher.finish()) {\n throw new Error('Failed to decrypt PKCS#12 SafeContents.');\n }\n\n return cipher.output.getBytes();\n}\n\n/**\n * Decode PKCS#12 SafeContents (BER-encoded) into array of Bag objects.\n *\n * The safeContents is a BER-encoded SEQUENCE OF SafeBag.\n *\n * @param {String} safeContents BER-encoded safeContents.\n * @param strict true to use strict DER decoding, false not to.\n * @param {String} password Password to decrypt with (optional).\n *\n * @return {Array} Array of Bag objects.\n */\nfunction _decodeSafeContents(safeContents, strict, password) {\n // if strict and no safe contents, return empty safes\n if(!strict && safeContents.length === 0) {\n return [];\n }\n\n // actually it's BER-encoded\n safeContents = asn1.fromDer(safeContents, strict);\n\n if(safeContents.tagClass !== asn1.Class.UNIVERSAL ||\n safeContents.type !== asn1.Type.SEQUENCE ||\n safeContents.constructed !== true) {\n throw new Error(\n 'PKCS#12 SafeContents expected to be a SEQUENCE OF SafeBag.');\n }\n\n var res = [];\n for(var i = 0; i < safeContents.value.length; i++) {\n var safeBag = safeContents.value[i];\n\n // validate SafeBag and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(safeBag, safeBagValidator, capture, errors)) {\n var error = new Error('Cannot read SafeBag.');\n error.errors = errors;\n throw error;\n }\n\n /* Create bag object and push to result array. */\n var bag = {\n type: asn1.derToOid(capture.bagId),\n attributes: _decodeBagAttributes(capture.bagAttributes)\n };\n res.push(bag);\n\n var validator, decoder;\n var bagAsn1 = capture.bagValue.value[0];\n switch(bag.type) {\n case pki.oids.pkcs8ShroudedKeyBag:\n /* bagAsn1 has a EncryptedPrivateKeyInfo, which we need to decrypt.\n Afterwards we can handle it like a keyBag,\n which is a PrivateKeyInfo. */\n bagAsn1 = pki.decryptPrivateKeyInfo(bagAsn1, password);\n if(bagAsn1 === null) {\n throw new Error(\n 'Unable to decrypt PKCS#8 ShroudedKeyBag, wrong password?');\n }\n\n /* fall through */\n case pki.oids.keyBag:\n /* A PKCS#12 keyBag is a simple PrivateKeyInfo as understood by our\n PKI module, hence we don't have to do validation/capturing here,\n just pass what we already got. */\n try {\n bag.key = pki.privateKeyFromAsn1(bagAsn1);\n } catch(e) {\n // ignore unknown key type, pass asn1 value\n bag.key = null;\n bag.asn1 = bagAsn1;\n }\n continue; /* Nothing more to do. */\n\n case pki.oids.certBag:\n /* A PKCS#12 certBag can wrap both X.509 and sdsi certificates.\n Therefore put the SafeBag content through another validator to\n capture the fields. Afterwards check & store the results. */\n validator = certBagValidator;\n decoder = function() {\n if(asn1.derToOid(capture.certId) !== pki.oids.x509Certificate) {\n var error = new Error(\n 'Unsupported certificate type, only X.509 supported.');\n error.oid = asn1.derToOid(capture.certId);\n throw error;\n }\n\n // true=produce cert hash\n var certAsn1 = asn1.fromDer(capture.cert, strict);\n try {\n bag.cert = pki.certificateFromAsn1(certAsn1, true);\n } catch(e) {\n // ignore unknown cert type, pass asn1 value\n bag.cert = null;\n bag.asn1 = certAsn1;\n }\n };\n break;\n\n default:\n var error = new Error('Unsupported PKCS#12 SafeBag type.');\n error.oid = bag.type;\n throw error;\n }\n\n /* Validate SafeBag value (i.e. CertBag, etc.) and capture data if needed. */\n if(validator !== undefined &&\n !asn1.validate(bagAsn1, validator, capture, errors)) {\n var error = new Error('Cannot read PKCS#12 ' + validator.name);\n error.errors = errors;\n throw error;\n }\n\n /* Call decoder function from above to store the results. */\n decoder();\n }\n\n return res;\n}\n\n/**\n * Decode PKCS#12 SET OF PKCS12Attribute into JavaScript object.\n *\n * @param attributes SET OF PKCS12Attribute (ASN.1 object).\n *\n * @return the decoded attributes.\n */\nfunction _decodeBagAttributes(attributes) {\n var decodedAttrs = {};\n\n if(attributes !== undefined) {\n for(var i = 0; i < attributes.length; ++i) {\n var capture = {};\n var errors = [];\n if(!asn1.validate(attributes[i], attributeValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#12 BagAttribute.');\n error.errors = errors;\n throw error;\n }\n\n var oid = asn1.derToOid(capture.oid);\n if(pki.oids[oid] === undefined) {\n // unsupported attribute type, ignore.\n continue;\n }\n\n decodedAttrs[pki.oids[oid]] = [];\n for(var j = 0; j < capture.values.length; ++j) {\n decodedAttrs[pki.oids[oid]].push(capture.values[j].value);\n }\n }\n }\n\n return decodedAttrs;\n}\n\n/**\n * Wraps a private key and certificate in a PKCS#12 PFX wrapper. If a\n * password is provided then the private key will be encrypted.\n *\n * An entire certificate chain may also be included. To do this, pass\n * an array for the \"cert\" parameter where the first certificate is\n * the one that is paired with the private key and each subsequent one\n * verifies the previous one. The certificates may be in PEM format or\n * have been already parsed by Forge.\n *\n * @todo implement password-based-encryption for the whole package\n *\n * @param key the private key.\n * @param cert the certificate (may be an array of certificates in order\n * to specify a certificate chain).\n * @param password the password to use, null for none.\n * @param options:\n * algorithm the encryption algorithm to use\n * ('aes128', 'aes192', 'aes256', '3des'), defaults to 'aes128'.\n * count the iteration count to use.\n * saltSize the salt size to use.\n * useMac true to include a MAC, false not to, defaults to true.\n * localKeyId the local key ID to use, in hex.\n * friendlyName the friendly name to use.\n * generateLocalKeyId true to generate a random local key ID,\n * false not to, defaults to true.\n *\n * @return the PKCS#12 PFX ASN.1 object.\n */\np12.toPkcs12Asn1 = function(key, cert, password, options) {\n // set default options\n options = options || {};\n options.saltSize = options.saltSize || 8;\n options.count = options.count || 2048;\n options.algorithm = options.algorithm || options.encAlgorithm || 'aes128';\n if(!('useMac' in options)) {\n options.useMac = true;\n }\n if(!('localKeyId' in options)) {\n options.localKeyId = null;\n }\n if(!('generateLocalKeyId' in options)) {\n options.generateLocalKeyId = true;\n }\n\n var localKeyId = options.localKeyId;\n var bagAttrs;\n if(localKeyId !== null) {\n localKeyId = forge.util.hexToBytes(localKeyId);\n } else if(options.generateLocalKeyId) {\n // use SHA-1 of paired cert, if available\n if(cert) {\n var pairedCert = forge.util.isArray(cert) ? cert[0] : cert;\n if(typeof pairedCert === 'string') {\n pairedCert = pki.certificateFromPem(pairedCert);\n }\n var sha1 = forge.md.sha1.create();\n sha1.update(asn1.toDer(pki.certificateToAsn1(pairedCert)).getBytes());\n localKeyId = sha1.digest().getBytes();\n } else {\n // FIXME: consider using SHA-1 of public key (which can be generated\n // from private key components), see: cert.generateSubjectKeyIdentifier\n // generate random bytes\n localKeyId = forge.random.getBytes(20);\n }\n }\n\n var attrs = [];\n if(localKeyId !== null) {\n attrs.push(\n // localKeyID\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // attrId\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.localKeyId).getBytes()),\n // attrValues\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n localKeyId)\n ])\n ]));\n }\n if('friendlyName' in options) {\n attrs.push(\n // friendlyName\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // attrId\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.friendlyName).getBytes()),\n // attrValues\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BMPSTRING, false,\n options.friendlyName)\n ])\n ]));\n }\n\n if(attrs.length > 0) {\n bagAttrs = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, attrs);\n }\n\n // collect contents for AuthenticatedSafe\n var contents = [];\n\n // create safe bag(s) for certificate chain\n var chain = [];\n if(cert !== null) {\n if(forge.util.isArray(cert)) {\n chain = cert;\n } else {\n chain = [cert];\n }\n }\n\n var certSafeBags = [];\n for(var i = 0; i < chain.length; ++i) {\n // convert cert from PEM as necessary\n cert = chain[i];\n if(typeof cert === 'string') {\n cert = pki.certificateFromPem(cert);\n }\n\n // SafeBag\n var certBagAttrs = (i === 0) ? bagAttrs : undefined;\n var certAsn1 = pki.certificateToAsn1(cert);\n var certSafeBag =\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // bagId\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.certBag).getBytes()),\n // bagValue\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n // CertBag\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // certId\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.x509Certificate).getBytes()),\n // certValue (x509Certificate)\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n asn1.toDer(certAsn1).getBytes())\n ])])]),\n // bagAttributes (OPTIONAL)\n certBagAttrs\n ]);\n certSafeBags.push(certSafeBag);\n }\n\n if(certSafeBags.length > 0) {\n // SafeContents\n var certSafeContents = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, certSafeBags);\n\n // ContentInfo\n var certCI =\n // PKCS#7 ContentInfo\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // contentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n // OID for the content type is 'data'\n asn1.oidToDer(pki.oids.data).getBytes()),\n // content\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n asn1.toDer(certSafeContents).getBytes())\n ])\n ]);\n contents.push(certCI);\n }\n\n // create safe contents for private key\n var keyBag = null;\n if(key !== null) {\n // SafeBag\n var pkAsn1 = pki.wrapRsaPrivateKey(pki.privateKeyToAsn1(key));\n if(password === null) {\n // no encryption\n keyBag = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // bagId\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.keyBag).getBytes()),\n // bagValue\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n // PrivateKeyInfo\n pkAsn1\n ]),\n // bagAttributes (OPTIONAL)\n bagAttrs\n ]);\n } else {\n // encrypted PrivateKeyInfo\n keyBag = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // bagId\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.pkcs8ShroudedKeyBag).getBytes()),\n // bagValue\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n // EncryptedPrivateKeyInfo\n pki.encryptPrivateKeyInfo(pkAsn1, password, options)\n ]),\n // bagAttributes (OPTIONAL)\n bagAttrs\n ]);\n }\n\n // SafeContents\n var keySafeContents =\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [keyBag]);\n\n // ContentInfo\n var keyCI =\n // PKCS#7 ContentInfo\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // contentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n // OID for the content type is 'data'\n asn1.oidToDer(pki.oids.data).getBytes()),\n // content\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n asn1.toDer(keySafeContents).getBytes())\n ])\n ]);\n contents.push(keyCI);\n }\n\n // create AuthenticatedSafe by stringing together the contents\n var safe = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, contents);\n\n var macData;\n if(options.useMac) {\n // MacData\n var sha1 = forge.md.sha1.create();\n var macSalt = new forge.util.ByteBuffer(\n forge.random.getBytes(options.saltSize));\n var count = options.count;\n // 160-bit key\n var key = p12.generateKey(password, macSalt, 3, count, 20);\n var mac = forge.hmac.create();\n mac.start(sha1, key);\n mac.update(asn1.toDer(safe).getBytes());\n var macValue = mac.getMac();\n macData = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // mac DigestInfo\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // digestAlgorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm = SHA-1\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids.sha1).getBytes()),\n // parameters = Null\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // digest\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING,\n false, macValue.getBytes())\n ]),\n // macSalt OCTET STRING\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, macSalt.getBytes()),\n // iterations INTEGER (XXX: Only support count < 65536)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(count).getBytes()\n )\n ]);\n }\n\n // PFX\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version (3)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(3).getBytes()),\n // PKCS#7 ContentInfo\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // contentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n // OID for the content type is 'data'\n asn1.oidToDer(pki.oids.data).getBytes()),\n // content\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n asn1.toDer(safe).getBytes())\n ])\n ]),\n macData\n ]);\n};\n\n/**\n * Derives a PKCS#12 key.\n *\n * @param password the password to derive the key material from, null or\n * undefined for none.\n * @param salt the salt, as a ByteBuffer, to use.\n * @param id the PKCS#12 ID byte (1 = key material, 2 = IV, 3 = MAC).\n * @param iter the iteration count.\n * @param n the number of bytes to derive from the password.\n * @param md the message digest to use, defaults to SHA-1.\n *\n * @return a ByteBuffer with the bytes derived from the password.\n */\np12.generateKey = forge.pbe.generatePkcs12Key;\n","/**\n * Javascript implementation of X.509 and related components (such as\n * Certification Signing Requests) of a Public Key Infrastructure.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n *\n * The ASN.1 representation of an X.509v3 certificate is as follows\n * (see RFC 2459):\n *\n * Certificate ::= SEQUENCE {\n * tbsCertificate TBSCertificate,\n * signatureAlgorithm AlgorithmIdentifier,\n * signatureValue BIT STRING\n * }\n *\n * TBSCertificate ::= SEQUENCE {\n * version [0] EXPLICIT Version DEFAULT v1,\n * serialNumber CertificateSerialNumber,\n * signature AlgorithmIdentifier,\n * issuer Name,\n * validity Validity,\n * subject Name,\n * subjectPublicKeyInfo SubjectPublicKeyInfo,\n * issuerUniqueID [1] IMPLICIT UniqueIdentifier OPTIONAL,\n * -- If present, version shall be v2 or v3\n * subjectUniqueID [2] IMPLICIT UniqueIdentifier OPTIONAL,\n * -- If present, version shall be v2 or v3\n * extensions [3] EXPLICIT Extensions OPTIONAL\n * -- If present, version shall be v3\n * }\n *\n * Version ::= INTEGER { v1(0), v2(1), v3(2) }\n *\n * CertificateSerialNumber ::= INTEGER\n *\n * Name ::= CHOICE {\n * // only one possible choice for now\n * RDNSequence\n * }\n *\n * RDNSequence ::= SEQUENCE OF RelativeDistinguishedName\n *\n * RelativeDistinguishedName ::= SET OF AttributeTypeAndValue\n *\n * AttributeTypeAndValue ::= SEQUENCE {\n * type AttributeType,\n * value AttributeValue\n * }\n * AttributeType ::= OBJECT IDENTIFIER\n * AttributeValue ::= ANY DEFINED BY AttributeType\n *\n * Validity ::= SEQUENCE {\n * notBefore Time,\n * notAfter Time\n * }\n *\n * Time ::= CHOICE {\n * utcTime UTCTime,\n * generalTime GeneralizedTime\n * }\n *\n * UniqueIdentifier ::= BIT STRING\n *\n * SubjectPublicKeyInfo ::= SEQUENCE {\n * algorithm AlgorithmIdentifier,\n * subjectPublicKey BIT STRING\n * }\n *\n * Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension\n *\n * Extension ::= SEQUENCE {\n * extnID OBJECT IDENTIFIER,\n * critical BOOLEAN DEFAULT FALSE,\n * extnValue OCTET STRING\n * }\n *\n * The only key algorithm currently supported for PKI is RSA.\n *\n * RSASSA-PSS signatures are described in RFC 3447 and RFC 4055.\n *\n * PKCS#10 v1.7 describes certificate signing requests:\n *\n * CertificationRequestInfo:\n *\n * CertificationRequestInfo ::= SEQUENCE {\n * version INTEGER { v1(0) } (v1,...),\n * subject Name,\n * subjectPKInfo SubjectPublicKeyInfo{{ PKInfoAlgorithms }},\n * attributes [0] Attributes{{ CRIAttributes }}\n * }\n *\n * Attributes { ATTRIBUTE:IOSet } ::= SET OF Attribute{{ IOSet }}\n *\n * CRIAttributes ATTRIBUTE ::= {\n * ... -- add any locally defined attributes here -- }\n *\n * Attribute { ATTRIBUTE:IOSet } ::= SEQUENCE {\n * type ATTRIBUTE.&id({IOSet}),\n * values SET SIZE(1..MAX) OF ATTRIBUTE.&Type({IOSet}{@type})\n * }\n *\n * CertificationRequest ::= SEQUENCE {\n * certificationRequestInfo CertificationRequestInfo,\n * signatureAlgorithm AlgorithmIdentifier{{ SignatureAlgorithms }},\n * signature BIT STRING\n * }\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./md');\nrequire('./mgf');\nrequire('./oids');\nrequire('./pem');\nrequire('./pss');\nrequire('./rsa');\nrequire('./util');\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n/* Public Key Infrastructure (PKI) implementation. */\nvar pki = module.exports = forge.pki = forge.pki || {};\nvar oids = pki.oids;\n\n// short name OID mappings\nvar _shortNames = {};\n_shortNames['CN'] = oids['commonName'];\n_shortNames['commonName'] = 'CN';\n_shortNames['C'] = oids['countryName'];\n_shortNames['countryName'] = 'C';\n_shortNames['L'] = oids['localityName'];\n_shortNames['localityName'] = 'L';\n_shortNames['ST'] = oids['stateOrProvinceName'];\n_shortNames['stateOrProvinceName'] = 'ST';\n_shortNames['O'] = oids['organizationName'];\n_shortNames['organizationName'] = 'O';\n_shortNames['OU'] = oids['organizationalUnitName'];\n_shortNames['organizationalUnitName'] = 'OU';\n_shortNames['E'] = oids['emailAddress'];\n_shortNames['emailAddress'] = 'E';\n\n// validator for an SubjectPublicKeyInfo structure\n// Note: Currently only works with an RSA public key\nvar publicKeyValidator = forge.pki.rsa.publicKeyValidator;\n\n// validator for an X.509v3 certificate\nvar x509CertificateValidator = {\n name: 'Certificate',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'Certificate.TBSCertificate',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'tbsCertificate',\n value: [{\n name: 'Certificate.TBSCertificate.version',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n value: [{\n name: 'Certificate.TBSCertificate.version.integer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'certVersion'\n }]\n }, {\n name: 'Certificate.TBSCertificate.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'certSerialNumber'\n }, {\n name: 'Certificate.TBSCertificate.signature',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'Certificate.TBSCertificate.signature.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'certinfoSignatureOid'\n }, {\n name: 'Certificate.TBSCertificate.signature.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: 'certinfoSignatureParams'\n }]\n }, {\n name: 'Certificate.TBSCertificate.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certIssuer'\n }, {\n name: 'Certificate.TBSCertificate.validity',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n // Note: UTC and generalized times may both appear so the capture\n // names are based on their detected order, the names used below\n // are only for the common case, which validity time really means\n // \"notBefore\" and which means \"notAfter\" will be determined by order\n value: [{\n // notBefore (Time) (UTC time case)\n name: 'Certificate.TBSCertificate.validity.notBefore (utc)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.UTCTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity1UTCTime'\n }, {\n // notBefore (Time) (generalized time case)\n name: 'Certificate.TBSCertificate.validity.notBefore (generalized)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.GENERALIZEDTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity2GeneralizedTime'\n }, {\n // notAfter (Time) (only UTC time is supported)\n name: 'Certificate.TBSCertificate.validity.notAfter (utc)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.UTCTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity3UTCTime'\n }, {\n // notAfter (Time) (only UTC time is supported)\n name: 'Certificate.TBSCertificate.validity.notAfter (generalized)',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.GENERALIZEDTIME,\n constructed: false,\n optional: true,\n capture: 'certValidity4GeneralizedTime'\n }]\n }, {\n // Name (subject) (RDNSequence)\n name: 'Certificate.TBSCertificate.subject',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certSubject'\n },\n // SubjectPublicKeyInfo\n publicKeyValidator,\n {\n // issuerUniqueID (optional)\n name: 'Certificate.TBSCertificate.issuerUniqueID',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n optional: true,\n value: [{\n name: 'Certificate.TBSCertificate.issuerUniqueID.id',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n // TODO: support arbitrary bit length ids\n captureBitStringValue: 'certIssuerUniqueId'\n }]\n }, {\n // subjectUniqueID (optional)\n name: 'Certificate.TBSCertificate.subjectUniqueID',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 2,\n constructed: true,\n optional: true,\n value: [{\n name: 'Certificate.TBSCertificate.subjectUniqueID.id',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n // TODO: support arbitrary bit length ids\n captureBitStringValue: 'certSubjectUniqueId'\n }]\n }, {\n // Extensions (optional)\n name: 'Certificate.TBSCertificate.extensions',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 3,\n constructed: true,\n captureAsn1: 'certExtensions',\n optional: true\n }]\n }, {\n // AlgorithmIdentifier (signature algorithm)\n name: 'Certificate.signatureAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // algorithm\n name: 'Certificate.signatureAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'certSignatureOid'\n }, {\n name: 'Certificate.TBSCertificate.signature.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: 'certSignatureParams'\n }]\n }, {\n // SignatureValue\n name: 'Certificate.signatureValue',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n captureBitStringValue: 'certSignature'\n }]\n};\n\nvar rsassaPssParameterValidator = {\n name: 'rsapss',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'rsapss.hashAlgorithm',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n value: [{\n name: 'rsapss.hashAlgorithm.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.SEQUENCE,\n constructed: true,\n optional: true,\n value: [{\n name: 'rsapss.hashAlgorithm.AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'hashOid'\n /* parameter block omitted, for SHA1 NULL anyhow. */\n }]\n }]\n }, {\n name: 'rsapss.maskGenAlgorithm',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n value: [{\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.SEQUENCE,\n constructed: true,\n optional: true,\n value: [{\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'maskGenOid'\n }, {\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier.params',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'rsapss.maskGenAlgorithm.AlgorithmIdentifier.params.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'maskGenHashOid'\n /* parameter block omitted, for SHA1 NULL anyhow. */\n }]\n }]\n }]\n }, {\n name: 'rsapss.saltLength',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 2,\n optional: true,\n value: [{\n name: 'rsapss.saltLength.saltLength',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.INTEGER,\n constructed: false,\n capture: 'saltLength'\n }]\n }, {\n name: 'rsapss.trailerField',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 3,\n optional: true,\n value: [{\n name: 'rsapss.trailer.trailer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Class.INTEGER,\n constructed: false,\n capture: 'trailer'\n }]\n }]\n};\n\n// validator for a CertificationRequestInfo structure\nvar certificationRequestInfoValidator = {\n name: 'CertificationRequestInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certificationRequestInfo',\n value: [{\n name: 'CertificationRequestInfo.integer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'certificationRequestInfoVersion'\n }, {\n // Name (subject) (RDNSequence)\n name: 'CertificationRequestInfo.subject',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'certificationRequestInfoSubject'\n },\n // SubjectPublicKeyInfo\n publicKeyValidator,\n {\n name: 'CertificationRequestInfo.attributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n capture: 'certificationRequestInfoAttributes',\n value: [{\n name: 'CertificationRequestInfo.attributes',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'CertificationRequestInfo.attributes.type',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false\n }, {\n name: 'CertificationRequestInfo.attributes.value',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true\n }]\n }]\n }]\n};\n\n// validator for a CertificationRequest structure\nvar certificationRequestValidator = {\n name: 'CertificationRequest',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'csr',\n value: [\n certificationRequestInfoValidator, {\n // AlgorithmIdentifier (signature algorithm)\n name: 'CertificationRequest.signatureAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // algorithm\n name: 'CertificationRequest.signatureAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'csrSignatureOid'\n }, {\n name: 'CertificationRequest.signatureAlgorithm.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: 'csrSignatureParams'\n }]\n }, {\n // signature\n name: 'CertificationRequest.signature',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n captureBitStringValue: 'csrSignature'\n }\n ]\n};\n\n/**\n * Converts an RDNSequence of ASN.1 DER-encoded RelativeDistinguishedName\n * sets into an array with objects that have type and value properties.\n *\n * @param rdn the RDNSequence to convert.\n * @param md a message digest to append type and value to if provided.\n */\npki.RDNAttributesAsArray = function(rdn, md) {\n var rval = [];\n\n // each value in 'rdn' in is a SET of RelativeDistinguishedName\n var set, attr, obj;\n for(var si = 0; si < rdn.value.length; ++si) {\n // get the RelativeDistinguishedName set\n set = rdn.value[si];\n\n // each value in the SET is an AttributeTypeAndValue sequence\n // containing first a type (an OID) and second a value (defined by\n // the OID)\n for(var i = 0; i < set.value.length; ++i) {\n obj = {};\n attr = set.value[i];\n obj.type = asn1.derToOid(attr.value[0].value);\n obj.value = attr.value[1].value;\n obj.valueTagClass = attr.value[1].type;\n // if the OID is known, get its name and short name\n if(obj.type in oids) {\n obj.name = oids[obj.type];\n if(obj.name in _shortNames) {\n obj.shortName = _shortNames[obj.name];\n }\n }\n if(md) {\n md.update(obj.type);\n md.update(obj.value);\n }\n rval.push(obj);\n }\n }\n\n return rval;\n};\n\n/**\n * Converts ASN.1 CRIAttributes into an array with objects that have type and\n * value properties.\n *\n * @param attributes the CRIAttributes to convert.\n */\npki.CRIAttributesAsArray = function(attributes) {\n var rval = [];\n\n // each value in 'attributes' in is a SEQUENCE with an OID and a SET\n for(var si = 0; si < attributes.length; ++si) {\n // get the attribute sequence\n var seq = attributes[si];\n\n // each value in the SEQUENCE containing first a type (an OID) and\n // second a set of values (defined by the OID)\n var type = asn1.derToOid(seq.value[0].value);\n var values = seq.value[1].value;\n for(var vi = 0; vi < values.length; ++vi) {\n var obj = {};\n obj.type = type;\n obj.value = values[vi].value;\n obj.valueTagClass = values[vi].type;\n // if the OID is known, get its name and short name\n if(obj.type in oids) {\n obj.name = oids[obj.type];\n if(obj.name in _shortNames) {\n obj.shortName = _shortNames[obj.name];\n }\n }\n // parse extensions\n if(obj.type === oids.extensionRequest) {\n obj.extensions = [];\n for(var ei = 0; ei < obj.value.length; ++ei) {\n obj.extensions.push(pki.certificateExtensionFromAsn1(obj.value[ei]));\n }\n }\n rval.push(obj);\n }\n }\n\n return rval;\n};\n\n/**\n * Gets an issuer or subject attribute from its name, type, or short name.\n *\n * @param obj the issuer or subject object.\n * @param options a short name string or an object with:\n * shortName the short name for the attribute.\n * name the name for the attribute.\n * type the type for the attribute.\n *\n * @return the attribute.\n */\nfunction _getAttribute(obj, options) {\n if(typeof options === 'string') {\n options = {shortName: options};\n }\n\n var rval = null;\n var attr;\n for(var i = 0; rval === null && i < obj.attributes.length; ++i) {\n attr = obj.attributes[i];\n if(options.type && options.type === attr.type) {\n rval = attr;\n } else if(options.name && options.name === attr.name) {\n rval = attr;\n } else if(options.shortName && options.shortName === attr.shortName) {\n rval = attr;\n }\n }\n return rval;\n}\n\n/**\n * Converts signature parameters from ASN.1 structure.\n *\n * Currently only RSASSA-PSS supported. The PKCS#1 v1.5 signature scheme had\n * no parameters.\n *\n * RSASSA-PSS-params ::= SEQUENCE {\n * hashAlgorithm [0] HashAlgorithm DEFAULT\n * sha1Identifier,\n * maskGenAlgorithm [1] MaskGenAlgorithm DEFAULT\n * mgf1SHA1Identifier,\n * saltLength [2] INTEGER DEFAULT 20,\n * trailerField [3] INTEGER DEFAULT 1\n * }\n *\n * HashAlgorithm ::= AlgorithmIdentifier\n *\n * MaskGenAlgorithm ::= AlgorithmIdentifier\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * @param oid The OID specifying the signature algorithm\n * @param obj The ASN.1 structure holding the parameters\n * @param fillDefaults Whether to use return default values where omitted\n * @return signature parameter object\n */\nvar _readSignatureParameters = function(oid, obj, fillDefaults) {\n var params = {};\n\n if(oid !== oids['RSASSA-PSS']) {\n return params;\n }\n\n if(fillDefaults) {\n params = {\n hash: {\n algorithmOid: oids['sha1']\n },\n mgf: {\n algorithmOid: oids['mgf1'],\n hash: {\n algorithmOid: oids['sha1']\n }\n },\n saltLength: 20\n };\n }\n\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, rsassaPssParameterValidator, capture, errors)) {\n var error = new Error('Cannot read RSASSA-PSS parameter block.');\n error.errors = errors;\n throw error;\n }\n\n if(capture.hashOid !== undefined) {\n params.hash = params.hash || {};\n params.hash.algorithmOid = asn1.derToOid(capture.hashOid);\n }\n\n if(capture.maskGenOid !== undefined) {\n params.mgf = params.mgf || {};\n params.mgf.algorithmOid = asn1.derToOid(capture.maskGenOid);\n params.mgf.hash = params.mgf.hash || {};\n params.mgf.hash.algorithmOid = asn1.derToOid(capture.maskGenHashOid);\n }\n\n if(capture.saltLength !== undefined) {\n params.saltLength = capture.saltLength.charCodeAt(0);\n }\n\n return params;\n};\n\n/**\n * Converts an X.509 certificate from PEM format.\n *\n * Note: If the certificate is to be verified then compute hash should\n * be set to true. This will scan the TBSCertificate part of the ASN.1\n * object while it is converted so it doesn't need to be converted back\n * to ASN.1-DER-encoding later.\n *\n * @param pem the PEM-formatted certificate.\n * @param computeHash true to compute the hash for verification.\n * @param strict true to be strict when checking ASN.1 value lengths, false to\n * allow truncated values (default: true).\n *\n * @return the certificate.\n */\npki.certificateFromPem = function(pem, computeHash, strict) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'CERTIFICATE' &&\n msg.type !== 'X509 CERTIFICATE' &&\n msg.type !== 'TRUSTED CERTIFICATE') {\n var error = new Error(\n 'Could not convert certificate from PEM; PEM header type ' +\n 'is not \"CERTIFICATE\", \"X509 CERTIFICATE\", or \"TRUSTED CERTIFICATE\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error(\n 'Could not convert certificate from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body, strict);\n\n return pki.certificateFromAsn1(obj, computeHash);\n};\n\n/**\n * Converts an X.509 certificate to PEM format.\n *\n * @param cert the certificate.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted certificate.\n */\npki.certificateToPem = function(cert, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'CERTIFICATE',\n body: asn1.toDer(pki.certificateToAsn1(cert)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts an RSA public key from PEM format.\n *\n * @param pem the PEM-formatted public key.\n *\n * @return the public key.\n */\npki.publicKeyFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'PUBLIC KEY' && msg.type !== 'RSA PUBLIC KEY') {\n var error = new Error('Could not convert public key from PEM; PEM header ' +\n 'type is not \"PUBLIC KEY\" or \"RSA PUBLIC KEY\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert public key from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body);\n\n return pki.publicKeyFromAsn1(obj);\n};\n\n/**\n * Converts an RSA public key to PEM format (using a SubjectPublicKeyInfo).\n *\n * @param key the public key.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted public key.\n */\npki.publicKeyToPem = function(key, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'PUBLIC KEY',\n body: asn1.toDer(pki.publicKeyToAsn1(key)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts an RSA public key to PEM format (using an RSAPublicKey).\n *\n * @param key the public key.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted public key.\n */\npki.publicKeyToRSAPublicKeyPem = function(key, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'RSA PUBLIC KEY',\n body: asn1.toDer(pki.publicKeyToRSAPublicKey(key)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Gets a fingerprint for the given public key.\n *\n * @param options the options to use.\n * [md] the message digest object to use (defaults to forge.md.sha1).\n * [type] the type of fingerprint, such as 'RSAPublicKey',\n * 'SubjectPublicKeyInfo' (defaults to 'RSAPublicKey').\n * [encoding] an alternative output encoding, such as 'hex'\n * (defaults to none, outputs a byte buffer).\n * [delimiter] the delimiter to use between bytes for 'hex' encoded\n * output, eg: ':' (defaults to none).\n *\n * @return the fingerprint as a byte buffer or other encoding based on options.\n */\npki.getPublicKeyFingerprint = function(key, options) {\n options = options || {};\n var md = options.md || forge.md.sha1.create();\n var type = options.type || 'RSAPublicKey';\n\n var bytes;\n switch(type) {\n case 'RSAPublicKey':\n bytes = asn1.toDer(pki.publicKeyToRSAPublicKey(key)).getBytes();\n break;\n case 'SubjectPublicKeyInfo':\n bytes = asn1.toDer(pki.publicKeyToAsn1(key)).getBytes();\n break;\n default:\n throw new Error('Unknown fingerprint type \"' + options.type + '\".');\n }\n\n // hash public key bytes\n md.start();\n md.update(bytes);\n var digest = md.digest();\n if(options.encoding === 'hex') {\n var hex = digest.toHex();\n if(options.delimiter) {\n return hex.match(/.{2}/g).join(options.delimiter);\n }\n return hex;\n } else if(options.encoding === 'binary') {\n return digest.getBytes();\n } else if(options.encoding) {\n throw new Error('Unknown encoding \"' + options.encoding + '\".');\n }\n return digest;\n};\n\n/**\n * Converts a PKCS#10 certification request (CSR) from PEM format.\n *\n * Note: If the certification request is to be verified then compute hash\n * should be set to true. This will scan the CertificationRequestInfo part of\n * the ASN.1 object while it is converted so it doesn't need to be converted\n * back to ASN.1-DER-encoding later.\n *\n * @param pem the PEM-formatted certificate.\n * @param computeHash true to compute the hash for verification.\n * @param strict true to be strict when checking ASN.1 value lengths, false to\n * allow truncated values (default: true).\n *\n * @return the certification request (CSR).\n */\npki.certificationRequestFromPem = function(pem, computeHash, strict) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'CERTIFICATE REQUEST') {\n var error = new Error('Could not convert certification request from PEM; ' +\n 'PEM header type is not \"CERTIFICATE REQUEST\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert certification request from PEM; ' +\n 'PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body, strict);\n\n return pki.certificationRequestFromAsn1(obj, computeHash);\n};\n\n/**\n * Converts a PKCS#10 certification request (CSR) to PEM format.\n *\n * @param csr the certification request.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted certification request.\n */\npki.certificationRequestToPem = function(csr, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var msg = {\n type: 'CERTIFICATE REQUEST',\n body: asn1.toDer(pki.certificationRequestToAsn1(csr)).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Creates an empty X.509v3 RSA certificate.\n *\n * @return the certificate.\n */\npki.createCertificate = function() {\n var cert = {};\n cert.version = 0x02;\n cert.serialNumber = '00';\n cert.signatureOid = null;\n cert.signature = null;\n cert.siginfo = {};\n cert.siginfo.algorithmOid = null;\n cert.validity = {};\n cert.validity.notBefore = new Date();\n cert.validity.notAfter = new Date();\n\n cert.issuer = {};\n cert.issuer.getField = function(sn) {\n return _getAttribute(cert.issuer, sn);\n };\n cert.issuer.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.issuer.attributes.push(attr);\n };\n cert.issuer.attributes = [];\n cert.issuer.hash = null;\n\n cert.subject = {};\n cert.subject.getField = function(sn) {\n return _getAttribute(cert.subject, sn);\n };\n cert.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.subject.attributes.push(attr);\n };\n cert.subject.attributes = [];\n cert.subject.hash = null;\n\n cert.extensions = [];\n cert.publicKey = null;\n cert.md = null;\n\n /**\n * Sets the subject of this certificate.\n *\n * @param attrs the array of subject attributes to use.\n * @param uniqueId an optional a unique ID to use.\n */\n cert.setSubject = function(attrs, uniqueId) {\n // set new attributes, clear hash\n _fillMissingFields(attrs);\n cert.subject.attributes = attrs;\n delete cert.subject.uniqueId;\n if(uniqueId) {\n // TODO: support arbitrary bit length ids\n cert.subject.uniqueId = uniqueId;\n }\n cert.subject.hash = null;\n };\n\n /**\n * Sets the issuer of this certificate.\n *\n * @param attrs the array of issuer attributes to use.\n * @param uniqueId an optional a unique ID to use.\n */\n cert.setIssuer = function(attrs, uniqueId) {\n // set new attributes, clear hash\n _fillMissingFields(attrs);\n cert.issuer.attributes = attrs;\n delete cert.issuer.uniqueId;\n if(uniqueId) {\n // TODO: support arbitrary bit length ids\n cert.issuer.uniqueId = uniqueId;\n }\n cert.issuer.hash = null;\n };\n\n /**\n * Sets the extensions of this certificate.\n *\n * @param exts the array of extensions to use.\n */\n cert.setExtensions = function(exts) {\n for(var i = 0; i < exts.length; ++i) {\n _fillMissingExtensionFields(exts[i], {cert: cert});\n }\n // set new extensions\n cert.extensions = exts;\n };\n\n /**\n * Gets an extension by its name or id.\n *\n * @param options the name to use or an object with:\n * name the name to use.\n * id the id to use.\n *\n * @return the extension or null if not found.\n */\n cert.getExtension = function(options) {\n if(typeof options === 'string') {\n options = {name: options};\n }\n\n var rval = null;\n var ext;\n for(var i = 0; rval === null && i < cert.extensions.length; ++i) {\n ext = cert.extensions[i];\n if(options.id && ext.id === options.id) {\n rval = ext;\n } else if(options.name && ext.name === options.name) {\n rval = ext;\n }\n }\n return rval;\n };\n\n /**\n * Signs this certificate using the given private key.\n *\n * @param key the private key to sign with.\n * @param md the message digest object to use (defaults to forge.md.sha1).\n */\n cert.sign = function(key, md) {\n // TODO: get signature OID from private key\n cert.md = md || forge.md.sha1.create();\n var algorithmOid = oids[cert.md.algorithm + 'WithRSAEncryption'];\n if(!algorithmOid) {\n var error = new Error('Could not compute certificate digest. ' +\n 'Unknown message digest algorithm OID.');\n error.algorithm = cert.md.algorithm;\n throw error;\n }\n cert.signatureOid = cert.siginfo.algorithmOid = algorithmOid;\n\n // get TBSCertificate, convert to DER\n cert.tbsCertificate = pki.getTBSCertificate(cert);\n var bytes = asn1.toDer(cert.tbsCertificate);\n\n // digest and sign\n cert.md.update(bytes.getBytes());\n cert.signature = key.sign(cert.md);\n };\n\n /**\n * Attempts verify the signature on the passed certificate using this\n * certificate's public key.\n *\n * @param child the certificate to verify.\n *\n * @return true if verified, false if not.\n */\n cert.verify = function(child) {\n var rval = false;\n\n if(!cert.issued(child)) {\n var issuer = child.issuer;\n var subject = cert.subject;\n var error = new Error(\n 'The parent certificate did not issue the given child ' +\n 'certificate; the child certificate\\'s issuer does not match the ' +\n 'parent\\'s subject.');\n error.expectedIssuer = issuer.attributes;\n error.actualIssuer = subject.attributes;\n throw error;\n }\n\n var md = child.md;\n if(md === null) {\n // check signature OID for supported signature types\n if(child.signatureOid in oids) {\n var oid = oids[child.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n md = forge.md.sha256.create();\n break;\n }\n }\n if(md === null) {\n var error = new Error('Could not compute certificate digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = child.signatureOid;\n throw error;\n }\n\n // produce DER formatted TBSCertificate and digest it\n var tbsCertificate = child.tbsCertificate || pki.getTBSCertificate(child);\n var bytes = asn1.toDer(tbsCertificate);\n md.update(bytes.getBytes());\n }\n\n if(md !== null) {\n var scheme;\n\n switch(child.signatureOid) {\n case oids.sha1WithRSAEncryption:\n scheme = undefined; /* use PKCS#1 v1.5 padding scheme */\n break;\n case oids['RSASSA-PSS']:\n var hash, mgf;\n\n /* initialize mgf */\n hash = oids[child.signatureParameters.mgf.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported MGF hash function.');\n error.oid = child.signatureParameters.mgf.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n mgf = oids[child.signatureParameters.mgf.algorithmOid];\n if(mgf === undefined || forge.mgf[mgf] === undefined) {\n var error = new Error('Unsupported MGF function.');\n error.oid = child.signatureParameters.mgf.algorithmOid;\n error.name = mgf;\n throw error;\n }\n\n mgf = forge.mgf[mgf].create(forge.md[hash].create());\n\n /* initialize hash function */\n hash = oids[child.signatureParameters.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n throw {\n message: 'Unsupported RSASSA-PSS hash function.',\n oid: child.signatureParameters.hash.algorithmOid,\n name: hash\n };\n }\n\n scheme = forge.pss.create(forge.md[hash].create(), mgf,\n child.signatureParameters.saltLength);\n break;\n }\n\n // verify signature on cert using public key\n rval = cert.publicKey.verify(\n md.digest().getBytes(), child.signature, scheme);\n }\n\n return rval;\n };\n\n /**\n * Returns true if this certificate's issuer matches the passed\n * certificate's subject. Note that no signature check is performed.\n *\n * @param parent the certificate to check.\n *\n * @return true if this certificate's issuer matches the passed certificate's\n * subject.\n */\n cert.isIssuer = function(parent) {\n var rval = false;\n\n var i = cert.issuer;\n var s = parent.subject;\n\n // compare hashes if present\n if(i.hash && s.hash) {\n rval = (i.hash === s.hash);\n } else if(i.attributes.length === s.attributes.length) {\n // all attributes are the same so issuer matches subject\n rval = true;\n var iattr, sattr;\n for(var n = 0; rval && n < i.attributes.length; ++n) {\n iattr = i.attributes[n];\n sattr = s.attributes[n];\n if(iattr.type !== sattr.type || iattr.value !== sattr.value) {\n // attribute mismatch\n rval = false;\n }\n }\n }\n\n return rval;\n };\n\n /**\n * Returns true if this certificate's subject matches the issuer of the\n * given certificate). Note that not signature check is performed.\n *\n * @param child the certificate to check.\n *\n * @return true if this certificate's subject matches the passed\n * certificate's issuer.\n */\n cert.issued = function(child) {\n return child.isIssuer(cert);\n };\n\n /**\n * Generates the subjectKeyIdentifier for this certificate as byte buffer.\n *\n * @return the subjectKeyIdentifier for this certificate as byte buffer.\n */\n cert.generateSubjectKeyIdentifier = function() {\n /* See: 4.2.1.2 section of the the RFC3280, keyIdentifier is either:\n\n (1) The keyIdentifier is composed of the 160-bit SHA-1 hash of the\n value of the BIT STRING subjectPublicKey (excluding the tag,\n length, and number of unused bits).\n\n (2) The keyIdentifier is composed of a four bit type field with\n the value 0100 followed by the least significant 60 bits of the\n SHA-1 hash of the value of the BIT STRING subjectPublicKey\n (excluding the tag, length, and number of unused bit string bits).\n */\n\n // skipping the tag, length, and number of unused bits is the same\n // as just using the RSAPublicKey (for RSA keys, which are the\n // only ones supported)\n return pki.getPublicKeyFingerprint(cert.publicKey, {type: 'RSAPublicKey'});\n };\n\n /**\n * Verifies the subjectKeyIdentifier extension value for this certificate\n * against its public key. If no extension is found, false will be\n * returned.\n *\n * @return true if verified, false if not.\n */\n cert.verifySubjectKeyIdentifier = function() {\n var oid = oids['subjectKeyIdentifier'];\n for(var i = 0; i < cert.extensions.length; ++i) {\n var ext = cert.extensions[i];\n if(ext.id === oid) {\n var ski = cert.generateSubjectKeyIdentifier().getBytes();\n return (forge.util.hexToBytes(ext.subjectKeyIdentifier) === ski);\n }\n }\n return false;\n };\n\n return cert;\n};\n\n/**\n * Converts an X.509v3 RSA certificate from an ASN.1 object.\n *\n * Note: If the certificate is to be verified then compute hash should\n * be set to true. There is currently no implementation for converting\n * a certificate back to ASN.1 so the TBSCertificate part of the ASN.1\n * object needs to be scanned before the cert object is created.\n *\n * @param obj the asn1 representation of an X.509v3 RSA certificate.\n * @param computeHash true to compute the hash for verification.\n *\n * @return the certificate.\n */\npki.certificateFromAsn1 = function(obj, computeHash) {\n // validate certificate and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, x509CertificateValidator, capture, errors)) {\n var error = new Error('Cannot read X.509 certificate. ' +\n 'ASN.1 object is not an X509v3 Certificate.');\n error.errors = errors;\n throw error;\n }\n\n // get oid\n var oid = asn1.derToOid(capture.publicKeyOid);\n if(oid !== pki.oids.rsaEncryption) {\n throw new Error('Cannot read public key. OID is not RSA.');\n }\n\n // create certificate\n var cert = pki.createCertificate();\n cert.version = capture.certVersion ?\n capture.certVersion.charCodeAt(0) : 0;\n var serial = forge.util.createBuffer(capture.certSerialNumber);\n cert.serialNumber = serial.toHex();\n cert.signatureOid = forge.asn1.derToOid(capture.certSignatureOid);\n cert.signatureParameters = _readSignatureParameters(\n cert.signatureOid, capture.certSignatureParams, true);\n cert.siginfo.algorithmOid = forge.asn1.derToOid(capture.certinfoSignatureOid);\n cert.siginfo.parameters = _readSignatureParameters(cert.siginfo.algorithmOid,\n capture.certinfoSignatureParams, false);\n cert.signature = capture.certSignature;\n\n var validity = [];\n if(capture.certValidity1UTCTime !== undefined) {\n validity.push(asn1.utcTimeToDate(capture.certValidity1UTCTime));\n }\n if(capture.certValidity2GeneralizedTime !== undefined) {\n validity.push(asn1.generalizedTimeToDate(\n capture.certValidity2GeneralizedTime));\n }\n if(capture.certValidity3UTCTime !== undefined) {\n validity.push(asn1.utcTimeToDate(capture.certValidity3UTCTime));\n }\n if(capture.certValidity4GeneralizedTime !== undefined) {\n validity.push(asn1.generalizedTimeToDate(\n capture.certValidity4GeneralizedTime));\n }\n if(validity.length > 2) {\n throw new Error('Cannot read notBefore/notAfter validity times; more ' +\n 'than two times were provided in the certificate.');\n }\n if(validity.length < 2) {\n throw new Error('Cannot read notBefore/notAfter validity times; they ' +\n 'were not provided as either UTCTime or GeneralizedTime.');\n }\n cert.validity.notBefore = validity[0];\n cert.validity.notAfter = validity[1];\n\n // keep TBSCertificate to preserve signature when exporting\n cert.tbsCertificate = capture.tbsCertificate;\n\n if(computeHash) {\n // check signature OID for supported signature types\n cert.md = null;\n if(cert.signatureOid in oids) {\n var oid = oids[cert.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n cert.md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n cert.md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n cert.md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n cert.md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n cert.md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n cert.md = forge.md.sha256.create();\n break;\n }\n }\n if(cert.md === null) {\n var error = new Error('Could not compute certificate digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = cert.signatureOid;\n throw error;\n }\n\n // produce DER formatted TBSCertificate and digest it\n var bytes = asn1.toDer(cert.tbsCertificate);\n cert.md.update(bytes.getBytes());\n }\n\n // handle issuer, build issuer message digest\n var imd = forge.md.sha1.create();\n cert.issuer.getField = function(sn) {\n return _getAttribute(cert.issuer, sn);\n };\n cert.issuer.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.issuer.attributes.push(attr);\n };\n cert.issuer.attributes = pki.RDNAttributesAsArray(capture.certIssuer, imd);\n if(capture.certIssuerUniqueId) {\n cert.issuer.uniqueId = capture.certIssuerUniqueId;\n }\n cert.issuer.hash = imd.digest().toHex();\n\n // handle subject, build subject message digest\n var smd = forge.md.sha1.create();\n cert.subject.getField = function(sn) {\n return _getAttribute(cert.subject, sn);\n };\n cert.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n cert.subject.attributes.push(attr);\n };\n cert.subject.attributes = pki.RDNAttributesAsArray(capture.certSubject, smd);\n if(capture.certSubjectUniqueId) {\n cert.subject.uniqueId = capture.certSubjectUniqueId;\n }\n cert.subject.hash = smd.digest().toHex();\n\n // handle extensions\n if(capture.certExtensions) {\n cert.extensions = pki.certificateExtensionsFromAsn1(capture.certExtensions);\n } else {\n cert.extensions = [];\n }\n\n // convert RSA public key from ASN.1\n cert.publicKey = pki.publicKeyFromAsn1(capture.subjectPublicKeyInfo);\n\n return cert;\n};\n\n/**\n * Converts an ASN.1 extensions object (with extension sequences as its\n * values) into an array of extension objects with types and values.\n *\n * Supported extensions:\n *\n * id-ce-keyUsage OBJECT IDENTIFIER ::= { id-ce 15 }\n * KeyUsage ::= BIT STRING {\n * digitalSignature (0),\n * nonRepudiation (1),\n * keyEncipherment (2),\n * dataEncipherment (3),\n * keyAgreement (4),\n * keyCertSign (5),\n * cRLSign (6),\n * encipherOnly (7),\n * decipherOnly (8)\n * }\n *\n * id-ce-basicConstraints OBJECT IDENTIFIER ::= { id-ce 19 }\n * BasicConstraints ::= SEQUENCE {\n * cA BOOLEAN DEFAULT FALSE,\n * pathLenConstraint INTEGER (0..MAX) OPTIONAL\n * }\n *\n * subjectAltName EXTENSION ::= {\n * SYNTAX GeneralNames\n * IDENTIFIED BY id-ce-subjectAltName\n * }\n *\n * GeneralNames ::= SEQUENCE SIZE (1..MAX) OF GeneralName\n *\n * GeneralName ::= CHOICE {\n * otherName [0] INSTANCE OF OTHER-NAME,\n * rfc822Name [1] IA5String,\n * dNSName [2] IA5String,\n * x400Address [3] ORAddress,\n * directoryName [4] Name,\n * ediPartyName [5] EDIPartyName,\n * uniformResourceIdentifier [6] IA5String,\n * IPAddress [7] OCTET STRING,\n * registeredID [8] OBJECT IDENTIFIER\n * }\n *\n * OTHER-NAME ::= TYPE-IDENTIFIER\n *\n * EDIPartyName ::= SEQUENCE {\n * nameAssigner [0] DirectoryString {ub-name} OPTIONAL,\n * partyName [1] DirectoryString {ub-name}\n * }\n *\n * @param exts the extensions ASN.1 with extension sequences to parse.\n *\n * @return the array.\n */\npki.certificateExtensionsFromAsn1 = function(exts) {\n var rval = [];\n for(var i = 0; i < exts.value.length; ++i) {\n // get extension sequence\n var extseq = exts.value[i];\n for(var ei = 0; ei < extseq.value.length; ++ei) {\n rval.push(pki.certificateExtensionFromAsn1(extseq.value[ei]));\n }\n }\n\n return rval;\n};\n\n/**\n * Parses a single certificate extension from ASN.1.\n *\n * @param ext the extension in ASN.1 format.\n *\n * @return the parsed extension as an object.\n */\npki.certificateExtensionFromAsn1 = function(ext) {\n // an extension has:\n // [0] extnID OBJECT IDENTIFIER\n // [1] critical BOOLEAN DEFAULT FALSE\n // [2] extnValue OCTET STRING\n var e = {};\n e.id = asn1.derToOid(ext.value[0].value);\n e.critical = false;\n if(ext.value[1].type === asn1.Type.BOOLEAN) {\n e.critical = (ext.value[1].value.charCodeAt(0) !== 0x00);\n e.value = ext.value[2].value;\n } else {\n e.value = ext.value[1].value;\n }\n // if the oid is known, get its name\n if(e.id in oids) {\n e.name = oids[e.id];\n\n // handle key usage\n if(e.name === 'keyUsage') {\n // get value as BIT STRING\n var ev = asn1.fromDer(e.value);\n var b2 = 0x00;\n var b3 = 0x00;\n if(ev.value.length > 1) {\n // skip first byte, just indicates unused bits which\n // will be padded with 0s anyway\n // get bytes with flag bits\n b2 = ev.value.charCodeAt(1);\n b3 = ev.value.length > 2 ? ev.value.charCodeAt(2) : 0;\n }\n // set flags\n e.digitalSignature = (b2 & 0x80) === 0x80;\n e.nonRepudiation = (b2 & 0x40) === 0x40;\n e.keyEncipherment = (b2 & 0x20) === 0x20;\n e.dataEncipherment = (b2 & 0x10) === 0x10;\n e.keyAgreement = (b2 & 0x08) === 0x08;\n e.keyCertSign = (b2 & 0x04) === 0x04;\n e.cRLSign = (b2 & 0x02) === 0x02;\n e.encipherOnly = (b2 & 0x01) === 0x01;\n e.decipherOnly = (b3 & 0x80) === 0x80;\n } else if(e.name === 'basicConstraints') {\n // handle basic constraints\n // get value as SEQUENCE\n var ev = asn1.fromDer(e.value);\n // get cA BOOLEAN flag (defaults to false)\n if(ev.value.length > 0 && ev.value[0].type === asn1.Type.BOOLEAN) {\n e.cA = (ev.value[0].value.charCodeAt(0) !== 0x00);\n } else {\n e.cA = false;\n }\n // get path length constraint\n var value = null;\n if(ev.value.length > 0 && ev.value[0].type === asn1.Type.INTEGER) {\n value = ev.value[0].value;\n } else if(ev.value.length > 1) {\n value = ev.value[1].value;\n }\n if(value !== null) {\n e.pathLenConstraint = asn1.derToInteger(value);\n }\n } else if(e.name === 'extKeyUsage') {\n // handle extKeyUsage\n // value is a SEQUENCE of OIDs\n var ev = asn1.fromDer(e.value);\n for(var vi = 0; vi < ev.value.length; ++vi) {\n var oid = asn1.derToOid(ev.value[vi].value);\n if(oid in oids) {\n e[oids[oid]] = true;\n } else {\n e[oid] = true;\n }\n }\n } else if(e.name === 'nsCertType') {\n // handle nsCertType\n // get value as BIT STRING\n var ev = asn1.fromDer(e.value);\n var b2 = 0x00;\n if(ev.value.length > 1) {\n // skip first byte, just indicates unused bits which\n // will be padded with 0s anyway\n // get bytes with flag bits\n b2 = ev.value.charCodeAt(1);\n }\n // set flags\n e.client = (b2 & 0x80) === 0x80;\n e.server = (b2 & 0x40) === 0x40;\n e.email = (b2 & 0x20) === 0x20;\n e.objsign = (b2 & 0x10) === 0x10;\n e.reserved = (b2 & 0x08) === 0x08;\n e.sslCA = (b2 & 0x04) === 0x04;\n e.emailCA = (b2 & 0x02) === 0x02;\n e.objCA = (b2 & 0x01) === 0x01;\n } else if(\n e.name === 'subjectAltName' ||\n e.name === 'issuerAltName') {\n // handle subjectAltName/issuerAltName\n e.altNames = [];\n\n // ev is a SYNTAX SEQUENCE\n var gn;\n var ev = asn1.fromDer(e.value);\n for(var n = 0; n < ev.value.length; ++n) {\n // get GeneralName\n gn = ev.value[n];\n\n var altName = {\n type: gn.type,\n value: gn.value\n };\n e.altNames.push(altName);\n\n // Note: Support for types 1,2,6,7,8\n switch(gn.type) {\n // rfc822Name\n case 1:\n // dNSName\n case 2:\n // uniformResourceIdentifier (URI)\n case 6:\n break;\n // IPAddress\n case 7:\n // convert to IPv4/IPv6 string representation\n altName.ip = forge.util.bytesToIP(gn.value);\n break;\n // registeredID\n case 8:\n altName.oid = asn1.derToOid(gn.value);\n break;\n default:\n // unsupported\n }\n }\n } else if(e.name === 'subjectKeyIdentifier') {\n // value is an OCTETSTRING w/the hash of the key-type specific\n // public key structure (eg: RSAPublicKey)\n var ev = asn1.fromDer(e.value);\n e.subjectKeyIdentifier = forge.util.bytesToHex(ev.value);\n }\n }\n return e;\n};\n\n/**\n * Converts a PKCS#10 certification request (CSR) from an ASN.1 object.\n *\n * Note: If the certification request is to be verified then compute hash\n * should be set to true. There is currently no implementation for converting\n * a certificate back to ASN.1 so the CertificationRequestInfo part of the\n * ASN.1 object needs to be scanned before the csr object is created.\n *\n * @param obj the asn1 representation of a PKCS#10 certification request (CSR).\n * @param computeHash true to compute the hash for verification.\n *\n * @return the certification request (CSR).\n */\npki.certificationRequestFromAsn1 = function(obj, computeHash) {\n // validate certification request and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, certificationRequestValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#10 certificate request. ' +\n 'ASN.1 object is not a PKCS#10 CertificationRequest.');\n error.errors = errors;\n throw error;\n }\n\n // get oid\n var oid = asn1.derToOid(capture.publicKeyOid);\n if(oid !== pki.oids.rsaEncryption) {\n throw new Error('Cannot read public key. OID is not RSA.');\n }\n\n // create certification request\n var csr = pki.createCertificationRequest();\n csr.version = capture.csrVersion ? capture.csrVersion.charCodeAt(0) : 0;\n csr.signatureOid = forge.asn1.derToOid(capture.csrSignatureOid);\n csr.signatureParameters = _readSignatureParameters(\n csr.signatureOid, capture.csrSignatureParams, true);\n csr.siginfo.algorithmOid = forge.asn1.derToOid(capture.csrSignatureOid);\n csr.siginfo.parameters = _readSignatureParameters(\n csr.siginfo.algorithmOid, capture.csrSignatureParams, false);\n csr.signature = capture.csrSignature;\n\n // keep CertificationRequestInfo to preserve signature when exporting\n csr.certificationRequestInfo = capture.certificationRequestInfo;\n\n if(computeHash) {\n // check signature OID for supported signature types\n csr.md = null;\n if(csr.signatureOid in oids) {\n var oid = oids[csr.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n csr.md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n csr.md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n csr.md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n csr.md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n csr.md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n csr.md = forge.md.sha256.create();\n break;\n }\n }\n if(csr.md === null) {\n var error = new Error('Could not compute certification request digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = csr.signatureOid;\n throw error;\n }\n\n // produce DER formatted CertificationRequestInfo and digest it\n var bytes = asn1.toDer(csr.certificationRequestInfo);\n csr.md.update(bytes.getBytes());\n }\n\n // handle subject, build subject message digest\n var smd = forge.md.sha1.create();\n csr.subject.getField = function(sn) {\n return _getAttribute(csr.subject, sn);\n };\n csr.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n csr.subject.attributes.push(attr);\n };\n csr.subject.attributes = pki.RDNAttributesAsArray(\n capture.certificationRequestInfoSubject, smd);\n csr.subject.hash = smd.digest().toHex();\n\n // convert RSA public key from ASN.1\n csr.publicKey = pki.publicKeyFromAsn1(capture.subjectPublicKeyInfo);\n\n // convert attributes from ASN.1\n csr.getAttribute = function(sn) {\n return _getAttribute(csr, sn);\n };\n csr.addAttribute = function(attr) {\n _fillMissingFields([attr]);\n csr.attributes.push(attr);\n };\n csr.attributes = pki.CRIAttributesAsArray(\n capture.certificationRequestInfoAttributes || []);\n\n return csr;\n};\n\n/**\n * Creates an empty certification request (a CSR or certificate signing\n * request). Once created, its public key and attributes can be set and then\n * it can be signed.\n *\n * @return the empty certification request.\n */\npki.createCertificationRequest = function() {\n var csr = {};\n csr.version = 0x00;\n csr.signatureOid = null;\n csr.signature = null;\n csr.siginfo = {};\n csr.siginfo.algorithmOid = null;\n\n csr.subject = {};\n csr.subject.getField = function(sn) {\n return _getAttribute(csr.subject, sn);\n };\n csr.subject.addField = function(attr) {\n _fillMissingFields([attr]);\n csr.subject.attributes.push(attr);\n };\n csr.subject.attributes = [];\n csr.subject.hash = null;\n\n csr.publicKey = null;\n csr.attributes = [];\n csr.getAttribute = function(sn) {\n return _getAttribute(csr, sn);\n };\n csr.addAttribute = function(attr) {\n _fillMissingFields([attr]);\n csr.attributes.push(attr);\n };\n csr.md = null;\n\n /**\n * Sets the subject of this certification request.\n *\n * @param attrs the array of subject attributes to use.\n */\n csr.setSubject = function(attrs) {\n // set new attributes\n _fillMissingFields(attrs);\n csr.subject.attributes = attrs;\n csr.subject.hash = null;\n };\n\n /**\n * Sets the attributes of this certification request.\n *\n * @param attrs the array of attributes to use.\n */\n csr.setAttributes = function(attrs) {\n // set new attributes\n _fillMissingFields(attrs);\n csr.attributes = attrs;\n };\n\n /**\n * Signs this certification request using the given private key.\n *\n * @param key the private key to sign with.\n * @param md the message digest object to use (defaults to forge.md.sha1).\n */\n csr.sign = function(key, md) {\n // TODO: get signature OID from private key\n csr.md = md || forge.md.sha1.create();\n var algorithmOid = oids[csr.md.algorithm + 'WithRSAEncryption'];\n if(!algorithmOid) {\n var error = new Error('Could not compute certification request digest. ' +\n 'Unknown message digest algorithm OID.');\n error.algorithm = csr.md.algorithm;\n throw error;\n }\n csr.signatureOid = csr.siginfo.algorithmOid = algorithmOid;\n\n // get CertificationRequestInfo, convert to DER\n csr.certificationRequestInfo = pki.getCertificationRequestInfo(csr);\n var bytes = asn1.toDer(csr.certificationRequestInfo);\n\n // digest and sign\n csr.md.update(bytes.getBytes());\n csr.signature = key.sign(csr.md);\n };\n\n /**\n * Attempts verify the signature on the passed certification request using\n * its public key.\n *\n * A CSR that has been exported to a file in PEM format can be verified using\n * OpenSSL using this command:\n *\n * openssl req -in <the-csr-pem-file> -verify -noout -text\n *\n * @return true if verified, false if not.\n */\n csr.verify = function() {\n var rval = false;\n\n var md = csr.md;\n if(md === null) {\n // check signature OID for supported signature types\n if(csr.signatureOid in oids) {\n // TODO: create DRY `OID to md` function\n var oid = oids[csr.signatureOid];\n switch(oid) {\n case 'sha1WithRSAEncryption':\n md = forge.md.sha1.create();\n break;\n case 'md5WithRSAEncryption':\n md = forge.md.md5.create();\n break;\n case 'sha256WithRSAEncryption':\n md = forge.md.sha256.create();\n break;\n case 'sha384WithRSAEncryption':\n md = forge.md.sha384.create();\n break;\n case 'sha512WithRSAEncryption':\n md = forge.md.sha512.create();\n break;\n case 'RSASSA-PSS':\n md = forge.md.sha256.create();\n break;\n }\n }\n if(md === null) {\n var error = new Error(\n 'Could not compute certification request digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = csr.signatureOid;\n throw error;\n }\n\n // produce DER formatted CertificationRequestInfo and digest it\n var cri = csr.certificationRequestInfo ||\n pki.getCertificationRequestInfo(csr);\n var bytes = asn1.toDer(cri);\n md.update(bytes.getBytes());\n }\n\n if(md !== null) {\n var scheme;\n\n switch(csr.signatureOid) {\n case oids.sha1WithRSAEncryption:\n /* use PKCS#1 v1.5 padding scheme */\n break;\n case oids['RSASSA-PSS']:\n var hash, mgf;\n\n /* initialize mgf */\n hash = oids[csr.signatureParameters.mgf.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported MGF hash function.');\n error.oid = csr.signatureParameters.mgf.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n mgf = oids[csr.signatureParameters.mgf.algorithmOid];\n if(mgf === undefined || forge.mgf[mgf] === undefined) {\n var error = new Error('Unsupported MGF function.');\n error.oid = csr.signatureParameters.mgf.algorithmOid;\n error.name = mgf;\n throw error;\n }\n\n mgf = forge.mgf[mgf].create(forge.md[hash].create());\n\n /* initialize hash function */\n hash = oids[csr.signatureParameters.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported RSASSA-PSS hash function.');\n error.oid = csr.signatureParameters.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n scheme = forge.pss.create(forge.md[hash].create(), mgf,\n csr.signatureParameters.saltLength);\n break;\n }\n\n // verify signature on csr using its public key\n rval = csr.publicKey.verify(\n md.digest().getBytes(), csr.signature, scheme);\n }\n\n return rval;\n };\n\n return csr;\n};\n\n/**\n * Converts an X.509 subject or issuer to an ASN.1 RDNSequence.\n *\n * @param obj the subject or issuer (distinguished name).\n *\n * @return the ASN.1 RDNSequence.\n */\nfunction _dnToAsn1(obj) {\n // create an empty RDNSequence\n var rval = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n // iterate over attributes\n var attr, set;\n var attrs = obj.attributes;\n for(var i = 0; i < attrs.length; ++i) {\n attr = attrs[i];\n var value = attr.value;\n\n // reuse tag class for attribute value if available\n var valueTagClass = asn1.Type.PRINTABLESTRING;\n if('valueTagClass' in attr) {\n valueTagClass = attr.valueTagClass;\n\n if(valueTagClass === asn1.Type.UTF8) {\n value = forge.util.encodeUtf8(value);\n }\n // FIXME: handle more encodings\n }\n\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n set = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n // AttributeValue\n asn1.create(asn1.Class.UNIVERSAL, valueTagClass, false, value)\n ])\n ]);\n rval.value.push(set);\n }\n\n return rval;\n}\n\n/**\n * Gets all printable attributes (typically of an issuer or subject) in a\n * simplified JSON format for display.\n *\n * @param attrs the attributes.\n *\n * @return the JSON for display.\n */\nfunction _getAttributesAsJson(attrs) {\n var rval = {};\n for(var i = 0; i < attrs.length; ++i) {\n var attr = attrs[i];\n if(attr.shortName && (\n attr.valueTagClass === asn1.Type.UTF8 ||\n attr.valueTagClass === asn1.Type.PRINTABLESTRING ||\n attr.valueTagClass === asn1.Type.IA5STRING)) {\n var value = attr.value;\n if(attr.valueTagClass === asn1.Type.UTF8) {\n value = forge.util.encodeUtf8(attr.value);\n }\n if(!(attr.shortName in rval)) {\n rval[attr.shortName] = value;\n } else if(forge.util.isArray(rval[attr.shortName])) {\n rval[attr.shortName].push(value);\n } else {\n rval[attr.shortName] = [rval[attr.shortName], value];\n }\n }\n }\n return rval;\n}\n\n/**\n * Fills in missing fields in attributes.\n *\n * @param attrs the attributes to fill missing fields in.\n */\nfunction _fillMissingFields(attrs) {\n var attr;\n for(var i = 0; i < attrs.length; ++i) {\n attr = attrs[i];\n\n // populate missing name\n if(typeof attr.name === 'undefined') {\n if(attr.type && attr.type in pki.oids) {\n attr.name = pki.oids[attr.type];\n } else if(attr.shortName && attr.shortName in _shortNames) {\n attr.name = pki.oids[_shortNames[attr.shortName]];\n }\n }\n\n // populate missing type (OID)\n if(typeof attr.type === 'undefined') {\n if(attr.name && attr.name in pki.oids) {\n attr.type = pki.oids[attr.name];\n } else {\n var error = new Error('Attribute type not specified.');\n error.attribute = attr;\n throw error;\n }\n }\n\n // populate missing shortname\n if(typeof attr.shortName === 'undefined') {\n if(attr.name && attr.name in _shortNames) {\n attr.shortName = _shortNames[attr.name];\n }\n }\n\n // convert extensions to value\n if(attr.type === oids.extensionRequest) {\n attr.valueConstructed = true;\n attr.valueTagClass = asn1.Type.SEQUENCE;\n if(!attr.value && attr.extensions) {\n attr.value = [];\n for(var ei = 0; ei < attr.extensions.length; ++ei) {\n attr.value.push(pki.certificateExtensionToAsn1(\n _fillMissingExtensionFields(attr.extensions[ei])));\n }\n }\n }\n\n if(typeof attr.value === 'undefined') {\n var error = new Error('Attribute value not specified.');\n error.attribute = attr;\n throw error;\n }\n }\n}\n\n/**\n * Fills in missing fields in certificate extensions.\n *\n * @param e the extension.\n * @param [options] the options to use.\n * [cert] the certificate the extensions are for.\n *\n * @return the extension.\n */\nfunction _fillMissingExtensionFields(e, options) {\n options = options || {};\n\n // populate missing name\n if(typeof e.name === 'undefined') {\n if(e.id && e.id in pki.oids) {\n e.name = pki.oids[e.id];\n }\n }\n\n // populate missing id\n if(typeof e.id === 'undefined') {\n if(e.name && e.name in pki.oids) {\n e.id = pki.oids[e.name];\n } else {\n var error = new Error('Extension ID not specified.');\n error.extension = e;\n throw error;\n }\n }\n\n if(typeof e.value !== 'undefined') {\n return e;\n }\n\n // handle missing value:\n\n // value is a BIT STRING\n if(e.name === 'keyUsage') {\n // build flags\n var unused = 0;\n var b2 = 0x00;\n var b3 = 0x00;\n if(e.digitalSignature) {\n b2 |= 0x80;\n unused = 7;\n }\n if(e.nonRepudiation) {\n b2 |= 0x40;\n unused = 6;\n }\n if(e.keyEncipherment) {\n b2 |= 0x20;\n unused = 5;\n }\n if(e.dataEncipherment) {\n b2 |= 0x10;\n unused = 4;\n }\n if(e.keyAgreement) {\n b2 |= 0x08;\n unused = 3;\n }\n if(e.keyCertSign) {\n b2 |= 0x04;\n unused = 2;\n }\n if(e.cRLSign) {\n b2 |= 0x02;\n unused = 1;\n }\n if(e.encipherOnly) {\n b2 |= 0x01;\n unused = 0;\n }\n if(e.decipherOnly) {\n b3 |= 0x80;\n unused = 7;\n }\n\n // create bit string\n var value = String.fromCharCode(unused);\n if(b3 !== 0) {\n value += String.fromCharCode(b2) + String.fromCharCode(b3);\n } else if(b2 !== 0) {\n value += String.fromCharCode(b2);\n }\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false, value);\n } else if(e.name === 'basicConstraints') {\n // basicConstraints is a SEQUENCE\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n // cA BOOLEAN flag defaults to false\n if(e.cA) {\n e.value.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BOOLEAN, false,\n String.fromCharCode(0xFF)));\n }\n if('pathLenConstraint' in e) {\n e.value.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(e.pathLenConstraint).getBytes()));\n }\n } else if(e.name === 'extKeyUsage') {\n // extKeyUsage is a SEQUENCE of OIDs\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var seq = e.value.value;\n for(var key in e) {\n if(e[key] !== true) {\n continue;\n }\n // key is name in OID map\n if(key in oids) {\n seq.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID,\n false, asn1.oidToDer(oids[key]).getBytes()));\n } else if(key.indexOf('.') !== -1) {\n // assume key is an OID\n seq.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID,\n false, asn1.oidToDer(key).getBytes()));\n }\n }\n } else if(e.name === 'nsCertType') {\n // nsCertType is a BIT STRING\n // build flags\n var unused = 0;\n var b2 = 0x00;\n\n if(e.client) {\n b2 |= 0x80;\n unused = 7;\n }\n if(e.server) {\n b2 |= 0x40;\n unused = 6;\n }\n if(e.email) {\n b2 |= 0x20;\n unused = 5;\n }\n if(e.objsign) {\n b2 |= 0x10;\n unused = 4;\n }\n if(e.reserved) {\n b2 |= 0x08;\n unused = 3;\n }\n if(e.sslCA) {\n b2 |= 0x04;\n unused = 2;\n }\n if(e.emailCA) {\n b2 |= 0x02;\n unused = 1;\n }\n if(e.objCA) {\n b2 |= 0x01;\n unused = 0;\n }\n\n // create bit string\n var value = String.fromCharCode(unused);\n if(b2 !== 0) {\n value += String.fromCharCode(b2);\n }\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false, value);\n } else if(e.name === 'subjectAltName' || e.name === 'issuerAltName') {\n // SYNTAX SEQUENCE\n e.value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n var altName;\n for(var n = 0; n < e.altNames.length; ++n) {\n altName = e.altNames[n];\n var value = altName.value;\n // handle IP\n if(altName.type === 7 && altName.ip) {\n value = forge.util.bytesFromIP(altName.ip);\n if(value === null) {\n var error = new Error(\n 'Extension \"ip\" value is not a valid IPv4 or IPv6 address.');\n error.extension = e;\n throw error;\n }\n } else if(altName.type === 8) {\n // handle OID\n if(altName.oid) {\n value = asn1.oidToDer(asn1.oidToDer(altName.oid));\n } else {\n // deprecated ... convert value to OID\n value = asn1.oidToDer(value);\n }\n }\n e.value.value.push(asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, altName.type, false,\n value));\n }\n } else if(e.name === 'nsComment' && options.cert) {\n // sanity check value is ASCII (req'd) and not too big\n if(!(/^[\\x00-\\x7F]*$/.test(e.comment)) ||\n (e.comment.length < 1) || (e.comment.length > 128)) {\n throw new Error('Invalid \"nsComment\" content.');\n }\n // IA5STRING opaque comment\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.IA5STRING, false, e.comment);\n } else if(e.name === 'subjectKeyIdentifier' && options.cert) {\n var ski = options.cert.generateSubjectKeyIdentifier();\n e.subjectKeyIdentifier = ski.toHex();\n // OCTETSTRING w/digest\n e.value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, ski.getBytes());\n } else if(e.name === 'authorityKeyIdentifier' && options.cert) {\n // SYNTAX SEQUENCE\n e.value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var seq = e.value.value;\n\n if(e.keyIdentifier) {\n var keyIdentifier = (e.keyIdentifier === true ?\n options.cert.generateSubjectKeyIdentifier().getBytes() :\n e.keyIdentifier);\n seq.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, false, keyIdentifier));\n }\n\n if(e.authorityCertIssuer) {\n var authorityCertIssuer = [\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 4, true, [\n _dnToAsn1(e.authorityCertIssuer === true ?\n options.cert.issuer : e.authorityCertIssuer)\n ])\n ];\n seq.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, authorityCertIssuer));\n }\n\n if(e.serialNumber) {\n var serialNumber = forge.util.hexToBytes(e.serialNumber === true ?\n options.cert.serialNumber : e.serialNumber);\n seq.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 2, false, serialNumber));\n }\n } else if(e.name === 'cRLDistributionPoints') {\n e.value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n var seq = e.value.value;\n\n // Create sub SEQUENCE of DistributionPointName\n var subSeq = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n // Create fullName CHOICE\n var fullNameGeneralNames = asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n var altName;\n for(var n = 0; n < e.altNames.length; ++n) {\n altName = e.altNames[n];\n var value = altName.value;\n // handle IP\n if(altName.type === 7 && altName.ip) {\n value = forge.util.bytesFromIP(altName.ip);\n if(value === null) {\n var error = new Error(\n 'Extension \"ip\" value is not a valid IPv4 or IPv6 address.');\n error.extension = e;\n throw error;\n }\n } else if(altName.type === 8) {\n // handle OID\n if(altName.oid) {\n value = asn1.oidToDer(asn1.oidToDer(altName.oid));\n } else {\n // deprecated ... convert value to OID\n value = asn1.oidToDer(value);\n }\n }\n fullNameGeneralNames.value.push(asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, altName.type, false,\n value));\n }\n\n // Add to the parent SEQUENCE\n subSeq.value.push(asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, [fullNameGeneralNames]));\n seq.push(subSeq);\n }\n\n // ensure value has been defined by now\n if(typeof e.value === 'undefined') {\n var error = new Error('Extension value not specified.');\n error.extension = e;\n throw error;\n }\n\n return e;\n}\n\n/**\n * Convert signature parameters object to ASN.1\n *\n * @param {String} oid Signature algorithm OID\n * @param params The signature parametrs object\n * @return ASN.1 object representing signature parameters\n */\nfunction _signatureParametersToAsn1(oid, params) {\n switch(oid) {\n case oids['RSASSA-PSS']:\n var parts = [];\n\n if(params.hash.algorithmOid !== undefined) {\n parts.push(asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(params.hash.algorithmOid).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ]));\n }\n\n if(params.mgf.algorithmOid !== undefined) {\n parts.push(asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(params.mgf.algorithmOid).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(params.mgf.hash.algorithmOid).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ])\n ]));\n }\n\n if(params.saltLength !== undefined) {\n parts.push(asn1.create(asn1.Class.CONTEXT_SPECIFIC, 2, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(params.saltLength).getBytes())\n ]));\n }\n\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, parts);\n\n default:\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '');\n }\n}\n\n/**\n * Converts a certification request's attributes to an ASN.1 set of\n * CRIAttributes.\n *\n * @param csr certification request.\n *\n * @return the ASN.1 set of CRIAttributes.\n */\nfunction _CRIAttributesToAsn1(csr) {\n // create an empty context-specific container\n var rval = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n\n // no attributes, return empty container\n if(csr.attributes.length === 0) {\n return rval;\n }\n\n // each attribute has a sequence with a type and a set of values\n var attrs = csr.attributes;\n for(var i = 0; i < attrs.length; ++i) {\n var attr = attrs[i];\n var value = attr.value;\n\n // reuse tag class for attribute value if available\n var valueTagClass = asn1.Type.UTF8;\n if('valueTagClass' in attr) {\n valueTagClass = attr.valueTagClass;\n }\n if(valueTagClass === asn1.Type.UTF8) {\n value = forge.util.encodeUtf8(value);\n }\n var valueConstructed = false;\n if('valueConstructed' in attr) {\n valueConstructed = attr.valueConstructed;\n }\n // FIXME: handle more encodings\n\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n var seq = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n // AttributeValue\n asn1.create(\n asn1.Class.UNIVERSAL, valueTagClass, valueConstructed, value)\n ])\n ]);\n rval.value.push(seq);\n }\n\n return rval;\n}\n\nvar jan_1_1950 = new Date('1950-01-01T00:00:00Z');\nvar jan_1_2050 = new Date('2050-01-01T00:00:00Z');\n\n/**\n * Converts a Date object to ASN.1\n * Handles the different format before and after 1st January 2050\n *\n * @param date date object.\n *\n * @return the ASN.1 object representing the date.\n */\nfunction _dateToAsn1(date) {\n if(date >= jan_1_1950 && date < jan_1_2050) {\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.UTCTIME, false,\n asn1.dateToUtcTime(date));\n } else {\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.GENERALIZEDTIME, false,\n asn1.dateToGeneralizedTime(date));\n }\n}\n\n/**\n * Gets the ASN.1 TBSCertificate part of an X.509v3 certificate.\n *\n * @param cert the certificate.\n *\n * @return the asn1 TBSCertificate.\n */\npki.getTBSCertificate = function(cert) {\n // TBSCertificate\n var notBefore = _dateToAsn1(cert.validity.notBefore);\n var notAfter = _dateToAsn1(cert.validity.notAfter);\n var tbs = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n // integer\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(cert.version).getBytes())\n ]),\n // serialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(cert.serialNumber)),\n // signature\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(cert.siginfo.algorithmOid).getBytes()),\n // parameters\n _signatureParametersToAsn1(\n cert.siginfo.algorithmOid, cert.siginfo.parameters)\n ]),\n // issuer\n _dnToAsn1(cert.issuer),\n // validity\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n notBefore,\n notAfter\n ]),\n // subject\n _dnToAsn1(cert.subject),\n // SubjectPublicKeyInfo\n pki.publicKeyToAsn1(cert.publicKey)\n ]);\n\n if(cert.issuer.uniqueId) {\n // issuerUniqueID (optional)\n tbs.value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n // TODO: support arbitrary bit length ids\n String.fromCharCode(0x00) +\n cert.issuer.uniqueId\n )\n ])\n );\n }\n if(cert.subject.uniqueId) {\n // subjectUniqueID (optional)\n tbs.value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 2, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n // TODO: support arbitrary bit length ids\n String.fromCharCode(0x00) +\n cert.subject.uniqueId\n )\n ])\n );\n }\n\n if(cert.extensions.length > 0) {\n // extensions (optional)\n tbs.value.push(pki.certificateExtensionsToAsn1(cert.extensions));\n }\n\n return tbs;\n};\n\n/**\n * Gets the ASN.1 CertificationRequestInfo part of a\n * PKCS#10 CertificationRequest.\n *\n * @param csr the certification request.\n *\n * @return the asn1 CertificationRequestInfo.\n */\npki.getCertificationRequestInfo = function(csr) {\n // CertificationRequestInfo\n var cri = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(csr.version).getBytes()),\n // subject\n _dnToAsn1(csr.subject),\n // SubjectPublicKeyInfo\n pki.publicKeyToAsn1(csr.publicKey),\n // attributes\n _CRIAttributesToAsn1(csr)\n ]);\n\n return cri;\n};\n\n/**\n * Converts a DistinguishedName (subject or issuer) to an ASN.1 object.\n *\n * @param dn the DistinguishedName.\n *\n * @return the asn1 representation of a DistinguishedName.\n */\npki.distinguishedNameToAsn1 = function(dn) {\n return _dnToAsn1(dn);\n};\n\n/**\n * Converts an X.509v3 RSA certificate to an ASN.1 object.\n *\n * @param cert the certificate.\n *\n * @return the asn1 representation of an X.509v3 RSA certificate.\n */\npki.certificateToAsn1 = function(cert) {\n // prefer cached TBSCertificate over generating one\n var tbsCertificate = cert.tbsCertificate || pki.getTBSCertificate(cert);\n\n // Certificate\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // TBSCertificate\n tbsCertificate,\n // AlgorithmIdentifier (signature algorithm)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(cert.signatureOid).getBytes()),\n // parameters\n _signatureParametersToAsn1(cert.signatureOid, cert.signatureParameters)\n ]),\n // SignatureValue\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n String.fromCharCode(0x00) + cert.signature)\n ]);\n};\n\n/**\n * Converts X.509v3 certificate extensions to ASN.1.\n *\n * @param exts the extensions to convert.\n *\n * @return the extensions in ASN.1 format.\n */\npki.certificateExtensionsToAsn1 = function(exts) {\n // create top-level extension container\n var rval = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 3, true, []);\n\n // create extension sequence (stores a sequence for each extension)\n var seq = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n rval.value.push(seq);\n\n for(var i = 0; i < exts.length; ++i) {\n seq.value.push(pki.certificateExtensionToAsn1(exts[i]));\n }\n\n return rval;\n};\n\n/**\n * Converts a single certificate extension to ASN.1.\n *\n * @param ext the extension to convert.\n *\n * @return the extension in ASN.1 format.\n */\npki.certificateExtensionToAsn1 = function(ext) {\n // create a sequence for each extension\n var extseq = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, []);\n\n // extnID (OID)\n extseq.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(ext.id).getBytes()));\n\n // critical defaults to false\n if(ext.critical) {\n // critical BOOLEAN DEFAULT FALSE\n extseq.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.BOOLEAN, false,\n String.fromCharCode(0xFF)));\n }\n\n var value = ext.value;\n if(typeof ext.value !== 'string') {\n // value is asn.1\n value = asn1.toDer(value).getBytes();\n }\n\n // extnValue (OCTET STRING)\n extseq.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, value));\n\n return extseq;\n};\n\n/**\n * Converts a PKCS#10 certification request to an ASN.1 object.\n *\n * @param csr the certification request.\n *\n * @return the asn1 representation of a certification request.\n */\npki.certificationRequestToAsn1 = function(csr) {\n // prefer cached CertificationRequestInfo over generating one\n var cri = csr.certificationRequestInfo ||\n pki.getCertificationRequestInfo(csr);\n\n // Certificate\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // CertificationRequestInfo\n cri,\n // AlgorithmIdentifier (signature algorithm)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(csr.signatureOid).getBytes()),\n // parameters\n _signatureParametersToAsn1(csr.signatureOid, csr.signatureParameters)\n ]),\n // signature\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BITSTRING, false,\n String.fromCharCode(0x00) + csr.signature)\n ]);\n};\n\n/**\n * Creates a CA store.\n *\n * @param certs an optional array of certificate objects or PEM-formatted\n * certificate strings to add to the CA store.\n *\n * @return the CA store.\n */\npki.createCaStore = function(certs) {\n // create CA store\n var caStore = {\n // stored certificates\n certs: {}\n };\n\n /**\n * Gets the certificate that issued the passed certificate or its\n * 'parent'.\n *\n * @param cert the certificate to get the parent for.\n *\n * @return the parent certificate or null if none was found.\n */\n caStore.getIssuer = function(cert) {\n var rval = getBySubject(cert.issuer);\n\n // see if there are multiple matches\n /*if(forge.util.isArray(rval)) {\n // TODO: resolve multiple matches by checking\n // authorityKey/subjectKey/issuerUniqueID/other identifiers, etc.\n // FIXME: or alternatively do authority key mapping\n // if possible (X.509v1 certs can't work?)\n throw new Error('Resolving multiple issuer matches not implemented yet.');\n }*/\n\n return rval;\n };\n\n /**\n * Adds a trusted certificate to the store.\n *\n * @param cert the certificate to add as a trusted certificate (either a\n * pki.certificate object or a PEM-formatted certificate).\n */\n caStore.addCertificate = function(cert) {\n // convert from pem if necessary\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n\n ensureSubjectHasHash(cert.subject);\n\n if(!caStore.hasCertificate(cert)) { // avoid duplicate certificates in store\n if(cert.subject.hash in caStore.certs) {\n // subject hash already exists, append to array\n var tmp = caStore.certs[cert.subject.hash];\n if(!forge.util.isArray(tmp)) {\n tmp = [tmp];\n }\n tmp.push(cert);\n caStore.certs[cert.subject.hash] = tmp;\n } else {\n caStore.certs[cert.subject.hash] = cert;\n }\n }\n };\n\n /**\n * Checks to see if the given certificate is in the store.\n *\n * @param cert the certificate to check (either a pki.certificate or a\n * PEM-formatted certificate).\n *\n * @return true if the certificate is in the store, false if not.\n */\n caStore.hasCertificate = function(cert) {\n // convert from pem if necessary\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n\n var match = getBySubject(cert.subject);\n if(!match) {\n return false;\n }\n if(!forge.util.isArray(match)) {\n match = [match];\n }\n // compare DER-encoding of certificates\n var der1 = asn1.toDer(pki.certificateToAsn1(cert)).getBytes();\n for(var i = 0; i < match.length; ++i) {\n var der2 = asn1.toDer(pki.certificateToAsn1(match[i])).getBytes();\n if(der1 === der2) {\n return true;\n }\n }\n return false;\n };\n\n /**\n * Lists all of the certificates kept in the store.\n *\n * @return an array of all of the pki.certificate objects in the store.\n */\n caStore.listAllCertificates = function() {\n var certList = [];\n\n for(var hash in caStore.certs) {\n if(caStore.certs.hasOwnProperty(hash)) {\n var value = caStore.certs[hash];\n if(!forge.util.isArray(value)) {\n certList.push(value);\n } else {\n for(var i = 0; i < value.length; ++i) {\n certList.push(value[i]);\n }\n }\n }\n }\n\n return certList;\n };\n\n /**\n * Removes a certificate from the store.\n *\n * @param cert the certificate to remove (either a pki.certificate or a\n * PEM-formatted certificate).\n *\n * @return the certificate that was removed or null if the certificate\n * wasn't in store.\n */\n caStore.removeCertificate = function(cert) {\n var result;\n\n // convert from pem if necessary\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n ensureSubjectHasHash(cert.subject);\n if(!caStore.hasCertificate(cert)) {\n return null;\n }\n\n var match = getBySubject(cert.subject);\n\n if(!forge.util.isArray(match)) {\n result = caStore.certs[cert.subject.hash];\n delete caStore.certs[cert.subject.hash];\n return result;\n }\n\n // compare DER-encoding of certificates\n var der1 = asn1.toDer(pki.certificateToAsn1(cert)).getBytes();\n for(var i = 0; i < match.length; ++i) {\n var der2 = asn1.toDer(pki.certificateToAsn1(match[i])).getBytes();\n if(der1 === der2) {\n result = match[i];\n match.splice(i, 1);\n }\n }\n if(match.length === 0) {\n delete caStore.certs[cert.subject.hash];\n }\n\n return result;\n };\n\n function getBySubject(subject) {\n ensureSubjectHasHash(subject);\n return caStore.certs[subject.hash] || null;\n }\n\n function ensureSubjectHasHash(subject) {\n // produce subject hash if it doesn't exist\n if(!subject.hash) {\n var md = forge.md.sha1.create();\n subject.attributes = pki.RDNAttributesAsArray(_dnToAsn1(subject), md);\n subject.hash = md.digest().toHex();\n }\n }\n\n // auto-add passed in certs\n if(certs) {\n // parse PEM-formatted certificates as necessary\n for(var i = 0; i < certs.length; ++i) {\n var cert = certs[i];\n caStore.addCertificate(cert);\n }\n }\n\n return caStore;\n};\n\n/**\n * Certificate verification errors, based on TLS.\n */\npki.certificateError = {\n bad_certificate: 'forge.pki.BadCertificate',\n unsupported_certificate: 'forge.pki.UnsupportedCertificate',\n certificate_revoked: 'forge.pki.CertificateRevoked',\n certificate_expired: 'forge.pki.CertificateExpired',\n certificate_unknown: 'forge.pki.CertificateUnknown',\n unknown_ca: 'forge.pki.UnknownCertificateAuthority'\n};\n\n/**\n * Verifies a certificate chain against the given Certificate Authority store\n * with an optional custom verify callback.\n *\n * @param caStore a certificate store to verify against.\n * @param chain the certificate chain to verify, with the root or highest\n * authority at the end (an array of certificates).\n * @param options a callback to be called for every certificate in the chain or\n * an object with:\n * verify a callback to be called for every certificate in the\n * chain\n * validityCheckDate the date against which the certificate\n * validity period should be checked. Pass null to not check\n * the validity period. By default, the current date is used.\n *\n * The verify callback has the following signature:\n *\n * verified - Set to true if certificate was verified, otherwise the\n * pki.certificateError for why the certificate failed.\n * depth - The current index in the chain, where 0 is the end point's cert.\n * certs - The certificate chain, *NOTE* an empty chain indicates an anonymous\n * end point.\n *\n * The function returns true on success and on failure either the appropriate\n * pki.certificateError or an object with 'error' set to the appropriate\n * pki.certificateError and 'message' set to a custom error message.\n *\n * @return true if successful, error thrown if not.\n */\npki.verifyCertificateChain = function(caStore, chain, options) {\n /* From: RFC3280 - Internet X.509 Public Key Infrastructure Certificate\n Section 6: Certification Path Validation\n See inline parentheticals related to this particular implementation.\n\n The primary goal of path validation is to verify the binding between\n a subject distinguished name or a subject alternative name and subject\n public key, as represented in the end entity certificate, based on the\n public key of the trust anchor. This requires obtaining a sequence of\n certificates that support that binding. That sequence should be provided\n in the passed 'chain'. The trust anchor should be in the given CA\n store. The 'end entity' certificate is the certificate provided by the\n end point (typically a server) and is the first in the chain.\n\n To meet this goal, the path validation process verifies, among other\n things, that a prospective certification path (a sequence of n\n certificates or a 'chain') satisfies the following conditions:\n\n (a) for all x in {1, ..., n-1}, the subject of certificate x is\n the issuer of certificate x+1;\n\n (b) certificate 1 is issued by the trust anchor;\n\n (c) certificate n is the certificate to be validated; and\n\n (d) for all x in {1, ..., n}, the certificate was valid at the\n time in question.\n\n Note that here 'n' is index 0 in the chain and 1 is the last certificate\n in the chain and it must be signed by a certificate in the connection's\n CA store.\n\n The path validation process also determines the set of certificate\n policies that are valid for this path, based on the certificate policies\n extension, policy mapping extension, policy constraints extension, and\n inhibit any-policy extension.\n\n Note: Policy mapping extension not supported (Not Required).\n\n Note: If the certificate has an unsupported critical extension, then it\n must be rejected.\n\n Note: A certificate is self-issued if the DNs that appear in the subject\n and issuer fields are identical and are not empty.\n\n The path validation algorithm assumes the following seven inputs are\n provided to the path processing logic. What this specific implementation\n will use is provided parenthetically:\n\n (a) a prospective certification path of length n (the 'chain')\n (b) the current date/time: ('now').\n (c) user-initial-policy-set: A set of certificate policy identifiers\n naming the policies that are acceptable to the certificate user.\n The user-initial-policy-set contains the special value any-policy\n if the user is not concerned about certificate policy\n (Not implemented. Any policy is accepted).\n (d) trust anchor information, describing a CA that serves as a trust\n anchor for the certification path. The trust anchor information\n includes:\n\n (1) the trusted issuer name,\n (2) the trusted public key algorithm,\n (3) the trusted public key, and\n (4) optionally, the trusted public key parameters associated\n with the public key.\n\n (Trust anchors are provided via certificates in the CA store).\n\n The trust anchor information may be provided to the path processing\n procedure in the form of a self-signed certificate. The trusted anchor\n information is trusted because it was delivered to the path processing\n procedure by some trustworthy out-of-band procedure. If the trusted\n public key algorithm requires parameters, then the parameters are\n provided along with the trusted public key (No parameters used in this\n implementation).\n\n (e) initial-policy-mapping-inhibit, which indicates if policy mapping is\n allowed in the certification path.\n (Not implemented, no policy checking)\n\n (f) initial-explicit-policy, which indicates if the path must be valid\n for at least one of the certificate policies in the user-initial-\n policy-set.\n (Not implemented, no policy checking)\n\n (g) initial-any-policy-inhibit, which indicates whether the\n anyPolicy OID should be processed if it is included in a\n certificate.\n (Not implemented, so any policy is valid provided that it is\n not marked as critical) */\n\n /* Basic Path Processing:\n\n For each certificate in the 'chain', the following is checked:\n\n 1. The certificate validity period includes the current time.\n 2. The certificate was signed by its parent (where the parent is either\n the next in the chain or from the CA store). Allow processing to\n continue to the next step if no parent is found but the certificate is\n in the CA store.\n 3. TODO: The certificate has not been revoked.\n 4. The certificate issuer name matches the parent's subject name.\n 5. TODO: If the certificate is self-issued and not the final certificate\n in the chain, skip this step, otherwise verify that the subject name\n is within one of the permitted subtrees of X.500 distinguished names\n and that each of the alternative names in the subjectAltName extension\n (critical or non-critical) is within one of the permitted subtrees for\n that name type.\n 6. TODO: If the certificate is self-issued and not the final certificate\n in the chain, skip this step, otherwise verify that the subject name\n is not within one of the excluded subtrees for X.500 distinguished\n names and none of the subjectAltName extension names are excluded for\n that name type.\n 7. The other steps in the algorithm for basic path processing involve\n handling the policy extension which is not presently supported in this\n implementation. Instead, if a critical policy extension is found, the\n certificate is rejected as not supported.\n 8. If the certificate is not the first or if its the only certificate in\n the chain (having no parent from the CA store or is self-signed) and it\n has a critical key usage extension, verify that the keyCertSign bit is\n set. If the key usage extension exists, verify that the basic\n constraints extension exists. If the basic constraints extension exists,\n verify that the cA flag is set. If pathLenConstraint is set, ensure that\n the number of certificates that precede in the chain (come earlier\n in the chain as implemented below), excluding the very first in the\n chain (typically the end-entity one), isn't greater than the\n pathLenConstraint. This constraint limits the number of intermediate\n CAs that may appear below a CA before only end-entity certificates\n may be issued. */\n\n // if a verify callback is passed as the third parameter, package it within\n // the options object. This is to support a legacy function signature that\n // expected the verify callback as the third parameter.\n if(typeof options === 'function') {\n options = {verify: options};\n }\n options = options || {};\n\n // copy cert chain references to another array to protect against changes\n // in verify callback\n chain = chain.slice(0);\n var certs = chain.slice(0);\n\n var validityCheckDate = options.validityCheckDate;\n // if no validityCheckDate is specified, default to the current date. Make\n // sure to maintain the value null because it indicates that the validity\n // period should not be checked.\n if(typeof validityCheckDate === 'undefined') {\n validityCheckDate = new Date();\n }\n\n // verify each cert in the chain using its parent, where the parent\n // is either the next in the chain or from the CA store\n var first = true;\n var error = null;\n var depth = 0;\n do {\n var cert = chain.shift();\n var parent = null;\n var selfSigned = false;\n\n if(validityCheckDate) {\n // 1. check valid time\n if(validityCheckDate < cert.validity.notBefore ||\n validityCheckDate > cert.validity.notAfter) {\n error = {\n message: 'Certificate is not valid yet or has expired.',\n error: pki.certificateError.certificate_expired,\n notBefore: cert.validity.notBefore,\n notAfter: cert.validity.notAfter,\n // TODO: we might want to reconsider renaming 'now' to\n // 'validityCheckDate' should this API be changed in the future.\n now: validityCheckDate\n };\n }\n }\n\n // 2. verify with parent from chain or CA store\n if(error === null) {\n parent = chain[0] || caStore.getIssuer(cert);\n if(parent === null) {\n // check for self-signed cert\n if(cert.isIssuer(cert)) {\n selfSigned = true;\n parent = cert;\n }\n }\n\n if(parent) {\n // FIXME: current CA store implementation might have multiple\n // certificates where the issuer can't be determined from the\n // certificate (happens rarely with, eg: old certificates) so normalize\n // by always putting parents into an array\n // TODO: there's may be an extreme degenerate case currently uncovered\n // where an old intermediate certificate seems to have a matching parent\n // but none of the parents actually verify ... but the intermediate\n // is in the CA and it should pass this check; needs investigation\n var parents = parent;\n if(!forge.util.isArray(parents)) {\n parents = [parents];\n }\n\n // try to verify with each possible parent (typically only one)\n var verified = false;\n while(!verified && parents.length > 0) {\n parent = parents.shift();\n try {\n verified = parent.verify(cert);\n } catch(ex) {\n // failure to verify, don't care why, try next one\n }\n }\n\n if(!verified) {\n error = {\n message: 'Certificate signature is invalid.',\n error: pki.certificateError.bad_certificate\n };\n }\n }\n\n if(error === null && (!parent || selfSigned) &&\n !caStore.hasCertificate(cert)) {\n // no parent issuer and certificate itself is not trusted\n error = {\n message: 'Certificate is not trusted.',\n error: pki.certificateError.unknown_ca\n };\n }\n }\n\n // TODO: 3. check revoked\n\n // 4. check for matching issuer/subject\n if(error === null && parent && !cert.isIssuer(parent)) {\n // parent is not issuer\n error = {\n message: 'Certificate issuer is invalid.',\n error: pki.certificateError.bad_certificate\n };\n }\n\n // 5. TODO: check names with permitted names tree\n\n // 6. TODO: check names against excluded names tree\n\n // 7. check for unsupported critical extensions\n if(error === null) {\n // supported extensions\n var se = {\n keyUsage: true,\n basicConstraints: true\n };\n for(var i = 0; error === null && i < cert.extensions.length; ++i) {\n var ext = cert.extensions[i];\n if(ext.critical && !(ext.name in se)) {\n error = {\n message:\n 'Certificate has an unsupported critical extension.',\n error: pki.certificateError.unsupported_certificate\n };\n }\n }\n }\n\n // 8. check for CA if cert is not first or is the only certificate\n // remaining in chain with no parent or is self-signed\n if(error === null &&\n (!first || (chain.length === 0 && (!parent || selfSigned)))) {\n // first check keyUsage extension and then basic constraints\n var bcExt = cert.getExtension('basicConstraints');\n var keyUsageExt = cert.getExtension('keyUsage');\n if(keyUsageExt !== null) {\n // keyCertSign must be true and there must be a basic\n // constraints extension\n if(!keyUsageExt.keyCertSign || bcExt === null) {\n // bad certificate\n error = {\n message:\n 'Certificate keyUsage or basicConstraints conflict ' +\n 'or indicate that the certificate is not a CA. ' +\n 'If the certificate is the only one in the chain or ' +\n 'isn\\'t the first then the certificate must be a ' +\n 'valid CA.',\n error: pki.certificateError.bad_certificate\n };\n }\n }\n // basic constraints cA flag must be set\n if(error === null && bcExt !== null && !bcExt.cA) {\n // bad certificate\n error = {\n message:\n 'Certificate basicConstraints indicates the certificate ' +\n 'is not a CA.',\n error: pki.certificateError.bad_certificate\n };\n }\n // if error is not null and keyUsage is available, then we know it\n // has keyCertSign and there is a basic constraints extension too,\n // which means we can check pathLenConstraint (if it exists)\n if(error === null && keyUsageExt !== null &&\n 'pathLenConstraint' in bcExt) {\n // pathLen is the maximum # of intermediate CA certs that can be\n // found between the current certificate and the end-entity (depth 0)\n // certificate; this number does not include the end-entity (depth 0,\n // last in the chain) even if it happens to be a CA certificate itself\n var pathLen = depth - 1;\n if(pathLen > bcExt.pathLenConstraint) {\n // pathLenConstraint violated, bad certificate\n error = {\n message:\n 'Certificate basicConstraints pathLenConstraint violated.',\n error: pki.certificateError.bad_certificate\n };\n }\n }\n }\n\n // call application callback\n var vfd = (error === null) ? true : error.error;\n var ret = options.verify ? options.verify(vfd, depth, certs) : vfd;\n if(ret === true) {\n // clear any set error\n error = null;\n } else {\n // if passed basic tests, set default message and alert\n if(vfd === true) {\n error = {\n message: 'The application rejected the certificate.',\n error: pki.certificateError.bad_certificate\n };\n }\n\n // check for custom error info\n if(ret || ret === 0) {\n // set custom message and error\n if(typeof ret === 'object' && !forge.util.isArray(ret)) {\n if(ret.message) {\n error.message = ret.message;\n }\n if(ret.error) {\n error.error = ret.error;\n }\n } else if(typeof ret === 'string') {\n // set custom error\n error.error = ret;\n }\n }\n\n // throw error\n throw error;\n }\n\n // no longer first cert in chain\n first = false;\n ++depth;\n } while(chain.length > 0);\n\n return true;\n};\n","/**\n * Javascript implementation of PKCS#1 PSS signature padding.\n *\n * @author Stefan Siegl\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n */\nvar forge = require('./forge');\nrequire('./random');\nrequire('./util');\n\n// shortcut for PSS API\nvar pss = module.exports = forge.pss = forge.pss || {};\n\n/**\n * Creates a PSS signature scheme object.\n *\n * There are several ways to provide a salt for encoding:\n *\n * 1. Specify the saltLength only and the built-in PRNG will generate it.\n * 2. Specify the saltLength and a custom PRNG with 'getBytesSync' defined that\n * will be used.\n * 3. Specify the salt itself as a forge.util.ByteBuffer.\n *\n * @param options the options to use:\n * md the message digest object to use, a forge md instance.\n * mgf the mask generation function to use, a forge mgf instance.\n * [saltLength] the length of the salt in octets.\n * [prng] the pseudo-random number generator to use to produce a salt.\n * [salt] the salt to use when encoding.\n *\n * @return a signature scheme object.\n */\npss.create = function(options) {\n // backwards compatibility w/legacy args: hash, mgf, sLen\n if(arguments.length === 3) {\n options = {\n md: arguments[0],\n mgf: arguments[1],\n saltLength: arguments[2]\n };\n }\n\n var hash = options.md;\n var mgf = options.mgf;\n var hLen = hash.digestLength;\n\n var salt_ = options.salt || null;\n if(typeof salt_ === 'string') {\n // assume binary-encoded string\n salt_ = forge.util.createBuffer(salt_);\n }\n\n var sLen;\n if('saltLength' in options) {\n sLen = options.saltLength;\n } else if(salt_ !== null) {\n sLen = salt_.length();\n } else {\n throw new Error('Salt length not specified or specific salt not given.');\n }\n\n if(salt_ !== null && salt_.length() !== sLen) {\n throw new Error('Given salt length does not match length of given salt.');\n }\n\n var prng = options.prng || forge.random;\n\n var pssobj = {};\n\n /**\n * Encodes a PSS signature.\n *\n * This function implements EMSA-PSS-ENCODE as per RFC 3447, section 9.1.1.\n *\n * @param md the message digest object with the hash to sign.\n * @param modsBits the length of the RSA modulus in bits.\n *\n * @return the encoded message as a binary-encoded string of length\n * ceil((modBits - 1) / 8).\n */\n pssobj.encode = function(md, modBits) {\n var i;\n var emBits = modBits - 1;\n var emLen = Math.ceil(emBits / 8);\n\n /* 2. Let mHash = Hash(M), an octet string of length hLen. */\n var mHash = md.digest().getBytes();\n\n /* 3. If emLen < hLen + sLen + 2, output \"encoding error\" and stop. */\n if(emLen < hLen + sLen + 2) {\n throw new Error('Message is too long to encrypt.');\n }\n\n /* 4. Generate a random octet string salt of length sLen; if sLen = 0,\n * then salt is the empty string. */\n var salt;\n if(salt_ === null) {\n salt = prng.getBytesSync(sLen);\n } else {\n salt = salt_.bytes();\n }\n\n /* 5. Let M' = (0x)00 00 00 00 00 00 00 00 || mHash || salt; */\n var m_ = new forge.util.ByteBuffer();\n m_.fillWithByte(0, 8);\n m_.putBytes(mHash);\n m_.putBytes(salt);\n\n /* 6. Let H = Hash(M'), an octet string of length hLen. */\n hash.start();\n hash.update(m_.getBytes());\n var h = hash.digest().getBytes();\n\n /* 7. Generate an octet string PS consisting of emLen - sLen - hLen - 2\n * zero octets. The length of PS may be 0. */\n var ps = new forge.util.ByteBuffer();\n ps.fillWithByte(0, emLen - sLen - hLen - 2);\n\n /* 8. Let DB = PS || 0x01 || salt; DB is an octet string of length\n * emLen - hLen - 1. */\n ps.putByte(0x01);\n ps.putBytes(salt);\n var db = ps.getBytes();\n\n /* 9. Let dbMask = MGF(H, emLen - hLen - 1). */\n var maskLen = emLen - hLen - 1;\n var dbMask = mgf.generate(h, maskLen);\n\n /* 10. Let maskedDB = DB \\xor dbMask. */\n var maskedDB = '';\n for(i = 0; i < maskLen; i++) {\n maskedDB += String.fromCharCode(db.charCodeAt(i) ^ dbMask.charCodeAt(i));\n }\n\n /* 11. Set the leftmost 8emLen - emBits bits of the leftmost octet in\n * maskedDB to zero. */\n var mask = (0xFF00 >> (8 * emLen - emBits)) & 0xFF;\n maskedDB = String.fromCharCode(maskedDB.charCodeAt(0) & ~mask) +\n maskedDB.substr(1);\n\n /* 12. Let EM = maskedDB || H || 0xbc.\n * 13. Output EM. */\n return maskedDB + h + String.fromCharCode(0xbc);\n };\n\n /**\n * Verifies a PSS signature.\n *\n * This function implements EMSA-PSS-VERIFY as per RFC 3447, section 9.1.2.\n *\n * @param mHash the message digest hash, as a binary-encoded string, to\n * compare against the signature.\n * @param em the encoded message, as a binary-encoded string\n * (RSA decryption result).\n * @param modsBits the length of the RSA modulus in bits.\n *\n * @return true if the signature was verified, false if not.\n */\n pssobj.verify = function(mHash, em, modBits) {\n var i;\n var emBits = modBits - 1;\n var emLen = Math.ceil(emBits / 8);\n\n /* c. Convert the message representative m to an encoded message EM\n * of length emLen = ceil((modBits - 1) / 8) octets, where modBits\n * is the length in bits of the RSA modulus n */\n em = em.substr(-emLen);\n\n /* 3. If emLen < hLen + sLen + 2, output \"inconsistent\" and stop. */\n if(emLen < hLen + sLen + 2) {\n throw new Error('Inconsistent parameters to PSS signature verification.');\n }\n\n /* 4. If the rightmost octet of EM does not have hexadecimal value\n * 0xbc, output \"inconsistent\" and stop. */\n if(em.charCodeAt(emLen - 1) !== 0xbc) {\n throw new Error('Encoded message does not end in 0xBC.');\n }\n\n /* 5. Let maskedDB be the leftmost emLen - hLen - 1 octets of EM, and\n * let H be the next hLen octets. */\n var maskLen = emLen - hLen - 1;\n var maskedDB = em.substr(0, maskLen);\n var h = em.substr(maskLen, hLen);\n\n /* 6. If the leftmost 8emLen - emBits bits of the leftmost octet in\n * maskedDB are not all equal to zero, output \"inconsistent\" and stop. */\n var mask = (0xFF00 >> (8 * emLen - emBits)) & 0xFF;\n if((maskedDB.charCodeAt(0) & mask) !== 0) {\n throw new Error('Bits beyond keysize not zero as expected.');\n }\n\n /* 7. Let dbMask = MGF(H, emLen - hLen - 1). */\n var dbMask = mgf.generate(h, maskLen);\n\n /* 8. Let DB = maskedDB \\xor dbMask. */\n var db = '';\n for(i = 0; i < maskLen; i++) {\n db += String.fromCharCode(maskedDB.charCodeAt(i) ^ dbMask.charCodeAt(i));\n }\n\n /* 9. Set the leftmost 8emLen - emBits bits of the leftmost octet\n * in DB to zero. */\n db = String.fromCharCode(db.charCodeAt(0) & ~mask) + db.substr(1);\n\n /* 10. If the emLen - hLen - sLen - 2 leftmost octets of DB are not zero\n * or if the octet at position emLen - hLen - sLen - 1 (the leftmost\n * position is \"position 1\") does not have hexadecimal value 0x01,\n * output \"inconsistent\" and stop. */\n var checkLen = emLen - hLen - sLen - 2;\n for(i = 0; i < checkLen; i++) {\n if(db.charCodeAt(i) !== 0x00) {\n throw new Error('Leftmost octets not zero as expected');\n }\n }\n\n if(db.charCodeAt(checkLen) !== 0x01) {\n throw new Error('Inconsistent PSS signature, 0x01 marker not found');\n }\n\n /* 11. Let salt be the last sLen octets of DB. */\n var salt = db.substr(-sLen);\n\n /* 12. Let M' = (0x)00 00 00 00 00 00 00 00 || mHash || salt */\n var m_ = new forge.util.ByteBuffer();\n m_.fillWithByte(0, 8);\n m_.putBytes(mHash);\n m_.putBytes(salt);\n\n /* 13. Let H' = Hash(M'), an octet string of length hLen. */\n hash.start();\n hash.update(m_.getBytes());\n var h_ = hash.digest().getBytes();\n\n /* 14. If H = H', output \"consistent.\" Otherwise, output \"inconsistent.\" */\n return h === h_;\n };\n\n return pssobj;\n};\n","\"use strict\";\n\nconst $ = document.querySelector.bind(document)\nconst _ = document.getElementById\n\nexport class ConfirmDialog {\n\n\tconstructor(message) {\n\t\tthis._div = document.getElementById('confirm-dialog-template').content.querySelector('div').cloneNode(true);\n\t\tthis._div.querySelector('.modal-body').innerHTML = message;\n\t}\n\n\tshow() {\n\t\tvar self = this;\n\t\tthis._promise = new Promise((resolve, reject) => {\n\t\t\tself._resolve = resolve;\n\t\t\tself._reject = reject;\n\t\t});\n\n\t\tthis._div.querySelectorAll('.close').forEach(function (o){\n\t\t\to.onclick=self.cancel.bind(self);\n\t\t});\n\n\t\tthis._div.querySelector('.process').onclick = () => {\n\t\t\tself._close();\n\t\t\tself._resolve();\n\t\t};\n\n\t\t$('.messages-box').appendChild(this._div);\n\t\treturn this._promise\n\t}\n\n\tcancel() {\n\t\tthis._close()\n\t\tthis._reject('canceled by user');\n\t}\n\n\t_close() {\n\t\t$('.messages-box').removeChild(this._div);\n\t}\n\n}\n\n\n\n","/**\n * Supported cipher modes.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nforge.cipher = forge.cipher || {};\n\n// supported cipher modes\nvar modes = module.exports = forge.cipher.modes = forge.cipher.modes || {};\n\n/** Electronic codebook (ECB) (Don't use this; it's not secure) **/\n\nmodes.ecb = function(options) {\n options = options || {};\n this.name = 'ECB';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = new Array(this._ints);\n this._outBlock = new Array(this._ints);\n};\n\nmodes.ecb.prototype.start = function(options) {};\n\nmodes.ecb.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // write output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n};\n\nmodes.ecb.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n }\n\n // decrypt block\n this.cipher.decrypt(this._inBlock, this._outBlock);\n\n // write output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n};\n\nmodes.ecb.prototype.pad = function(input, options) {\n // add PKCS#7 padding to block (each pad byte is the\n // value of the number of pad bytes)\n var padding = (input.length() === this.blockSize ?\n this.blockSize : (this.blockSize - input.length()));\n input.fillWithByte(padding, padding);\n return true;\n};\n\nmodes.ecb.prototype.unpad = function(output, options) {\n // check for error: input data not a multiple of blockSize\n if(options.overflow > 0) {\n return false;\n }\n\n // ensure padding byte count is valid\n var len = output.length();\n var count = output.at(len - 1);\n if(count > (this.blockSize << 2)) {\n return false;\n }\n\n // trim off padding bytes\n output.truncate(count);\n return true;\n};\n\n/** Cipher-block Chaining (CBC) **/\n\nmodes.cbc = function(options) {\n options = options || {};\n this.name = 'CBC';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = new Array(this._ints);\n this._outBlock = new Array(this._ints);\n};\n\nmodes.cbc.prototype.start = function(options) {\n // Note: legacy support for using IV residue (has security flaws)\n // if IV is null, reuse block from previous processing\n if(options.iv === null) {\n // must have a previous block\n if(!this._prev) {\n throw new Error('Invalid IV parameter.');\n }\n this._iv = this._prev.slice(0);\n } else if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n } else {\n // save IV as \"previous\" block\n this._iv = transformIV(options.iv, this.blockSize);\n this._prev = this._iv.slice(0);\n }\n};\n\nmodes.cbc.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n // CBC XOR's IV (or previous block) with plaintext\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._prev[i] ^ input.getInt32();\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // write output, save previous block\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n this._prev = this._outBlock;\n};\n\nmodes.cbc.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n // get next block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n }\n\n // decrypt block\n this.cipher.decrypt(this._inBlock, this._outBlock);\n\n // write output, save previous ciphered block\n // CBC XOR's IV (or previous block) with ciphertext\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._prev[i] ^ this._outBlock[i]);\n }\n this._prev = this._inBlock.slice(0);\n};\n\nmodes.cbc.prototype.pad = function(input, options) {\n // add PKCS#7 padding to block (each pad byte is the\n // value of the number of pad bytes)\n var padding = (input.length() === this.blockSize ?\n this.blockSize : (this.blockSize - input.length()));\n input.fillWithByte(padding, padding);\n return true;\n};\n\nmodes.cbc.prototype.unpad = function(output, options) {\n // check for error: input data not a multiple of blockSize\n if(options.overflow > 0) {\n return false;\n }\n\n // ensure padding byte count is valid\n var len = output.length();\n var count = output.at(len - 1);\n if(count > (this.blockSize << 2)) {\n return false;\n }\n\n // trim off padding bytes\n output.truncate(count);\n return true;\n};\n\n/** Cipher feedback (CFB) **/\n\nmodes.cfb = function(options) {\n options = options || {};\n this.name = 'CFB';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = null;\n this._outBlock = new Array(this._ints);\n this._partialBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n};\n\nmodes.cfb.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // use IV as first input\n this._iv = transformIV(options.iv, this.blockSize);\n this._inBlock = this._iv.slice(0);\n this._partialBytes = 0;\n};\n\nmodes.cfb.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output, write input as output\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32() ^ this._outBlock[i];\n output.putInt32(this._inBlock[i]);\n }\n return;\n }\n\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output, write input as partial output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialBlock[i] = input.getInt32() ^ this._outBlock[i];\n this._partialOutput.putInt32(this._partialBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n } else {\n // block complete, update input block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._partialBlock[i];\n }\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n};\n\nmodes.cfb.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block (CFB always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output, write input as output\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = input.getInt32();\n output.putInt32(this._inBlock[i] ^ this._outBlock[i]);\n }\n return;\n }\n\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output, write input as partial output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialBlock[i] = input.getInt32();\n this._partialOutput.putInt32(this._partialBlock[i] ^ this._outBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n } else {\n // block complete, update input block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._partialBlock[i];\n }\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n};\n\n/** Output feedback (OFB) **/\n\nmodes.ofb = function(options) {\n options = options || {};\n this.name = 'OFB';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = null;\n this._outBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n};\n\nmodes.ofb.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // use IV as first input\n this._iv = transformIV(options.iv, this.blockSize);\n this._inBlock = this._iv.slice(0);\n this._partialBytes = 0;\n};\n\nmodes.ofb.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(input.length() === 0) {\n return true;\n }\n\n // encrypt block (OFB always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output and update next input\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(input.getInt32() ^ this._outBlock[i]);\n this._inBlock[i] = this._outBlock[i];\n }\n return;\n }\n\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialOutput.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n } else {\n // block complete, update input block\n for(var i = 0; i < this._ints; ++i) {\n this._inBlock[i] = this._outBlock[i];\n }\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n};\n\nmodes.ofb.prototype.decrypt = modes.ofb.prototype.encrypt;\n\n/** Counter (CTR) **/\n\nmodes.ctr = function(options) {\n options = options || {};\n this.name = 'CTR';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = null;\n this._outBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n};\n\nmodes.ctr.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // use IV as first input\n this._iv = transformIV(options.iv, this.blockSize);\n this._inBlock = this._iv.slice(0);\n this._partialBytes = 0;\n};\n\nmodes.ctr.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block (CTR always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n } else {\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialOutput.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n\n if(partialBytes > 0) {\n // block still incomplete, restore input buffer\n input.read -= this.blockSize;\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n }\n\n // block complete, increment counter (input block)\n inc32(this._inBlock);\n};\n\nmodes.ctr.prototype.decrypt = modes.ctr.prototype.encrypt;\n\n/** Galois/Counter Mode (GCM) **/\n\nmodes.gcm = function(options) {\n options = options || {};\n this.name = 'GCM';\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._ints = this.blockSize / 4;\n this._inBlock = new Array(this._ints);\n this._outBlock = new Array(this._ints);\n this._partialOutput = forge.util.createBuffer();\n this._partialBytes = 0;\n\n // R is actually this value concatenated with 120 more zero bits, but\n // we only XOR against R so the other zeros have no effect -- we just\n // apply this value to the first integer in a block\n this._R = 0xE1000000;\n};\n\nmodes.gcm.prototype.start = function(options) {\n if(!('iv' in options)) {\n throw new Error('Invalid IV parameter.');\n }\n // ensure IV is a byte buffer\n var iv = forge.util.createBuffer(options.iv);\n\n // no ciphered data processed yet\n this._cipherLength = 0;\n\n // default additional data is none\n var additionalData;\n if('additionalData' in options) {\n additionalData = forge.util.createBuffer(options.additionalData);\n } else {\n additionalData = forge.util.createBuffer();\n }\n\n // default tag length is 128 bits\n if('tagLength' in options) {\n this._tagLength = options.tagLength;\n } else {\n this._tagLength = 128;\n }\n\n // if tag is given, ensure tag matches tag length\n this._tag = null;\n if(options.decrypt) {\n // save tag to check later\n this._tag = forge.util.createBuffer(options.tag).getBytes();\n if(this._tag.length !== (this._tagLength / 8)) {\n throw new Error('Authentication tag does not match tag length.');\n }\n }\n\n // create tmp storage for hash calculation\n this._hashBlock = new Array(this._ints);\n\n // no tag generated yet\n this.tag = null;\n\n // generate hash subkey\n // (apply block cipher to \"zero\" block)\n this._hashSubkey = new Array(this._ints);\n this.cipher.encrypt([0, 0, 0, 0], this._hashSubkey);\n\n // generate table M\n // use 4-bit tables (32 component decomposition of a 16 byte value)\n // 8-bit tables take more space and are known to have security\n // vulnerabilities (in native implementations)\n this.componentBits = 4;\n this._m = this.generateHashTable(this._hashSubkey, this.componentBits);\n\n // Note: support IV length different from 96 bits? (only supporting\n // 96 bits is recommended by NIST SP-800-38D)\n // generate J_0\n var ivLength = iv.length();\n if(ivLength === 12) {\n // 96-bit IV\n this._j0 = [iv.getInt32(), iv.getInt32(), iv.getInt32(), 1];\n } else {\n // IV is NOT 96-bits\n this._j0 = [0, 0, 0, 0];\n while(iv.length() > 0) {\n this._j0 = this.ghash(\n this._hashSubkey, this._j0,\n [iv.getInt32(), iv.getInt32(), iv.getInt32(), iv.getInt32()]);\n }\n this._j0 = this.ghash(\n this._hashSubkey, this._j0, [0, 0].concat(from64To32(ivLength * 8)));\n }\n\n // generate ICB (initial counter block)\n this._inBlock = this._j0.slice(0);\n inc32(this._inBlock);\n this._partialBytes = 0;\n\n // consume authentication data\n additionalData = forge.util.createBuffer(additionalData);\n // save additional data length as a BE 64-bit number\n this._aDataLength = from64To32(additionalData.length() * 8);\n // pad additional data to 128 bit (16 byte) block size\n var overflow = additionalData.length() % this.blockSize;\n if(overflow) {\n additionalData.fillWithByte(0, this.blockSize - overflow);\n }\n this._s = [0, 0, 0, 0];\n while(additionalData.length() > 0) {\n this._s = this.ghash(this._hashSubkey, this._s, [\n additionalData.getInt32(),\n additionalData.getInt32(),\n additionalData.getInt32(),\n additionalData.getInt32()\n ]);\n }\n};\n\nmodes.gcm.prototype.encrypt = function(input, output, finish) {\n // not enough input to encrypt\n var inputLength = input.length();\n if(inputLength === 0) {\n return true;\n }\n\n // encrypt block\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // handle full block\n if(this._partialBytes === 0 && inputLength >= this.blockSize) {\n // XOR input with output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i] ^= input.getInt32());\n }\n this._cipherLength += this.blockSize;\n } else {\n // handle partial block\n var partialBytes = (this.blockSize - inputLength) % this.blockSize;\n if(partialBytes > 0) {\n partialBytes = this.blockSize - partialBytes;\n }\n\n // XOR input with output\n this._partialOutput.clear();\n for(var i = 0; i < this._ints; ++i) {\n this._partialOutput.putInt32(input.getInt32() ^ this._outBlock[i]);\n }\n\n if(partialBytes <= 0 || finish) {\n // handle overflow prior to hashing\n if(finish) {\n // get block overflow\n var overflow = inputLength % this.blockSize;\n this._cipherLength += overflow;\n // truncate for hash function\n this._partialOutput.truncate(this.blockSize - overflow);\n } else {\n this._cipherLength += this.blockSize;\n }\n\n // get output block for hashing\n for(var i = 0; i < this._ints; ++i) {\n this._outBlock[i] = this._partialOutput.getInt32();\n }\n this._partialOutput.read -= this.blockSize;\n }\n\n // skip any previous partial bytes\n if(this._partialBytes > 0) {\n this._partialOutput.getBytes(this._partialBytes);\n }\n\n if(partialBytes > 0 && !finish) {\n // block still incomplete, restore input buffer, get partial output,\n // and return early\n input.read -= this.blockSize;\n output.putBytes(this._partialOutput.getBytes(\n partialBytes - this._partialBytes));\n this._partialBytes = partialBytes;\n return true;\n }\n\n output.putBytes(this._partialOutput.getBytes(\n inputLength - this._partialBytes));\n this._partialBytes = 0;\n }\n\n // update hash block S\n this._s = this.ghash(this._hashSubkey, this._s, this._outBlock);\n\n // increment counter (input block)\n inc32(this._inBlock);\n};\n\nmodes.gcm.prototype.decrypt = function(input, output, finish) {\n // not enough input to decrypt\n var inputLength = input.length();\n if(inputLength < this.blockSize && !(finish && inputLength > 0)) {\n return true;\n }\n\n // encrypt block (GCM always uses encryption mode)\n this.cipher.encrypt(this._inBlock, this._outBlock);\n\n // increment counter (input block)\n inc32(this._inBlock);\n\n // update hash block S\n this._hashBlock[0] = input.getInt32();\n this._hashBlock[1] = input.getInt32();\n this._hashBlock[2] = input.getInt32();\n this._hashBlock[3] = input.getInt32();\n this._s = this.ghash(this._hashSubkey, this._s, this._hashBlock);\n\n // XOR hash input with output\n for(var i = 0; i < this._ints; ++i) {\n output.putInt32(this._outBlock[i] ^ this._hashBlock[i]);\n }\n\n // increment cipher data length\n if(inputLength < this.blockSize) {\n this._cipherLength += inputLength % this.blockSize;\n } else {\n this._cipherLength += this.blockSize;\n }\n};\n\nmodes.gcm.prototype.afterFinish = function(output, options) {\n var rval = true;\n\n // handle overflow\n if(options.decrypt && options.overflow) {\n output.truncate(this.blockSize - options.overflow);\n }\n\n // handle authentication tag\n this.tag = forge.util.createBuffer();\n\n // concatenate additional data length with cipher length\n var lengths = this._aDataLength.concat(from64To32(this._cipherLength * 8));\n\n // include lengths in hash\n this._s = this.ghash(this._hashSubkey, this._s, lengths);\n\n // do GCTR(J_0, S)\n var tag = [];\n this.cipher.encrypt(this._j0, tag);\n for(var i = 0; i < this._ints; ++i) {\n this.tag.putInt32(this._s[i] ^ tag[i]);\n }\n\n // trim tag to length\n this.tag.truncate(this.tag.length() % (this._tagLength / 8));\n\n // check authentication tag\n if(options.decrypt && this.tag.bytes() !== this._tag) {\n rval = false;\n }\n\n return rval;\n};\n\n/**\n * See NIST SP-800-38D 6.3 (Algorithm 1). This function performs Galois\n * field multiplication. The field, GF(2^128), is defined by the polynomial:\n *\n * x^128 + x^7 + x^2 + x + 1\n *\n * Which is represented in little-endian binary form as: 11100001 (0xe1). When\n * the value of a coefficient is 1, a bit is set. The value R, is the\n * concatenation of this value and 120 zero bits, yielding a 128-bit value\n * which matches the block size.\n *\n * This function will multiply two elements (vectors of bytes), X and Y, in\n * the field GF(2^128). The result is initialized to zero. For each bit of\n * X (out of 128), x_i, if x_i is set, then the result is multiplied (XOR'd)\n * by the current value of Y. For each bit, the value of Y will be raised by\n * a power of x (multiplied by the polynomial x). This can be achieved by\n * shifting Y once to the right. If the current value of Y, prior to being\n * multiplied by x, has 0 as its LSB, then it is a 127th degree polynomial.\n * Otherwise, we must divide by R after shifting to find the remainder.\n *\n * @param x the first block to multiply by the second.\n * @param y the second block to multiply by the first.\n *\n * @return the block result of the multiplication.\n */\nmodes.gcm.prototype.multiply = function(x, y) {\n var z_i = [0, 0, 0, 0];\n var v_i = y.slice(0);\n\n // calculate Z_128 (block has 128 bits)\n for(var i = 0; i < 128; ++i) {\n // if x_i is 0, Z_{i+1} = Z_i (unchanged)\n // else Z_{i+1} = Z_i ^ V_i\n // get x_i by finding 32-bit int position, then left shift 1 by remainder\n var x_i = x[(i / 32) | 0] & (1 << (31 - i % 32));\n if(x_i) {\n z_i[0] ^= v_i[0];\n z_i[1] ^= v_i[1];\n z_i[2] ^= v_i[2];\n z_i[3] ^= v_i[3];\n }\n\n // if LSB(V_i) is 1, V_i = V_i >> 1\n // else V_i = (V_i >> 1) ^ R\n this.pow(v_i, v_i);\n }\n\n return z_i;\n};\n\nmodes.gcm.prototype.pow = function(x, out) {\n // if LSB(x) is 1, x = x >>> 1\n // else x = (x >>> 1) ^ R\n var lsb = x[3] & 1;\n\n // always do x >>> 1:\n // starting with the rightmost integer, shift each integer to the right\n // one bit, pulling in the bit from the integer to the left as its top\n // most bit (do this for the last 3 integers)\n for(var i = 3; i > 0; --i) {\n out[i] = (x[i] >>> 1) | ((x[i - 1] & 1) << 31);\n }\n // shift the first integer normally\n out[0] = x[0] >>> 1;\n\n // if lsb was not set, then polynomial had a degree of 127 and doesn't\n // need to divided; otherwise, XOR with R to find the remainder; we only\n // need to XOR the first integer since R technically ends w/120 zero bits\n if(lsb) {\n out[0] ^= this._R;\n }\n};\n\nmodes.gcm.prototype.tableMultiply = function(x) {\n // assumes 4-bit tables are used\n var z = [0, 0, 0, 0];\n for(var i = 0; i < 32; ++i) {\n var idx = (i / 8) | 0;\n var x_i = (x[idx] >>> ((7 - (i % 8)) * 4)) & 0xF;\n var ah = this._m[i][x_i];\n z[0] ^= ah[0];\n z[1] ^= ah[1];\n z[2] ^= ah[2];\n z[3] ^= ah[3];\n }\n return z;\n};\n\n/**\n * A continuing version of the GHASH algorithm that operates on a single\n * block. The hash block, last hash value (Ym) and the new block to hash\n * are given.\n *\n * @param h the hash block.\n * @param y the previous value for Ym, use [0, 0, 0, 0] for a new hash.\n * @param x the block to hash.\n *\n * @return the hashed value (Ym).\n */\nmodes.gcm.prototype.ghash = function(h, y, x) {\n y[0] ^= x[0];\n y[1] ^= x[1];\n y[2] ^= x[2];\n y[3] ^= x[3];\n return this.tableMultiply(y);\n //return this.multiply(y, h);\n};\n\n/**\n * Precomputes a table for multiplying against the hash subkey. This\n * mechanism provides a substantial speed increase over multiplication\n * performed without a table. The table-based multiplication this table is\n * for solves X * H by multiplying each component of X by H and then\n * composing the results together using XOR.\n *\n * This function can be used to generate tables with different bit sizes\n * for the components, however, this implementation assumes there are\n * 32 components of X (which is a 16 byte vector), therefore each component\n * takes 4-bits (so the table is constructed with bits=4).\n *\n * @param h the hash subkey.\n * @param bits the bit size for a component.\n */\nmodes.gcm.prototype.generateHashTable = function(h, bits) {\n // TODO: There are further optimizations that would use only the\n // first table M_0 (or some variant) along with a remainder table;\n // this can be explored in the future\n var multiplier = 8 / bits;\n var perInt = 4 * multiplier;\n var size = 16 * multiplier;\n var m = new Array(size);\n for(var i = 0; i < size; ++i) {\n var tmp = [0, 0, 0, 0];\n var idx = (i / perInt) | 0;\n var shft = ((perInt - 1 - (i % perInt)) * bits);\n tmp[idx] = (1 << (bits - 1)) << shft;\n m[i] = this.generateSubHashTable(this.multiply(tmp, h), bits);\n }\n return m;\n};\n\n/**\n * Generates a table for multiplying against the hash subkey for one\n * particular component (out of all possible component values).\n *\n * @param mid the pre-multiplied value for the middle key of the table.\n * @param bits the bit size for a component.\n */\nmodes.gcm.prototype.generateSubHashTable = function(mid, bits) {\n // compute the table quickly by minimizing the number of\n // POW operations -- they only need to be performed for powers of 2,\n // all other entries can be composed from those powers using XOR\n var size = 1 << bits;\n var half = size >>> 1;\n var m = new Array(size);\n m[half] = mid.slice(0);\n var i = half >>> 1;\n while(i > 0) {\n // raise m0[2 * i] and store in m0[i]\n this.pow(m[2 * i], m[i] = []);\n i >>= 1;\n }\n i = 2;\n while(i < half) {\n for(var j = 1; j < i; ++j) {\n var m_i = m[i];\n var m_j = m[j];\n m[i + j] = [\n m_i[0] ^ m_j[0],\n m_i[1] ^ m_j[1],\n m_i[2] ^ m_j[2],\n m_i[3] ^ m_j[3]\n ];\n }\n i *= 2;\n }\n m[0] = [0, 0, 0, 0];\n /* Note: We could avoid storing these by doing composition during multiply\n calculate top half using composition by speed is preferred. */\n for(i = half + 1; i < size; ++i) {\n var c = m[i ^ half];\n m[i] = [mid[0] ^ c[0], mid[1] ^ c[1], mid[2] ^ c[2], mid[3] ^ c[3]];\n }\n return m;\n};\n\n/** Utility functions */\n\nfunction transformIV(iv, blockSize) {\n if(typeof iv === 'string') {\n // convert iv string into byte buffer\n iv = forge.util.createBuffer(iv);\n }\n\n if(forge.util.isArray(iv) && iv.length > 4) {\n // convert iv byte array into byte buffer\n var tmp = iv;\n iv = forge.util.createBuffer();\n for(var i = 0; i < tmp.length; ++i) {\n iv.putByte(tmp[i]);\n }\n }\n\n if(iv.length() < blockSize) {\n throw new Error(\n 'Invalid IV length; got ' + iv.length() +\n ' bytes and expected ' + blockSize + ' bytes.');\n }\n\n if(!forge.util.isArray(iv)) {\n // convert iv byte buffer into 32-bit integer array\n var ints = [];\n var blocks = blockSize / 4;\n for(var i = 0; i < blocks; ++i) {\n ints.push(iv.getInt32());\n }\n iv = ints;\n }\n\n return iv;\n}\n\nfunction inc32(block) {\n // increment last 32 bits of block only\n block[block.length - 1] = (block[block.length - 1] + 1) & 0xFFFFFFFF;\n}\n\nfunction from64To32(num) {\n // convert 64-bit number to two BE Int32s\n return [(num / 0x100000000) | 0, num & 0xFFFFFFFF];\n}\n","/**\n * A Javascript implementation of Transport Layer Security (TLS).\n *\n * @author Dave Longley\n *\n * Copyright (c) 2009-2014 Digital Bazaar, Inc.\n *\n * The TLS Handshake Protocol involves the following steps:\n *\n * - Exchange hello messages to agree on algorithms, exchange random values,\n * and check for session resumption.\n *\n * - Exchange the necessary cryptographic parameters to allow the client and\n * server to agree on a premaster secret.\n *\n * - Exchange certificates and cryptographic information to allow the client\n * and server to authenticate themselves.\n *\n * - Generate a master secret from the premaster secret and exchanged random\n * values.\n *\n * - Provide security parameters to the record layer.\n *\n * - Allow the client and server to verify that their peer has calculated the\n * same security parameters and that the handshake occurred without tampering\n * by an attacker.\n *\n * Up to 4 different messages may be sent during a key exchange. The server\n * certificate, the server key exchange, the client certificate, and the\n * client key exchange.\n *\n * A typical handshake (from the client's perspective).\n *\n * 1. Client sends ClientHello.\n * 2. Client receives ServerHello.\n * 3. Client receives optional Certificate.\n * 4. Client receives optional ServerKeyExchange.\n * 5. Client receives ServerHelloDone.\n * 6. Client sends optional Certificate.\n * 7. Client sends ClientKeyExchange.\n * 8. Client sends optional CertificateVerify.\n * 9. Client sends ChangeCipherSpec.\n * 10. Client sends Finished.\n * 11. Client receives ChangeCipherSpec.\n * 12. Client receives Finished.\n * 13. Client sends/receives application data.\n *\n * To reuse an existing session:\n *\n * 1. Client sends ClientHello with session ID for reuse.\n * 2. Client receives ServerHello with same session ID if reusing.\n * 3. Client receives ChangeCipherSpec message if reusing.\n * 4. Client receives Finished.\n * 5. Client sends ChangeCipherSpec.\n * 6. Client sends Finished.\n *\n * Note: Client ignores HelloRequest if in the middle of a handshake.\n *\n * Record Layer:\n *\n * The record layer fragments information blocks into TLSPlaintext records\n * carrying data in chunks of 2^14 bytes or less. Client message boundaries are\n * not preserved in the record layer (i.e., multiple client messages of the\n * same ContentType MAY be coalesced into a single TLSPlaintext record, or a\n * single message MAY be fragmented across several records).\n *\n * struct {\n * uint8 major;\n * uint8 minor;\n * } ProtocolVersion;\n *\n * struct {\n * ContentType type;\n * ProtocolVersion version;\n * uint16 length;\n * opaque fragment[TLSPlaintext.length];\n * } TLSPlaintext;\n *\n * type:\n * The higher-level protocol used to process the enclosed fragment.\n *\n * version:\n * The version of the protocol being employed. TLS Version 1.2 uses version\n * {3, 3}. TLS Version 1.0 uses version {3, 1}. Note that a client that\n * supports multiple versions of TLS may not know what version will be\n * employed before it receives the ServerHello.\n *\n * length:\n * The length (in bytes) of the following TLSPlaintext.fragment. The length\n * MUST NOT exceed 2^14 = 16384 bytes.\n *\n * fragment:\n * The application data. This data is transparent and treated as an\n * independent block to be dealt with by the higher-level protocol specified\n * by the type field.\n *\n * Implementations MUST NOT send zero-length fragments of Handshake, Alert, or\n * ChangeCipherSpec content types. Zero-length fragments of Application data\n * MAY be sent as they are potentially useful as a traffic analysis\n * countermeasure.\n *\n * Note: Data of different TLS record layer content types MAY be interleaved.\n * Application data is generally of lower precedence for transmission than\n * other content types. However, records MUST be delivered to the network in\n * the same order as they are protected by the record layer. Recipients MUST\n * receive and process interleaved application layer traffic during handshakes\n * subsequent to the first one on a connection.\n *\n * struct {\n * ContentType type; // same as TLSPlaintext.type\n * ProtocolVersion version;// same as TLSPlaintext.version\n * uint16 length;\n * opaque fragment[TLSCompressed.length];\n * } TLSCompressed;\n *\n * length:\n * The length (in bytes) of the following TLSCompressed.fragment.\n * The length MUST NOT exceed 2^14 + 1024.\n *\n * fragment:\n * The compressed form of TLSPlaintext.fragment.\n *\n * Note: A CompressionMethod.null operation is an identity operation; no fields\n * are altered. In this implementation, since no compression is supported,\n * uncompressed records are always the same as compressed records.\n *\n * Encryption Information:\n *\n * The encryption and MAC functions translate a TLSCompressed structure into a\n * TLSCiphertext. The decryption functions reverse the process. The MAC of the\n * record also includes a sequence number so that missing, extra, or repeated\n * messages are detectable.\n *\n * struct {\n * ContentType type;\n * ProtocolVersion version;\n * uint16 length;\n * select (SecurityParameters.cipher_type) {\n * case stream: GenericStreamCipher;\n * case block: GenericBlockCipher;\n * case aead: GenericAEADCipher;\n * } fragment;\n * } TLSCiphertext;\n *\n * type:\n * The type field is identical to TLSCompressed.type.\n *\n * version:\n * The version field is identical to TLSCompressed.version.\n *\n * length:\n * The length (in bytes) of the following TLSCiphertext.fragment.\n * The length MUST NOT exceed 2^14 + 2048.\n *\n * fragment:\n * The encrypted form of TLSCompressed.fragment, with the MAC.\n *\n * Note: Only CBC Block Ciphers are supported by this implementation.\n *\n * The TLSCompressed.fragment structures are converted to/from block\n * TLSCiphertext.fragment structures.\n *\n * struct {\n * opaque IV[SecurityParameters.record_iv_length];\n * block-ciphered struct {\n * opaque content[TLSCompressed.length];\n * opaque MAC[SecurityParameters.mac_length];\n * uint8 padding[GenericBlockCipher.padding_length];\n * uint8 padding_length;\n * };\n * } GenericBlockCipher;\n *\n * The MAC is generated as described in Section 6.2.3.1.\n *\n * IV:\n * The Initialization Vector (IV) SHOULD be chosen at random, and MUST be\n * unpredictable. Note that in versions of TLS prior to 1.1, there was no\n * IV field, and the last ciphertext block of the previous record (the \"CBC\n * residue\") was used as the IV. This was changed to prevent the attacks\n * described in [CBCATT]. For block ciphers, the IV length is of length\n * SecurityParameters.record_iv_length, which is equal to the\n * SecurityParameters.block_size.\n *\n * padding:\n * Padding that is added to force the length of the plaintext to be an\n * integral multiple of the block cipher's block length. The padding MAY be\n * any length up to 255 bytes, as long as it results in the\n * TLSCiphertext.length being an integral multiple of the block length.\n * Lengths longer than necessary might be desirable to frustrate attacks on\n * a protocol that are based on analysis of the lengths of exchanged\n * messages. Each uint8 in the padding data vector MUST be filled with the\n * padding length value. The receiver MUST check this padding and MUST use\n * the bad_record_mac alert to indicate padding errors.\n *\n * padding_length:\n * The padding length MUST be such that the total size of the\n * GenericBlockCipher structure is a multiple of the cipher's block length.\n * Legal values range from zero to 255, inclusive. This length specifies the\n * length of the padding field exclusive of the padding_length field itself.\n *\n * The encrypted data length (TLSCiphertext.length) is one more than the sum of\n * SecurityParameters.block_length, TLSCompressed.length,\n * SecurityParameters.mac_length, and padding_length.\n *\n * Example: If the block length is 8 bytes, the content length\n * (TLSCompressed.length) is 61 bytes, and the MAC length is 20 bytes, then the\n * length before padding is 82 bytes (this does not include the IV. Thus, the\n * padding length modulo 8 must be equal to 6 in order to make the total length\n * an even multiple of 8 bytes (the block length). The padding length can be\n * 6, 14, 22, and so on, through 254. If the padding length were the minimum\n * necessary, 6, the padding would be 6 bytes, each containing the value 6.\n * Thus, the last 8 octets of the GenericBlockCipher before block encryption\n * would be xx 06 06 06 06 06 06 06, where xx is the last octet of the MAC.\n *\n * Note: With block ciphers in CBC mode (Cipher Block Chaining), it is critical\n * that the entire plaintext of the record be known before any ciphertext is\n * transmitted. Otherwise, it is possible for the attacker to mount the attack\n * described in [CBCATT].\n *\n * Implementation note: Canvel et al. [CBCTIME] have demonstrated a timing\n * attack on CBC padding based on the time required to compute the MAC. In\n * order to defend against this attack, implementations MUST ensure that\n * record processing time is essentially the same whether or not the padding\n * is correct. In general, the best way to do this is to compute the MAC even\n * if the padding is incorrect, and only then reject the packet. For instance,\n * if the pad appears to be incorrect, the implementation might assume a\n * zero-length pad and then compute the MAC. This leaves a small timing\n * channel, since MAC performance depends, to some extent, on the size of the\n * data fragment, but it is not believed to be large enough to be exploitable,\n * due to the large block size of existing MACs and the small size of the\n * timing signal.\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./hmac');\nrequire('./md5');\nrequire('./pem');\nrequire('./pki');\nrequire('./random');\nrequire('./sha1');\nrequire('./util');\n\n/**\n * Generates pseudo random bytes by mixing the result of two hash functions,\n * MD5 and SHA-1.\n *\n * prf_TLS1(secret, label, seed) =\n * P_MD5(S1, label + seed) XOR P_SHA-1(S2, label + seed);\n *\n * Each P_hash function functions as follows:\n *\n * P_hash(secret, seed) = HMAC_hash(secret, A(1) + seed) +\n * HMAC_hash(secret, A(2) + seed) +\n * HMAC_hash(secret, A(3) + seed) + ...\n * A() is defined as:\n * A(0) = seed\n * A(i) = HMAC_hash(secret, A(i-1))\n *\n * The '+' operator denotes concatenation.\n *\n * As many iterations A(N) as are needed are performed to generate enough\n * pseudo random byte output. If an iteration creates more data than is\n * necessary, then it is truncated.\n *\n * Therefore:\n * A(1) = HMAC_hash(secret, A(0))\n * = HMAC_hash(secret, seed)\n * A(2) = HMAC_hash(secret, A(1))\n * = HMAC_hash(secret, HMAC_hash(secret, seed))\n *\n * Therefore:\n * P_hash(secret, seed) =\n * HMAC_hash(secret, HMAC_hash(secret, A(0)) + seed) +\n * HMAC_hash(secret, HMAC_hash(secret, A(1)) + seed) +\n * ...\n *\n * Therefore:\n * P_hash(secret, seed) =\n * HMAC_hash(secret, HMAC_hash(secret, seed) + seed) +\n * HMAC_hash(secret, HMAC_hash(secret, HMAC_hash(secret, seed)) + seed) +\n * ...\n *\n * @param secret the secret to use.\n * @param label the label to use.\n * @param seed the seed value to use.\n * @param length the number of bytes to generate.\n *\n * @return the pseudo random bytes in a byte buffer.\n */\nvar prf_TLS1 = function(secret, label, seed, length) {\n var rval = forge.util.createBuffer();\n\n /* For TLS 1.0, the secret is split in half, into two secrets of equal\n length. If the secret has an odd length then the last byte of the first\n half will be the same as the first byte of the second. The length of the\n two secrets is half of the secret rounded up. */\n var idx = (secret.length >> 1);\n var slen = idx + (secret.length & 1);\n var s1 = secret.substr(0, slen);\n var s2 = secret.substr(idx, slen);\n var ai = forge.util.createBuffer();\n var hmac = forge.hmac.create();\n seed = label + seed;\n\n // determine the number of iterations that must be performed to generate\n // enough output bytes, md5 creates 16 byte hashes, sha1 creates 20\n var md5itr = Math.ceil(length / 16);\n var sha1itr = Math.ceil(length / 20);\n\n // do md5 iterations\n hmac.start('MD5', s1);\n var md5bytes = forge.util.createBuffer();\n ai.putBytes(seed);\n for(var i = 0; i < md5itr; ++i) {\n // HMAC_hash(secret, A(i-1))\n hmac.start(null, null);\n hmac.update(ai.getBytes());\n ai.putBuffer(hmac.digest());\n\n // HMAC_hash(secret, A(i) + seed)\n hmac.start(null, null);\n hmac.update(ai.bytes() + seed);\n md5bytes.putBuffer(hmac.digest());\n }\n\n // do sha1 iterations\n hmac.start('SHA1', s2);\n var sha1bytes = forge.util.createBuffer();\n ai.clear();\n ai.putBytes(seed);\n for(var i = 0; i < sha1itr; ++i) {\n // HMAC_hash(secret, A(i-1))\n hmac.start(null, null);\n hmac.update(ai.getBytes());\n ai.putBuffer(hmac.digest());\n\n // HMAC_hash(secret, A(i) + seed)\n hmac.start(null, null);\n hmac.update(ai.bytes() + seed);\n sha1bytes.putBuffer(hmac.digest());\n }\n\n // XOR the md5 bytes with the sha1 bytes\n rval.putBytes(forge.util.xorBytes(\n md5bytes.getBytes(), sha1bytes.getBytes(), length));\n\n return rval;\n};\n\n/**\n * Generates pseudo random bytes using a SHA256 algorithm. For TLS 1.2.\n *\n * @param secret the secret to use.\n * @param label the label to use.\n * @param seed the seed value to use.\n * @param length the number of bytes to generate.\n *\n * @return the pseudo random bytes in a byte buffer.\n */\nvar prf_sha256 = function(secret, label, seed, length) {\n // FIXME: implement me for TLS 1.2\n};\n\n/**\n * Gets a MAC for a record using the SHA-1 hash algorithm.\n *\n * @param key the mac key.\n * @param state the sequence number (array of two 32-bit integers).\n * @param record the record.\n *\n * @return the sha-1 hash (20 bytes) for the given record.\n */\nvar hmac_sha1 = function(key, seqNum, record) {\n /* MAC is computed like so:\n HMAC_hash(\n key, seqNum +\n TLSCompressed.type +\n TLSCompressed.version +\n TLSCompressed.length +\n TLSCompressed.fragment)\n */\n var hmac = forge.hmac.create();\n hmac.start('SHA1', key);\n var b = forge.util.createBuffer();\n b.putInt32(seqNum[0]);\n b.putInt32(seqNum[1]);\n b.putByte(record.type);\n b.putByte(record.version.major);\n b.putByte(record.version.minor);\n b.putInt16(record.length);\n b.putBytes(record.fragment.bytes());\n hmac.update(b.getBytes());\n return hmac.digest().getBytes();\n};\n\n/**\n * Compresses the TLSPlaintext record into a TLSCompressed record using the\n * deflate algorithm.\n *\n * @param c the TLS connection.\n * @param record the TLSPlaintext record to compress.\n * @param s the ConnectionState to use.\n *\n * @return true on success, false on failure.\n */\nvar deflate = function(c, record, s) {\n var rval = false;\n\n try {\n var bytes = c.deflate(record.fragment.getBytes());\n record.fragment = forge.util.createBuffer(bytes);\n record.length = bytes.length;\n rval = true;\n } catch(ex) {\n // deflate error, fail out\n }\n\n return rval;\n};\n\n/**\n * Decompresses the TLSCompressed record into a TLSPlaintext record using the\n * deflate algorithm.\n *\n * @param c the TLS connection.\n * @param record the TLSCompressed record to decompress.\n * @param s the ConnectionState to use.\n *\n * @return true on success, false on failure.\n */\nvar inflate = function(c, record, s) {\n var rval = false;\n\n try {\n var bytes = c.inflate(record.fragment.getBytes());\n record.fragment = forge.util.createBuffer(bytes);\n record.length = bytes.length;\n rval = true;\n } catch(ex) {\n // inflate error, fail out\n }\n\n return rval;\n};\n\n/**\n * Reads a TLS variable-length vector from a byte buffer.\n *\n * Variable-length vectors are defined by specifying a subrange of legal\n * lengths, inclusively, using the notation <floor..ceiling>. When these are\n * encoded, the actual length precedes the vector's contents in the byte\n * stream. The length will be in the form of a number consuming as many bytes\n * as required to hold the vector's specified maximum (ceiling) length. A\n * variable-length vector with an actual length field of zero is referred to\n * as an empty vector.\n *\n * @param b the byte buffer.\n * @param lenBytes the number of bytes required to store the length.\n *\n * @return the resulting byte buffer.\n */\nvar readVector = function(b, lenBytes) {\n var len = 0;\n switch(lenBytes) {\n case 1:\n len = b.getByte();\n break;\n case 2:\n len = b.getInt16();\n break;\n case 3:\n len = b.getInt24();\n break;\n case 4:\n len = b.getInt32();\n break;\n }\n\n // read vector bytes into a new buffer\n return forge.util.createBuffer(b.getBytes(len));\n};\n\n/**\n * Writes a TLS variable-length vector to a byte buffer.\n *\n * @param b the byte buffer.\n * @param lenBytes the number of bytes required to store the length.\n * @param v the byte buffer vector.\n */\nvar writeVector = function(b, lenBytes, v) {\n // encode length at the start of the vector, where the number of bytes for\n // the length is the maximum number of bytes it would take to encode the\n // vector's ceiling\n b.putInt(v.length(), lenBytes << 3);\n b.putBuffer(v);\n};\n\n/**\n * The tls implementation.\n */\nvar tls = {};\n\n/**\n * Version: TLS 1.2 = 3.3, TLS 1.1 = 3.2, TLS 1.0 = 3.1. Both TLS 1.1 and\n * TLS 1.2 were still too new (ie: openSSL didn't implement them) at the time\n * of this implementation so TLS 1.0 was implemented instead.\n */\ntls.Versions = {\n TLS_1_0: {major: 3, minor: 1},\n TLS_1_1: {major: 3, minor: 2},\n TLS_1_2: {major: 3, minor: 3}\n};\ntls.SupportedVersions = [\n tls.Versions.TLS_1_1,\n tls.Versions.TLS_1_0\n];\ntls.Version = tls.SupportedVersions[0];\n\n/**\n * Maximum fragment size. True maximum is 16384, but we fragment before that\n * to allow for unusual small increases during compression.\n */\ntls.MaxFragment = 16384 - 1024;\n\n/**\n * Whether this entity is considered the \"client\" or \"server\".\n * enum { server, client } ConnectionEnd;\n */\ntls.ConnectionEnd = {\n server: 0,\n client: 1\n};\n\n/**\n * Pseudo-random function algorithm used to generate keys from the master\n * secret.\n * enum { tls_prf_sha256 } PRFAlgorithm;\n */\ntls.PRFAlgorithm = {\n tls_prf_sha256: 0\n};\n\n/**\n * Bulk encryption algorithms.\n * enum { null, rc4, des3, aes } BulkCipherAlgorithm;\n */\ntls.BulkCipherAlgorithm = {\n none: null,\n rc4: 0,\n des3: 1,\n aes: 2\n};\n\n/**\n * Cipher types.\n * enum { stream, block, aead } CipherType;\n */\ntls.CipherType = {\n stream: 0,\n block: 1,\n aead: 2\n};\n\n/**\n * MAC (Message Authentication Code) algorithms.\n * enum { null, hmac_md5, hmac_sha1, hmac_sha256,\n * hmac_sha384, hmac_sha512} MACAlgorithm;\n */\ntls.MACAlgorithm = {\n none: null,\n hmac_md5: 0,\n hmac_sha1: 1,\n hmac_sha256: 2,\n hmac_sha384: 3,\n hmac_sha512: 4\n};\n\n/**\n * Compression algorithms.\n * enum { null(0), deflate(1), (255) } CompressionMethod;\n */\ntls.CompressionMethod = {\n none: 0,\n deflate: 1\n};\n\n/**\n * TLS record content types.\n * enum {\n * change_cipher_spec(20), alert(21), handshake(22),\n * application_data(23), (255)\n * } ContentType;\n */\ntls.ContentType = {\n change_cipher_spec: 20,\n alert: 21,\n handshake: 22,\n application_data: 23,\n heartbeat: 24\n};\n\n/**\n * TLS handshake types.\n * enum {\n * hello_request(0), client_hello(1), server_hello(2),\n * certificate(11), server_key_exchange (12),\n * certificate_request(13), server_hello_done(14),\n * certificate_verify(15), client_key_exchange(16),\n * finished(20), (255)\n * } HandshakeType;\n */\ntls.HandshakeType = {\n hello_request: 0,\n client_hello: 1,\n server_hello: 2,\n certificate: 11,\n server_key_exchange: 12,\n certificate_request: 13,\n server_hello_done: 14,\n certificate_verify: 15,\n client_key_exchange: 16,\n finished: 20\n};\n\n/**\n * TLS Alert Protocol.\n *\n * enum { warning(1), fatal(2), (255) } AlertLevel;\n *\n * enum {\n * close_notify(0),\n * unexpected_message(10),\n * bad_record_mac(20),\n * decryption_failed(21),\n * record_overflow(22),\n * decompression_failure(30),\n * handshake_failure(40),\n * bad_certificate(42),\n * unsupported_certificate(43),\n * certificate_revoked(44),\n * certificate_expired(45),\n * certificate_unknown(46),\n * illegal_parameter(47),\n * unknown_ca(48),\n * access_denied(49),\n * decode_error(50),\n * decrypt_error(51),\n * export_restriction(60),\n * protocol_version(70),\n * insufficient_security(71),\n * internal_error(80),\n * user_canceled(90),\n * no_renegotiation(100),\n * (255)\n * } AlertDescription;\n *\n * struct {\n * AlertLevel level;\n * AlertDescription description;\n * } Alert;\n */\ntls.Alert = {};\ntls.Alert.Level = {\n warning: 1,\n fatal: 2\n};\ntls.Alert.Description = {\n close_notify: 0,\n unexpected_message: 10,\n bad_record_mac: 20,\n decryption_failed: 21,\n record_overflow: 22,\n decompression_failure: 30,\n handshake_failure: 40,\n bad_certificate: 42,\n unsupported_certificate: 43,\n certificate_revoked: 44,\n certificate_expired: 45,\n certificate_unknown: 46,\n illegal_parameter: 47,\n unknown_ca: 48,\n access_denied: 49,\n decode_error: 50,\n decrypt_error: 51,\n export_restriction: 60,\n protocol_version: 70,\n insufficient_security: 71,\n internal_error: 80,\n user_canceled: 90,\n no_renegotiation: 100\n};\n\n/**\n * TLS Heartbeat Message types.\n * enum {\n * heartbeat_request(1),\n * heartbeat_response(2),\n * (255)\n * } HeartbeatMessageType;\n */\ntls.HeartbeatMessageType = {\n heartbeat_request: 1,\n heartbeat_response: 2\n};\n\n/**\n * Supported cipher suites.\n */\ntls.CipherSuites = {};\n\n/**\n * Gets a supported cipher suite from its 2 byte ID.\n *\n * @param twoBytes two bytes in a string.\n *\n * @return the matching supported cipher suite or null.\n */\ntls.getCipherSuite = function(twoBytes) {\n var rval = null;\n for(var key in tls.CipherSuites) {\n var cs = tls.CipherSuites[key];\n if(cs.id[0] === twoBytes.charCodeAt(0) &&\n cs.id[1] === twoBytes.charCodeAt(1)) {\n rval = cs;\n break;\n }\n }\n return rval;\n};\n\n/**\n * Called when an unexpected record is encountered.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleUnexpected = function(c, record) {\n // if connection is client and closed, ignore unexpected messages\n var ignore = (!c.open && c.entity === tls.ConnectionEnd.client);\n if(!ignore) {\n c.error(c, {\n message: 'Unexpected message. Received TLS record out of order.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.unexpected_message\n }\n });\n }\n};\n\n/**\n * Called when a client receives a HelloRequest record.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleHelloRequest = function(c, record, length) {\n // ignore renegotiation requests from the server during a handshake, but\n // if handshaking, send a warning alert that renegotation is denied\n if(!c.handshaking && c.handshakes > 0) {\n // send alert warning\n tls.queue(c, tls.createAlert(c, {\n level: tls.Alert.Level.warning,\n description: tls.Alert.Description.no_renegotiation\n }));\n tls.flush(c);\n }\n\n // continue\n c.process();\n};\n\n/**\n * Parses a hello message from a ClientHello or ServerHello record.\n *\n * @param record the record to parse.\n *\n * @return the parsed message.\n */\ntls.parseHelloMessage = function(c, record, length) {\n var msg = null;\n\n var client = (c.entity === tls.ConnectionEnd.client);\n\n // minimum of 38 bytes in message\n if(length < 38) {\n c.error(c, {\n message: client ?\n 'Invalid ServerHello message. Message too short.' :\n 'Invalid ClientHello message. Message too short.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.illegal_parameter\n }\n });\n } else {\n // use 'remaining' to calculate # of remaining bytes in the message\n var b = record.fragment;\n var remaining = b.length();\n msg = {\n version: {\n major: b.getByte(),\n minor: b.getByte()\n },\n random: forge.util.createBuffer(b.getBytes(32)),\n session_id: readVector(b, 1),\n extensions: []\n };\n if(client) {\n msg.cipher_suite = b.getBytes(2);\n msg.compression_method = b.getByte();\n } else {\n msg.cipher_suites = readVector(b, 2);\n msg.compression_methods = readVector(b, 1);\n }\n\n // read extensions if there are any bytes left in the message\n remaining = length - (remaining - b.length());\n if(remaining > 0) {\n // parse extensions\n var exts = readVector(b, 2);\n while(exts.length() > 0) {\n msg.extensions.push({\n type: [exts.getByte(), exts.getByte()],\n data: readVector(exts, 2)\n });\n }\n\n // TODO: make extension support modular\n if(!client) {\n for(var i = 0; i < msg.extensions.length; ++i) {\n var ext = msg.extensions[i];\n\n // support SNI extension\n if(ext.type[0] === 0x00 && ext.type[1] === 0x00) {\n // get server name list\n var snl = readVector(ext.data, 2);\n while(snl.length() > 0) {\n // read server name type\n var snType = snl.getByte();\n\n // only HostName type (0x00) is known, break out if\n // another type is detected\n if(snType !== 0x00) {\n break;\n }\n\n // add host name to server name list\n c.session.extensions.server_name.serverNameList.push(\n readVector(snl, 2).getBytes());\n }\n }\n }\n }\n }\n\n // version already set, do not allow version change\n if(c.session.version) {\n if(msg.version.major !== c.session.version.major ||\n msg.version.minor !== c.session.version.minor) {\n return c.error(c, {\n message: 'TLS version change is disallowed during renegotiation.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.protocol_version\n }\n });\n }\n }\n\n // get the chosen (ServerHello) cipher suite\n if(client) {\n // FIXME: should be checking configured acceptable cipher suites\n c.session.cipherSuite = tls.getCipherSuite(msg.cipher_suite);\n } else {\n // get a supported preferred (ClientHello) cipher suite\n // choose the first supported cipher suite\n var tmp = forge.util.createBuffer(msg.cipher_suites.bytes());\n while(tmp.length() > 0) {\n // FIXME: should be checking configured acceptable suites\n // cipher suites take up 2 bytes\n c.session.cipherSuite = tls.getCipherSuite(tmp.getBytes(2));\n if(c.session.cipherSuite !== null) {\n break;\n }\n }\n }\n\n // cipher suite not supported\n if(c.session.cipherSuite === null) {\n return c.error(c, {\n message: 'No cipher suites in common.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.handshake_failure\n },\n cipherSuite: forge.util.bytesToHex(msg.cipher_suite)\n });\n }\n\n // TODO: handle compression methods\n if(client) {\n c.session.compressionMethod = msg.compression_method;\n } else {\n // no compression\n c.session.compressionMethod = tls.CompressionMethod.none;\n }\n }\n\n return msg;\n};\n\n/**\n * Creates security parameters for the given connection based on the given\n * hello message.\n *\n * @param c the TLS connection.\n * @param msg the hello message.\n */\ntls.createSecurityParameters = function(c, msg) {\n /* Note: security params are from TLS 1.2, some values like prf_algorithm\n are ignored for TLS 1.0/1.1 and the builtin as specified in the spec is\n used. */\n\n // TODO: handle other options from server when more supported\n\n // get client and server randoms\n var client = (c.entity === tls.ConnectionEnd.client);\n var msgRandom = msg.random.bytes();\n var cRandom = client ? c.session.sp.client_random : msgRandom;\n var sRandom = client ? msgRandom : tls.createRandom().getBytes();\n\n // create new security parameters\n c.session.sp = {\n entity: c.entity,\n prf_algorithm: tls.PRFAlgorithm.tls_prf_sha256,\n bulk_cipher_algorithm: null,\n cipher_type: null,\n enc_key_length: null,\n block_length: null,\n fixed_iv_length: null,\n record_iv_length: null,\n mac_algorithm: null,\n mac_length: null,\n mac_key_length: null,\n compression_algorithm: c.session.compressionMethod,\n pre_master_secret: null,\n master_secret: null,\n client_random: cRandom,\n server_random: sRandom\n };\n};\n\n/**\n * Called when a client receives a ServerHello record.\n *\n * When a ServerHello message will be sent:\n * The server will send this message in response to a client hello message\n * when it was able to find an acceptable set of algorithms. If it cannot\n * find such a match, it will respond with a handshake failure alert.\n *\n * uint24 length;\n * struct {\n * ProtocolVersion server_version;\n * Random random;\n * SessionID session_id;\n * CipherSuite cipher_suite;\n * CompressionMethod compression_method;\n * select(extensions_present) {\n * case false:\n * struct {};\n * case true:\n * Extension extensions<0..2^16-1>;\n * };\n * } ServerHello;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleServerHello = function(c, record, length) {\n var msg = tls.parseHelloMessage(c, record, length);\n if(c.fail) {\n return;\n }\n\n // ensure server version is compatible\n if(msg.version.minor <= c.version.minor) {\n c.version.minor = msg.version.minor;\n } else {\n return c.error(c, {\n message: 'Incompatible TLS version.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.protocol_version\n }\n });\n }\n\n // indicate session version has been set\n c.session.version = c.version;\n\n // get the session ID from the message\n var sessionId = msg.session_id.bytes();\n\n // if the session ID is not blank and matches the cached one, resume\n // the session\n if(sessionId.length > 0 && sessionId === c.session.id) {\n // resuming session, expect a ChangeCipherSpec next\n c.expect = SCC;\n c.session.resuming = true;\n\n // get new server random\n c.session.sp.server_random = msg.random.bytes();\n } else {\n // not resuming, expect a server Certificate message next\n c.expect = SCE;\n c.session.resuming = false;\n\n // create new security parameters\n tls.createSecurityParameters(c, msg);\n }\n\n // set new session ID\n c.session.id = sessionId;\n\n // continue\n c.process();\n};\n\n/**\n * Called when a server receives a ClientHello record.\n *\n * When a ClientHello message will be sent:\n * When a client first connects to a server it is required to send the\n * client hello as its first message. The client can also send a client\n * hello in response to a hello request or on its own initiative in order\n * to renegotiate the security parameters in an existing connection.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleClientHello = function(c, record, length) {\n var msg = tls.parseHelloMessage(c, record, length);\n if(c.fail) {\n return;\n }\n\n // get the session ID from the message\n var sessionId = msg.session_id.bytes();\n\n // see if the given session ID is in the cache\n var session = null;\n if(c.sessionCache) {\n session = c.sessionCache.getSession(sessionId);\n if(session === null) {\n // session ID not found\n sessionId = '';\n } else if(session.version.major !== msg.version.major ||\n session.version.minor > msg.version.minor) {\n // if session version is incompatible with client version, do not resume\n session = null;\n sessionId = '';\n }\n }\n\n // no session found to resume, generate a new session ID\n if(sessionId.length === 0) {\n sessionId = forge.random.getBytes(32);\n }\n\n // update session\n c.session.id = sessionId;\n c.session.clientHelloVersion = msg.version;\n c.session.sp = {};\n if(session) {\n // use version and security parameters from resumed session\n c.version = c.session.version = session.version;\n c.session.sp = session.sp;\n } else {\n // use highest compatible minor version\n var version;\n for(var i = 1; i < tls.SupportedVersions.length; ++i) {\n version = tls.SupportedVersions[i];\n if(version.minor <= msg.version.minor) {\n break;\n }\n }\n c.version = {major: version.major, minor: version.minor};\n c.session.version = c.version;\n }\n\n // if a session is set, resume it\n if(session !== null) {\n // resuming session, expect a ChangeCipherSpec next\n c.expect = CCC;\n c.session.resuming = true;\n\n // get new client random\n c.session.sp.client_random = msg.random.bytes();\n } else {\n // not resuming, expect a Certificate or ClientKeyExchange\n c.expect = (c.verifyClient !== false) ? CCE : CKE;\n c.session.resuming = false;\n\n // create new security parameters\n tls.createSecurityParameters(c, msg);\n }\n\n // connection now open\n c.open = true;\n\n // queue server hello\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createServerHello(c)\n }));\n\n if(c.session.resuming) {\n // queue change cipher spec message\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.change_cipher_spec,\n data: tls.createChangeCipherSpec()\n }));\n\n // create pending state\n c.state.pending = tls.createConnectionState(c);\n\n // change current write state to pending write state\n c.state.current.write = c.state.pending.write;\n\n // queue finished\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createFinished(c)\n }));\n } else {\n // queue server certificate\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createCertificate(c)\n }));\n\n if(!c.fail) {\n // queue server key exchange\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createServerKeyExchange(c)\n }));\n\n // request client certificate if set\n if(c.verifyClient !== false) {\n // queue certificate request\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createCertificateRequest(c)\n }));\n }\n\n // queue server hello done\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createServerHelloDone(c)\n }));\n }\n }\n\n // send records\n tls.flush(c);\n\n // continue\n c.process();\n};\n\n/**\n * Called when a client receives a Certificate record.\n *\n * When this message will be sent:\n * The server must send a certificate whenever the agreed-upon key exchange\n * method is not an anonymous one. This message will always immediately\n * follow the server hello message.\n *\n * Meaning of this message:\n * The certificate type must be appropriate for the selected cipher suite's\n * key exchange algorithm, and is generally an X.509v3 certificate. It must\n * contain a key which matches the key exchange method, as follows. Unless\n * otherwise specified, the signing algorithm for the certificate must be\n * the same as the algorithm for the certificate key. Unless otherwise\n * specified, the public key may be of any length.\n *\n * opaque ASN.1Cert<1..2^24-1>;\n * struct {\n * ASN.1Cert certificate_list<1..2^24-1>;\n * } Certificate;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleCertificate = function(c, record, length) {\n // minimum of 3 bytes in message\n if(length < 3) {\n return c.error(c, {\n message: 'Invalid Certificate message. Message too short.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.illegal_parameter\n }\n });\n }\n\n var b = record.fragment;\n var msg = {\n certificate_list: readVector(b, 3)\n };\n\n /* The sender's certificate will be first in the list (chain), each\n subsequent one that follows will certify the previous one, but root\n certificates (self-signed) that specify the certificate authority may\n be omitted under the assumption that clients must already possess it. */\n var cert, asn1;\n var certs = [];\n try {\n while(msg.certificate_list.length() > 0) {\n // each entry in msg.certificate_list is a vector with 3 len bytes\n cert = readVector(msg.certificate_list, 3);\n asn1 = forge.asn1.fromDer(cert);\n cert = forge.pki.certificateFromAsn1(asn1, true);\n certs.push(cert);\n }\n } catch(ex) {\n return c.error(c, {\n message: 'Could not parse certificate list.',\n cause: ex,\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.bad_certificate\n }\n });\n }\n\n // ensure at least 1 certificate was provided if in client-mode\n // or if verifyClient was set to true to require a certificate\n // (as opposed to 'optional')\n var client = (c.entity === tls.ConnectionEnd.client);\n if((client || c.verifyClient === true) && certs.length === 0) {\n // error, no certificate\n c.error(c, {\n message: client ?\n 'No server certificate provided.' :\n 'No client certificate provided.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.illegal_parameter\n }\n });\n } else if(certs.length === 0) {\n // no certs to verify\n // expect a ServerKeyExchange or ClientKeyExchange message next\n c.expect = client ? SKE : CKE;\n } else {\n // save certificate in session\n if(client) {\n c.session.serverCertificate = certs[0];\n } else {\n c.session.clientCertificate = certs[0];\n }\n\n if(tls.verifyCertificateChain(c, certs)) {\n // expect a ServerKeyExchange or ClientKeyExchange message next\n c.expect = client ? SKE : CKE;\n }\n }\n\n // continue\n c.process();\n};\n\n/**\n * Called when a client receives a ServerKeyExchange record.\n *\n * When this message will be sent:\n * This message will be sent immediately after the server certificate\n * message (or the server hello message, if this is an anonymous\n * negotiation).\n *\n * The server key exchange message is sent by the server only when the\n * server certificate message (if sent) does not contain enough data to\n * allow the client to exchange a premaster secret.\n *\n * Meaning of this message:\n * This message conveys cryptographic information to allow the client to\n * communicate the premaster secret: either an RSA public key to encrypt\n * the premaster secret with, or a Diffie-Hellman public key with which the\n * client can complete a key exchange (with the result being the premaster\n * secret.)\n *\n * enum {\n * dhe_dss, dhe_rsa, dh_anon, rsa, dh_dss, dh_rsa\n * } KeyExchangeAlgorithm;\n *\n * struct {\n * opaque dh_p<1..2^16-1>;\n * opaque dh_g<1..2^16-1>;\n * opaque dh_Ys<1..2^16-1>;\n * } ServerDHParams;\n *\n * struct {\n * select(KeyExchangeAlgorithm) {\n * case dh_anon:\n * ServerDHParams params;\n * case dhe_dss:\n * case dhe_rsa:\n * ServerDHParams params;\n * digitally-signed struct {\n * opaque client_random[32];\n * opaque server_random[32];\n * ServerDHParams params;\n * } signed_params;\n * case rsa:\n * case dh_dss:\n * case dh_rsa:\n * struct {};\n * };\n * } ServerKeyExchange;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleServerKeyExchange = function(c, record, length) {\n // this implementation only supports RSA, no Diffie-Hellman support\n // so any length > 0 is invalid\n if(length > 0) {\n return c.error(c, {\n message: 'Invalid key parameters. Only RSA is supported.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.unsupported_certificate\n }\n });\n }\n\n // expect an optional CertificateRequest message next\n c.expect = SCR;\n\n // continue\n c.process();\n};\n\n/**\n * Called when a client receives a ClientKeyExchange record.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleClientKeyExchange = function(c, record, length) {\n // this implementation only supports RSA, no Diffie-Hellman support\n // so any length < 48 is invalid\n if(length < 48) {\n return c.error(c, {\n message: 'Invalid key parameters. Only RSA is supported.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.unsupported_certificate\n }\n });\n }\n\n var b = record.fragment;\n var msg = {\n enc_pre_master_secret: readVector(b, 2).getBytes()\n };\n\n // do rsa decryption\n var privateKey = null;\n if(c.getPrivateKey) {\n try {\n privateKey = c.getPrivateKey(c, c.session.serverCertificate);\n privateKey = forge.pki.privateKeyFromPem(privateKey);\n } catch(ex) {\n c.error(c, {\n message: 'Could not get private key.',\n cause: ex,\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.internal_error\n }\n });\n }\n }\n\n if(privateKey === null) {\n return c.error(c, {\n message: 'No private key set.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.internal_error\n }\n });\n }\n\n try {\n // decrypt 48-byte pre-master secret\n var sp = c.session.sp;\n sp.pre_master_secret = privateKey.decrypt(msg.enc_pre_master_secret);\n\n // ensure client hello version matches first 2 bytes\n var version = c.session.clientHelloVersion;\n if(version.major !== sp.pre_master_secret.charCodeAt(0) ||\n version.minor !== sp.pre_master_secret.charCodeAt(1)) {\n // error, do not send alert (see BLEI attack below)\n throw new Error('TLS version rollback attack detected.');\n }\n } catch(ex) {\n /* Note: Daniel Bleichenbacher [BLEI] can be used to attack a\n TLS server which is using PKCS#1 encoded RSA, so instead of\n failing here, we generate 48 random bytes and use that as\n the pre-master secret. */\n sp.pre_master_secret = forge.random.getBytes(48);\n }\n\n // expect a CertificateVerify message if a Certificate was received that\n // does not have fixed Diffie-Hellman params, otherwise expect\n // ChangeCipherSpec\n c.expect = CCC;\n if(c.session.clientCertificate !== null) {\n // only RSA support, so expect CertificateVerify\n // TODO: support Diffie-Hellman\n c.expect = CCV;\n }\n\n // continue\n c.process();\n};\n\n/**\n * Called when a client receives a CertificateRequest record.\n *\n * When this message will be sent:\n * A non-anonymous server can optionally request a certificate from the\n * client, if appropriate for the selected cipher suite. This message, if\n * sent, will immediately follow the Server Key Exchange message (if it is\n * sent; otherwise, the Server Certificate message).\n *\n * enum {\n * rsa_sign(1), dss_sign(2), rsa_fixed_dh(3), dss_fixed_dh(4),\n * rsa_ephemeral_dh_RESERVED(5), dss_ephemeral_dh_RESERVED(6),\n * fortezza_dms_RESERVED(20), (255)\n * } ClientCertificateType;\n *\n * opaque DistinguishedName<1..2^16-1>;\n *\n * struct {\n * ClientCertificateType certificate_types<1..2^8-1>;\n * SignatureAndHashAlgorithm supported_signature_algorithms<2^16-1>;\n * DistinguishedName certificate_authorities<0..2^16-1>;\n * } CertificateRequest;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleCertificateRequest = function(c, record, length) {\n // minimum of 3 bytes in message\n if(length < 3) {\n return c.error(c, {\n message: 'Invalid CertificateRequest. Message too short.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.illegal_parameter\n }\n });\n }\n\n // TODO: TLS 1.2+ has different format including\n // SignatureAndHashAlgorithm after cert types\n var b = record.fragment;\n var msg = {\n certificate_types: readVector(b, 1),\n certificate_authorities: readVector(b, 2)\n };\n\n // save certificate request in session\n c.session.certificateRequest = msg;\n\n // expect a ServerHelloDone message next\n c.expect = SHD;\n\n // continue\n c.process();\n};\n\n/**\n * Called when a server receives a CertificateVerify record.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleCertificateVerify = function(c, record, length) {\n if(length < 2) {\n return c.error(c, {\n message: 'Invalid CertificateVerify. Message too short.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.illegal_parameter\n }\n });\n }\n\n // rewind to get full bytes for message so it can be manually\n // digested below (special case for CertificateVerify messages because\n // they must be digested *after* handling as opposed to all others)\n var b = record.fragment;\n b.read -= 4;\n var msgBytes = b.bytes();\n b.read += 4;\n\n var msg = {\n signature: readVector(b, 2).getBytes()\n };\n\n // TODO: add support for DSA\n\n // generate data to verify\n var verify = forge.util.createBuffer();\n verify.putBuffer(c.session.md5.digest());\n verify.putBuffer(c.session.sha1.digest());\n verify = verify.getBytes();\n\n try {\n var cert = c.session.clientCertificate;\n /*b = forge.pki.rsa.decrypt(\n msg.signature, cert.publicKey, true, verify.length);\n if(b !== verify) {*/\n if(!cert.publicKey.verify(verify, msg.signature, 'NONE')) {\n throw new Error('CertificateVerify signature does not match.');\n }\n\n // digest message now that it has been handled\n c.session.md5.update(msgBytes);\n c.session.sha1.update(msgBytes);\n } catch(ex) {\n return c.error(c, {\n message: 'Bad signature in CertificateVerify.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.handshake_failure\n }\n });\n }\n\n // expect ChangeCipherSpec\n c.expect = CCC;\n\n // continue\n c.process();\n};\n\n/**\n * Called when a client receives a ServerHelloDone record.\n *\n * When this message will be sent:\n * The server hello done message is sent by the server to indicate the end\n * of the server hello and associated messages. After sending this message\n * the server will wait for a client response.\n *\n * Meaning of this message:\n * This message means that the server is done sending messages to support\n * the key exchange, and the client can proceed with its phase of the key\n * exchange.\n *\n * Upon receipt of the server hello done message the client should verify\n * that the server provided a valid certificate if required and check that\n * the server hello parameters are acceptable.\n *\n * struct {} ServerHelloDone;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleServerHelloDone = function(c, record, length) {\n // len must be 0 bytes\n if(length > 0) {\n return c.error(c, {\n message: 'Invalid ServerHelloDone message. Invalid length.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.record_overflow\n }\n });\n }\n\n if(c.serverCertificate === null) {\n // no server certificate was provided\n var error = {\n message: 'No server certificate provided. Not enough security.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.insufficient_security\n }\n };\n\n // call application callback\n var depth = 0;\n var ret = c.verify(c, error.alert.description, depth, []);\n if(ret !== true) {\n // check for custom alert info\n if(ret || ret === 0) {\n // set custom message and alert description\n if(typeof ret === 'object' && !forge.util.isArray(ret)) {\n if(ret.message) {\n error.message = ret.message;\n }\n if(ret.alert) {\n error.alert.description = ret.alert;\n }\n } else if(typeof ret === 'number') {\n // set custom alert description\n error.alert.description = ret;\n }\n }\n\n // send error\n return c.error(c, error);\n }\n }\n\n // create client certificate message if requested\n if(c.session.certificateRequest !== null) {\n record = tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createCertificate(c)\n });\n tls.queue(c, record);\n }\n\n // create client key exchange message\n record = tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createClientKeyExchange(c)\n });\n tls.queue(c, record);\n\n // expect no messages until the following callback has been called\n c.expect = SER;\n\n // create callback to handle client signature (for client-certs)\n var callback = function(c, signature) {\n if(c.session.certificateRequest !== null &&\n c.session.clientCertificate !== null) {\n // create certificate verify message\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createCertificateVerify(c, signature)\n }));\n }\n\n // create change cipher spec message\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.change_cipher_spec,\n data: tls.createChangeCipherSpec()\n }));\n\n // create pending state\n c.state.pending = tls.createConnectionState(c);\n\n // change current write state to pending write state\n c.state.current.write = c.state.pending.write;\n\n // create finished message\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createFinished(c)\n }));\n\n // expect a server ChangeCipherSpec message next\n c.expect = SCC;\n\n // send records\n tls.flush(c);\n\n // continue\n c.process();\n };\n\n // if there is no certificate request or no client certificate, do\n // callback immediately\n if(c.session.certificateRequest === null ||\n c.session.clientCertificate === null) {\n return callback(c, null);\n }\n\n // otherwise get the client signature\n tls.getClientSignature(c, callback);\n};\n\n/**\n * Called when a ChangeCipherSpec record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleChangeCipherSpec = function(c, record) {\n if(record.fragment.getByte() !== 0x01) {\n return c.error(c, {\n message: 'Invalid ChangeCipherSpec message received.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.illegal_parameter\n }\n });\n }\n\n // create pending state if:\n // 1. Resuming session in client mode OR\n // 2. NOT resuming session in server mode\n var client = (c.entity === tls.ConnectionEnd.client);\n if((c.session.resuming && client) || (!c.session.resuming && !client)) {\n c.state.pending = tls.createConnectionState(c);\n }\n\n // change current read state to pending read state\n c.state.current.read = c.state.pending.read;\n\n // clear pending state if:\n // 1. NOT resuming session in client mode OR\n // 2. resuming a session in server mode\n if((!c.session.resuming && client) || (c.session.resuming && !client)) {\n c.state.pending = null;\n }\n\n // expect a Finished record next\n c.expect = client ? SFI : CFI;\n\n // continue\n c.process();\n};\n\n/**\n * Called when a Finished record is received.\n *\n * When this message will be sent:\n * A finished message is always sent immediately after a change\n * cipher spec message to verify that the key exchange and\n * authentication processes were successful. It is essential that a\n * change cipher spec message be received between the other\n * handshake messages and the Finished message.\n *\n * Meaning of this message:\n * The finished message is the first protected with the just-\n * negotiated algorithms, keys, and secrets. Recipients of finished\n * messages must verify that the contents are correct. Once a side\n * has sent its Finished message and received and validated the\n * Finished message from its peer, it may begin to send and receive\n * application data over the connection.\n *\n * struct {\n * opaque verify_data[verify_data_length];\n * } Finished;\n *\n * verify_data\n * PRF(master_secret, finished_label, Hash(handshake_messages))\n * [0..verify_data_length-1];\n *\n * finished_label\n * For Finished messages sent by the client, the string\n * \"client finished\". For Finished messages sent by the server, the\n * string \"server finished\".\n *\n * verify_data_length depends on the cipher suite. If it is not specified\n * by the cipher suite, then it is 12. Versions of TLS < 1.2 always used\n * 12 bytes.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleFinished = function(c, record, length) {\n // rewind to get full bytes for message so it can be manually\n // digested below (special case for Finished messages because they\n // must be digested *after* handling as opposed to all others)\n var b = record.fragment;\n b.read -= 4;\n var msgBytes = b.bytes();\n b.read += 4;\n\n // message contains only verify_data\n var vd = record.fragment.getBytes();\n\n // ensure verify data is correct\n b = forge.util.createBuffer();\n b.putBuffer(c.session.md5.digest());\n b.putBuffer(c.session.sha1.digest());\n\n // set label based on entity type\n var client = (c.entity === tls.ConnectionEnd.client);\n var label = client ? 'server finished' : 'client finished';\n\n // TODO: determine prf function and verify length for TLS 1.2\n var sp = c.session.sp;\n var vdl = 12;\n var prf = prf_TLS1;\n b = prf(sp.master_secret, label, b.getBytes(), vdl);\n if(b.getBytes() !== vd) {\n return c.error(c, {\n message: 'Invalid verify_data in Finished message.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.decrypt_error\n }\n });\n }\n\n // digest finished message now that it has been handled\n c.session.md5.update(msgBytes);\n c.session.sha1.update(msgBytes);\n\n // resuming session as client or NOT resuming session as server\n if((c.session.resuming && client) || (!c.session.resuming && !client)) {\n // create change cipher spec message\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.change_cipher_spec,\n data: tls.createChangeCipherSpec()\n }));\n\n // change current write state to pending write state, clear pending\n c.state.current.write = c.state.pending.write;\n c.state.pending = null;\n\n // create finished message\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createFinished(c)\n }));\n }\n\n // expect application data next\n c.expect = client ? SAD : CAD;\n\n // handshake complete\n c.handshaking = false;\n ++c.handshakes;\n\n // save access to peer certificate\n c.peerCertificate = client ?\n c.session.serverCertificate : c.session.clientCertificate;\n\n // send records\n tls.flush(c);\n\n // now connected\n c.isConnected = true;\n c.connected(c);\n\n // continue\n c.process();\n};\n\n/**\n * Called when an Alert record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleAlert = function(c, record) {\n // read alert\n var b = record.fragment;\n var alert = {\n level: b.getByte(),\n description: b.getByte()\n };\n\n // TODO: consider using a table?\n // get appropriate message\n var msg;\n switch(alert.description) {\n case tls.Alert.Description.close_notify:\n msg = 'Connection closed.';\n break;\n case tls.Alert.Description.unexpected_message:\n msg = 'Unexpected message.';\n break;\n case tls.Alert.Description.bad_record_mac:\n msg = 'Bad record MAC.';\n break;\n case tls.Alert.Description.decryption_failed:\n msg = 'Decryption failed.';\n break;\n case tls.Alert.Description.record_overflow:\n msg = 'Record overflow.';\n break;\n case tls.Alert.Description.decompression_failure:\n msg = 'Decompression failed.';\n break;\n case tls.Alert.Description.handshake_failure:\n msg = 'Handshake failure.';\n break;\n case tls.Alert.Description.bad_certificate:\n msg = 'Bad certificate.';\n break;\n case tls.Alert.Description.unsupported_certificate:\n msg = 'Unsupported certificate.';\n break;\n case tls.Alert.Description.certificate_revoked:\n msg = 'Certificate revoked.';\n break;\n case tls.Alert.Description.certificate_expired:\n msg = 'Certificate expired.';\n break;\n case tls.Alert.Description.certificate_unknown:\n msg = 'Certificate unknown.';\n break;\n case tls.Alert.Description.illegal_parameter:\n msg = 'Illegal parameter.';\n break;\n case tls.Alert.Description.unknown_ca:\n msg = 'Unknown certificate authority.';\n break;\n case tls.Alert.Description.access_denied:\n msg = 'Access denied.';\n break;\n case tls.Alert.Description.decode_error:\n msg = 'Decode error.';\n break;\n case tls.Alert.Description.decrypt_error:\n msg = 'Decrypt error.';\n break;\n case tls.Alert.Description.export_restriction:\n msg = 'Export restriction.';\n break;\n case tls.Alert.Description.protocol_version:\n msg = 'Unsupported protocol version.';\n break;\n case tls.Alert.Description.insufficient_security:\n msg = 'Insufficient security.';\n break;\n case tls.Alert.Description.internal_error:\n msg = 'Internal error.';\n break;\n case tls.Alert.Description.user_canceled:\n msg = 'User canceled.';\n break;\n case tls.Alert.Description.no_renegotiation:\n msg = 'Renegotiation not supported.';\n break;\n default:\n msg = 'Unknown error.';\n break;\n }\n\n // close connection on close_notify, not an error\n if(alert.description === tls.Alert.Description.close_notify) {\n return c.close();\n }\n\n // call error handler\n c.error(c, {\n message: msg,\n send: false,\n // origin is the opposite end\n origin: (c.entity === tls.ConnectionEnd.client) ? 'server' : 'client',\n alert: alert\n });\n\n // continue\n c.process();\n};\n\n/**\n * Called when a Handshake record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleHandshake = function(c, record) {\n // get the handshake type and message length\n var b = record.fragment;\n var type = b.getByte();\n var length = b.getInt24();\n\n // see if the record fragment doesn't yet contain the full message\n if(length > b.length()) {\n // cache the record, clear its fragment, and reset the buffer read\n // pointer before the type and length were read\n c.fragmented = record;\n record.fragment = forge.util.createBuffer();\n b.read -= 4;\n\n // continue\n return c.process();\n }\n\n // full message now available, clear cache, reset read pointer to\n // before type and length\n c.fragmented = null;\n b.read -= 4;\n\n // save the handshake bytes for digestion after handler is found\n // (include type and length of handshake msg)\n var bytes = b.bytes(length + 4);\n\n // restore read pointer\n b.read += 4;\n\n // handle expected message\n if(type in hsTable[c.entity][c.expect]) {\n // initialize server session\n if(c.entity === tls.ConnectionEnd.server && !c.open && !c.fail) {\n c.handshaking = true;\n c.session = {\n version: null,\n extensions: {\n server_name: {\n serverNameList: []\n }\n },\n cipherSuite: null,\n compressionMethod: null,\n serverCertificate: null,\n clientCertificate: null,\n md5: forge.md.md5.create(),\n sha1: forge.md.sha1.create()\n };\n }\n\n /* Update handshake messages digest. Finished and CertificateVerify\n messages are not digested here. They can't be digested as part of\n the verify_data that they contain. These messages are manually\n digested in their handlers. HelloRequest messages are simply never\n included in the handshake message digest according to spec. */\n if(type !== tls.HandshakeType.hello_request &&\n type !== tls.HandshakeType.certificate_verify &&\n type !== tls.HandshakeType.finished) {\n c.session.md5.update(bytes);\n c.session.sha1.update(bytes);\n }\n\n // handle specific handshake type record\n hsTable[c.entity][c.expect][type](c, record, length);\n } else {\n // unexpected record\n tls.handleUnexpected(c, record);\n }\n};\n\n/**\n * Called when an ApplicationData record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleApplicationData = function(c, record) {\n // buffer data, notify that its ready\n c.data.putBuffer(record.fragment);\n c.dataReady(c);\n\n // continue\n c.process();\n};\n\n/**\n * Called when a Heartbeat record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleHeartbeat = function(c, record) {\n // get the heartbeat type and payload\n var b = record.fragment;\n var type = b.getByte();\n var length = b.getInt16();\n var payload = b.getBytes(length);\n\n if(type === tls.HeartbeatMessageType.heartbeat_request) {\n // discard request during handshake or if length is too large\n if(c.handshaking || length > payload.length) {\n // continue\n return c.process();\n }\n // retransmit payload\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.heartbeat,\n data: tls.createHeartbeat(\n tls.HeartbeatMessageType.heartbeat_response, payload)\n }));\n tls.flush(c);\n } else if(type === tls.HeartbeatMessageType.heartbeat_response) {\n // check payload against expected payload, discard heartbeat if no match\n if(payload !== c.expectedHeartbeatPayload) {\n // continue\n return c.process();\n }\n\n // notify that a valid heartbeat was received\n if(c.heartbeatReceived) {\n c.heartbeatReceived(c, forge.util.createBuffer(payload));\n }\n }\n\n // continue\n c.process();\n};\n\n/**\n * The transistional state tables for receiving TLS records. It maps the\n * current TLS engine state and a received record to a function to handle the\n * record and update the state.\n *\n * For instance, if the current state is SHE, then the TLS engine is expecting\n * a ServerHello record. Once a record is received, the handler function is\n * looked up using the state SHE and the record's content type.\n *\n * The resulting function will either be an error handler or a record handler.\n * The function will take whatever action is appropriate and update the state\n * for the next record.\n *\n * The states are all based on possible server record types. Note that the\n * client will never specifically expect to receive a HelloRequest or an alert\n * from the server so there is no state that reflects this. These messages may\n * occur at any time.\n *\n * There are two tables for mapping states because there is a second tier of\n * types for handshake messages. Once a record with a content type of handshake\n * is received, the handshake record handler will look up the handshake type in\n * the secondary map to get its appropriate handler.\n *\n * Valid message orders are as follows:\n *\n * =======================FULL HANDSHAKE======================\n * Client Server\n *\n * ClientHello -------->\n * ServerHello\n * Certificate*\n * ServerKeyExchange*\n * CertificateRequest*\n * <-------- ServerHelloDone\n * Certificate*\n * ClientKeyExchange\n * CertificateVerify*\n * [ChangeCipherSpec]\n * Finished -------->\n * [ChangeCipherSpec]\n * <-------- Finished\n * Application Data <-------> Application Data\n *\n * =====================SESSION RESUMPTION=====================\n * Client Server\n *\n * ClientHello -------->\n * ServerHello\n * [ChangeCipherSpec]\n * <-------- Finished\n * [ChangeCipherSpec]\n * Finished -------->\n * Application Data <-------> Application Data\n */\n// client expect states (indicate which records are expected to be received)\nvar SHE = 0; // rcv server hello\nvar SCE = 1; // rcv server certificate\nvar SKE = 2; // rcv server key exchange\nvar SCR = 3; // rcv certificate request\nvar SHD = 4; // rcv server hello done\nvar SCC = 5; // rcv change cipher spec\nvar SFI = 6; // rcv finished\nvar SAD = 7; // rcv application data\nvar SER = 8; // not expecting any messages at this point\n\n// server expect states\nvar CHE = 0; // rcv client hello\nvar CCE = 1; // rcv client certificate\nvar CKE = 2; // rcv client key exchange\nvar CCV = 3; // rcv certificate verify\nvar CCC = 4; // rcv change cipher spec\nvar CFI = 5; // rcv finished\nvar CAD = 6; // rcv application data\nvar CER = 7; // not expecting any messages at this point\n\n// map client current expect state and content type to function\nvar __ = tls.handleUnexpected;\nvar R0 = tls.handleChangeCipherSpec;\nvar R1 = tls.handleAlert;\nvar R2 = tls.handleHandshake;\nvar R3 = tls.handleApplicationData;\nvar R4 = tls.handleHeartbeat;\nvar ctTable = [];\nctTable[tls.ConnectionEnd.client] = [\n// CC,AL,HS,AD,HB\n/*SHE*/[__,R1,R2,__,R4],\n/*SCE*/[__,R1,R2,__,R4],\n/*SKE*/[__,R1,R2,__,R4],\n/*SCR*/[__,R1,R2,__,R4],\n/*SHD*/[__,R1,R2,__,R4],\n/*SCC*/[R0,R1,__,__,R4],\n/*SFI*/[__,R1,R2,__,R4],\n/*SAD*/[__,R1,R2,R3,R4],\n/*SER*/[__,R1,R2,__,R4]\n];\n\n// map server current expect state and content type to function\nctTable[tls.ConnectionEnd.server] = [\n// CC,AL,HS,AD\n/*CHE*/[__,R1,R2,__,R4],\n/*CCE*/[__,R1,R2,__,R4],\n/*CKE*/[__,R1,R2,__,R4],\n/*CCV*/[__,R1,R2,__,R4],\n/*CCC*/[R0,R1,__,__,R4],\n/*CFI*/[__,R1,R2,__,R4],\n/*CAD*/[__,R1,R2,R3,R4],\n/*CER*/[__,R1,R2,__,R4]\n];\n\n// map client current expect state and handshake type to function\nvar H0 = tls.handleHelloRequest;\nvar H1 = tls.handleServerHello;\nvar H2 = tls.handleCertificate;\nvar H3 = tls.handleServerKeyExchange;\nvar H4 = tls.handleCertificateRequest;\nvar H5 = tls.handleServerHelloDone;\nvar H6 = tls.handleFinished;\nvar hsTable = [];\nhsTable[tls.ConnectionEnd.client] = [\n// HR,01,SH,03,04,05,06,07,08,09,10,SC,SK,CR,HD,15,CK,17,18,19,FI\n/*SHE*/[__,__,H1,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*SCE*/[H0,__,__,__,__,__,__,__,__,__,__,H2,H3,H4,H5,__,__,__,__,__,__],\n/*SKE*/[H0,__,__,__,__,__,__,__,__,__,__,__,H3,H4,H5,__,__,__,__,__,__],\n/*SCR*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,H4,H5,__,__,__,__,__,__],\n/*SHD*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,H5,__,__,__,__,__,__],\n/*SCC*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*SFI*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,H6],\n/*SAD*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*SER*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__]\n];\n\n// map server current expect state and handshake type to function\n// Note: CAD[CH] does not map to FB because renegotation is prohibited\nvar H7 = tls.handleClientHello;\nvar H8 = tls.handleClientKeyExchange;\nvar H9 = tls.handleCertificateVerify;\nhsTable[tls.ConnectionEnd.server] = [\n// 01,CH,02,03,04,05,06,07,08,09,10,CC,12,13,14,CV,CK,17,18,19,FI\n/*CHE*/[__,H7,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*CCE*/[__,__,__,__,__,__,__,__,__,__,__,H2,__,__,__,__,__,__,__,__,__],\n/*CKE*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,H8,__,__,__,__],\n/*CCV*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,H9,__,__,__,__,__],\n/*CCC*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*CFI*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,H6],\n/*CAD*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*CER*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__]\n];\n\n/**\n * Generates the master_secret and keys using the given security parameters.\n *\n * The security parameters for a TLS connection state are defined as such:\n *\n * struct {\n * ConnectionEnd entity;\n * PRFAlgorithm prf_algorithm;\n * BulkCipherAlgorithm bulk_cipher_algorithm;\n * CipherType cipher_type;\n * uint8 enc_key_length;\n * uint8 block_length;\n * uint8 fixed_iv_length;\n * uint8 record_iv_length;\n * MACAlgorithm mac_algorithm;\n * uint8 mac_length;\n * uint8 mac_key_length;\n * CompressionMethod compression_algorithm;\n * opaque master_secret[48];\n * opaque client_random[32];\n * opaque server_random[32];\n * } SecurityParameters;\n *\n * Note that this definition is from TLS 1.2. In TLS 1.0 some of these\n * parameters are ignored because, for instance, the PRFAlgorithm is a\n * builtin-fixed algorithm combining iterations of MD5 and SHA-1 in TLS 1.0.\n *\n * The Record Protocol requires an algorithm to generate keys required by the\n * current connection state.\n *\n * The master secret is expanded into a sequence of secure bytes, which is then\n * split to a client write MAC key, a server write MAC key, a client write\n * encryption key, and a server write encryption key. In TLS 1.0 a client write\n * IV and server write IV are also generated. Each of these is generated from\n * the byte sequence in that order. Unused values are empty. In TLS 1.2, some\n * AEAD ciphers may additionally require a client write IV and a server write\n * IV (see Section 6.2.3.3).\n *\n * When keys, MAC keys, and IVs are generated, the master secret is used as an\n * entropy source.\n *\n * To generate the key material, compute:\n *\n * master_secret = PRF(pre_master_secret, \"master secret\",\n * ClientHello.random + ServerHello.random)\n *\n * key_block = PRF(SecurityParameters.master_secret,\n * \"key expansion\",\n * SecurityParameters.server_random +\n * SecurityParameters.client_random);\n *\n * until enough output has been generated. Then, the key_block is\n * partitioned as follows:\n *\n * client_write_MAC_key[SecurityParameters.mac_key_length]\n * server_write_MAC_key[SecurityParameters.mac_key_length]\n * client_write_key[SecurityParameters.enc_key_length]\n * server_write_key[SecurityParameters.enc_key_length]\n * client_write_IV[SecurityParameters.fixed_iv_length]\n * server_write_IV[SecurityParameters.fixed_iv_length]\n *\n * In TLS 1.2, the client_write_IV and server_write_IV are only generated for\n * implicit nonce techniques as described in Section 3.2.1 of [AEAD]. This\n * implementation uses TLS 1.0 so IVs are generated.\n *\n * Implementation note: The currently defined cipher suite which requires the\n * most material is AES_256_CBC_SHA256. It requires 2 x 32 byte keys and 2 x 32\n * byte MAC keys, for a total 128 bytes of key material. In TLS 1.0 it also\n * requires 2 x 16 byte IVs, so it actually takes 160 bytes of key material.\n *\n * @param c the connection.\n * @param sp the security parameters to use.\n *\n * @return the security keys.\n */\ntls.generateKeys = function(c, sp) {\n // TLS_RSA_WITH_AES_128_CBC_SHA (required to be compliant with TLS 1.2) &\n // TLS_RSA_WITH_AES_256_CBC_SHA are the only cipher suites implemented\n // at present\n\n // TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA is required to be compliant with\n // TLS 1.0 but we don't care right now because AES is better and we have\n // an implementation for it\n\n // TODO: TLS 1.2 implementation\n /*\n // determine the PRF\n var prf;\n switch(sp.prf_algorithm) {\n case tls.PRFAlgorithm.tls_prf_sha256:\n prf = prf_sha256;\n break;\n default:\n // should never happen\n throw new Error('Invalid PRF');\n }\n */\n\n // TLS 1.0/1.1 implementation\n var prf = prf_TLS1;\n\n // concatenate server and client random\n var random = sp.client_random + sp.server_random;\n\n // only create master secret if session is new\n if(!c.session.resuming) {\n // create master secret, clean up pre-master secret\n sp.master_secret = prf(\n sp.pre_master_secret, 'master secret', random, 48).bytes();\n sp.pre_master_secret = null;\n }\n\n // generate the amount of key material needed\n random = sp.server_random + sp.client_random;\n var length = 2 * sp.mac_key_length + 2 * sp.enc_key_length;\n\n // include IV for TLS/1.0\n var tls10 = (c.version.major === tls.Versions.TLS_1_0.major &&\n c.version.minor === tls.Versions.TLS_1_0.minor);\n if(tls10) {\n length += 2 * sp.fixed_iv_length;\n }\n var km = prf(sp.master_secret, 'key expansion', random, length);\n\n // split the key material into the MAC and encryption keys\n var rval = {\n client_write_MAC_key: km.getBytes(sp.mac_key_length),\n server_write_MAC_key: km.getBytes(sp.mac_key_length),\n client_write_key: km.getBytes(sp.enc_key_length),\n server_write_key: km.getBytes(sp.enc_key_length)\n };\n\n // include TLS 1.0 IVs\n if(tls10) {\n rval.client_write_IV = km.getBytes(sp.fixed_iv_length);\n rval.server_write_IV = km.getBytes(sp.fixed_iv_length);\n }\n\n return rval;\n};\n\n/**\n * Creates a new initialized TLS connection state. A connection state has\n * a read mode and a write mode.\n *\n * compression state:\n * The current state of the compression algorithm.\n *\n * cipher state:\n * The current state of the encryption algorithm. This will consist of the\n * scheduled key for that connection. For stream ciphers, this will also\n * contain whatever state information is necessary to allow the stream to\n * continue to encrypt or decrypt data.\n *\n * MAC key:\n * The MAC key for the connection.\n *\n * sequence number:\n * Each connection state contains a sequence number, which is maintained\n * separately for read and write states. The sequence number MUST be set to\n * zero whenever a connection state is made the active state. Sequence\n * numbers are of type uint64 and may not exceed 2^64-1. Sequence numbers do\n * not wrap. If a TLS implementation would need to wrap a sequence number,\n * it must renegotiate instead. A sequence number is incremented after each\n * record: specifically, the first record transmitted under a particular\n * connection state MUST use sequence number 0.\n *\n * @param c the connection.\n *\n * @return the new initialized TLS connection state.\n */\ntls.createConnectionState = function(c) {\n var client = (c.entity === tls.ConnectionEnd.client);\n\n var createMode = function() {\n var mode = {\n // two 32-bit numbers, first is most significant\n sequenceNumber: [0, 0],\n macKey: null,\n macLength: 0,\n macFunction: null,\n cipherState: null,\n cipherFunction: function(record) {return true;},\n compressionState: null,\n compressFunction: function(record) {return true;},\n updateSequenceNumber: function() {\n if(mode.sequenceNumber[1] === 0xFFFFFFFF) {\n mode.sequenceNumber[1] = 0;\n ++mode.sequenceNumber[0];\n } else {\n ++mode.sequenceNumber[1];\n }\n }\n };\n return mode;\n };\n var state = {\n read: createMode(),\n write: createMode()\n };\n\n // update function in read mode will decrypt then decompress a record\n state.read.update = function(c, record) {\n if(!state.read.cipherFunction(record, state.read)) {\n c.error(c, {\n message: 'Could not decrypt record or bad MAC.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n // doesn't matter if decryption failed or MAC was\n // invalid, return the same error so as not to reveal\n // which one occurred\n description: tls.Alert.Description.bad_record_mac\n }\n });\n } else if(!state.read.compressFunction(c, record, state.read)) {\n c.error(c, {\n message: 'Could not decompress record.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.decompression_failure\n }\n });\n }\n return !c.fail;\n };\n\n // update function in write mode will compress then encrypt a record\n state.write.update = function(c, record) {\n if(!state.write.compressFunction(c, record, state.write)) {\n // error, but do not send alert since it would require\n // compression as well\n c.error(c, {\n message: 'Could not compress record.',\n send: false,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.internal_error\n }\n });\n } else if(!state.write.cipherFunction(record, state.write)) {\n // error, but do not send alert since it would require\n // encryption as well\n c.error(c, {\n message: 'Could not encrypt record.',\n send: false,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.internal_error\n }\n });\n }\n return !c.fail;\n };\n\n // handle security parameters\n if(c.session) {\n var sp = c.session.sp;\n c.session.cipherSuite.initSecurityParameters(sp);\n\n // generate keys\n sp.keys = tls.generateKeys(c, sp);\n state.read.macKey = client ?\n sp.keys.server_write_MAC_key : sp.keys.client_write_MAC_key;\n state.write.macKey = client ?\n sp.keys.client_write_MAC_key : sp.keys.server_write_MAC_key;\n\n // cipher suite setup\n c.session.cipherSuite.initConnectionState(state, c, sp);\n\n // compression setup\n switch(sp.compression_algorithm) {\n case tls.CompressionMethod.none:\n break;\n case tls.CompressionMethod.deflate:\n state.read.compressFunction = inflate;\n state.write.compressFunction = deflate;\n break;\n default:\n throw new Error('Unsupported compression algorithm.');\n }\n }\n\n return state;\n};\n\n/**\n * Creates a Random structure.\n *\n * struct {\n * uint32 gmt_unix_time;\n * opaque random_bytes[28];\n * } Random;\n *\n * gmt_unix_time:\n * The current time and date in standard UNIX 32-bit format (seconds since\n * the midnight starting Jan 1, 1970, UTC, ignoring leap seconds) according\n * to the sender's internal clock. Clocks are not required to be set\n * correctly by the basic TLS protocol; higher-level or application\n * protocols may define additional requirements. Note that, for historical\n * reasons, the data element is named using GMT, the predecessor of the\n * current worldwide time base, UTC.\n * random_bytes:\n * 28 bytes generated by a secure random number generator.\n *\n * @return the Random structure as a byte array.\n */\ntls.createRandom = function() {\n // get UTC milliseconds\n var d = new Date();\n var utc = +d + d.getTimezoneOffset() * 60000;\n var rval = forge.util.createBuffer();\n rval.putInt32(utc);\n rval.putBytes(forge.random.getBytes(28));\n return rval;\n};\n\n/**\n * Creates a TLS record with the given type and data.\n *\n * @param c the connection.\n * @param options:\n * type: the record type.\n * data: the plain text data in a byte buffer.\n *\n * @return the created record.\n */\ntls.createRecord = function(c, options) {\n if(!options.data) {\n return null;\n }\n var record = {\n type: options.type,\n version: {\n major: c.version.major,\n minor: c.version.minor\n },\n length: options.data.length(),\n fragment: options.data\n };\n return record;\n};\n\n/**\n * Creates a TLS alert record.\n *\n * @param c the connection.\n * @param alert:\n * level: the TLS alert level.\n * description: the TLS alert description.\n *\n * @return the created alert record.\n */\ntls.createAlert = function(c, alert) {\n var b = forge.util.createBuffer();\n b.putByte(alert.level);\n b.putByte(alert.description);\n return tls.createRecord(c, {\n type: tls.ContentType.alert,\n data: b\n });\n};\n\n/* The structure of a TLS handshake message.\n *\n * struct {\n * HandshakeType msg_type; // handshake type\n * uint24 length; // bytes in message\n * select(HandshakeType) {\n * case hello_request: HelloRequest;\n * case client_hello: ClientHello;\n * case server_hello: ServerHello;\n * case certificate: Certificate;\n * case server_key_exchange: ServerKeyExchange;\n * case certificate_request: CertificateRequest;\n * case server_hello_done: ServerHelloDone;\n * case certificate_verify: CertificateVerify;\n * case client_key_exchange: ClientKeyExchange;\n * case finished: Finished;\n * } body;\n * } Handshake;\n */\n\n/**\n * Creates a ClientHello message.\n *\n * opaque SessionID<0..32>;\n * enum { null(0), deflate(1), (255) } CompressionMethod;\n * uint8 CipherSuite[2];\n *\n * struct {\n * ProtocolVersion client_version;\n * Random random;\n * SessionID session_id;\n * CipherSuite cipher_suites<2..2^16-2>;\n * CompressionMethod compression_methods<1..2^8-1>;\n * select(extensions_present) {\n * case false:\n * struct {};\n * case true:\n * Extension extensions<0..2^16-1>;\n * };\n * } ClientHello;\n *\n * The extension format for extended client hellos and server hellos is:\n *\n * struct {\n * ExtensionType extension_type;\n * opaque extension_data<0..2^16-1>;\n * } Extension;\n *\n * Here:\n *\n * - \"extension_type\" identifies the particular extension type.\n * - \"extension_data\" contains information specific to the particular\n * extension type.\n *\n * The extension types defined in this document are:\n *\n * enum {\n * server_name(0), max_fragment_length(1),\n * client_certificate_url(2), trusted_ca_keys(3),\n * truncated_hmac(4), status_request(5), (65535)\n * } ExtensionType;\n *\n * @param c the connection.\n *\n * @return the ClientHello byte buffer.\n */\ntls.createClientHello = function(c) {\n // save hello version\n c.session.clientHelloVersion = {\n major: c.version.major,\n minor: c.version.minor\n };\n\n // create supported cipher suites\n var cipherSuites = forge.util.createBuffer();\n for(var i = 0; i < c.cipherSuites.length; ++i) {\n var cs = c.cipherSuites[i];\n cipherSuites.putByte(cs.id[0]);\n cipherSuites.putByte(cs.id[1]);\n }\n var cSuites = cipherSuites.length();\n\n // create supported compression methods, null always supported, but\n // also support deflate if connection has inflate and deflate methods\n var compressionMethods = forge.util.createBuffer();\n compressionMethods.putByte(tls.CompressionMethod.none);\n // FIXME: deflate support disabled until issues with raw deflate data\n // without zlib headers are resolved\n /*\n if(c.inflate !== null && c.deflate !== null) {\n compressionMethods.putByte(tls.CompressionMethod.deflate);\n }\n */\n var cMethods = compressionMethods.length();\n\n // create TLS SNI (server name indication) extension if virtual host\n // has been specified, see RFC 3546\n var extensions = forge.util.createBuffer();\n if(c.virtualHost) {\n // create extension struct\n var ext = forge.util.createBuffer();\n ext.putByte(0x00); // type server_name (ExtensionType is 2 bytes)\n ext.putByte(0x00);\n\n /* In order to provide the server name, clients MAY include an\n * extension of type \"server_name\" in the (extended) client hello.\n * The \"extension_data\" field of this extension SHALL contain\n * \"ServerNameList\" where:\n *\n * struct {\n * NameType name_type;\n * select(name_type) {\n * case host_name: HostName;\n * } name;\n * } ServerName;\n *\n * enum {\n * host_name(0), (255)\n * } NameType;\n *\n * opaque HostName<1..2^16-1>;\n *\n * struct {\n * ServerName server_name_list<1..2^16-1>\n * } ServerNameList;\n */\n var serverName = forge.util.createBuffer();\n serverName.putByte(0x00); // type host_name\n writeVector(serverName, 2, forge.util.createBuffer(c.virtualHost));\n\n // ServerNameList is in extension_data\n var snList = forge.util.createBuffer();\n writeVector(snList, 2, serverName);\n writeVector(ext, 2, snList);\n extensions.putBuffer(ext);\n }\n var extLength = extensions.length();\n if(extLength > 0) {\n // add extension vector length\n extLength += 2;\n }\n\n // determine length of the handshake message\n // cipher suites and compression methods size will need to be\n // updated if more get added to the list\n var sessionId = c.session.id;\n var length =\n sessionId.length + 1 + // session ID vector\n 2 + // version (major + minor)\n 4 + 28 + // random time and random bytes\n 2 + cSuites + // cipher suites vector\n 1 + cMethods + // compression methods vector\n extLength; // extensions vector\n\n // build record fragment\n var rval = forge.util.createBuffer();\n rval.putByte(tls.HandshakeType.client_hello);\n rval.putInt24(length); // handshake length\n rval.putByte(c.version.major); // major version\n rval.putByte(c.version.minor); // minor version\n rval.putBytes(c.session.sp.client_random); // random time + bytes\n writeVector(rval, 1, forge.util.createBuffer(sessionId));\n writeVector(rval, 2, cipherSuites);\n writeVector(rval, 1, compressionMethods);\n if(extLength > 0) {\n writeVector(rval, 2, extensions);\n }\n return rval;\n};\n\n/**\n * Creates a ServerHello message.\n *\n * @param c the connection.\n *\n * @return the ServerHello byte buffer.\n */\ntls.createServerHello = function(c) {\n // determine length of the handshake message\n var sessionId = c.session.id;\n var length =\n sessionId.length + 1 + // session ID vector\n 2 + // version (major + minor)\n 4 + 28 + // random time and random bytes\n 2 + // chosen cipher suite\n 1; // chosen compression method\n\n // build record fragment\n var rval = forge.util.createBuffer();\n rval.putByte(tls.HandshakeType.server_hello);\n rval.putInt24(length); // handshake length\n rval.putByte(c.version.major); // major version\n rval.putByte(c.version.minor); // minor version\n rval.putBytes(c.session.sp.server_random); // random time + bytes\n writeVector(rval, 1, forge.util.createBuffer(sessionId));\n rval.putByte(c.session.cipherSuite.id[0]);\n rval.putByte(c.session.cipherSuite.id[1]);\n rval.putByte(c.session.compressionMethod);\n return rval;\n};\n\n/**\n * Creates a Certificate message.\n *\n * When this message will be sent:\n * This is the first message the client can send after receiving a server\n * hello done message and the first message the server can send after\n * sending a ServerHello. This client message is only sent if the server\n * requests a certificate. If no suitable certificate is available, the\n * client should send a certificate message containing no certificates. If\n * client authentication is required by the server for the handshake to\n * continue, it may respond with a fatal handshake failure alert.\n *\n * opaque ASN.1Cert<1..2^24-1>;\n *\n * struct {\n * ASN.1Cert certificate_list<0..2^24-1>;\n * } Certificate;\n *\n * @param c the connection.\n *\n * @return the Certificate byte buffer.\n */\ntls.createCertificate = function(c) {\n // TODO: check certificate request to ensure types are supported\n\n // get a certificate (a certificate as a PEM string)\n var client = (c.entity === tls.ConnectionEnd.client);\n var cert = null;\n if(c.getCertificate) {\n var hint;\n if(client) {\n hint = c.session.certificateRequest;\n } else {\n hint = c.session.extensions.server_name.serverNameList;\n }\n cert = c.getCertificate(c, hint);\n }\n\n // buffer to hold certificate list\n var certList = forge.util.createBuffer();\n if(cert !== null) {\n try {\n // normalize cert to a chain of certificates\n if(!forge.util.isArray(cert)) {\n cert = [cert];\n }\n var asn1 = null;\n for(var i = 0; i < cert.length; ++i) {\n var msg = forge.pem.decode(cert[i])[0];\n if(msg.type !== 'CERTIFICATE' &&\n msg.type !== 'X509 CERTIFICATE' &&\n msg.type !== 'TRUSTED CERTIFICATE') {\n var error = new Error('Could not convert certificate from PEM; PEM ' +\n 'header type is not \"CERTIFICATE\", \"X509 CERTIFICATE\", or ' +\n '\"TRUSTED CERTIFICATE\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert certificate from PEM; PEM is encrypted.');\n }\n\n var der = forge.util.createBuffer(msg.body);\n if(asn1 === null) {\n asn1 = forge.asn1.fromDer(der.bytes(), false);\n }\n\n // certificate entry is itself a vector with 3 length bytes\n var certBuffer = forge.util.createBuffer();\n writeVector(certBuffer, 3, der);\n\n // add cert vector to cert list vector\n certList.putBuffer(certBuffer);\n }\n\n // save certificate\n cert = forge.pki.certificateFromAsn1(asn1);\n if(client) {\n c.session.clientCertificate = cert;\n } else {\n c.session.serverCertificate = cert;\n }\n } catch(ex) {\n return c.error(c, {\n message: 'Could not send certificate list.',\n cause: ex,\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.bad_certificate\n }\n });\n }\n }\n\n // determine length of the handshake message\n var length = 3 + certList.length(); // cert list vector\n\n // build record fragment\n var rval = forge.util.createBuffer();\n rval.putByte(tls.HandshakeType.certificate);\n rval.putInt24(length);\n writeVector(rval, 3, certList);\n return rval;\n};\n\n/**\n * Creates a ClientKeyExchange message.\n *\n * When this message will be sent:\n * This message is always sent by the client. It will immediately follow the\n * client certificate message, if it is sent. Otherwise it will be the first\n * message sent by the client after it receives the server hello done\n * message.\n *\n * Meaning of this message:\n * With this message, the premaster secret is set, either though direct\n * transmission of the RSA-encrypted secret, or by the transmission of\n * Diffie-Hellman parameters which will allow each side to agree upon the\n * same premaster secret. When the key exchange method is DH_RSA or DH_DSS,\n * client certification has been requested, and the client was able to\n * respond with a certificate which contained a Diffie-Hellman public key\n * whose parameters (group and generator) matched those specified by the\n * server in its certificate, this message will not contain any data.\n *\n * Meaning of this message:\n * If RSA is being used for key agreement and authentication, the client\n * generates a 48-byte premaster secret, encrypts it using the public key\n * from the server's certificate or the temporary RSA key provided in a\n * server key exchange message, and sends the result in an encrypted\n * premaster secret message. This structure is a variant of the client\n * key exchange message, not a message in itself.\n *\n * struct {\n * select(KeyExchangeAlgorithm) {\n * case rsa: EncryptedPreMasterSecret;\n * case diffie_hellman: ClientDiffieHellmanPublic;\n * } exchange_keys;\n * } ClientKeyExchange;\n *\n * struct {\n * ProtocolVersion client_version;\n * opaque random[46];\n * } PreMasterSecret;\n *\n * struct {\n * public-key-encrypted PreMasterSecret pre_master_secret;\n * } EncryptedPreMasterSecret;\n *\n * A public-key-encrypted element is encoded as a vector <0..2^16-1>.\n *\n * @param c the connection.\n *\n * @return the ClientKeyExchange byte buffer.\n */\ntls.createClientKeyExchange = function(c) {\n // create buffer to encrypt\n var b = forge.util.createBuffer();\n\n // add highest client-supported protocol to help server avoid version\n // rollback attacks\n b.putByte(c.session.clientHelloVersion.major);\n b.putByte(c.session.clientHelloVersion.minor);\n\n // generate and add 46 random bytes\n b.putBytes(forge.random.getBytes(46));\n\n // save pre-master secret\n var sp = c.session.sp;\n sp.pre_master_secret = b.getBytes();\n\n // RSA-encrypt the pre-master secret\n var key = c.session.serverCertificate.publicKey;\n b = key.encrypt(sp.pre_master_secret);\n\n /* Note: The encrypted pre-master secret will be stored in a\n public-key-encrypted opaque vector that has the length prefixed using\n 2 bytes, so include those 2 bytes in the handshake message length. This\n is done as a minor optimization instead of calling writeVector(). */\n\n // determine length of the handshake message\n var length = b.length + 2;\n\n // build record fragment\n var rval = forge.util.createBuffer();\n rval.putByte(tls.HandshakeType.client_key_exchange);\n rval.putInt24(length);\n // add vector length bytes\n rval.putInt16(b.length);\n rval.putBytes(b);\n return rval;\n};\n\n/**\n * Creates a ServerKeyExchange message.\n *\n * @param c the connection.\n *\n * @return the ServerKeyExchange byte buffer.\n */\ntls.createServerKeyExchange = function(c) {\n // this implementation only supports RSA, no Diffie-Hellman support,\n // so this record is empty\n\n // determine length of the handshake message\n var length = 0;\n\n // build record fragment\n var rval = forge.util.createBuffer();\n if(length > 0) {\n rval.putByte(tls.HandshakeType.server_key_exchange);\n rval.putInt24(length);\n }\n return rval;\n};\n\n/**\n * Gets the signed data used to verify a client-side certificate. See\n * tls.createCertificateVerify() for details.\n *\n * @param c the connection.\n * @param callback the callback to call once the signed data is ready.\n */\ntls.getClientSignature = function(c, callback) {\n // generate data to RSA encrypt\n var b = forge.util.createBuffer();\n b.putBuffer(c.session.md5.digest());\n b.putBuffer(c.session.sha1.digest());\n b = b.getBytes();\n\n // create default signing function as necessary\n c.getSignature = c.getSignature || function(c, b, callback) {\n // do rsa encryption, call callback\n var privateKey = null;\n if(c.getPrivateKey) {\n try {\n privateKey = c.getPrivateKey(c, c.session.clientCertificate);\n privateKey = forge.pki.privateKeyFromPem(privateKey);\n } catch(ex) {\n c.error(c, {\n message: 'Could not get private key.',\n cause: ex,\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.internal_error\n }\n });\n }\n }\n if(privateKey === null) {\n c.error(c, {\n message: 'No private key set.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.internal_error\n }\n });\n } else {\n b = privateKey.sign(b, null);\n }\n callback(c, b);\n };\n\n // get client signature\n c.getSignature(c, b, callback);\n};\n\n/**\n * Creates a CertificateVerify message.\n *\n * Meaning of this message:\n * This structure conveys the client's Diffie-Hellman public value\n * (Yc) if it was not already included in the client's certificate.\n * The encoding used for Yc is determined by the enumerated\n * PublicValueEncoding. This structure is a variant of the client\n * key exchange message, not a message in itself.\n *\n * When this message will be sent:\n * This message is used to provide explicit verification of a client\n * certificate. This message is only sent following a client\n * certificate that has signing capability (i.e. all certificates\n * except those containing fixed Diffie-Hellman parameters). When\n * sent, it will immediately follow the client key exchange message.\n *\n * struct {\n * Signature signature;\n * } CertificateVerify;\n *\n * CertificateVerify.signature.md5_hash\n * MD5(handshake_messages);\n *\n * Certificate.signature.sha_hash\n * SHA(handshake_messages);\n *\n * Here handshake_messages refers to all handshake messages sent or\n * received starting at client hello up to but not including this\n * message, including the type and length fields of the handshake\n * messages.\n *\n * select(SignatureAlgorithm) {\n * case anonymous: struct { };\n * case rsa:\n * digitally-signed struct {\n * opaque md5_hash[16];\n * opaque sha_hash[20];\n * };\n * case dsa:\n * digitally-signed struct {\n * opaque sha_hash[20];\n * };\n * } Signature;\n *\n * In digital signing, one-way hash functions are used as input for a\n * signing algorithm. A digitally-signed element is encoded as an opaque\n * vector <0..2^16-1>, where the length is specified by the signing\n * algorithm and key.\n *\n * In RSA signing, a 36-byte structure of two hashes (one SHA and one\n * MD5) is signed (encrypted with the private key). It is encoded with\n * PKCS #1 block type 0 or type 1 as described in [PKCS1].\n *\n * In DSS, the 20 bytes of the SHA hash are run directly through the\n * Digital Signing Algorithm with no additional hashing.\n *\n * @param c the connection.\n * @param signature the signature to include in the message.\n *\n * @return the CertificateVerify byte buffer.\n */\ntls.createCertificateVerify = function(c, signature) {\n /* Note: The signature will be stored in a \"digitally-signed\" opaque\n vector that has the length prefixed using 2 bytes, so include those\n 2 bytes in the handshake message length. This is done as a minor\n optimization instead of calling writeVector(). */\n\n // determine length of the handshake message\n var length = signature.length + 2;\n\n // build record fragment\n var rval = forge.util.createBuffer();\n rval.putByte(tls.HandshakeType.certificate_verify);\n rval.putInt24(length);\n // add vector length bytes\n rval.putInt16(signature.length);\n rval.putBytes(signature);\n return rval;\n};\n\n/**\n * Creates a CertificateRequest message.\n *\n * @param c the connection.\n *\n * @return the CertificateRequest byte buffer.\n */\ntls.createCertificateRequest = function(c) {\n // TODO: support other certificate types\n var certTypes = forge.util.createBuffer();\n\n // common RSA certificate type\n certTypes.putByte(0x01);\n\n // add distinguished names from CA store\n var cAs = forge.util.createBuffer();\n for(var key in c.caStore.certs) {\n var cert = c.caStore.certs[key];\n var dn = forge.pki.distinguishedNameToAsn1(cert.subject);\n var byteBuffer = forge.asn1.toDer(dn);\n cAs.putInt16(byteBuffer.length());\n cAs.putBuffer(byteBuffer);\n }\n\n // TODO: TLS 1.2+ has a different format\n\n // determine length of the handshake message\n var length =\n 1 + certTypes.length() +\n 2 + cAs.length();\n\n // build record fragment\n var rval = forge.util.createBuffer();\n rval.putByte(tls.HandshakeType.certificate_request);\n rval.putInt24(length);\n writeVector(rval, 1, certTypes);\n writeVector(rval, 2, cAs);\n return rval;\n};\n\n/**\n * Creates a ServerHelloDone message.\n *\n * @param c the connection.\n *\n * @return the ServerHelloDone byte buffer.\n */\ntls.createServerHelloDone = function(c) {\n // build record fragment\n var rval = forge.util.createBuffer();\n rval.putByte(tls.HandshakeType.server_hello_done);\n rval.putInt24(0);\n return rval;\n};\n\n/**\n * Creates a ChangeCipherSpec message.\n *\n * The change cipher spec protocol exists to signal transitions in\n * ciphering strategies. The protocol consists of a single message,\n * which is encrypted and compressed under the current (not the pending)\n * connection state. The message consists of a single byte of value 1.\n *\n * struct {\n * enum { change_cipher_spec(1), (255) } type;\n * } ChangeCipherSpec;\n *\n * @return the ChangeCipherSpec byte buffer.\n */\ntls.createChangeCipherSpec = function() {\n var rval = forge.util.createBuffer();\n rval.putByte(0x01);\n return rval;\n};\n\n/**\n * Creates a Finished message.\n *\n * struct {\n * opaque verify_data[12];\n * } Finished;\n *\n * verify_data\n * PRF(master_secret, finished_label, MD5(handshake_messages) +\n * SHA-1(handshake_messages)) [0..11];\n *\n * finished_label\n * For Finished messages sent by the client, the string \"client\n * finished\". For Finished messages sent by the server, the\n * string \"server finished\".\n *\n * handshake_messages\n * All of the data from all handshake messages up to but not\n * including this message. This is only data visible at the\n * handshake layer and does not include record layer headers.\n * This is the concatenation of all the Handshake structures as\n * defined in 7.4 exchanged thus far.\n *\n * @param c the connection.\n *\n * @return the Finished byte buffer.\n */\ntls.createFinished = function(c) {\n // generate verify_data\n var b = forge.util.createBuffer();\n b.putBuffer(c.session.md5.digest());\n b.putBuffer(c.session.sha1.digest());\n\n // TODO: determine prf function and verify length for TLS 1.2\n var client = (c.entity === tls.ConnectionEnd.client);\n var sp = c.session.sp;\n var vdl = 12;\n var prf = prf_TLS1;\n var label = client ? 'client finished' : 'server finished';\n b = prf(sp.master_secret, label, b.getBytes(), vdl);\n\n // build record fragment\n var rval = forge.util.createBuffer();\n rval.putByte(tls.HandshakeType.finished);\n rval.putInt24(b.length());\n rval.putBuffer(b);\n return rval;\n};\n\n/**\n * Creates a HeartbeatMessage (See RFC 6520).\n *\n * struct {\n * HeartbeatMessageType type;\n * uint16 payload_length;\n * opaque payload[HeartbeatMessage.payload_length];\n * opaque padding[padding_length];\n * } HeartbeatMessage;\n *\n * The total length of a HeartbeatMessage MUST NOT exceed 2^14 or\n * max_fragment_length when negotiated as defined in [RFC6066].\n *\n * type: The message type, either heartbeat_request or heartbeat_response.\n *\n * payload_length: The length of the payload.\n *\n * payload: The payload consists of arbitrary content.\n *\n * padding: The padding is random content that MUST be ignored by the\n * receiver. The length of a HeartbeatMessage is TLSPlaintext.length\n * for TLS and DTLSPlaintext.length for DTLS. Furthermore, the\n * length of the type field is 1 byte, and the length of the\n * payload_length is 2. Therefore, the padding_length is\n * TLSPlaintext.length - payload_length - 3 for TLS and\n * DTLSPlaintext.length - payload_length - 3 for DTLS. The\n * padding_length MUST be at least 16.\n *\n * The sender of a HeartbeatMessage MUST use a random padding of at\n * least 16 bytes. The padding of a received HeartbeatMessage message\n * MUST be ignored.\n *\n * If the payload_length of a received HeartbeatMessage is too large,\n * the received HeartbeatMessage MUST be discarded silently.\n *\n * @param c the connection.\n * @param type the tls.HeartbeatMessageType.\n * @param payload the heartbeat data to send as the payload.\n * @param [payloadLength] the payload length to use, defaults to the\n * actual payload length.\n *\n * @return the HeartbeatRequest byte buffer.\n */\ntls.createHeartbeat = function(type, payload, payloadLength) {\n if(typeof payloadLength === 'undefined') {\n payloadLength = payload.length;\n }\n // build record fragment\n var rval = forge.util.createBuffer();\n rval.putByte(type); // heartbeat message type\n rval.putInt16(payloadLength); // payload length\n rval.putBytes(payload); // payload\n // padding\n var plaintextLength = rval.length();\n var paddingLength = Math.max(16, plaintextLength - payloadLength - 3);\n rval.putBytes(forge.random.getBytes(paddingLength));\n return rval;\n};\n\n/**\n * Fragments, compresses, encrypts, and queues a record for delivery.\n *\n * @param c the connection.\n * @param record the record to queue.\n */\ntls.queue = function(c, record) {\n // error during record creation\n if(!record) {\n return;\n }\n\n if(record.fragment.length() === 0) {\n if(record.type === tls.ContentType.handshake ||\n record.type === tls.ContentType.alert ||\n record.type === tls.ContentType.change_cipher_spec) {\n // Empty handshake, alert of change cipher spec messages are not allowed per the TLS specification and should not be sent.\n return;\n }\n }\n\n // if the record is a handshake record, update handshake hashes\n if(record.type === tls.ContentType.handshake) {\n var bytes = record.fragment.bytes();\n c.session.md5.update(bytes);\n c.session.sha1.update(bytes);\n bytes = null;\n }\n\n // handle record fragmentation\n var records;\n if(record.fragment.length() <= tls.MaxFragment) {\n records = [record];\n } else {\n // fragment data as long as it is too long\n records = [];\n var data = record.fragment.bytes();\n while(data.length > tls.MaxFragment) {\n records.push(tls.createRecord(c, {\n type: record.type,\n data: forge.util.createBuffer(data.slice(0, tls.MaxFragment))\n }));\n data = data.slice(tls.MaxFragment);\n }\n // add last record\n if(data.length > 0) {\n records.push(tls.createRecord(c, {\n type: record.type,\n data: forge.util.createBuffer(data)\n }));\n }\n }\n\n // compress and encrypt all fragmented records\n for(var i = 0; i < records.length && !c.fail; ++i) {\n // update the record using current write state\n var rec = records[i];\n var s = c.state.current.write;\n if(s.update(c, rec)) {\n // store record\n c.records.push(rec);\n }\n }\n};\n\n/**\n * Flushes all queued records to the output buffer and calls the\n * tlsDataReady() handler on the given connection.\n *\n * @param c the connection.\n *\n * @return true on success, false on failure.\n */\ntls.flush = function(c) {\n for(var i = 0; i < c.records.length; ++i) {\n var record = c.records[i];\n\n // add record header and fragment\n c.tlsData.putByte(record.type);\n c.tlsData.putByte(record.version.major);\n c.tlsData.putByte(record.version.minor);\n c.tlsData.putInt16(record.fragment.length());\n c.tlsData.putBuffer(c.records[i].fragment);\n }\n c.records = [];\n return c.tlsDataReady(c);\n};\n\n/**\n * Maps a pki.certificateError to a tls.Alert.Description.\n *\n * @param error the error to map.\n *\n * @return the alert description.\n */\nvar _certErrorToAlertDesc = function(error) {\n switch(error) {\n case true:\n return true;\n case forge.pki.certificateError.bad_certificate:\n return tls.Alert.Description.bad_certificate;\n case forge.pki.certificateError.unsupported_certificate:\n return tls.Alert.Description.unsupported_certificate;\n case forge.pki.certificateError.certificate_revoked:\n return tls.Alert.Description.certificate_revoked;\n case forge.pki.certificateError.certificate_expired:\n return tls.Alert.Description.certificate_expired;\n case forge.pki.certificateError.certificate_unknown:\n return tls.Alert.Description.certificate_unknown;\n case forge.pki.certificateError.unknown_ca:\n return tls.Alert.Description.unknown_ca;\n default:\n return tls.Alert.Description.bad_certificate;\n }\n};\n\n/**\n * Maps a tls.Alert.Description to a pki.certificateError.\n *\n * @param desc the alert description.\n *\n * @return the certificate error.\n */\nvar _alertDescToCertError = function(desc) {\n switch(desc) {\n case true:\n return true;\n case tls.Alert.Description.bad_certificate:\n return forge.pki.certificateError.bad_certificate;\n case tls.Alert.Description.unsupported_certificate:\n return forge.pki.certificateError.unsupported_certificate;\n case tls.Alert.Description.certificate_revoked:\n return forge.pki.certificateError.certificate_revoked;\n case tls.Alert.Description.certificate_expired:\n return forge.pki.certificateError.certificate_expired;\n case tls.Alert.Description.certificate_unknown:\n return forge.pki.certificateError.certificate_unknown;\n case tls.Alert.Description.unknown_ca:\n return forge.pki.certificateError.unknown_ca;\n default:\n return forge.pki.certificateError.bad_certificate;\n }\n};\n\n/**\n * Verifies a certificate chain against the given connection's\n * Certificate Authority store.\n *\n * @param c the TLS connection.\n * @param chain the certificate chain to verify, with the root or highest\n * authority at the end.\n *\n * @return true if successful, false if not.\n */\ntls.verifyCertificateChain = function(c, chain) {\n try {\n // Make a copy of c.verifyOptions so that we can modify options.verify\n // without modifying c.verifyOptions.\n var options = {};\n for (var key in c.verifyOptions) {\n options[key] = c.verifyOptions[key];\n }\n\n options.verify = function(vfd, depth, chain) {\n // convert pki.certificateError to tls alert description\n var desc = _certErrorToAlertDesc(vfd);\n\n // call application callback\n var ret = c.verify(c, vfd, depth, chain);\n if(ret !== true) {\n if(typeof ret === 'object' && !forge.util.isArray(ret)) {\n // throw custom error\n var error = new Error('The application rejected the certificate.');\n error.send = true;\n error.alert = {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.bad_certificate\n };\n if(ret.message) {\n error.message = ret.message;\n }\n if(ret.alert) {\n error.alert.description = ret.alert;\n }\n throw error;\n }\n\n // convert tls alert description to pki.certificateError\n if(ret !== vfd) {\n ret = _alertDescToCertError(ret);\n }\n }\n\n return ret;\n };\n\n // verify chain\n forge.pki.verifyCertificateChain(c.caStore, chain, options);\n } catch(ex) {\n // build tls error if not already customized\n var err = ex;\n if(typeof err !== 'object' || forge.util.isArray(err)) {\n err = {\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: _certErrorToAlertDesc(ex)\n }\n };\n }\n if(!('send' in err)) {\n err.send = true;\n }\n if(!('alert' in err)) {\n err.alert = {\n level: tls.Alert.Level.fatal,\n description: _certErrorToAlertDesc(err.error)\n };\n }\n\n // send error\n c.error(c, err);\n }\n\n return !c.fail;\n};\n\n/**\n * Creates a new TLS session cache.\n *\n * @param cache optional map of session ID to cached session.\n * @param capacity the maximum size for the cache (default: 100).\n *\n * @return the new TLS session cache.\n */\ntls.createSessionCache = function(cache, capacity) {\n var rval = null;\n\n // assume input is already a session cache object\n if(cache && cache.getSession && cache.setSession && cache.order) {\n rval = cache;\n } else {\n // create cache\n rval = {};\n rval.cache = cache || {};\n rval.capacity = Math.max(capacity || 100, 1);\n rval.order = [];\n\n // store order for sessions, delete session overflow\n for(var key in cache) {\n if(rval.order.length <= capacity) {\n rval.order.push(key);\n } else {\n delete cache[key];\n }\n }\n\n // get a session from a session ID (or get any session)\n rval.getSession = function(sessionId) {\n var session = null;\n var key = null;\n\n // if session ID provided, use it\n if(sessionId) {\n key = forge.util.bytesToHex(sessionId);\n } else if(rval.order.length > 0) {\n // get first session from cache\n key = rval.order[0];\n }\n\n if(key !== null && key in rval.cache) {\n // get cached session and remove from cache\n session = rval.cache[key];\n delete rval.cache[key];\n for(var i in rval.order) {\n if(rval.order[i] === key) {\n rval.order.splice(i, 1);\n break;\n }\n }\n }\n\n return session;\n };\n\n // set a session in the cache\n rval.setSession = function(sessionId, session) {\n // remove session from cache if at capacity\n if(rval.order.length === rval.capacity) {\n var key = rval.order.shift();\n delete rval.cache[key];\n }\n // add session to cache\n var key = forge.util.bytesToHex(sessionId);\n rval.order.push(key);\n rval.cache[key] = session;\n };\n }\n\n return rval;\n};\n\n/**\n * Creates a new TLS connection.\n *\n * See public createConnection() docs for more details.\n *\n * @param options the options for this connection.\n *\n * @return the new TLS connection.\n */\ntls.createConnection = function(options) {\n var caStore = null;\n if(options.caStore) {\n // if CA store is an array, convert it to a CA store object\n if(forge.util.isArray(options.caStore)) {\n caStore = forge.pki.createCaStore(options.caStore);\n } else {\n caStore = options.caStore;\n }\n } else {\n // create empty CA store\n caStore = forge.pki.createCaStore();\n }\n\n // setup default cipher suites\n var cipherSuites = options.cipherSuites || null;\n if(cipherSuites === null) {\n cipherSuites = [];\n for(var key in tls.CipherSuites) {\n cipherSuites.push(tls.CipherSuites[key]);\n }\n }\n\n // set default entity\n var entity = (options.server || false) ?\n tls.ConnectionEnd.server : tls.ConnectionEnd.client;\n\n // create session cache if requested\n var sessionCache = options.sessionCache ?\n tls.createSessionCache(options.sessionCache) : null;\n\n // create TLS connection\n var c = {\n version: {major: tls.Version.major, minor: tls.Version.minor},\n entity: entity,\n sessionId: options.sessionId,\n caStore: caStore,\n sessionCache: sessionCache,\n cipherSuites: cipherSuites,\n connected: options.connected,\n virtualHost: options.virtualHost || null,\n verifyClient: options.verifyClient || false,\n verify: options.verify || function(cn, vfd, dpth, cts) {return vfd;},\n verifyOptions: options.verifyOptions || {},\n getCertificate: options.getCertificate || null,\n getPrivateKey: options.getPrivateKey || null,\n getSignature: options.getSignature || null,\n input: forge.util.createBuffer(),\n tlsData: forge.util.createBuffer(),\n data: forge.util.createBuffer(),\n tlsDataReady: options.tlsDataReady,\n dataReady: options.dataReady,\n heartbeatReceived: options.heartbeatReceived,\n closed: options.closed,\n error: function(c, ex) {\n // set origin if not set\n ex.origin = ex.origin ||\n ((c.entity === tls.ConnectionEnd.client) ? 'client' : 'server');\n\n // send TLS alert\n if(ex.send) {\n tls.queue(c, tls.createAlert(c, ex.alert));\n tls.flush(c);\n }\n\n // error is fatal by default\n var fatal = (ex.fatal !== false);\n if(fatal) {\n // set fail flag\n c.fail = true;\n }\n\n // call error handler first\n options.error(c, ex);\n\n if(fatal) {\n // fatal error, close connection, do not clear fail\n c.close(false);\n }\n },\n deflate: options.deflate || null,\n inflate: options.inflate || null\n };\n\n /**\n * Resets a closed TLS connection for reuse. Called in c.close().\n *\n * @param clearFail true to clear the fail flag (default: true).\n */\n c.reset = function(clearFail) {\n c.version = {major: tls.Version.major, minor: tls.Version.minor};\n c.record = null;\n c.session = null;\n c.peerCertificate = null;\n c.state = {\n pending: null,\n current: null\n };\n c.expect = (c.entity === tls.ConnectionEnd.client) ? SHE : CHE;\n c.fragmented = null;\n c.records = [];\n c.open = false;\n c.handshakes = 0;\n c.handshaking = false;\n c.isConnected = false;\n c.fail = !(clearFail || typeof(clearFail) === 'undefined');\n c.input.clear();\n c.tlsData.clear();\n c.data.clear();\n c.state.current = tls.createConnectionState(c);\n };\n\n // do initial reset of connection\n c.reset();\n\n /**\n * Updates the current TLS engine state based on the given record.\n *\n * @param c the TLS connection.\n * @param record the TLS record to act on.\n */\n var _update = function(c, record) {\n // get record handler (align type in table by subtracting lowest)\n var aligned = record.type - tls.ContentType.change_cipher_spec;\n var handlers = ctTable[c.entity][c.expect];\n if(aligned in handlers) {\n handlers[aligned](c, record);\n } else {\n // unexpected record\n tls.handleUnexpected(c, record);\n }\n };\n\n /**\n * Reads the record header and initializes the next record on the given\n * connection.\n *\n * @param c the TLS connection with the next record.\n *\n * @return 0 if the input data could be processed, otherwise the\n * number of bytes required for data to be processed.\n */\n var _readRecordHeader = function(c) {\n var rval = 0;\n\n // get input buffer and its length\n var b = c.input;\n var len = b.length();\n\n // need at least 5 bytes to initialize a record\n if(len < 5) {\n rval = 5 - len;\n } else {\n // enough bytes for header\n // initialize record\n c.record = {\n type: b.getByte(),\n version: {\n major: b.getByte(),\n minor: b.getByte()\n },\n length: b.getInt16(),\n fragment: forge.util.createBuffer(),\n ready: false\n };\n\n // check record version\n var compatibleVersion = (c.record.version.major === c.version.major);\n if(compatibleVersion && c.session && c.session.version) {\n // session version already set, require same minor version\n compatibleVersion = (c.record.version.minor === c.version.minor);\n }\n if(!compatibleVersion) {\n c.error(c, {\n message: 'Incompatible TLS version.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description: tls.Alert.Description.protocol_version\n }\n });\n }\n }\n\n return rval;\n };\n\n /**\n * Reads the next record's contents and appends its message to any\n * previously fragmented message.\n *\n * @param c the TLS connection with the next record.\n *\n * @return 0 if the input data could be processed, otherwise the\n * number of bytes required for data to be processed.\n */\n var _readRecord = function(c) {\n var rval = 0;\n\n // ensure there is enough input data to get the entire record\n var b = c.input;\n var len = b.length();\n if(len < c.record.length) {\n // not enough data yet, return how much is required\n rval = c.record.length - len;\n } else {\n // there is enough data to parse the pending record\n // fill record fragment and compact input buffer\n c.record.fragment.putBytes(b.getBytes(c.record.length));\n b.compact();\n\n // update record using current read state\n var s = c.state.current.read;\n if(s.update(c, c.record)) {\n // see if there is a previously fragmented message that the\n // new record's message fragment should be appended to\n if(c.fragmented !== null) {\n // if the record type matches a previously fragmented\n // record, append the record fragment to it\n if(c.fragmented.type === c.record.type) {\n // concatenate record fragments\n c.fragmented.fragment.putBuffer(c.record.fragment);\n c.record = c.fragmented;\n } else {\n // error, invalid fragmented record\n c.error(c, {\n message: 'Invalid fragmented record.',\n send: true,\n alert: {\n level: tls.Alert.Level.fatal,\n description:\n tls.Alert.Description.unexpected_message\n }\n });\n }\n }\n\n // record is now ready\n c.record.ready = true;\n }\n }\n\n return rval;\n };\n\n /**\n * Performs a handshake using the TLS Handshake Protocol, as a client.\n *\n * This method should only be called if the connection is in client mode.\n *\n * @param sessionId the session ID to use, null to start a new one.\n */\n c.handshake = function(sessionId) {\n // error to call this in non-client mode\n if(c.entity !== tls.ConnectionEnd.client) {\n // not fatal error\n c.error(c, {\n message: 'Cannot initiate handshake as a server.',\n fatal: false\n });\n } else if(c.handshaking) {\n // handshake is already in progress, fail but not fatal error\n c.error(c, {\n message: 'Handshake already in progress.',\n fatal: false\n });\n } else {\n // clear fail flag on reuse\n if(c.fail && !c.open && c.handshakes === 0) {\n c.fail = false;\n }\n\n // now handshaking\n c.handshaking = true;\n\n // default to blank (new session)\n sessionId = sessionId || '';\n\n // if a session ID was specified, try to find it in the cache\n var session = null;\n if(sessionId.length > 0) {\n if(c.sessionCache) {\n session = c.sessionCache.getSession(sessionId);\n }\n\n // matching session not found in cache, clear session ID\n if(session === null) {\n sessionId = '';\n }\n }\n\n // no session given, grab a session from the cache, if available\n if(sessionId.length === 0 && c.sessionCache) {\n session = c.sessionCache.getSession();\n if(session !== null) {\n sessionId = session.id;\n }\n }\n\n // set up session\n c.session = {\n id: sessionId,\n version: null,\n cipherSuite: null,\n compressionMethod: null,\n serverCertificate: null,\n certificateRequest: null,\n clientCertificate: null,\n sp: {},\n md5: forge.md.md5.create(),\n sha1: forge.md.sha1.create()\n };\n\n // use existing session information\n if(session) {\n // only update version on connection, session version not yet set\n c.version = session.version;\n c.session.sp = session.sp;\n }\n\n // generate new client random\n c.session.sp.client_random = tls.createRandom().getBytes();\n\n // connection now open\n c.open = true;\n\n // send hello\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.handshake,\n data: tls.createClientHello(c)\n }));\n tls.flush(c);\n }\n };\n\n /**\n * Called when TLS protocol data has been received from somewhere and should\n * be processed by the TLS engine.\n *\n * @param data the TLS protocol data, as a string, to process.\n *\n * @return 0 if the data could be processed, otherwise the number of bytes\n * required for data to be processed.\n */\n c.process = function(data) {\n var rval = 0;\n\n // buffer input data\n if(data) {\n c.input.putBytes(data);\n }\n\n // process next record if no failure, process will be called after\n // each record is handled (since handling can be asynchronous)\n if(!c.fail) {\n // reset record if ready and now empty\n if(c.record !== null &&\n c.record.ready && c.record.fragment.isEmpty()) {\n c.record = null;\n }\n\n // if there is no pending record, try to read record header\n if(c.record === null) {\n rval = _readRecordHeader(c);\n }\n\n // read the next record (if record not yet ready)\n if(!c.fail && c.record !== null && !c.record.ready) {\n rval = _readRecord(c);\n }\n\n // record ready to be handled, update engine state\n if(!c.fail && c.record !== null && c.record.ready) {\n _update(c, c.record);\n }\n }\n\n return rval;\n };\n\n /**\n * Requests that application data be packaged into a TLS record. The\n * tlsDataReady handler will be called when the TLS record(s) have been\n * prepared.\n *\n * @param data the application data, as a raw 'binary' encoded string, to\n * be sent; to send utf-16/utf-8 string data, use the return value\n * of util.encodeUtf8(str).\n *\n * @return true on success, false on failure.\n */\n c.prepare = function(data) {\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.application_data,\n data: forge.util.createBuffer(data)\n }));\n return tls.flush(c);\n };\n\n /**\n * Requests that a heartbeat request be packaged into a TLS record for\n * transmission. The tlsDataReady handler will be called when TLS record(s)\n * have been prepared.\n *\n * When a heartbeat response has been received, the heartbeatReceived\n * handler will be called with the matching payload. This handler can\n * be used to clear a retransmission timer, etc.\n *\n * @param payload the heartbeat data to send as the payload in the message.\n * @param [payloadLength] the payload length to use, defaults to the\n * actual payload length.\n *\n * @return true on success, false on failure.\n */\n c.prepareHeartbeatRequest = function(payload, payloadLength) {\n if(payload instanceof forge.util.ByteBuffer) {\n payload = payload.bytes();\n }\n if(typeof payloadLength === 'undefined') {\n payloadLength = payload.length;\n }\n c.expectedHeartbeatPayload = payload;\n tls.queue(c, tls.createRecord(c, {\n type: tls.ContentType.heartbeat,\n data: tls.createHeartbeat(\n tls.HeartbeatMessageType.heartbeat_request, payload, payloadLength)\n }));\n return tls.flush(c);\n };\n\n /**\n * Closes the connection (sends a close_notify alert).\n *\n * @param clearFail true to clear the fail flag (default: true).\n */\n c.close = function(clearFail) {\n // save session if connection didn't fail\n if(!c.fail && c.sessionCache && c.session) {\n // only need to preserve session ID, version, and security params\n var session = {\n id: c.session.id,\n version: c.session.version,\n sp: c.session.sp\n };\n session.sp.keys = null;\n c.sessionCache.setSession(session.id, session);\n }\n\n if(c.open) {\n // connection no longer open, clear input\n c.open = false;\n c.input.clear();\n\n // if connected or handshaking, send an alert\n if(c.isConnected || c.handshaking) {\n c.isConnected = c.handshaking = false;\n\n // send close_notify alert\n tls.queue(c, tls.createAlert(c, {\n level: tls.Alert.Level.warning,\n description: tls.Alert.Description.close_notify\n }));\n tls.flush(c);\n }\n\n // call handler\n c.closed(c);\n }\n\n // reset TLS connection, do not clear fail flag\n c.reset(clearFail);\n };\n\n return c;\n};\n\n/* TLS API */\nmodule.exports = forge.tls = forge.tls || {};\n\n// expose non-functions\nfor(var key in tls) {\n if(typeof tls[key] !== 'function') {\n forge.tls[key] = tls[key];\n }\n}\n\n// expose prf_tls1 for testing\nforge.tls.prf_tls1 = prf_TLS1;\n\n// expose sha1 hmac method\nforge.tls.hmac_sha1 = hmac_sha1;\n\n// expose session cache creation\nforge.tls.createSessionCache = tls.createSessionCache;\n\n/**\n * Creates a new TLS connection. This does not make any assumptions about the\n * transport layer that TLS is working on top of, ie: it does not assume there\n * is a TCP/IP connection or establish one. A TLS connection is totally\n * abstracted away from the layer is runs on top of, it merely establishes a\n * secure channel between a client\" and a \"server\".\n *\n * A TLS connection contains 4 connection states: pending read and write, and\n * current read and write.\n *\n * At initialization, the current read and write states will be null. Only once\n * the security parameters have been set and the keys have been generated can\n * the pending states be converted into current states. Current states will be\n * updated for each record processed.\n *\n * A custom certificate verify callback may be provided to check information\n * like the common name on the server's certificate. It will be called for\n * every certificate in the chain. It has the following signature:\n *\n * variable func(c, certs, index, preVerify)\n * Where:\n * c The TLS connection\n * verified Set to true if certificate was verified, otherwise the alert\n * tls.Alert.Description for why the certificate failed.\n * depth The current index in the chain, where 0 is the server's cert.\n * certs The certificate chain, *NOTE* if the server was anonymous then\n * the chain will be empty.\n *\n * The function returns true on success and on failure either the appropriate\n * tls.Alert.Description or an object with 'alert' set to the appropriate\n * tls.Alert.Description and 'message' set to a custom error message. If true\n * is not returned then the connection will abort using, in order of\n * availability, first the returned alert description, second the preVerify\n * alert description, and lastly the default 'bad_certificate'.\n *\n * There are three callbacks that can be used to make use of client-side\n * certificates where each takes the TLS connection as the first parameter:\n *\n * getCertificate(conn, hint)\n * The second parameter is a hint as to which certificate should be\n * returned. If the connection entity is a client, then the hint will be\n * the CertificateRequest message from the server that is part of the\n * TLS protocol. If the connection entity is a server, then it will be\n * the servername list provided via an SNI extension the ClientHello, if\n * one was provided (empty array if not). The hint can be examined to\n * determine which certificate to use (advanced). Most implementations\n * will just return a certificate. The return value must be a\n * PEM-formatted certificate or an array of PEM-formatted certificates\n * that constitute a certificate chain, with the first in the array/chain\n * being the client's certificate.\n * getPrivateKey(conn, certificate)\n * The second parameter is an forge.pki X.509 certificate object that\n * is associated with the requested private key. The return value must\n * be a PEM-formatted private key.\n * getSignature(conn, bytes, callback)\n * This callback can be used instead of getPrivateKey if the private key\n * is not directly accessible in javascript or should not be. For\n * instance, a secure external web service could provide the signature\n * in exchange for appropriate credentials. The second parameter is a\n * string of bytes to be signed that are part of the TLS protocol. These\n * bytes are used to verify that the private key for the previously\n * provided client-side certificate is accessible to the client. The\n * callback is a function that takes 2 parameters, the TLS connection\n * and the RSA encrypted (signed) bytes as a string. This callback must\n * be called once the signature is ready.\n *\n * @param options the options for this connection:\n * server: true if the connection is server-side, false for client.\n * sessionId: a session ID to reuse, null for a new connection.\n * caStore: an array of certificates to trust.\n * sessionCache: a session cache to use.\n * cipherSuites: an optional array of cipher suites to use,\n * see tls.CipherSuites.\n * connected: function(conn) called when the first handshake completes.\n * virtualHost: the virtual server name to use in a TLS SNI extension.\n * verifyClient: true to require a client certificate in server mode,\n * 'optional' to request one, false not to (default: false).\n * verify: a handler used to custom verify certificates in the chain.\n * verifyOptions: an object with options for the certificate chain validation.\n * See documentation of pki.verifyCertificateChain for possible options.\n * verifyOptions.verify is ignored. If you wish to specify a verify handler\n * use the verify key.\n * getCertificate: an optional callback used to get a certificate or\n * a chain of certificates (as an array).\n * getPrivateKey: an optional callback used to get a private key.\n * getSignature: an optional callback used to get a signature.\n * tlsDataReady: function(conn) called when TLS protocol data has been\n * prepared and is ready to be used (typically sent over a socket\n * connection to its destination), read from conn.tlsData buffer.\n * dataReady: function(conn) called when application data has\n * been parsed from a TLS record and should be consumed by the\n * application, read from conn.data buffer.\n * closed: function(conn) called when the connection has been closed.\n * error: function(conn, error) called when there was an error.\n * deflate: function(inBytes) if provided, will deflate TLS records using\n * the deflate algorithm if the server supports it.\n * inflate: function(inBytes) if provided, will inflate TLS records using\n * the deflate algorithm if the server supports it.\n *\n * @return the new TLS connection.\n */\nforge.tls.createConnection = tls.createConnection;\n","/**\n * Password-based encryption functions.\n *\n * @author Dave Longley\n * @author Stefan Siegl <stesie@brokenpipe.de>\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * An EncryptedPrivateKeyInfo:\n *\n * EncryptedPrivateKeyInfo ::= SEQUENCE {\n * encryptionAlgorithm EncryptionAlgorithmIdentifier,\n * encryptedData EncryptedData }\n *\n * EncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * EncryptedData ::= OCTET STRING\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./md');\nrequire('./oids');\nrequire('./pbkdf2');\nrequire('./pem');\nrequire('./random');\nrequire('./rc2');\nrequire('./rsa');\nrequire('./util');\n\nif(typeof BigInteger === 'undefined') {\n var BigInteger = forge.jsbn.BigInteger;\n}\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n/* Password-based encryption implementation. */\nvar pki = forge.pki = forge.pki || {};\nmodule.exports = pki.pbe = forge.pbe = forge.pbe || {};\nvar oids = pki.oids;\n\n// validator for an EncryptedPrivateKeyInfo structure\n// Note: Currently only works w/algorithm params\nvar encryptedPrivateKeyValidator = {\n name: 'EncryptedPrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedPrivateKeyInfo.encryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encryptionOid'\n }, {\n name: 'AlgorithmIdentifier.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'encryptionParams'\n }]\n }, {\n // encryptedData\n name: 'EncryptedPrivateKeyInfo.encryptedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encryptedData'\n }]\n};\n\n// validator for a PBES2Algorithms structure\n// Note: Currently only works w/PBKDF2 + AES encryption schemes\nvar PBES2AlgorithmsValidator = {\n name: 'PBES2Algorithms',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.keyDerivationFunc',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.keyDerivationFunc.oid',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'kdfOid'\n }, {\n name: 'PBES2Algorithms.params',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.params.salt',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'kdfSalt'\n }, {\n name: 'PBES2Algorithms.params.iterationCount',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'kdfIterationCount'\n }, {\n name: 'PBES2Algorithms.params.keyLength',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n optional: true,\n capture: 'keyLength'\n }, {\n // prf\n name: 'PBES2Algorithms.params.prf',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n value: [{\n name: 'PBES2Algorithms.params.prf.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'prfOid'\n }]\n }]\n }]\n }, {\n name: 'PBES2Algorithms.encryptionScheme',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'PBES2Algorithms.encryptionScheme.oid',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encOid'\n }, {\n name: 'PBES2Algorithms.encryptionScheme.iv',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encIv'\n }]\n }]\n};\n\nvar pkcs12PbeParamsValidator = {\n name: 'pkcs-12PbeParams',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'pkcs-12PbeParams.salt',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'salt'\n }, {\n name: 'pkcs-12PbeParams.iterations',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'iterations'\n }]\n};\n\n/**\n * Encrypts a ASN.1 PrivateKeyInfo object, producing an EncryptedPrivateKeyInfo.\n *\n * PBES2Algorithms ALGORITHM-IDENTIFIER ::=\n * { {PBES2-params IDENTIFIED BY id-PBES2}, ...}\n *\n * id-PBES2 OBJECT IDENTIFIER ::= {pkcs-5 13}\n *\n * PBES2-params ::= SEQUENCE {\n * keyDerivationFunc AlgorithmIdentifier {{PBES2-KDFs}},\n * encryptionScheme AlgorithmIdentifier {{PBES2-Encs}}\n * }\n *\n * PBES2-KDFs ALGORITHM-IDENTIFIER ::=\n * { {PBKDF2-params IDENTIFIED BY id-PBKDF2}, ... }\n *\n * PBES2-Encs ALGORITHM-IDENTIFIER ::= { ... }\n *\n * PBKDF2-params ::= SEQUENCE {\n * salt CHOICE {\n * specified OCTET STRING,\n * otherSource AlgorithmIdentifier {{PBKDF2-SaltSources}}\n * },\n * iterationCount INTEGER (1..MAX),\n * keyLength INTEGER (1..MAX) OPTIONAL,\n * prf AlgorithmIdentifier {{PBKDF2-PRFs}} DEFAULT algid-hmacWithSHA1\n * }\n *\n * @param obj the ASN.1 PrivateKeyInfo object.\n * @param password the password to encrypt with.\n * @param options:\n * algorithm the encryption algorithm to use\n * ('aes128', 'aes192', 'aes256', '3des'), defaults to 'aes128'.\n * count the iteration count to use.\n * saltSize the salt size to use.\n * prfAlgorithm the PRF message digest algorithm to use\n * ('sha1', 'sha224', 'sha256', 'sha384', 'sha512')\n *\n * @return the ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptPrivateKeyInfo = function(obj, password, options) {\n // set default options\n options = options || {};\n options.saltSize = options.saltSize || 8;\n options.count = options.count || 2048;\n options.algorithm = options.algorithm || 'aes128';\n options.prfAlgorithm = options.prfAlgorithm || 'sha1';\n\n // generate PBE params\n var salt = forge.random.getBytesSync(options.saltSize);\n var count = options.count;\n var countBytes = asn1.integerToDer(count);\n var dkLen;\n var encryptionAlgorithm;\n var encryptedData;\n if(options.algorithm.indexOf('aes') === 0 || options.algorithm === 'des') {\n // do PBES2\n var ivLen, encOid, cipherFn;\n switch(options.algorithm) {\n case 'aes128':\n dkLen = 16;\n ivLen = 16;\n encOid = oids['aes128-CBC'];\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes192':\n dkLen = 24;\n ivLen = 16;\n encOid = oids['aes192-CBC'];\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes256':\n dkLen = 32;\n ivLen = 16;\n encOid = oids['aes256-CBC'];\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'des':\n dkLen = 8;\n ivLen = 8;\n encOid = oids['desCBC'];\n cipherFn = forge.des.createEncryptionCipher;\n break;\n default:\n var error = new Error('Cannot encrypt private key. Unknown encryption algorithm.');\n error.algorithm = options.algorithm;\n throw error;\n }\n\n // get PRF message digest\n var prfAlgorithm = 'hmacWith' + options.prfAlgorithm.toUpperCase();\n var md = prfAlgorithmToMessageDigest(prfAlgorithm);\n\n // encrypt private key using pbe SHA-1 and AES/DES\n var dk = forge.pkcs5.pbkdf2(password, salt, count, dkLen, md);\n var iv = forge.random.getBytesSync(ivLen);\n var cipher = cipherFn(dk);\n cipher.start(iv);\n cipher.update(asn1.toDer(obj));\n cipher.finish();\n encryptedData = cipher.output.getBytes();\n\n // get PBKDF2-params\n var params = createPbkdf2Params(salt, countBytes, dkLen, prfAlgorithm);\n\n encryptionAlgorithm = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oids['pkcs5PBES2']).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // keyDerivationFunc\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oids['pkcs5PBKDF2']).getBytes()),\n // PBKDF2-params\n params\n ]),\n // encryptionScheme\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(encOid).getBytes()),\n // iv\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, iv)\n ])\n ])\n ]);\n } else if(options.algorithm === '3des') {\n // Do PKCS12 PBE\n dkLen = 24;\n\n var saltBytes = new forge.util.ByteBuffer(salt);\n var dk = pki.pbe.generatePkcs12Key(password, saltBytes, 1, count, dkLen);\n var iv = pki.pbe.generatePkcs12Key(password, saltBytes, 2, count, dkLen);\n var cipher = forge.des.createEncryptionCipher(dk);\n cipher.start(iv);\n cipher.update(asn1.toDer(obj));\n cipher.finish();\n encryptedData = cipher.output.getBytes();\n\n encryptionAlgorithm = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oids['pbeWithSHAAnd3-KeyTripleDES-CBC']).getBytes()),\n // pkcs-12PbeParams\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // salt\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, salt),\n // iteration count\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n countBytes.getBytes())\n ])\n ]);\n } else {\n var error = new Error('Cannot encrypt private key. Unknown encryption algorithm.');\n error.algorithm = options.algorithm;\n throw error;\n }\n\n // EncryptedPrivateKeyInfo\n var rval = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // encryptionAlgorithm\n encryptionAlgorithm,\n // encryptedData\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, encryptedData)\n ]);\n return rval;\n};\n\n/**\n * Decrypts a ASN.1 PrivateKeyInfo object.\n *\n * @param obj the ASN.1 EncryptedPrivateKeyInfo object.\n * @param password the password to decrypt with.\n *\n * @return the ASN.1 PrivateKeyInfo on success, null on failure.\n */\npki.decryptPrivateKeyInfo = function(obj, password) {\n var rval = null;\n\n // get PBE params\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, encryptedPrivateKeyValidator, capture, errors)) {\n var error = new Error('Cannot read encrypted private key. ' +\n 'ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n error.errors = errors;\n throw error;\n }\n\n // get cipher\n var oid = asn1.derToOid(capture.encryptionOid);\n var cipher = pki.pbe.getCipher(oid, capture.encryptionParams, password);\n\n // get encrypted data\n var encrypted = forge.util.createBuffer(capture.encryptedData);\n\n cipher.update(encrypted);\n if(cipher.finish()) {\n rval = asn1.fromDer(cipher.output);\n }\n\n return rval;\n};\n\n/**\n * Converts a EncryptedPrivateKeyInfo to PEM format.\n *\n * @param epki the EncryptedPrivateKeyInfo.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted encrypted private key.\n */\npki.encryptedPrivateKeyToPem = function(epki, maxline) {\n // convert to DER, then PEM-encode\n var msg = {\n type: 'ENCRYPTED PRIVATE KEY',\n body: asn1.toDer(epki).getBytes()\n };\n return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts a PEM-encoded EncryptedPrivateKeyInfo to ASN.1 format. Decryption\n * is not performed.\n *\n * @param pem the EncryptedPrivateKeyInfo in PEM-format.\n *\n * @return the ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptedPrivateKeyFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'ENCRYPTED PRIVATE KEY') {\n var error = new Error('Could not convert encrypted private key from PEM; ' +\n 'PEM header type is \"ENCRYPTED PRIVATE KEY\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert encrypted private key from PEM; ' +\n 'PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n return asn1.fromDer(msg.body);\n};\n\n/**\n * Encrypts an RSA private key. By default, the key will be wrapped in\n * a PrivateKeyInfo and encrypted to produce a PKCS#8 EncryptedPrivateKeyInfo.\n * This is the standard, preferred way to encrypt a private key.\n *\n * To produce a non-standard PEM-encrypted private key that uses encapsulated\n * headers to indicate the encryption algorithm (old-style non-PKCS#8 OpenSSL\n * private key encryption), set the 'legacy' option to true. Note: Using this\n * option will cause the iteration count to be forced to 1.\n *\n * Note: The 'des' algorithm is supported, but it is not considered to be\n * secure because it only uses a single 56-bit key. If possible, it is highly\n * recommended that a different algorithm be used.\n *\n * @param rsaKey the RSA key to encrypt.\n * @param password the password to use.\n * @param options:\n * algorithm: the encryption algorithm to use\n * ('aes128', 'aes192', 'aes256', '3des', 'des').\n * count: the iteration count to use.\n * saltSize: the salt size to use.\n * legacy: output an old non-PKCS#8 PEM-encrypted+encapsulated\n * headers (DEK-Info) private key.\n *\n * @return the PEM-encoded ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptRsaPrivateKey = function(rsaKey, password, options) {\n // standard PKCS#8\n options = options || {};\n if(!options.legacy) {\n // encrypt PrivateKeyInfo\n var rval = pki.wrapRsaPrivateKey(pki.privateKeyToAsn1(rsaKey));\n rval = pki.encryptPrivateKeyInfo(rval, password, options);\n return pki.encryptedPrivateKeyToPem(rval);\n }\n\n // legacy non-PKCS#8\n var algorithm;\n var iv;\n var dkLen;\n var cipherFn;\n switch(options.algorithm) {\n case 'aes128':\n algorithm = 'AES-128-CBC';\n dkLen = 16;\n iv = forge.random.getBytesSync(16);\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes192':\n algorithm = 'AES-192-CBC';\n dkLen = 24;\n iv = forge.random.getBytesSync(16);\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case 'aes256':\n algorithm = 'AES-256-CBC';\n dkLen = 32;\n iv = forge.random.getBytesSync(16);\n cipherFn = forge.aes.createEncryptionCipher;\n break;\n case '3des':\n algorithm = 'DES-EDE3-CBC';\n dkLen = 24;\n iv = forge.random.getBytesSync(8);\n cipherFn = forge.des.createEncryptionCipher;\n break;\n case 'des':\n algorithm = 'DES-CBC';\n dkLen = 8;\n iv = forge.random.getBytesSync(8);\n cipherFn = forge.des.createEncryptionCipher;\n break;\n default:\n var error = new Error('Could not encrypt RSA private key; unsupported ' +\n 'encryption algorithm \"' + options.algorithm + '\".');\n error.algorithm = options.algorithm;\n throw error;\n }\n\n // encrypt private key using OpenSSL legacy key derivation\n var dk = forge.pbe.opensslDeriveBytes(password, iv.substr(0, 8), dkLen);\n var cipher = cipherFn(dk);\n cipher.start(iv);\n cipher.update(asn1.toDer(pki.privateKeyToAsn1(rsaKey)));\n cipher.finish();\n\n var msg = {\n type: 'RSA PRIVATE KEY',\n procType: {\n version: '4',\n type: 'ENCRYPTED'\n },\n dekInfo: {\n algorithm: algorithm,\n parameters: forge.util.bytesToHex(iv).toUpperCase()\n },\n body: cipher.output.getBytes()\n };\n return forge.pem.encode(msg);\n};\n\n/**\n * Decrypts an RSA private key.\n *\n * @param pem the PEM-formatted EncryptedPrivateKeyInfo to decrypt.\n * @param password the password to use.\n *\n * @return the RSA key on success, null on failure.\n */\npki.decryptRsaPrivateKey = function(pem, password) {\n var rval = null;\n\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'ENCRYPTED PRIVATE KEY' &&\n msg.type !== 'PRIVATE KEY' &&\n msg.type !== 'RSA PRIVATE KEY') {\n var error = new Error('Could not convert private key from PEM; PEM header type ' +\n 'is not \"ENCRYPTED PRIVATE KEY\", \"PRIVATE KEY\", or \"RSA PRIVATE KEY\".');\n error.headerType = error;\n throw error;\n }\n\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n var dkLen;\n var cipherFn;\n switch(msg.dekInfo.algorithm) {\n case 'DES-CBC':\n dkLen = 8;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n case 'DES-EDE3-CBC':\n dkLen = 24;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n case 'AES-128-CBC':\n dkLen = 16;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'AES-192-CBC':\n dkLen = 24;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'AES-256-CBC':\n dkLen = 32;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'RC2-40-CBC':\n dkLen = 5;\n cipherFn = function(key) {\n return forge.rc2.createDecryptionCipher(key, 40);\n };\n break;\n case 'RC2-64-CBC':\n dkLen = 8;\n cipherFn = function(key) {\n return forge.rc2.createDecryptionCipher(key, 64);\n };\n break;\n case 'RC2-128-CBC':\n dkLen = 16;\n cipherFn = function(key) {\n return forge.rc2.createDecryptionCipher(key, 128);\n };\n break;\n default:\n var error = new Error('Could not decrypt private key; unsupported ' +\n 'encryption algorithm \"' + msg.dekInfo.algorithm + '\".');\n error.algorithm = msg.dekInfo.algorithm;\n throw error;\n }\n\n // use OpenSSL legacy key derivation\n var iv = forge.util.hexToBytes(msg.dekInfo.parameters);\n var dk = forge.pbe.opensslDeriveBytes(password, iv.substr(0, 8), dkLen);\n var cipher = cipherFn(dk);\n cipher.start(iv);\n cipher.update(forge.util.createBuffer(msg.body));\n if(cipher.finish()) {\n rval = cipher.output.getBytes();\n } else {\n return rval;\n }\n } else {\n rval = msg.body;\n }\n\n if(msg.type === 'ENCRYPTED PRIVATE KEY') {\n rval = pki.decryptPrivateKeyInfo(asn1.fromDer(rval), password);\n } else {\n // decryption already performed above\n rval = asn1.fromDer(rval);\n }\n\n if(rval !== null) {\n rval = pki.privateKeyFromAsn1(rval);\n }\n\n return rval;\n};\n\n/**\n * Derives a PKCS#12 key.\n *\n * @param password the password to derive the key material from, null or\n * undefined for none.\n * @param salt the salt, as a ByteBuffer, to use.\n * @param id the PKCS#12 ID byte (1 = key material, 2 = IV, 3 = MAC).\n * @param iter the iteration count.\n * @param n the number of bytes to derive from the password.\n * @param md the message digest to use, defaults to SHA-1.\n *\n * @return a ByteBuffer with the bytes derived from the password.\n */\npki.pbe.generatePkcs12Key = function(password, salt, id, iter, n, md) {\n var j, l;\n\n if(typeof md === 'undefined' || md === null) {\n if(!('sha1' in forge.md)) {\n throw new Error('\"sha1\" hash algorithm unavailable.');\n }\n md = forge.md.sha1.create();\n }\n\n var u = md.digestLength;\n var v = md.blockLength;\n var result = new forge.util.ByteBuffer();\n\n /* Convert password to Unicode byte buffer + trailing 0-byte. */\n var passBuf = new forge.util.ByteBuffer();\n if(password !== null && password !== undefined) {\n for(l = 0; l < password.length; l++) {\n passBuf.putInt16(password.charCodeAt(l));\n }\n passBuf.putInt16(0);\n }\n\n /* Length of salt and password in BYTES. */\n var p = passBuf.length();\n var s = salt.length();\n\n /* 1. Construct a string, D (the \"diversifier\"), by concatenating\n v copies of ID. */\n var D = new forge.util.ByteBuffer();\n D.fillWithByte(id, v);\n\n /* 2. Concatenate copies of the salt together to create a string S of length\n v * ceil(s / v) bytes (the final copy of the salt may be trunacted\n to create S).\n Note that if the salt is the empty string, then so is S. */\n var Slen = v * Math.ceil(s / v);\n var S = new forge.util.ByteBuffer();\n for(l = 0; l < Slen; l++) {\n S.putByte(salt.at(l % s));\n }\n\n /* 3. Concatenate copies of the password together to create a string P of\n length v * ceil(p / v) bytes (the final copy of the password may be\n truncated to create P).\n Note that if the password is the empty string, then so is P. */\n var Plen = v * Math.ceil(p / v);\n var P = new forge.util.ByteBuffer();\n for(l = 0; l < Plen; l++) {\n P.putByte(passBuf.at(l % p));\n }\n\n /* 4. Set I=S||P to be the concatenation of S and P. */\n var I = S;\n I.putBuffer(P);\n\n /* 5. Set c=ceil(n / u). */\n var c = Math.ceil(n / u);\n\n /* 6. For i=1, 2, ..., c, do the following: */\n for(var i = 1; i <= c; i++) {\n /* a) Set Ai=H^r(D||I). (l.e. the rth hash of D||I, H(H(H(...H(D||I)))) */\n var buf = new forge.util.ByteBuffer();\n buf.putBytes(D.bytes());\n buf.putBytes(I.bytes());\n for(var round = 0; round < iter; round++) {\n md.start();\n md.update(buf.getBytes());\n buf = md.digest();\n }\n\n /* b) Concatenate copies of Ai to create a string B of length v bytes (the\n final copy of Ai may be truncated to create B). */\n var B = new forge.util.ByteBuffer();\n for(l = 0; l < v; l++) {\n B.putByte(buf.at(l % u));\n }\n\n /* c) Treating I as a concatenation I0, I1, ..., Ik-1 of v-byte blocks,\n where k=ceil(s / v) + ceil(p / v), modify I by setting\n Ij=(Ij+B+1) mod 2v for each j. */\n var k = Math.ceil(s / v) + Math.ceil(p / v);\n var Inew = new forge.util.ByteBuffer();\n for(j = 0; j < k; j++) {\n var chunk = new forge.util.ByteBuffer(I.getBytes(v));\n var x = 0x1ff;\n for(l = B.length() - 1; l >= 0; l--) {\n x = x >> 8;\n x += B.at(l) + chunk.at(l);\n chunk.setAt(l, x & 0xff);\n }\n Inew.putBuffer(chunk);\n }\n I = Inew;\n\n /* Add Ai to A. */\n result.putBuffer(buf);\n }\n\n result.truncate(result.length() - n);\n return result;\n};\n\n/**\n * Get new Forge cipher object instance.\n *\n * @param oid the OID (in string notation).\n * @param params the ASN.1 params object.\n * @param password the password to decrypt with.\n *\n * @return new cipher object instance.\n */\npki.pbe.getCipher = function(oid, params, password) {\n switch(oid) {\n case pki.oids['pkcs5PBES2']:\n return pki.pbe.getCipherForPBES2(oid, params, password);\n\n case pki.oids['pbeWithSHAAnd3-KeyTripleDES-CBC']:\n case pki.oids['pbewithSHAAnd40BitRC2-CBC']:\n return pki.pbe.getCipherForPKCS12PBE(oid, params, password);\n\n default:\n var error = new Error('Cannot read encrypted PBE data block. Unsupported OID.');\n error.oid = oid;\n error.supportedOids = [\n 'pkcs5PBES2',\n 'pbeWithSHAAnd3-KeyTripleDES-CBC',\n 'pbewithSHAAnd40BitRC2-CBC'\n ];\n throw error;\n }\n};\n\n/**\n * Get new Forge cipher object instance according to PBES2 params block.\n *\n * The returned cipher instance is already started using the IV\n * from PBES2 parameter block.\n *\n * @param oid the PKCS#5 PBKDF2 OID (in string notation).\n * @param params the ASN.1 PBES2-params object.\n * @param password the password to decrypt with.\n *\n * @return new cipher object instance.\n */\npki.pbe.getCipherForPBES2 = function(oid, params, password) {\n // get PBE params\n var capture = {};\n var errors = [];\n if(!asn1.validate(params, PBES2AlgorithmsValidator, capture, errors)) {\n var error = new Error('Cannot read password-based-encryption algorithm ' +\n 'parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n error.errors = errors;\n throw error;\n }\n\n // check oids\n oid = asn1.derToOid(capture.kdfOid);\n if(oid !== pki.oids['pkcs5PBKDF2']) {\n var error = new Error('Cannot read encrypted private key. ' +\n 'Unsupported key derivation function OID.');\n error.oid = oid;\n error.supportedOids = ['pkcs5PBKDF2'];\n throw error;\n }\n oid = asn1.derToOid(capture.encOid);\n if(oid !== pki.oids['aes128-CBC'] &&\n oid !== pki.oids['aes192-CBC'] &&\n oid !== pki.oids['aes256-CBC'] &&\n oid !== pki.oids['des-EDE3-CBC'] &&\n oid !== pki.oids['desCBC']) {\n var error = new Error('Cannot read encrypted private key. ' +\n 'Unsupported encryption scheme OID.');\n error.oid = oid;\n error.supportedOids = [\n 'aes128-CBC', 'aes192-CBC', 'aes256-CBC', 'des-EDE3-CBC', 'desCBC'];\n throw error;\n }\n\n // set PBE params\n var salt = capture.kdfSalt;\n var count = forge.util.createBuffer(capture.kdfIterationCount);\n count = count.getInt(count.length() << 3);\n var dkLen;\n var cipherFn;\n switch(pki.oids[oid]) {\n case 'aes128-CBC':\n dkLen = 16;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'aes192-CBC':\n dkLen = 24;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'aes256-CBC':\n dkLen = 32;\n cipherFn = forge.aes.createDecryptionCipher;\n break;\n case 'des-EDE3-CBC':\n dkLen = 24;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n case 'desCBC':\n dkLen = 8;\n cipherFn = forge.des.createDecryptionCipher;\n break;\n }\n\n // get PRF message digest\n var md = prfOidToMessageDigest(capture.prfOid);\n\n // decrypt private key using pbe with chosen PRF and AES/DES\n var dk = forge.pkcs5.pbkdf2(password, salt, count, dkLen, md);\n var iv = capture.encIv;\n var cipher = cipherFn(dk);\n cipher.start(iv);\n\n return cipher;\n};\n\n/**\n * Get new Forge cipher object instance for PKCS#12 PBE.\n *\n * The returned cipher instance is already started using the key & IV\n * derived from the provided password and PKCS#12 PBE salt.\n *\n * @param oid The PKCS#12 PBE OID (in string notation).\n * @param params The ASN.1 PKCS#12 PBE-params object.\n * @param password The password to decrypt with.\n *\n * @return the new cipher object instance.\n */\npki.pbe.getCipherForPKCS12PBE = function(oid, params, password) {\n // get PBE params\n var capture = {};\n var errors = [];\n if(!asn1.validate(params, pkcs12PbeParamsValidator, capture, errors)) {\n var error = new Error('Cannot read password-based-encryption algorithm ' +\n 'parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n error.errors = errors;\n throw error;\n }\n\n var salt = forge.util.createBuffer(capture.salt);\n var count = forge.util.createBuffer(capture.iterations);\n count = count.getInt(count.length() << 3);\n\n var dkLen, dIvLen, cipherFn;\n switch(oid) {\n case pki.oids['pbeWithSHAAnd3-KeyTripleDES-CBC']:\n dkLen = 24;\n dIvLen = 8;\n cipherFn = forge.des.startDecrypting;\n break;\n\n case pki.oids['pbewithSHAAnd40BitRC2-CBC']:\n dkLen = 5;\n dIvLen = 8;\n cipherFn = function(key, iv) {\n var cipher = forge.rc2.createDecryptionCipher(key, 40);\n cipher.start(iv, null);\n return cipher;\n };\n break;\n\n default:\n var error = new Error('Cannot read PKCS #12 PBE data block. Unsupported OID.');\n error.oid = oid;\n throw error;\n }\n\n // get PRF message digest\n var md = prfOidToMessageDigest(capture.prfOid);\n var key = pki.pbe.generatePkcs12Key(password, salt, 1, count, dkLen, md);\n md.start();\n var iv = pki.pbe.generatePkcs12Key(password, salt, 2, count, dIvLen, md);\n\n return cipherFn(key, iv);\n};\n\n/**\n * OpenSSL's legacy key derivation function.\n *\n * See: http://www.openssl.org/docs/crypto/EVP_BytesToKey.html\n *\n * @param password the password to derive the key from.\n * @param salt the salt to use, null for none.\n * @param dkLen the number of bytes needed for the derived key.\n * @param [options] the options to use:\n * [md] an optional message digest object to use.\n */\npki.pbe.opensslDeriveBytes = function(password, salt, dkLen, md) {\n if(typeof md === 'undefined' || md === null) {\n if(!('md5' in forge.md)) {\n throw new Error('\"md5\" hash algorithm unavailable.');\n }\n md = forge.md.md5.create();\n }\n if(salt === null) {\n salt = '';\n }\n var digests = [hash(md, password + salt)];\n for(var length = 16, i = 1; length < dkLen; ++i, length += 16) {\n digests.push(hash(md, digests[i - 1] + password + salt));\n }\n return digests.join('').substr(0, dkLen);\n};\n\nfunction hash(md, bytes) {\n return md.start().update(bytes).digest().getBytes();\n}\n\nfunction prfOidToMessageDigest(prfOid) {\n // get PRF algorithm, default to SHA-1\n var prfAlgorithm;\n if(!prfOid) {\n prfAlgorithm = 'hmacWithSHA1';\n } else {\n prfAlgorithm = pki.oids[asn1.derToOid(prfOid)];\n if(!prfAlgorithm) {\n var error = new Error('Unsupported PRF OID.');\n error.oid = prfOid;\n error.supported = [\n 'hmacWithSHA1', 'hmacWithSHA224', 'hmacWithSHA256', 'hmacWithSHA384',\n 'hmacWithSHA512'];\n throw error;\n }\n }\n return prfAlgorithmToMessageDigest(prfAlgorithm);\n}\n\nfunction prfAlgorithmToMessageDigest(prfAlgorithm) {\n var factory = forge.md;\n switch(prfAlgorithm) {\n case 'hmacWithSHA224':\n factory = forge.md.sha512;\n case 'hmacWithSHA1':\n case 'hmacWithSHA256':\n case 'hmacWithSHA384':\n case 'hmacWithSHA512':\n prfAlgorithm = prfAlgorithm.substr(8).toLowerCase();\n break;\n default:\n var error = new Error('Unsupported PRF algorithm.');\n error.algorithm = prfAlgorithm;\n error.supported = [\n 'hmacWithSHA1', 'hmacWithSHA224', 'hmacWithSHA256', 'hmacWithSHA384',\n 'hmacWithSHA512'];\n throw error;\n }\n if(!factory || !(prfAlgorithm in factory)) {\n throw new Error('Unknown hash algorithm: ' + prfAlgorithm);\n }\n return factory[prfAlgorithm].create();\n}\n\nfunction createPbkdf2Params(salt, countBytes, dkLen, prfAlgorithm) {\n var params = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // salt\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, salt),\n // iteration count\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n countBytes.getBytes())\n ]);\n // when PRF algorithm is not SHA-1 default, add key length and PRF algorithm\n if(prfAlgorithm !== 'hmacWithSHA1') {\n params.value.push(\n // key length\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(dkLen.toString(16))),\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(pki.oids[prfAlgorithm]).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n }\n return params;\n}\n","/**\n * Secure Hash Algorithm with 256-bit digest (SHA-256) implementation.\n *\n * See FIPS 180-2 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha256 = module.exports = forge.sha256 = forge.sha256 || {};\nforge.md.sha256 = forge.md.algorithms.sha256 = sha256;\n\n/**\n * Creates a SHA-256 message digest object.\n *\n * @return a message digest object.\n */\nsha256.create = function() {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n // SHA-256 state contains eight 32-bit integers\n var _state = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for word storage\n var _w = new Array(64);\n\n // message digest object\n var md = {\n algorithm: 'sha256',\n blockLength: 64,\n digestLength: 32,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 8\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength64 for backwards-compatibility)\n md.fullMessageLength = md.messageLength64 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _state = {\n h0: 0x6A09E667,\n h1: 0xBB67AE85,\n h2: 0x3C6EF372,\n h3: 0xA54FF53A,\n h4: 0x510E527F,\n h5: 0x9B05688C,\n h6: 0x1F83D9AB,\n h7: 0x5BE0CD19\n };\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = ((len[1] / 0x100000000) >>> 0);\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_state, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate SHA-256 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 448 mod 512. In other words,\n the data to be digested must be a multiple of 512 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 8 bytes (64\n bits), that means that the last segment of the data must have 56 bytes\n (448 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 448 mod 512 because\n 512 - 128 = 448.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 448 mod 512, then 512 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in big-endian order; since length\n // is stored in bytes we multiply by 8 and add carry from next int\n var next, carry;\n var bits = md.fullMessageLength[0] * 8;\n for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n next = md.fullMessageLength[i + 1] * 8;\n carry = (next / 0x100000000) >>> 0;\n bits += carry;\n finalBlock.putInt32(bits >>> 0);\n bits = next >>> 0;\n }\n finalBlock.putInt32(bits);\n\n var s2 = {\n h0: _state.h0,\n h1: _state.h1,\n h2: _state.h2,\n h3: _state.h3,\n h4: _state.h4,\n h5: _state.h5,\n h6: _state.h6,\n h7: _state.h7\n };\n _update(s2, _w, finalBlock);\n var rval = forge.util.createBuffer();\n rval.putInt32(s2.h0);\n rval.putInt32(s2.h1);\n rval.putInt32(s2.h2);\n rval.putInt32(s2.h3);\n rval.putInt32(s2.h4);\n rval.putInt32(s2.h5);\n rval.putInt32(s2.h6);\n rval.putInt32(s2.h7);\n return rval;\n };\n\n return md;\n};\n\n// sha-256 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n// table of constants\nvar _k = null;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 64);\n\n // create K table for SHA-256\n _k = [\n 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2];\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates a SHA-256 state with the given byte buffer.\n *\n * @param s the SHA-256 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (64 byte) chunks\n var t1, t2, s0, s1, ch, maj, i, a, b, c, d, e, f, g, h;\n var len = bytes.length();\n while(len >= 64) {\n // the w array will be populated with sixteen 32-bit big-endian words\n // and then extended into 64 32-bit words according to SHA-256\n for(i = 0; i < 16; ++i) {\n w[i] = bytes.getInt32();\n }\n for(; i < 64; ++i) {\n // XOR word 2 words ago rot right 17, rot right 19, shft right 10\n t1 = w[i - 2];\n t1 =\n ((t1 >>> 17) | (t1 << 15)) ^\n ((t1 >>> 19) | (t1 << 13)) ^\n (t1 >>> 10);\n // XOR word 15 words ago rot right 7, rot right 18, shft right 3\n t2 = w[i - 15];\n t2 =\n ((t2 >>> 7) | (t2 << 25)) ^\n ((t2 >>> 18) | (t2 << 14)) ^\n (t2 >>> 3);\n // sum(t1, word 7 ago, t2, word 16 ago) modulo 2^32\n w[i] = (t1 + w[i - 7] + t2 + w[i - 16]) | 0;\n }\n\n // initialize hash value for this chunk\n a = s.h0;\n b = s.h1;\n c = s.h2;\n d = s.h3;\n e = s.h4;\n f = s.h5;\n g = s.h6;\n h = s.h7;\n\n // round function\n for(i = 0; i < 64; ++i) {\n // Sum1(e)\n s1 =\n ((e >>> 6) | (e << 26)) ^\n ((e >>> 11) | (e << 21)) ^\n ((e >>> 25) | (e << 7));\n // Ch(e, f, g) (optimized the same way as SHA-1)\n ch = g ^ (e & (f ^ g));\n // Sum0(a)\n s0 =\n ((a >>> 2) | (a << 30)) ^\n ((a >>> 13) | (a << 19)) ^\n ((a >>> 22) | (a << 10));\n // Maj(a, b, c) (optimized the same way as SHA-1)\n maj = (a & b) | (c & (a ^ b));\n\n // main algorithm\n t1 = h + s1 + ch + _k[i] + w[i];\n t2 = s0 + maj;\n h = g;\n g = f;\n f = e;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n // can't truncate with `| 0`\n e = (d + t1) >>> 0;\n d = c;\n c = b;\n b = a;\n // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n // can't truncate with `| 0`\n a = (t1 + t2) >>> 0;\n }\n\n // update hash state\n s.h0 = (s.h0 + a) | 0;\n s.h1 = (s.h1 + b) | 0;\n s.h2 = (s.h2 + c) | 0;\n s.h3 = (s.h3 + d) | 0;\n s.h4 = (s.h4 + e) | 0;\n s.h5 = (s.h5 + f) | 0;\n s.h6 = (s.h6 + g) | 0;\n s.h7 = (s.h7 + h) | 0;\n len -= 64;\n }\n}\n","/**\n * A javascript implementation of a cryptographically-secure\n * Pseudo Random Number Generator (PRNG). The Fortuna algorithm is followed\n * here though the use of SHA-256 is not enforced; when generating an\n * a PRNG context, the hashing algorithm and block cipher used for\n * the generator are specified via a plugin.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nvar _crypto = null;\nif(forge.util.isNodejs && !forge.options.usePureJavaScript &&\n !process.versions['node-webkit']) {\n _crypto = require('crypto');\n}\n\n/* PRNG API */\nvar prng = module.exports = forge.prng = forge.prng || {};\n\n/**\n * Creates a new PRNG context.\n *\n * A PRNG plugin must be passed in that will provide:\n *\n * 1. A function that initializes the key and seed of a PRNG context. It\n * will be given a 16 byte key and a 16 byte seed. Any key expansion\n * or transformation of the seed from a byte string into an array of\n * integers (or similar) should be performed.\n * 2. The cryptographic function used by the generator. It takes a key and\n * a seed.\n * 3. A seed increment function. It takes the seed and returns seed + 1.\n * 4. An api to create a message digest.\n *\n * For an example, see random.js.\n *\n * @param plugin the PRNG plugin to use.\n */\nprng.create = function(plugin) {\n var ctx = {\n plugin: plugin,\n key: null,\n seed: null,\n time: null,\n // number of reseeds so far\n reseeds: 0,\n // amount of data generated so far\n generated: 0,\n // no initial key bytes\n keyBytes: ''\n };\n\n // create 32 entropy pools (each is a message digest)\n var md = plugin.md;\n var pools = new Array(32);\n for(var i = 0; i < 32; ++i) {\n pools[i] = md.create();\n }\n ctx.pools = pools;\n\n // entropy pools are written to cyclically, starting at index 0\n ctx.pool = 0;\n\n /**\n * Generates random bytes. The bytes may be generated synchronously or\n * asynchronously. Web workers must use the asynchronous interface or\n * else the behavior is undefined.\n *\n * @param count the number of random bytes to generate.\n * @param [callback(err, bytes)] called once the operation completes.\n *\n * @return count random bytes as a string.\n */\n ctx.generate = function(count, callback) {\n // do synchronously\n if(!callback) {\n return ctx.generateSync(count);\n }\n\n // simple generator using counter-based CBC\n var cipher = ctx.plugin.cipher;\n var increment = ctx.plugin.increment;\n var formatKey = ctx.plugin.formatKey;\n var formatSeed = ctx.plugin.formatSeed;\n var b = forge.util.createBuffer();\n\n // paranoid deviation from Fortuna:\n // reset key for every request to protect previously\n // generated random bytes should the key be discovered;\n // there is no 100ms based reseeding because of this\n // forced reseed for every `generate` call\n ctx.key = null;\n\n generate();\n\n function generate(err) {\n if(err) {\n return callback(err);\n }\n\n // sufficient bytes generated\n if(b.length() >= count) {\n return callback(null, b.getBytes(count));\n }\n\n // if amount of data generated is greater than 1 MiB, trigger reseed\n if(ctx.generated > 0xfffff) {\n ctx.key = null;\n }\n\n if(ctx.key === null) {\n // prevent stack overflow\n return forge.util.nextTick(function() {\n _reseed(generate);\n });\n }\n\n // generate the random bytes\n var bytes = cipher(ctx.key, ctx.seed);\n ctx.generated += bytes.length;\n b.putBytes(bytes);\n\n // generate bytes for a new key and seed\n ctx.key = formatKey(cipher(ctx.key, increment(ctx.seed)));\n ctx.seed = formatSeed(cipher(ctx.key, ctx.seed));\n\n forge.util.setImmediate(generate);\n }\n };\n\n /**\n * Generates random bytes synchronously.\n *\n * @param count the number of random bytes to generate.\n *\n * @return count random bytes as a string.\n */\n ctx.generateSync = function(count) {\n // simple generator using counter-based CBC\n var cipher = ctx.plugin.cipher;\n var increment = ctx.plugin.increment;\n var formatKey = ctx.plugin.formatKey;\n var formatSeed = ctx.plugin.formatSeed;\n\n // paranoid deviation from Fortuna:\n // reset key for every request to protect previously\n // generated random bytes should the key be discovered;\n // there is no 100ms based reseeding because of this\n // forced reseed for every `generateSync` call\n ctx.key = null;\n\n var b = forge.util.createBuffer();\n while(b.length() < count) {\n // if amount of data generated is greater than 1 MiB, trigger reseed\n if(ctx.generated > 0xfffff) {\n ctx.key = null;\n }\n\n if(ctx.key === null) {\n _reseedSync();\n }\n\n // generate the random bytes\n var bytes = cipher(ctx.key, ctx.seed);\n ctx.generated += bytes.length;\n b.putBytes(bytes);\n\n // generate bytes for a new key and seed\n ctx.key = formatKey(cipher(ctx.key, increment(ctx.seed)));\n ctx.seed = formatSeed(cipher(ctx.key, ctx.seed));\n }\n\n return b.getBytes(count);\n };\n\n /**\n * Private function that asynchronously reseeds a generator.\n *\n * @param callback(err) called once the operation completes.\n */\n function _reseed(callback) {\n if(ctx.pools[0].messageLength >= 32) {\n _seed();\n return callback();\n }\n // not enough seed data...\n var needed = (32 - ctx.pools[0].messageLength) << 5;\n ctx.seedFile(needed, function(err, bytes) {\n if(err) {\n return callback(err);\n }\n ctx.collect(bytes);\n _seed();\n callback();\n });\n }\n\n /**\n * Private function that synchronously reseeds a generator.\n */\n function _reseedSync() {\n if(ctx.pools[0].messageLength >= 32) {\n return _seed();\n }\n // not enough seed data...\n var needed = (32 - ctx.pools[0].messageLength) << 5;\n ctx.collect(ctx.seedFileSync(needed));\n _seed();\n }\n\n /**\n * Private function that seeds a generator once enough bytes are available.\n */\n function _seed() {\n // update reseed count\n ctx.reseeds = (ctx.reseeds === 0xffffffff) ? 0 : ctx.reseeds + 1;\n\n // goal is to update `key` via:\n // key = hash(key + s)\n // where 's' is all collected entropy from selected pools, then...\n\n // create a plugin-based message digest\n var md = ctx.plugin.md.create();\n\n // consume current key bytes\n md.update(ctx.keyBytes);\n\n // digest the entropy of pools whose index k meet the\n // condition 'n mod 2^k == 0' where n is the number of reseeds\n var _2powK = 1;\n for(var k = 0; k < 32; ++k) {\n if(ctx.reseeds % _2powK === 0) {\n md.update(ctx.pools[k].digest().getBytes());\n ctx.pools[k].start();\n }\n _2powK = _2powK << 1;\n }\n\n // get digest for key bytes\n ctx.keyBytes = md.digest().getBytes();\n\n // paranoid deviation from Fortuna:\n // update `seed` via `seed = hash(key)`\n // instead of initializing to zero once and only\n // ever incrementing it\n md.start();\n md.update(ctx.keyBytes);\n var seedBytes = md.digest().getBytes();\n\n // update state\n ctx.key = ctx.plugin.formatKey(ctx.keyBytes);\n ctx.seed = ctx.plugin.formatSeed(seedBytes);\n ctx.generated = 0;\n }\n\n /**\n * The built-in default seedFile. This seedFile is used when entropy\n * is needed immediately.\n *\n * @param needed the number of bytes that are needed.\n *\n * @return the random bytes.\n */\n function defaultSeedFile(needed) {\n // use window.crypto.getRandomValues strong source of entropy if available\n var getRandomValues = null;\n var globalScope = forge.util.globalScope;\n var _crypto = globalScope.crypto || globalScope.msCrypto;\n if(_crypto && _crypto.getRandomValues) {\n getRandomValues = function(arr) {\n return _crypto.getRandomValues(arr);\n };\n }\n\n var b = forge.util.createBuffer();\n if(getRandomValues) {\n while(b.length() < needed) {\n // max byte length is 65536 before QuotaExceededError is thrown\n // http://www.w3.org/TR/WebCryptoAPI/#RandomSource-method-getRandomValues\n var count = Math.max(1, Math.min(needed - b.length(), 65536) / 4);\n var entropy = new Uint32Array(Math.floor(count));\n try {\n getRandomValues(entropy);\n for(var i = 0; i < entropy.length; ++i) {\n b.putInt32(entropy[i]);\n }\n } catch(e) {\n /* only ignore QuotaExceededError */\n if(!(typeof QuotaExceededError !== 'undefined' &&\n e instanceof QuotaExceededError)) {\n throw e;\n }\n }\n }\n }\n\n // be sad and add some weak random data\n if(b.length() < needed) {\n /* Draws from Park-Miller \"minimal standard\" 31 bit PRNG,\n implemented with David G. Carta's optimization: with 32 bit math\n and without division (Public Domain). */\n var hi, lo, next;\n var seed = Math.floor(Math.random() * 0x010000);\n while(b.length() < needed) {\n lo = 16807 * (seed & 0xFFFF);\n hi = 16807 * (seed >> 16);\n lo += (hi & 0x7FFF) << 16;\n lo += hi >> 15;\n lo = (lo & 0x7FFFFFFF) + (lo >> 31);\n seed = lo & 0xFFFFFFFF;\n\n // consume lower 3 bytes of seed\n for(var i = 0; i < 3; ++i) {\n // throw in more pseudo random\n next = seed >>> (i << 3);\n next ^= Math.floor(Math.random() * 0x0100);\n b.putByte(String.fromCharCode(next & 0xFF));\n }\n }\n }\n\n return b.getBytes(needed);\n }\n // initialize seed file APIs\n if(_crypto) {\n // use nodejs async API\n ctx.seedFile = function(needed, callback) {\n _crypto.randomBytes(needed, function(err, bytes) {\n if(err) {\n return callback(err);\n }\n callback(null, bytes.toString());\n });\n };\n // use nodejs sync API\n ctx.seedFileSync = function(needed) {\n return _crypto.randomBytes(needed).toString();\n };\n } else {\n ctx.seedFile = function(needed, callback) {\n try {\n callback(null, defaultSeedFile(needed));\n } catch(e) {\n callback(e);\n }\n };\n ctx.seedFileSync = defaultSeedFile;\n }\n\n /**\n * Adds entropy to a prng ctx's accumulator.\n *\n * @param bytes the bytes of entropy as a string.\n */\n ctx.collect = function(bytes) {\n // iterate over pools distributing entropy cyclically\n var count = bytes.length;\n for(var i = 0; i < count; ++i) {\n ctx.pools[ctx.pool].update(bytes.substr(i, 1));\n ctx.pool = (ctx.pool === 31) ? 0 : ctx.pool + 1;\n }\n };\n\n /**\n * Collects an integer of n bits.\n *\n * @param i the integer entropy.\n * @param n the number of bits in the integer.\n */\n ctx.collectInt = function(i, n) {\n var bytes = '';\n for(var x = 0; x < n; x += 8) {\n bytes += String.fromCharCode((i >> x) & 0xFF);\n }\n ctx.collect(bytes);\n };\n\n /**\n * Registers a Web Worker to receive immediate entropy from the main thread.\n * This method is required until Web Workers can access the native crypto\n * API. This method should be called twice for each created worker, once in\n * the main thread, and once in the worker itself.\n *\n * @param worker the worker to register.\n */\n ctx.registerWorker = function(worker) {\n // worker receives random bytes\n if(worker === self) {\n ctx.seedFile = function(needed, callback) {\n function listener(e) {\n var data = e.data;\n if(data.forge && data.forge.prng) {\n self.removeEventListener('message', listener);\n callback(data.forge.prng.err, data.forge.prng.bytes);\n }\n }\n self.addEventListener('message', listener);\n self.postMessage({forge: {prng: {needed: needed}}});\n };\n } else {\n // main thread sends random bytes upon request\n var listener = function(e) {\n var data = e.data;\n if(data.forge && data.forge.prng) {\n ctx.seedFile(data.forge.prng.needed, function(err, bytes) {\n worker.postMessage({forge: {prng: {err: err, bytes: bytes}}});\n });\n }\n };\n // TODO: do we need to remove the event listener when the worker dies?\n worker.addEventListener('message', listener);\n }\n };\n\n return ctx;\n};\n","/**\n * RC2 implementation.\n *\n * @author Stefan Siegl\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * Information on the RC2 cipher is available from RFC #2268,\n * http://www.ietf.org/rfc/rfc2268.txt\n */\nvar forge = require('./forge');\nrequire('./util');\n\nvar piTable = [\n 0xd9, 0x78, 0xf9, 0xc4, 0x19, 0xdd, 0xb5, 0xed, 0x28, 0xe9, 0xfd, 0x79, 0x4a, 0xa0, 0xd8, 0x9d,\n 0xc6, 0x7e, 0x37, 0x83, 0x2b, 0x76, 0x53, 0x8e, 0x62, 0x4c, 0x64, 0x88, 0x44, 0x8b, 0xfb, 0xa2,\n 0x17, 0x9a, 0x59, 0xf5, 0x87, 0xb3, 0x4f, 0x13, 0x61, 0x45, 0x6d, 0x8d, 0x09, 0x81, 0x7d, 0x32,\n 0xbd, 0x8f, 0x40, 0xeb, 0x86, 0xb7, 0x7b, 0x0b, 0xf0, 0x95, 0x21, 0x22, 0x5c, 0x6b, 0x4e, 0x82,\n 0x54, 0xd6, 0x65, 0x93, 0xce, 0x60, 0xb2, 0x1c, 0x73, 0x56, 0xc0, 0x14, 0xa7, 0x8c, 0xf1, 0xdc,\n 0x12, 0x75, 0xca, 0x1f, 0x3b, 0xbe, 0xe4, 0xd1, 0x42, 0x3d, 0xd4, 0x30, 0xa3, 0x3c, 0xb6, 0x26,\n 0x6f, 0xbf, 0x0e, 0xda, 0x46, 0x69, 0x07, 0x57, 0x27, 0xf2, 0x1d, 0x9b, 0xbc, 0x94, 0x43, 0x03,\n 0xf8, 0x11, 0xc7, 0xf6, 0x90, 0xef, 0x3e, 0xe7, 0x06, 0xc3, 0xd5, 0x2f, 0xc8, 0x66, 0x1e, 0xd7,\n 0x08, 0xe8, 0xea, 0xde, 0x80, 0x52, 0xee, 0xf7, 0x84, 0xaa, 0x72, 0xac, 0x35, 0x4d, 0x6a, 0x2a,\n 0x96, 0x1a, 0xd2, 0x71, 0x5a, 0x15, 0x49, 0x74, 0x4b, 0x9f, 0xd0, 0x5e, 0x04, 0x18, 0xa4, 0xec,\n 0xc2, 0xe0, 0x41, 0x6e, 0x0f, 0x51, 0xcb, 0xcc, 0x24, 0x91, 0xaf, 0x50, 0xa1, 0xf4, 0x70, 0x39,\n 0x99, 0x7c, 0x3a, 0x85, 0x23, 0xb8, 0xb4, 0x7a, 0xfc, 0x02, 0x36, 0x5b, 0x25, 0x55, 0x97, 0x31,\n 0x2d, 0x5d, 0xfa, 0x98, 0xe3, 0x8a, 0x92, 0xae, 0x05, 0xdf, 0x29, 0x10, 0x67, 0x6c, 0xba, 0xc9,\n 0xd3, 0x00, 0xe6, 0xcf, 0xe1, 0x9e, 0xa8, 0x2c, 0x63, 0x16, 0x01, 0x3f, 0x58, 0xe2, 0x89, 0xa9,\n 0x0d, 0x38, 0x34, 0x1b, 0xab, 0x33, 0xff, 0xb0, 0xbb, 0x48, 0x0c, 0x5f, 0xb9, 0xb1, 0xcd, 0x2e,\n 0xc5, 0xf3, 0xdb, 0x47, 0xe5, 0xa5, 0x9c, 0x77, 0x0a, 0xa6, 0x20, 0x68, 0xfe, 0x7f, 0xc1, 0xad\n];\n\nvar s = [1, 2, 3, 5];\n\n/**\n * Rotate a word left by given number of bits.\n *\n * Bits that are shifted out on the left are put back in on the right\n * hand side.\n *\n * @param word The word to shift left.\n * @param bits The number of bits to shift by.\n * @return The rotated word.\n */\nvar rol = function(word, bits) {\n return ((word << bits) & 0xffff) | ((word & 0xffff) >> (16 - bits));\n};\n\n/**\n * Rotate a word right by given number of bits.\n *\n * Bits that are shifted out on the right are put back in on the left\n * hand side.\n *\n * @param word The word to shift right.\n * @param bits The number of bits to shift by.\n * @return The rotated word.\n */\nvar ror = function(word, bits) {\n return ((word & 0xffff) >> bits) | ((word << (16 - bits)) & 0xffff);\n};\n\n/* RC2 API */\nmodule.exports = forge.rc2 = forge.rc2 || {};\n\n/**\n * Perform RC2 key expansion as per RFC #2268, section 2.\n *\n * @param key variable-length user key (between 1 and 128 bytes)\n * @param effKeyBits number of effective key bits (default: 128)\n * @return the expanded RC2 key (ByteBuffer of 128 bytes)\n */\nforge.rc2.expandKey = function(key, effKeyBits) {\n if(typeof key === 'string') {\n key = forge.util.createBuffer(key);\n }\n effKeyBits = effKeyBits || 128;\n\n /* introduce variables that match the names used in RFC #2268 */\n var L = key;\n var T = key.length();\n var T1 = effKeyBits;\n var T8 = Math.ceil(T1 / 8);\n var TM = 0xff >> (T1 & 0x07);\n var i;\n\n for(i = T; i < 128; i++) {\n L.putByte(piTable[(L.at(i - 1) + L.at(i - T)) & 0xff]);\n }\n\n L.setAt(128 - T8, piTable[L.at(128 - T8) & TM]);\n\n for(i = 127 - T8; i >= 0; i--) {\n L.setAt(i, piTable[L.at(i + 1) ^ L.at(i + T8)]);\n }\n\n return L;\n};\n\n/**\n * Creates a RC2 cipher object.\n *\n * @param key the symmetric key to use (as base for key generation).\n * @param bits the number of effective key bits.\n * @param encrypt false for decryption, true for encryption.\n *\n * @return the cipher.\n */\nvar createCipher = function(key, bits, encrypt) {\n var _finish = false, _input = null, _output = null, _iv = null;\n var mixRound, mashRound;\n var i, j, K = [];\n\n /* Expand key and fill into K[] Array */\n key = forge.rc2.expandKey(key, bits);\n for(i = 0; i < 64; i++) {\n K.push(key.getInt16Le());\n }\n\n if(encrypt) {\n /**\n * Perform one mixing round \"in place\".\n *\n * @param R Array of four words to perform mixing on.\n */\n mixRound = function(R) {\n for(i = 0; i < 4; i++) {\n R[i] += K[j] + (R[(i + 3) % 4] & R[(i + 2) % 4]) +\n ((~R[(i + 3) % 4]) & R[(i + 1) % 4]);\n R[i] = rol(R[i], s[i]);\n j++;\n }\n };\n\n /**\n * Perform one mashing round \"in place\".\n *\n * @param R Array of four words to perform mashing on.\n */\n mashRound = function(R) {\n for(i = 0; i < 4; i++) {\n R[i] += K[R[(i + 3) % 4] & 63];\n }\n };\n } else {\n /**\n * Perform one r-mixing round \"in place\".\n *\n * @param R Array of four words to perform mixing on.\n */\n mixRound = function(R) {\n for(i = 3; i >= 0; i--) {\n R[i] = ror(R[i], s[i]);\n R[i] -= K[j] + (R[(i + 3) % 4] & R[(i + 2) % 4]) +\n ((~R[(i + 3) % 4]) & R[(i + 1) % 4]);\n j--;\n }\n };\n\n /**\n * Perform one r-mashing round \"in place\".\n *\n * @param R Array of four words to perform mashing on.\n */\n mashRound = function(R) {\n for(i = 3; i >= 0; i--) {\n R[i] -= K[R[(i + 3) % 4] & 63];\n }\n };\n }\n\n /**\n * Run the specified cipher execution plan.\n *\n * This function takes four words from the input buffer, applies the IV on\n * it (if requested) and runs the provided execution plan.\n *\n * The plan must be put together in form of a array of arrays. Where the\n * outer one is simply a list of steps to perform and the inner one needs\n * to have two elements: the first one telling how many rounds to perform,\n * the second one telling what to do (i.e. the function to call).\n *\n * @param {Array} plan The plan to execute.\n */\n var runPlan = function(plan) {\n var R = [];\n\n /* Get data from input buffer and fill the four words into R */\n for(i = 0; i < 4; i++) {\n var val = _input.getInt16Le();\n\n if(_iv !== null) {\n if(encrypt) {\n /* We're encrypting, apply the IV first. */\n val ^= _iv.getInt16Le();\n } else {\n /* We're decryption, keep cipher text for next block. */\n _iv.putInt16Le(val);\n }\n }\n\n R.push(val & 0xffff);\n }\n\n /* Reset global \"j\" variable as per spec. */\n j = encrypt ? 0 : 63;\n\n /* Run execution plan. */\n for(var ptr = 0; ptr < plan.length; ptr++) {\n for(var ctr = 0; ctr < plan[ptr][0]; ctr++) {\n plan[ptr][1](R);\n }\n }\n\n /* Write back result to output buffer. */\n for(i = 0; i < 4; i++) {\n if(_iv !== null) {\n if(encrypt) {\n /* We're encrypting in CBC-mode, feed back encrypted bytes into\n IV buffer to carry it forward to next block. */\n _iv.putInt16Le(R[i]);\n } else {\n R[i] ^= _iv.getInt16Le();\n }\n }\n\n _output.putInt16Le(R[i]);\n }\n };\n\n /* Create cipher object */\n var cipher = null;\n cipher = {\n /**\n * Starts or restarts the encryption or decryption process, whichever\n * was previously configured.\n *\n * To use the cipher in CBC mode, iv may be given either as a string\n * of bytes, or as a byte buffer. For ECB mode, give null as iv.\n *\n * @param iv the initialization vector to use, null for ECB mode.\n * @param output the output the buffer to write to, null to create one.\n */\n start: function(iv, output) {\n if(iv) {\n /* CBC mode */\n if(typeof iv === 'string') {\n iv = forge.util.createBuffer(iv);\n }\n }\n\n _finish = false;\n _input = forge.util.createBuffer();\n _output = output || new forge.util.createBuffer();\n _iv = iv;\n\n cipher.output = _output;\n },\n\n /**\n * Updates the next block.\n *\n * @param input the buffer to read from.\n */\n update: function(input) {\n if(!_finish) {\n // not finishing, so fill the input buffer with more input\n _input.putBuffer(input);\n }\n\n while(_input.length() >= 8) {\n runPlan([\n [ 5, mixRound ],\n [ 1, mashRound ],\n [ 6, mixRound ],\n [ 1, mashRound ],\n [ 5, mixRound ]\n ]);\n }\n },\n\n /**\n * Finishes encrypting or decrypting.\n *\n * @param pad a padding function to use, null for PKCS#7 padding,\n * signature(blockSize, buffer, decrypt).\n *\n * @return true if successful, false on error.\n */\n finish: function(pad) {\n var rval = true;\n\n if(encrypt) {\n if(pad) {\n rval = pad(8, _input, !encrypt);\n } else {\n // add PKCS#7 padding to block (each pad byte is the\n // value of the number of pad bytes)\n var padding = (_input.length() === 8) ? 8 : (8 - _input.length());\n _input.fillWithByte(padding, padding);\n }\n }\n\n if(rval) {\n // do final update\n _finish = true;\n cipher.update();\n }\n\n if(!encrypt) {\n // check for error: input data not a multiple of block size\n rval = (_input.length() === 0);\n if(rval) {\n if(pad) {\n rval = pad(8, _output, !encrypt);\n } else {\n // ensure padding byte count is valid\n var len = _output.length();\n var count = _output.at(len - 1);\n\n if(count > len) {\n rval = false;\n } else {\n // trim off padding bytes\n _output.truncate(count);\n }\n }\n }\n }\n\n return rval;\n }\n };\n\n return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to encrypt data in ECB or CBC mode using the\n * given symmetric key. The output will be stored in the 'output' member\n * of the returned cipher.\n *\n * The key and iv may be given as a string of bytes or a byte buffer.\n * The cipher is initialized to use 128 effective key bits.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n *\n * @return the cipher.\n */\nforge.rc2.startEncrypting = function(key, iv, output) {\n var cipher = forge.rc2.createEncryptionCipher(key, 128);\n cipher.start(iv, output);\n return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to encrypt data in ECB or CBC mode using the\n * given symmetric key.\n *\n * The key may be given as a string of bytes or a byte buffer.\n *\n * To start encrypting call start() on the cipher with an iv and optional\n * output buffer.\n *\n * @param key the symmetric key to use.\n *\n * @return the cipher.\n */\nforge.rc2.createEncryptionCipher = function(key, bits) {\n return createCipher(key, bits, true);\n};\n\n/**\n * Creates an RC2 cipher object to decrypt data in ECB or CBC mode using the\n * given symmetric key. The output will be stored in the 'output' member\n * of the returned cipher.\n *\n * The key and iv may be given as a string of bytes or a byte buffer.\n * The cipher is initialized to use 128 effective key bits.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n *\n * @return the cipher.\n */\nforge.rc2.startDecrypting = function(key, iv, output) {\n var cipher = forge.rc2.createDecryptionCipher(key, 128);\n cipher.start(iv, output);\n return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to decrypt data in ECB or CBC mode using the\n * given symmetric key.\n *\n * The key may be given as a string of bytes or a byte buffer.\n *\n * To start decrypting call start() on the cipher with an iv and optional\n * output buffer.\n *\n * @param key the symmetric key to use.\n *\n * @return the cipher.\n */\nforge.rc2.createDecryptionCipher = function(key, bits) {\n return createCipher(key, bits, false);\n};\n","/**\n * Partial implementation of PKCS#1 v2.2: RSA-OEAP\n *\n * Modified but based on the following MIT and BSD licensed code:\n *\n * https://github.com/kjur/jsjws/blob/master/rsa.js:\n *\n * The 'jsjws'(JSON Web Signature JavaScript Library) License\n *\n * Copyright (c) 2012 Kenji Urushima\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n *\n * http://webrsa.cvs.sourceforge.net/viewvc/webrsa/Client/RSAES-OAEP.js?content-type=text%2Fplain:\n *\n * RSAES-OAEP.js\n * $Id: RSAES-OAEP.js,v 1.1.1.1 2003/03/19 15:37:20 ellispritchard Exp $\n * JavaScript Implementation of PKCS #1 v2.1 RSA CRYPTOGRAPHY STANDARD (RSA Laboratories, June 14, 2002)\n * Copyright (C) Ellis Pritchard, Guardian Unlimited 2003.\n * Contact: ellis@nukinetics.com\n * Distributed under the BSD License.\n *\n * Official documentation: http://www.rsa.com/rsalabs/node.asp?id=2125\n *\n * @author Evan Jones (http://evanjones.ca/)\n * @author Dave Longley\n *\n * Copyright (c) 2013-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./random');\nrequire('./sha1');\n\n// shortcut for PKCS#1 API\nvar pkcs1 = module.exports = forge.pkcs1 = forge.pkcs1 || {};\n\n/**\n * Encode the given RSAES-OAEP message (M) using key, with optional label (L)\n * and seed.\n *\n * This method does not perform RSA encryption, it only encodes the message\n * using RSAES-OAEP.\n *\n * @param key the RSA key to use.\n * @param message the message to encode.\n * @param options the options to use:\n * label an optional label to use.\n * seed the seed to use.\n * md the message digest object to use, undefined for SHA-1.\n * mgf1 optional mgf1 parameters:\n * md the message digest object to use for MGF1.\n *\n * @return the encoded message bytes.\n */\npkcs1.encode_rsa_oaep = function(key, message, options) {\n // parse arguments\n var label;\n var seed;\n var md;\n var mgf1Md;\n // legacy args (label, seed, md)\n if(typeof options === 'string') {\n label = options;\n seed = arguments[3] || undefined;\n md = arguments[4] || undefined;\n } else if(options) {\n label = options.label || undefined;\n seed = options.seed || undefined;\n md = options.md || undefined;\n if(options.mgf1 && options.mgf1.md) {\n mgf1Md = options.mgf1.md;\n }\n }\n\n // default OAEP to SHA-1 message digest\n if(!md) {\n md = forge.md.sha1.create();\n } else {\n md.start();\n }\n\n // default MGF-1 to same as OAEP\n if(!mgf1Md) {\n mgf1Md = md;\n }\n\n // compute length in bytes and check output\n var keyLength = Math.ceil(key.n.bitLength() / 8);\n var maxLength = keyLength - 2 * md.digestLength - 2;\n if(message.length > maxLength) {\n var error = new Error('RSAES-OAEP input message length is too long.');\n error.length = message.length;\n error.maxLength = maxLength;\n throw error;\n }\n\n if(!label) {\n label = '';\n }\n md.update(label, 'raw');\n var lHash = md.digest();\n\n var PS = '';\n var PS_length = maxLength - message.length;\n for(var i = 0; i < PS_length; i++) {\n PS += '\\x00';\n }\n\n var DB = lHash.getBytes() + PS + '\\x01' + message;\n\n if(!seed) {\n seed = forge.random.getBytes(md.digestLength);\n } else if(seed.length !== md.digestLength) {\n var error = new Error('Invalid RSAES-OAEP seed. The seed length must ' +\n 'match the digest length.');\n error.seedLength = seed.length;\n error.digestLength = md.digestLength;\n throw error;\n }\n\n var dbMask = rsa_mgf1(seed, keyLength - md.digestLength - 1, mgf1Md);\n var maskedDB = forge.util.xorBytes(DB, dbMask, DB.length);\n\n var seedMask = rsa_mgf1(maskedDB, md.digestLength, mgf1Md);\n var maskedSeed = forge.util.xorBytes(seed, seedMask, seed.length);\n\n // return encoded message\n return '\\x00' + maskedSeed + maskedDB;\n};\n\n/**\n * Decode the given RSAES-OAEP encoded message (EM) using key, with optional\n * label (L).\n *\n * This method does not perform RSA decryption, it only decodes the message\n * using RSAES-OAEP.\n *\n * @param key the RSA key to use.\n * @param em the encoded message to decode.\n * @param options the options to use:\n * label an optional label to use.\n * md the message digest object to use for OAEP, undefined for SHA-1.\n * mgf1 optional mgf1 parameters:\n * md the message digest object to use for MGF1.\n *\n * @return the decoded message bytes.\n */\npkcs1.decode_rsa_oaep = function(key, em, options) {\n // parse args\n var label;\n var md;\n var mgf1Md;\n // legacy args\n if(typeof options === 'string') {\n label = options;\n md = arguments[3] || undefined;\n } else if(options) {\n label = options.label || undefined;\n md = options.md || undefined;\n if(options.mgf1 && options.mgf1.md) {\n mgf1Md = options.mgf1.md;\n }\n }\n\n // compute length in bytes\n var keyLength = Math.ceil(key.n.bitLength() / 8);\n\n if(em.length !== keyLength) {\n var error = new Error('RSAES-OAEP encoded message length is invalid.');\n error.length = em.length;\n error.expectedLength = keyLength;\n throw error;\n }\n\n // default OAEP to SHA-1 message digest\n if(md === undefined) {\n md = forge.md.sha1.create();\n } else {\n md.start();\n }\n\n // default MGF-1 to same as OAEP\n if(!mgf1Md) {\n mgf1Md = md;\n }\n\n if(keyLength < 2 * md.digestLength + 2) {\n throw new Error('RSAES-OAEP key is too short for the hash function.');\n }\n\n if(!label) {\n label = '';\n }\n md.update(label, 'raw');\n var lHash = md.digest().getBytes();\n\n // split the message into its parts\n var y = em.charAt(0);\n var maskedSeed = em.substring(1, md.digestLength + 1);\n var maskedDB = em.substring(1 + md.digestLength);\n\n var seedMask = rsa_mgf1(maskedDB, md.digestLength, mgf1Md);\n var seed = forge.util.xorBytes(maskedSeed, seedMask, maskedSeed.length);\n\n var dbMask = rsa_mgf1(seed, keyLength - md.digestLength - 1, mgf1Md);\n var db = forge.util.xorBytes(maskedDB, dbMask, maskedDB.length);\n\n var lHashPrime = db.substring(0, md.digestLength);\n\n // constant time check that all values match what is expected\n var error = (y !== '\\x00');\n\n // constant time check lHash vs lHashPrime\n for(var i = 0; i < md.digestLength; ++i) {\n error |= (lHash.charAt(i) !== lHashPrime.charAt(i));\n }\n\n // \"constant time\" find the 0x1 byte separating the padding (zeros) from the\n // message\n // TODO: It must be possible to do this in a better/smarter way?\n var in_ps = 1;\n var index = md.digestLength;\n for(var j = md.digestLength; j < db.length; j++) {\n var code = db.charCodeAt(j);\n\n var is_0 = (code & 0x1) ^ 0x1;\n\n // non-zero if not 0 or 1 in the ps section\n var error_mask = in_ps ? 0xfffe : 0x0000;\n error |= (code & error_mask);\n\n // latch in_ps to zero after we find 0x1\n in_ps = in_ps & is_0;\n index += in_ps;\n }\n\n if(error || db.charCodeAt(index) !== 0x1) {\n throw new Error('Invalid RSAES-OAEP padding.');\n }\n\n return db.substring(index + 1);\n};\n\nfunction rsa_mgf1(seed, maskLength, hash) {\n // default to SHA-1 message digest\n if(!hash) {\n hash = forge.md.sha1.create();\n }\n var t = '';\n var count = Math.ceil(maskLength / hash.digestLength);\n for(var i = 0; i < count; ++i) {\n var c = String.fromCharCode(\n (i >> 24) & 0xFF, (i >> 16) & 0xFF, (i >> 8) & 0xFF, i & 0xFF);\n hash.start();\n hash.update(seed + c);\n t += hash.digest().getBytes();\n }\n return t.substring(0, maskLength);\n}\n","/**\n * Prime number generation API.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./jsbn');\nrequire('./random');\n\n(function() {\n\n// forge.prime already defined\nif(forge.prime) {\n module.exports = forge.prime;\n return;\n}\n\n/* PRIME API */\nvar prime = module.exports = forge.prime = forge.prime || {};\n\nvar BigInteger = forge.jsbn.BigInteger;\n\n// primes are 30k+i for i = 1, 7, 11, 13, 17, 19, 23, 29\nvar GCD_30_DELTA = [6, 4, 2, 4, 2, 4, 6, 2];\nvar THIRTY = new BigInteger(null);\nTHIRTY.fromInt(30);\nvar op_or = function(x, y) {return x|y;};\n\n/**\n * Generates a random probable prime with the given number of bits.\n *\n * Alternative algorithms can be specified by name as a string or as an\n * object with custom options like so:\n *\n * {\n * name: 'PRIMEINC',\n * options: {\n * maxBlockTime: <the maximum amount of time to block the main\n * thread before allowing I/O other JS to run>,\n * millerRabinTests: <the number of miller-rabin tests to run>,\n * workerScript: <the worker script URL>,\n * workers: <the number of web workers (if supported) to use,\n * -1 to use estimated cores minus one>.\n * workLoad: the size of the work load, ie: number of possible prime\n * numbers for each web worker to check per work assignment,\n * (default: 100).\n * }\n * }\n *\n * @param bits the number of bits for the prime number.\n * @param options the options to use.\n * [algorithm] the algorithm to use (default: 'PRIMEINC').\n * [prng] a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\".\n *\n * @return callback(err, num) called once the operation completes.\n */\nprime.generateProbablePrime = function(bits, options, callback) {\n if(typeof options === 'function') {\n callback = options;\n options = {};\n }\n options = options || {};\n\n // default to PRIMEINC algorithm\n var algorithm = options.algorithm || 'PRIMEINC';\n if(typeof algorithm === 'string') {\n algorithm = {name: algorithm};\n }\n algorithm.options = algorithm.options || {};\n\n // create prng with api that matches BigInteger secure random\n var prng = options.prng || forge.random;\n var rng = {\n // x is an array to fill with bytes\n nextBytes: function(x) {\n var b = prng.getBytesSync(x.length);\n for(var i = 0; i < x.length; ++i) {\n x[i] = b.charCodeAt(i);\n }\n }\n };\n\n if(algorithm.name === 'PRIMEINC') {\n return primeincFindPrime(bits, rng, algorithm.options, callback);\n }\n\n throw new Error('Invalid prime generation algorithm: ' + algorithm.name);\n};\n\nfunction primeincFindPrime(bits, rng, options, callback) {\n if('workers' in options) {\n return primeincFindPrimeWithWorkers(bits, rng, options, callback);\n }\n return primeincFindPrimeWithoutWorkers(bits, rng, options, callback);\n}\n\nfunction primeincFindPrimeWithoutWorkers(bits, rng, options, callback) {\n // initialize random number\n var num = generateRandom(bits, rng);\n\n /* Note: All primes are of the form 30k+i for i < 30 and gcd(30, i)=1. The\n number we are given is always aligned at 30k + 1. Each time the number is\n determined not to be prime we add to get to the next 'i', eg: if the number\n was at 30k + 1 we add 6. */\n var deltaIdx = 0;\n\n // get required number of MR tests\n var mrTests = getMillerRabinTests(num.bitLength());\n if('millerRabinTests' in options) {\n mrTests = options.millerRabinTests;\n }\n\n // find prime nearest to 'num' for maxBlockTime ms\n // 10 ms gives 5ms of leeway for other calculations before dropping\n // below 60fps (1000/60 == 16.67), but in reality, the number will\n // likely be higher due to an 'atomic' big int modPow\n var maxBlockTime = 10;\n if('maxBlockTime' in options) {\n maxBlockTime = options.maxBlockTime;\n }\n\n _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback);\n}\n\nfunction _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback) {\n var start = +new Date();\n do {\n // overflow, regenerate random number\n if(num.bitLength() > bits) {\n num = generateRandom(bits, rng);\n }\n // do primality test\n if(num.isProbablePrime(mrTests)) {\n return callback(null, num);\n }\n // get next potential prime\n num.dAddOffset(GCD_30_DELTA[deltaIdx++ % 8], 0);\n } while(maxBlockTime < 0 || (+new Date() - start < maxBlockTime));\n\n // keep trying later\n forge.util.setImmediate(function() {\n _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback);\n });\n}\n\n// NOTE: This algorithm is indeterminate in nature because workers\n// run in parallel looking at different segments of numbers. Even if this\n// algorithm is run twice with the same input from a predictable RNG, it\n// may produce different outputs.\nfunction primeincFindPrimeWithWorkers(bits, rng, options, callback) {\n // web workers unavailable\n if(typeof Worker === 'undefined') {\n return primeincFindPrimeWithoutWorkers(bits, rng, options, callback);\n }\n\n // initialize random number\n var num = generateRandom(bits, rng);\n\n // use web workers to generate keys\n var numWorkers = options.workers;\n var workLoad = options.workLoad || 100;\n var range = workLoad * 30 / 8;\n var workerScript = options.workerScript || 'forge/prime.worker.js';\n if(numWorkers === -1) {\n return forge.util.estimateCores(function(err, cores) {\n if(err) {\n // default to 2\n cores = 2;\n }\n numWorkers = cores - 1;\n generate();\n });\n }\n generate();\n\n function generate() {\n // require at least 1 worker\n numWorkers = Math.max(1, numWorkers);\n\n // TODO: consider optimizing by starting workers outside getPrime() ...\n // note that in order to clean up they will have to be made internally\n // asynchronous which may actually be slower\n\n // start workers immediately\n var workers = [];\n for(var i = 0; i < numWorkers; ++i) {\n // FIXME: fix path or use blob URLs\n workers[i] = new Worker(workerScript);\n }\n var running = numWorkers;\n\n // listen for requests from workers and assign ranges to find prime\n for(var i = 0; i < numWorkers; ++i) {\n workers[i].addEventListener('message', workerMessage);\n }\n\n /* Note: The distribution of random numbers is unknown. Therefore, each\n web worker is continuously allocated a range of numbers to check for a\n random number until one is found.\n\n Every 30 numbers will be checked just 8 times, because prime numbers\n have the form:\n\n 30k+i, for i < 30 and gcd(30, i)=1 (there are 8 values of i for this)\n\n Therefore, if we want a web worker to run N checks before asking for\n a new range of numbers, each range must contain N*30/8 numbers.\n\n For 100 checks (workLoad), this is a range of 375. */\n\n var found = false;\n function workerMessage(e) {\n // ignore message, prime already found\n if(found) {\n return;\n }\n\n --running;\n var data = e.data;\n if(data.found) {\n // terminate all workers\n for(var i = 0; i < workers.length; ++i) {\n workers[i].terminate();\n }\n found = true;\n return callback(null, new BigInteger(data.prime, 16));\n }\n\n // overflow, regenerate random number\n if(num.bitLength() > bits) {\n num = generateRandom(bits, rng);\n }\n\n // assign new range to check\n var hex = num.toString(16);\n\n // start prime search\n e.target.postMessage({\n hex: hex,\n workLoad: workLoad\n });\n\n num.dAddOffset(range, 0);\n }\n }\n}\n\n/**\n * Generates a random number using the given number of bits and RNG.\n *\n * @param bits the number of bits for the number.\n * @param rng the random number generator to use.\n *\n * @return the random number.\n */\nfunction generateRandom(bits, rng) {\n var num = new BigInteger(bits, rng);\n // force MSB set\n var bits1 = bits - 1;\n if(!num.testBit(bits1)) {\n num.bitwiseTo(BigInteger.ONE.shiftLeft(bits1), op_or, num);\n }\n // align number on 30k+1 boundary\n num.dAddOffset(31 - num.mod(THIRTY).byteValue(), 0);\n return num;\n}\n\n/**\n * Returns the required number of Miller-Rabin tests to generate a\n * prime with an error probability of (1/2)^80.\n *\n * See Handbook of Applied Cryptography Chapter 4, Table 4.4.\n *\n * @param bits the bit size.\n *\n * @return the required number of iterations.\n */\nfunction getMillerRabinTests(bits) {\n if(bits <= 100) return 27;\n if(bits <= 150) return 18;\n if(bits <= 200) return 15;\n if(bits <= 250) return 12;\n if(bits <= 300) return 9;\n if(bits <= 350) return 8;\n if(bits <= 400) return 7;\n if(bits <= 500) return 6;\n if(bits <= 600) return 5;\n if(bits <= 800) return 4;\n if(bits <= 1250) return 3;\n return 2;\n}\n\n})();\n","/**\n * Javascript implementation of ASN.1 validators for PKCS#7 v1.5.\n *\n * @author Dave Longley\n * @author Stefan Siegl\n *\n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * The ASN.1 representation of PKCS#7 is as follows\n * (see RFC #2315 for details, http://www.ietf.org/rfc/rfc2315.txt):\n *\n * A PKCS#7 message consists of a ContentInfo on root level, which may\n * contain any number of further ContentInfo nested into it.\n *\n * ContentInfo ::= SEQUENCE {\n * contentType ContentType,\n * content [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL\n * }\n *\n * ContentType ::= OBJECT IDENTIFIER\n *\n * EnvelopedData ::= SEQUENCE {\n * version Version,\n * recipientInfos RecipientInfos,\n * encryptedContentInfo EncryptedContentInfo\n * }\n *\n * EncryptedData ::= SEQUENCE {\n * version Version,\n * encryptedContentInfo EncryptedContentInfo\n * }\n *\n * id-signedData OBJECT IDENTIFIER ::= { iso(1) member-body(2)\n * us(840) rsadsi(113549) pkcs(1) pkcs7(7) 2 }\n *\n * SignedData ::= SEQUENCE {\n * version INTEGER,\n * digestAlgorithms DigestAlgorithmIdentifiers,\n * contentInfo ContentInfo,\n * certificates [0] IMPLICIT Certificates OPTIONAL,\n * crls [1] IMPLICIT CertificateRevocationLists OPTIONAL,\n * signerInfos SignerInfos\n * }\n *\n * SignerInfos ::= SET OF SignerInfo\n *\n * SignerInfo ::= SEQUENCE {\n * version Version,\n * issuerAndSerialNumber IssuerAndSerialNumber,\n * digestAlgorithm DigestAlgorithmIdentifier,\n * authenticatedAttributes [0] IMPLICIT Attributes OPTIONAL,\n * digestEncryptionAlgorithm DigestEncryptionAlgorithmIdentifier,\n * encryptedDigest EncryptedDigest,\n * unauthenticatedAttributes [1] IMPLICIT Attributes OPTIONAL\n * }\n *\n * EncryptedDigest ::= OCTET STRING\n *\n * Attributes ::= SET OF Attribute\n *\n * Attribute ::= SEQUENCE {\n * attrType OBJECT IDENTIFIER,\n * attrValues SET OF AttributeValue\n * }\n *\n * AttributeValue ::= ANY\n *\n * Version ::= INTEGER\n *\n * RecipientInfos ::= SET OF RecipientInfo\n *\n * EncryptedContentInfo ::= SEQUENCE {\n * contentType ContentType,\n * contentEncryptionAlgorithm ContentEncryptionAlgorithmIdentifier,\n * encryptedContent [0] IMPLICIT EncryptedContent OPTIONAL\n * }\n *\n * ContentEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of AES and DES3, there is only one,\n * the IV.\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n * algorithm OBJECT IDENTIFIER,\n * parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * EncryptedContent ::= OCTET STRING\n *\n * RecipientInfo ::= SEQUENCE {\n * version Version,\n * issuerAndSerialNumber IssuerAndSerialNumber,\n * keyEncryptionAlgorithm KeyEncryptionAlgorithmIdentifier,\n * encryptedKey EncryptedKey\n * }\n *\n * IssuerAndSerialNumber ::= SEQUENCE {\n * issuer Name,\n * serialNumber CertificateSerialNumber\n * }\n *\n * CertificateSerialNumber ::= INTEGER\n *\n * KeyEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * EncryptedKey ::= OCTET STRING\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./util');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7v = module.exports = forge.pkcs7asn1 = forge.pkcs7asn1 || {};\nforge.pkcs7 = forge.pkcs7 || {};\nforge.pkcs7.asn1 = p7v;\n\nvar contentInfoValidator = {\n name: 'ContentInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'ContentInfo.ContentType',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'contentType'\n }, {\n name: 'ContentInfo.content',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n captureAsn1: 'content'\n }]\n};\np7v.contentInfoValidator = contentInfoValidator;\n\nvar encryptedContentInfoValidator = {\n name: 'EncryptedContentInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedContentInfo.contentType',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'contentType'\n }, {\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encAlgorithm'\n }, {\n name: 'EncryptedContentInfo.contentEncryptionAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n captureAsn1: 'encParameter'\n }]\n }, {\n name: 'EncryptedContentInfo.encryptedContent',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n /* The PKCS#7 structure output by OpenSSL somewhat differs from what\n * other implementations do generate.\n *\n * OpenSSL generates a structure like this:\n * SEQUENCE {\n * ...\n * [0]\n * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n * ...\n * }\n *\n * Whereas other implementations (and this PKCS#7 module) generate:\n * SEQUENCE {\n * ...\n * [0] {\n * OCTET STRING\n * 26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n * C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n * ...\n * }\n * }\n *\n * In order to support both, we just capture the context specific\n * field here. The OCTET STRING bit is removed below.\n */\n capture: 'encryptedContent',\n captureAsn1: 'encryptedContentAsn1'\n }]\n};\n\np7v.envelopedDataValidator = {\n name: 'EnvelopedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EnvelopedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'EnvelopedData.RecipientInfos',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n captureAsn1: 'recipientInfos'\n }].concat(encryptedContentInfoValidator)\n};\n\np7v.encryptedDataValidator = {\n name: 'EncryptedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'EncryptedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }].concat(encryptedContentInfoValidator)\n};\n\nvar signerValidator = {\n name: 'SignerInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false\n }, {\n name: 'SignerInfo.issuerAndSerialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.issuerAndSerialNumber.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'issuer'\n }, {\n name: 'SignerInfo.issuerAndSerialNumber.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'serial'\n }]\n }, {\n name: 'SignerInfo.digestAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignerInfo.digestAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'digestAlgorithm'\n }, {\n name: 'SignerInfo.digestAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n constructed: false,\n captureAsn1: 'digestParameter',\n optional: true\n }]\n }, {\n name: 'SignerInfo.authenticatedAttributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n capture: 'authenticatedAttributes'\n }, {\n name: 'SignerInfo.digestEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n capture: 'signatureAlgorithm'\n }, {\n name: 'SignerInfo.encryptedDigest',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'signature'\n }, {\n name: 'SignerInfo.unauthenticatedAttributes',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n optional: true,\n capture: 'unauthenticatedAttributes'\n }]\n};\n\np7v.signedDataValidator = {\n name: 'SignedData',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'SignedData.Version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'SignedData.DigestAlgorithms',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n constructed: true,\n captureAsn1: 'digestAlgorithms'\n },\n contentInfoValidator,\n {\n name: 'SignedData.Certificates',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n optional: true,\n captureAsn1: 'certificates'\n }, {\n name: 'SignedData.CertificateRevocationLists',\n tagClass: asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n optional: true,\n captureAsn1: 'crls'\n }, {\n name: 'SignedData.SignerInfos',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SET,\n capture: 'signerInfos',\n optional: true,\n value: [signerValidator]\n }]\n};\n\np7v.recipientInfoValidator = {\n name: 'RecipientInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'version'\n }, {\n name: 'RecipientInfo.issuerAndSerial',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.issuerAndSerial.issuer',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'issuer'\n }, {\n name: 'RecipientInfo.issuerAndSerial.serialNumber',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'serial'\n }]\n }, {\n name: 'RecipientInfo.keyEncryptionAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'RecipientInfo.keyEncryptionAlgorithm.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'encAlgorithm'\n }, {\n name: 'RecipientInfo.keyEncryptionAlgorithm.parameter',\n tagClass: asn1.Class.UNIVERSAL,\n constructed: false,\n captureAsn1: 'encParameter'\n }]\n }, {\n name: 'RecipientInfo.encryptedKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'encKey'\n }]\n};\n","/**\n * Javascript implementation of mask generation function MGF1.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nforge.mgf = forge.mgf || {};\nvar mgf1 = module.exports = forge.mgf.mgf1 = forge.mgf1 = forge.mgf1 || {};\n\n/**\n * Creates a MGF1 mask generation function object.\n *\n * @param md the message digest API to use (eg: forge.md.sha1.create()).\n *\n * @return a mask generation function object.\n */\nmgf1.create = function(md) {\n var mgf = {\n /**\n * Generate mask of specified length.\n *\n * @param {String} seed The seed for mask generation.\n * @param maskLen Number of bytes to generate.\n * @return {String} The generated mask.\n */\n generate: function(seed, maskLen) {\n /* 2. Let T be the empty octet string. */\n var t = new forge.util.ByteBuffer();\n\n /* 3. For counter from 0 to ceil(maskLen / hLen), do the following: */\n var len = Math.ceil(maskLen / md.digestLength);\n for(var i = 0; i < len; i++) {\n /* a. Convert counter to an octet string C of length 4 octets */\n var c = new forge.util.ByteBuffer();\n c.putInt32(i);\n\n /* b. Concatenate the hash of the seed mgfSeed and C to the octet\n * string T: */\n md.start();\n md.update(seed + c.getBytes());\n t.putBuffer(md.digest());\n }\n\n /* Output the leading maskLen octets of T as the octet string mask. */\n t.truncate(t.length() - maskLen);\n return t.getBytes();\n }\n };\n\n return mgf;\n};\n","/**\n * Debugging support for web applications.\n *\n * @author David I. Lehn <dlehn@digitalbazaar.com>\n *\n * Copyright 2008-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\n\n/* DEBUG API */\nmodule.exports = forge.debug = forge.debug || {};\n\n// Private storage for debugging.\n// Useful to expose data that is otherwise unviewable behind closures.\n// NOTE: remember that this can hold references to data and cause leaks!\n// format is \"forge._debug.<modulename>.<dataname> = data\"\n// Example:\n// (function() {\n// var cat = 'forge.test.Test'; // debugging category\n// var sState = {...}; // local state\n// forge.debug.set(cat, 'sState', sState);\n// })();\nforge.debug.storage = {};\n\n/**\n * Gets debug data. Omit name for all cat data Omit name and cat for\n * all data.\n *\n * @param cat name of debugging category.\n * @param name name of data to get (optional).\n * @return object with requested debug data or undefined.\n */\nforge.debug.get = function(cat, name) {\n var rval;\n if(typeof(cat) === 'undefined') {\n rval = forge.debug.storage;\n } else if(cat in forge.debug.storage) {\n if(typeof(name) === 'undefined') {\n rval = forge.debug.storage[cat];\n } else {\n rval = forge.debug.storage[cat][name];\n }\n }\n return rval;\n};\n\n/**\n * Sets debug data.\n *\n * @param cat name of debugging category.\n * @param name name of data to set.\n * @param data data to set.\n */\nforge.debug.set = function(cat, name, data) {\n if(!(cat in forge.debug.storage)) {\n forge.debug.storage[cat] = {};\n }\n forge.debug.storage[cat][name] = data;\n};\n\n/**\n * Clears debug data. Omit name for all cat data. Omit name and cat for\n * all data.\n *\n * @param cat name of debugging category.\n * @param name name of data to clear or omit to clear entire category.\n */\nforge.debug.clear = function(cat, name) {\n if(typeof(cat) === 'undefined') {\n forge.debug.storage = {};\n } else if(cat in forge.debug.storage) {\n if(typeof(name) === 'undefined') {\n delete forge.debug.storage[cat];\n } else {\n delete forge.debug.storage[cat][name];\n }\n }\n};\n","/**\n * Secure Hash Algorithm with a 1024-bit block size implementation.\n *\n * This includes: SHA-512, SHA-384, SHA-512/224, and SHA-512/256. For\n * SHA-256 (block size 512 bits), see sha256.js.\n *\n * See FIPS 180-4 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2014-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha512 = module.exports = forge.sha512 = forge.sha512 || {};\n\n// SHA-512\nforge.md.sha512 = forge.md.algorithms.sha512 = sha512;\n\n// SHA-384\nvar sha384 = forge.sha384 = forge.sha512.sha384 = forge.sha512.sha384 || {};\nsha384.create = function() {\n return sha512.create('SHA-384');\n};\nforge.md.sha384 = forge.md.algorithms.sha384 = sha384;\n\n// SHA-512/256\nforge.sha512.sha256 = forge.sha512.sha256 || {\n create: function() {\n return sha512.create('SHA-512/256');\n }\n};\nforge.md['sha512/256'] = forge.md.algorithms['sha512/256'] =\n forge.sha512.sha256;\n\n// SHA-512/224\nforge.sha512.sha224 = forge.sha512.sha224 || {\n create: function() {\n return sha512.create('SHA-512/224');\n }\n};\nforge.md['sha512/224'] = forge.md.algorithms['sha512/224'] =\n forge.sha512.sha224;\n\n/**\n * Creates a SHA-2 message digest object.\n *\n * @param algorithm the algorithm to use (SHA-512, SHA-384, SHA-512/224,\n * SHA-512/256).\n *\n * @return a message digest object.\n */\nsha512.create = function(algorithm) {\n // do initialization as necessary\n if(!_initialized) {\n _init();\n }\n\n if(typeof algorithm === 'undefined') {\n algorithm = 'SHA-512';\n }\n\n if(!(algorithm in _states)) {\n throw new Error('Invalid SHA-512 algorithm: ' + algorithm);\n }\n\n // SHA-512 state contains eight 64-bit integers (each as two 32-bit ints)\n var _state = _states[algorithm];\n var _h = null;\n\n // input buffer\n var _input = forge.util.createBuffer();\n\n // used for 64-bit word storage\n var _w = new Array(80);\n for(var wi = 0; wi < 80; ++wi) {\n _w[wi] = new Array(2);\n }\n\n // determine digest length by algorithm name (default)\n var digestLength = 64;\n switch(algorithm) {\n case 'SHA-384':\n digestLength = 48;\n break;\n case 'SHA-512/256':\n digestLength = 32;\n break;\n case 'SHA-512/224':\n digestLength = 28;\n break;\n }\n\n // message digest object\n var md = {\n // SHA-512 => sha512\n algorithm: algorithm.replace('-', '').toLowerCase(),\n blockLength: 128,\n digestLength: digestLength,\n // 56-bit length of message so far (does not including padding)\n messageLength: 0,\n // true message length\n fullMessageLength: null,\n // size of message length in bytes\n messageLengthSize: 16\n };\n\n /**\n * Starts the digest.\n *\n * @return this digest object.\n */\n md.start = function() {\n // up to 56-bit message length for convenience\n md.messageLength = 0;\n\n // full message length (set md.messageLength128 for backwards-compatibility)\n md.fullMessageLength = md.messageLength128 = [];\n var int32s = md.messageLengthSize / 4;\n for(var i = 0; i < int32s; ++i) {\n md.fullMessageLength.push(0);\n }\n _input = forge.util.createBuffer();\n _h = new Array(_state.length);\n for(var i = 0; i < _state.length; ++i) {\n _h[i] = _state[i].slice(0);\n }\n return md;\n };\n // start digest automatically for first time\n md.start();\n\n /**\n * Updates the digest with the given message input. The given input can\n * treated as raw input (no encoding will be applied) or an encoding of\n * 'utf8' maybe given to encode the input using UTF-8.\n *\n * @param msg the message input to update with.\n * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n *\n * @return this digest object.\n */\n md.update = function(msg, encoding) {\n if(encoding === 'utf8') {\n msg = forge.util.encodeUtf8(msg);\n }\n\n // update message length\n var len = msg.length;\n md.messageLength += len;\n len = [(len / 0x100000000) >>> 0, len >>> 0];\n for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n md.fullMessageLength[i] += len[1];\n len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n len[0] = ((len[1] / 0x100000000) >>> 0);\n }\n\n // add bytes to input buffer\n _input.putBytes(msg);\n\n // process bytes\n _update(_h, _w, _input);\n\n // compact input buffer every 2K or if empty\n if(_input.read > 2048 || _input.length() === 0) {\n _input.compact();\n }\n\n return md;\n };\n\n /**\n * Produces the digest.\n *\n * @return a byte buffer containing the digest value.\n */\n md.digest = function() {\n /* Note: Here we copy the remaining bytes in the input buffer and\n add the appropriate SHA-512 padding. Then we do the final update\n on a copy of the state so that if the user wants to get\n intermediate digests they can do so. */\n\n /* Determine the number of bytes that must be added to the message\n to ensure its length is congruent to 896 mod 1024. In other words,\n the data to be digested must be a multiple of 1024 bits (or 128 bytes).\n This data includes the message, some padding, and the length of the\n message. Since the length of the message will be encoded as 16 bytes (128\n bits), that means that the last segment of the data must have 112 bytes\n (896 bits) of message and padding. Therefore, the length of the message\n plus the padding must be congruent to 896 mod 1024 because\n 1024 - 128 = 896.\n\n In order to fill up the message length it must be filled with\n padding that begins with 1 bit followed by all 0 bits. Padding\n must *always* be present, so if the message length is already\n congruent to 896 mod 1024, then 1024 padding bits must be added. */\n\n var finalBlock = forge.util.createBuffer();\n finalBlock.putBytes(_input.bytes());\n\n // compute remaining size to be digested (include message length size)\n var remaining = (\n md.fullMessageLength[md.fullMessageLength.length - 1] +\n md.messageLengthSize);\n\n // add padding for overflow blockSize - overflow\n // _padding starts with 1 byte with first bit is set (byte value 128), then\n // there may be up to (blockSize - 1) other pad bytes\n var overflow = remaining & (md.blockLength - 1);\n finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n // serialize message length in bits in big-endian order; since length\n // is stored in bytes we multiply by 8 and add carry from next int\n var next, carry;\n var bits = md.fullMessageLength[0] * 8;\n for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n next = md.fullMessageLength[i + 1] * 8;\n carry = (next / 0x100000000) >>> 0;\n bits += carry;\n finalBlock.putInt32(bits >>> 0);\n bits = next >>> 0;\n }\n finalBlock.putInt32(bits);\n\n var h = new Array(_h.length);\n for(var i = 0; i < _h.length; ++i) {\n h[i] = _h[i].slice(0);\n }\n _update(h, _w, finalBlock);\n var rval = forge.util.createBuffer();\n var hlen;\n if(algorithm === 'SHA-512') {\n hlen = h.length;\n } else if(algorithm === 'SHA-384') {\n hlen = h.length - 2;\n } else {\n hlen = h.length - 4;\n }\n for(var i = 0; i < hlen; ++i) {\n rval.putInt32(h[i][0]);\n if(i !== hlen - 1 || algorithm !== 'SHA-512/224') {\n rval.putInt32(h[i][1]);\n }\n }\n return rval;\n };\n\n return md;\n};\n\n// sha-512 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n// table of constants\nvar _k = null;\n\n// initial hash states\nvar _states = null;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n // create padding\n _padding = String.fromCharCode(128);\n _padding += forge.util.fillString(String.fromCharCode(0x00), 128);\n\n // create K table for SHA-512\n _k = [\n [0x428a2f98, 0xd728ae22], [0x71374491, 0x23ef65cd],\n [0xb5c0fbcf, 0xec4d3b2f], [0xe9b5dba5, 0x8189dbbc],\n [0x3956c25b, 0xf348b538], [0x59f111f1, 0xb605d019],\n [0x923f82a4, 0xaf194f9b], [0xab1c5ed5, 0xda6d8118],\n [0xd807aa98, 0xa3030242], [0x12835b01, 0x45706fbe],\n [0x243185be, 0x4ee4b28c], [0x550c7dc3, 0xd5ffb4e2],\n [0x72be5d74, 0xf27b896f], [0x80deb1fe, 0x3b1696b1],\n [0x9bdc06a7, 0x25c71235], [0xc19bf174, 0xcf692694],\n [0xe49b69c1, 0x9ef14ad2], [0xefbe4786, 0x384f25e3],\n [0x0fc19dc6, 0x8b8cd5b5], [0x240ca1cc, 0x77ac9c65],\n [0x2de92c6f, 0x592b0275], [0x4a7484aa, 0x6ea6e483],\n [0x5cb0a9dc, 0xbd41fbd4], [0x76f988da, 0x831153b5],\n [0x983e5152, 0xee66dfab], [0xa831c66d, 0x2db43210],\n [0xb00327c8, 0x98fb213f], [0xbf597fc7, 0xbeef0ee4],\n [0xc6e00bf3, 0x3da88fc2], [0xd5a79147, 0x930aa725],\n [0x06ca6351, 0xe003826f], [0x14292967, 0x0a0e6e70],\n [0x27b70a85, 0x46d22ffc], [0x2e1b2138, 0x5c26c926],\n [0x4d2c6dfc, 0x5ac42aed], [0x53380d13, 0x9d95b3df],\n [0x650a7354, 0x8baf63de], [0x766a0abb, 0x3c77b2a8],\n [0x81c2c92e, 0x47edaee6], [0x92722c85, 0x1482353b],\n [0xa2bfe8a1, 0x4cf10364], [0xa81a664b, 0xbc423001],\n [0xc24b8b70, 0xd0f89791], [0xc76c51a3, 0x0654be30],\n [0xd192e819, 0xd6ef5218], [0xd6990624, 0x5565a910],\n [0xf40e3585, 0x5771202a], [0x106aa070, 0x32bbd1b8],\n [0x19a4c116, 0xb8d2d0c8], [0x1e376c08, 0x5141ab53],\n [0x2748774c, 0xdf8eeb99], [0x34b0bcb5, 0xe19b48a8],\n [0x391c0cb3, 0xc5c95a63], [0x4ed8aa4a, 0xe3418acb],\n [0x5b9cca4f, 0x7763e373], [0x682e6ff3, 0xd6b2b8a3],\n [0x748f82ee, 0x5defb2fc], [0x78a5636f, 0x43172f60],\n [0x84c87814, 0xa1f0ab72], [0x8cc70208, 0x1a6439ec],\n [0x90befffa, 0x23631e28], [0xa4506ceb, 0xde82bde9],\n [0xbef9a3f7, 0xb2c67915], [0xc67178f2, 0xe372532b],\n [0xca273ece, 0xea26619c], [0xd186b8c7, 0x21c0c207],\n [0xeada7dd6, 0xcde0eb1e], [0xf57d4f7f, 0xee6ed178],\n [0x06f067aa, 0x72176fba], [0x0a637dc5, 0xa2c898a6],\n [0x113f9804, 0xbef90dae], [0x1b710b35, 0x131c471b],\n [0x28db77f5, 0x23047d84], [0x32caab7b, 0x40c72493],\n [0x3c9ebe0a, 0x15c9bebc], [0x431d67c4, 0x9c100d4c],\n [0x4cc5d4be, 0xcb3e42b6], [0x597f299c, 0xfc657e2a],\n [0x5fcb6fab, 0x3ad6faec], [0x6c44198c, 0x4a475817]\n ];\n\n // initial hash states\n _states = {};\n _states['SHA-512'] = [\n [0x6a09e667, 0xf3bcc908],\n [0xbb67ae85, 0x84caa73b],\n [0x3c6ef372, 0xfe94f82b],\n [0xa54ff53a, 0x5f1d36f1],\n [0x510e527f, 0xade682d1],\n [0x9b05688c, 0x2b3e6c1f],\n [0x1f83d9ab, 0xfb41bd6b],\n [0x5be0cd19, 0x137e2179]\n ];\n _states['SHA-384'] = [\n [0xcbbb9d5d, 0xc1059ed8],\n [0x629a292a, 0x367cd507],\n [0x9159015a, 0x3070dd17],\n [0x152fecd8, 0xf70e5939],\n [0x67332667, 0xffc00b31],\n [0x8eb44a87, 0x68581511],\n [0xdb0c2e0d, 0x64f98fa7],\n [0x47b5481d, 0xbefa4fa4]\n ];\n _states['SHA-512/256'] = [\n [0x22312194, 0xFC2BF72C],\n [0x9F555FA3, 0xC84C64C2],\n [0x2393B86B, 0x6F53B151],\n [0x96387719, 0x5940EABD],\n [0x96283EE2, 0xA88EFFE3],\n [0xBE5E1E25, 0x53863992],\n [0x2B0199FC, 0x2C85B8AA],\n [0x0EB72DDC, 0x81C52CA2]\n ];\n _states['SHA-512/224'] = [\n [0x8C3D37C8, 0x19544DA2],\n [0x73E19966, 0x89DCD4D6],\n [0x1DFAB7AE, 0x32FF9C82],\n [0x679DD514, 0x582F9FCF],\n [0x0F6D2B69, 0x7BD44DA8],\n [0x77E36F73, 0x04C48942],\n [0x3F9D85A8, 0x6A1D36C8],\n [0x1112E6AD, 0x91D692A1]\n ];\n\n // now initialized\n _initialized = true;\n}\n\n/**\n * Updates a SHA-512 state with the given byte buffer.\n *\n * @param s the SHA-512 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n // consume 512 bit (128 byte) chunks\n var t1_hi, t1_lo;\n var t2_hi, t2_lo;\n var s0_hi, s0_lo;\n var s1_hi, s1_lo;\n var ch_hi, ch_lo;\n var maj_hi, maj_lo;\n var a_hi, a_lo;\n var b_hi, b_lo;\n var c_hi, c_lo;\n var d_hi, d_lo;\n var e_hi, e_lo;\n var f_hi, f_lo;\n var g_hi, g_lo;\n var h_hi, h_lo;\n var i, hi, lo, w2, w7, w15, w16;\n var len = bytes.length();\n while(len >= 128) {\n // the w array will be populated with sixteen 64-bit big-endian words\n // and then extended into 64 64-bit words according to SHA-512\n for(i = 0; i < 16; ++i) {\n w[i][0] = bytes.getInt32() >>> 0;\n w[i][1] = bytes.getInt32() >>> 0;\n }\n for(; i < 80; ++i) {\n // for word 2 words ago: ROTR 19(x) ^ ROTR 61(x) ^ SHR 6(x)\n w2 = w[i - 2];\n hi = w2[0];\n lo = w2[1];\n\n // high bits\n t1_hi = (\n ((hi >>> 19) | (lo << 13)) ^ // ROTR 19\n ((lo >>> 29) | (hi << 3)) ^ // ROTR 61/(swap + ROTR 29)\n (hi >>> 6)) >>> 0; // SHR 6\n // low bits\n t1_lo = (\n ((hi << 13) | (lo >>> 19)) ^ // ROTR 19\n ((lo << 3) | (hi >>> 29)) ^ // ROTR 61/(swap + ROTR 29)\n ((hi << 26) | (lo >>> 6))) >>> 0; // SHR 6\n\n // for word 15 words ago: ROTR 1(x) ^ ROTR 8(x) ^ SHR 7(x)\n w15 = w[i - 15];\n hi = w15[0];\n lo = w15[1];\n\n // high bits\n t2_hi = (\n ((hi >>> 1) | (lo << 31)) ^ // ROTR 1\n ((hi >>> 8) | (lo << 24)) ^ // ROTR 8\n (hi >>> 7)) >>> 0; // SHR 7\n // low bits\n t2_lo = (\n ((hi << 31) | (lo >>> 1)) ^ // ROTR 1\n ((hi << 24) | (lo >>> 8)) ^ // ROTR 8\n ((hi << 25) | (lo >>> 7))) >>> 0; // SHR 7\n\n // sum(t1, word 7 ago, t2, word 16 ago) modulo 2^64 (carry lo overflow)\n w7 = w[i - 7];\n w16 = w[i - 16];\n lo = (t1_lo + w7[1] + t2_lo + w16[1]);\n w[i][0] = (t1_hi + w7[0] + t2_hi + w16[0] +\n ((lo / 0x100000000) >>> 0)) >>> 0;\n w[i][1] = lo >>> 0;\n }\n\n // initialize hash value for this chunk\n a_hi = s[0][0];\n a_lo = s[0][1];\n b_hi = s[1][0];\n b_lo = s[1][1];\n c_hi = s[2][0];\n c_lo = s[2][1];\n d_hi = s[3][0];\n d_lo = s[3][1];\n e_hi = s[4][0];\n e_lo = s[4][1];\n f_hi = s[5][0];\n f_lo = s[5][1];\n g_hi = s[6][0];\n g_lo = s[6][1];\n h_hi = s[7][0];\n h_lo = s[7][1];\n\n // round function\n for(i = 0; i < 80; ++i) {\n // Sum1(e) = ROTR 14(e) ^ ROTR 18(e) ^ ROTR 41(e)\n s1_hi = (\n ((e_hi >>> 14) | (e_lo << 18)) ^ // ROTR 14\n ((e_hi >>> 18) | (e_lo << 14)) ^ // ROTR 18\n ((e_lo >>> 9) | (e_hi << 23))) >>> 0; // ROTR 41/(swap + ROTR 9)\n s1_lo = (\n ((e_hi << 18) | (e_lo >>> 14)) ^ // ROTR 14\n ((e_hi << 14) | (e_lo >>> 18)) ^ // ROTR 18\n ((e_lo << 23) | (e_hi >>> 9))) >>> 0; // ROTR 41/(swap + ROTR 9)\n\n // Ch(e, f, g) (optimized the same way as SHA-1)\n ch_hi = (g_hi ^ (e_hi & (f_hi ^ g_hi))) >>> 0;\n ch_lo = (g_lo ^ (e_lo & (f_lo ^ g_lo))) >>> 0;\n\n // Sum0(a) = ROTR 28(a) ^ ROTR 34(a) ^ ROTR 39(a)\n s0_hi = (\n ((a_hi >>> 28) | (a_lo << 4)) ^ // ROTR 28\n ((a_lo >>> 2) | (a_hi << 30)) ^ // ROTR 34/(swap + ROTR 2)\n ((a_lo >>> 7) | (a_hi << 25))) >>> 0; // ROTR 39/(swap + ROTR 7)\n s0_lo = (\n ((a_hi << 4) | (a_lo >>> 28)) ^ // ROTR 28\n ((a_lo << 30) | (a_hi >>> 2)) ^ // ROTR 34/(swap + ROTR 2)\n ((a_lo << 25) | (a_hi >>> 7))) >>> 0; // ROTR 39/(swap + ROTR 7)\n\n // Maj(a, b, c) (optimized the same way as SHA-1)\n maj_hi = ((a_hi & b_hi) | (c_hi & (a_hi ^ b_hi))) >>> 0;\n maj_lo = ((a_lo & b_lo) | (c_lo & (a_lo ^ b_lo))) >>> 0;\n\n // main algorithm\n // t1 = (h + s1 + ch + _k[i] + _w[i]) modulo 2^64 (carry lo overflow)\n lo = (h_lo + s1_lo + ch_lo + _k[i][1] + w[i][1]);\n t1_hi = (h_hi + s1_hi + ch_hi + _k[i][0] + w[i][0] +\n ((lo / 0x100000000) >>> 0)) >>> 0;\n t1_lo = lo >>> 0;\n\n // t2 = s0 + maj modulo 2^64 (carry lo overflow)\n lo = s0_lo + maj_lo;\n t2_hi = (s0_hi + maj_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n t2_lo = lo >>> 0;\n\n h_hi = g_hi;\n h_lo = g_lo;\n\n g_hi = f_hi;\n g_lo = f_lo;\n\n f_hi = e_hi;\n f_lo = e_lo;\n\n // e = (d + t1) modulo 2^64 (carry lo overflow)\n lo = d_lo + t1_lo;\n e_hi = (d_hi + t1_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n e_lo = lo >>> 0;\n\n d_hi = c_hi;\n d_lo = c_lo;\n\n c_hi = b_hi;\n c_lo = b_lo;\n\n b_hi = a_hi;\n b_lo = a_lo;\n\n // a = (t1 + t2) modulo 2^64 (carry lo overflow)\n lo = t1_lo + t2_lo;\n a_hi = (t1_hi + t2_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n a_lo = lo >>> 0;\n }\n\n // update hash state (additional modulo 2^64)\n lo = s[0][1] + a_lo;\n s[0][0] = (s[0][0] + a_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[0][1] = lo >>> 0;\n\n lo = s[1][1] + b_lo;\n s[1][0] = (s[1][0] + b_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[1][1] = lo >>> 0;\n\n lo = s[2][1] + c_lo;\n s[2][0] = (s[2][0] + c_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[2][1] = lo >>> 0;\n\n lo = s[3][1] + d_lo;\n s[3][0] = (s[3][0] + d_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[3][1] = lo >>> 0;\n\n lo = s[4][1] + e_lo;\n s[4][0] = (s[4][0] + e_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[4][1] = lo >>> 0;\n\n lo = s[5][1] + f_lo;\n s[5][0] = (s[5][0] + f_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[5][1] = lo >>> 0;\n\n lo = s[6][1] + g_lo;\n s[6][0] = (s[6][0] + g_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[6][1] = lo >>> 0;\n\n lo = s[7][1] + h_lo;\n s[7][0] = (s[7][0] + h_hi + ((lo / 0x100000000) >>> 0)) >>> 0;\n s[7][1] = lo >>> 0;\n\n len -= 128;\n }\n}\n","/**\n * Cross-browser support for logging in a web application.\n *\n * @author David I. Lehn <dlehn@digitalbazaar.com>\n *\n * Copyright (c) 2008-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\n/* LOG API */\nmodule.exports = forge.log = forge.log || {};\n\n/**\n * Application logging system.\n *\n * Each logger level available as it's own function of the form:\n * forge.log.level(category, args...)\n * The category is an arbitrary string, and the args are the same as\n * Firebug's console.log API. By default the call will be output as:\n * 'LEVEL [category] <args[0]>, args[1], ...'\n * This enables proper % formatting via the first argument.\n * Each category is enabled by default but can be enabled or disabled with\n * the setCategoryEnabled() function.\n */\n// list of known levels\nforge.log.levels = [\n 'none', 'error', 'warning', 'info', 'debug', 'verbose', 'max'];\n// info on the levels indexed by name:\n// index: level index\n// name: uppercased display name\nvar sLevelInfo = {};\n// list of loggers\nvar sLoggers = [];\n/**\n * Standard console logger. If no console support is enabled this will\n * remain null. Check before using.\n */\nvar sConsoleLogger = null;\n\n// logger flags\n/**\n * Lock the level at the current value. Used in cases where user config may\n * set the level such that only critical messages are seen but more verbose\n * messages are needed for debugging or other purposes.\n */\nforge.log.LEVEL_LOCKED = (1 << 1);\n/**\n * Always call log function. By default, the logging system will check the\n * message level against logger.level before calling the log function. This\n * flag allows the function to do its own check.\n */\nforge.log.NO_LEVEL_CHECK = (1 << 2);\n/**\n * Perform message interpolation with the passed arguments. \"%\" style\n * fields in log messages will be replaced by arguments as needed. Some\n * loggers, such as Firebug, may do this automatically. The original log\n * message will be available as 'message' and the interpolated version will\n * be available as 'fullMessage'.\n */\nforge.log.INTERPOLATE = (1 << 3);\n\n// setup each log level\nfor(var i = 0; i < forge.log.levels.length; ++i) {\n var level = forge.log.levels[i];\n sLevelInfo[level] = {\n index: i,\n name: level.toUpperCase()\n };\n}\n\n/**\n * Message logger. Will dispatch a message to registered loggers as needed.\n *\n * @param message message object\n */\nforge.log.logMessage = function(message) {\n var messageLevelIndex = sLevelInfo[message.level].index;\n for(var i = 0; i < sLoggers.length; ++i) {\n var logger = sLoggers[i];\n if(logger.flags & forge.log.NO_LEVEL_CHECK) {\n logger.f(message);\n } else {\n // get logger level\n var loggerLevelIndex = sLevelInfo[logger.level].index;\n // check level\n if(messageLevelIndex <= loggerLevelIndex) {\n // message critical enough, call logger\n logger.f(logger, message);\n }\n }\n }\n};\n\n/**\n * Sets the 'standard' key on a message object to:\n * \"LEVEL [category] \" + message\n *\n * @param message a message log object\n */\nforge.log.prepareStandard = function(message) {\n if(!('standard' in message)) {\n message.standard =\n sLevelInfo[message.level].name +\n //' ' + +message.timestamp +\n ' [' + message.category + '] ' +\n message.message;\n }\n};\n\n/**\n * Sets the 'full' key on a message object to the original message\n * interpolated via % formatting with the message arguments.\n *\n * @param message a message log object.\n */\nforge.log.prepareFull = function(message) {\n if(!('full' in message)) {\n // copy args and insert message at the front\n var args = [message.message];\n args = args.concat([] || message['arguments']);\n // format the message\n message.full = forge.util.format.apply(this, args);\n }\n};\n\n/**\n * Applies both preparseStandard() and prepareFull() to a message object and\n * store result in 'standardFull'.\n *\n * @param message a message log object.\n */\nforge.log.prepareStandardFull = function(message) {\n if(!('standardFull' in message)) {\n // FIXME implement 'standardFull' logging\n forge.log.prepareStandard(message);\n message.standardFull = message.standard;\n }\n};\n\n// create log level functions\nif(true) {\n // levels for which we want functions\n var levels = ['error', 'warning', 'info', 'debug', 'verbose'];\n for(var i = 0; i < levels.length; ++i) {\n // wrap in a function to ensure proper level var is passed\n (function(level) {\n // create function for this level\n forge.log[level] = function(category, message/*, args...*/) {\n // convert arguments to real array, remove category and message\n var args = Array.prototype.slice.call(arguments).slice(2);\n // create message object\n // Note: interpolation and standard formatting is done lazily\n var msg = {\n timestamp: new Date(),\n level: level,\n category: category,\n message: message,\n 'arguments': args\n /*standard*/\n /*full*/\n /*fullMessage*/\n };\n // process this message\n forge.log.logMessage(msg);\n };\n })(levels[i]);\n }\n}\n\n/**\n * Creates a new logger with specified custom logging function.\n *\n * The logging function has a signature of:\n * function(logger, message)\n * logger: current logger\n * message: object:\n * level: level id\n * category: category\n * message: string message\n * arguments: Array of extra arguments\n * fullMessage: interpolated message and arguments if INTERPOLATE flag set\n *\n * @param logFunction a logging function which takes a log message object\n * as a parameter.\n *\n * @return a logger object.\n */\nforge.log.makeLogger = function(logFunction) {\n var logger = {\n flags: 0,\n f: logFunction\n };\n forge.log.setLevel(logger, 'none');\n return logger;\n};\n\n/**\n * Sets the current log level on a logger.\n *\n * @param logger the target logger.\n * @param level the new maximum log level as a string.\n *\n * @return true if set, false if not.\n */\nforge.log.setLevel = function(logger, level) {\n var rval = false;\n if(logger && !(logger.flags & forge.log.LEVEL_LOCKED)) {\n for(var i = 0; i < forge.log.levels.length; ++i) {\n var aValidLevel = forge.log.levels[i];\n if(level == aValidLevel) {\n // set level\n logger.level = level;\n rval = true;\n break;\n }\n }\n }\n\n return rval;\n};\n\n/**\n * Locks the log level at its current value.\n *\n * @param logger the target logger.\n * @param lock boolean lock value, default to true.\n */\nforge.log.lock = function(logger, lock) {\n if(typeof lock === 'undefined' || lock) {\n logger.flags |= forge.log.LEVEL_LOCKED;\n } else {\n logger.flags &= ~forge.log.LEVEL_LOCKED;\n }\n};\n\n/**\n * Adds a logger.\n *\n * @param logger the logger object.\n */\nforge.log.addLogger = function(logger) {\n sLoggers.push(logger);\n};\n\n// setup the console logger if possible, else create fake console.log\nif(typeof(console) !== 'undefined' && 'log' in console) {\n var logger;\n if(console.error && console.warn && console.info && console.debug) {\n // looks like Firebug-style logging is available\n // level handlers map\n var levelHandlers = {\n error: console.error,\n warning: console.warn,\n info: console.info,\n debug: console.debug,\n verbose: console.debug\n };\n var f = function(logger, message) {\n forge.log.prepareStandard(message);\n var handler = levelHandlers[message.level];\n // prepend standard message and concat args\n var args = [message.standard];\n args = args.concat(message['arguments'].slice());\n // apply to low-level console function\n handler.apply(console, args);\n };\n logger = forge.log.makeLogger(f);\n } else {\n // only appear to have basic console.log\n var f = function(logger, message) {\n forge.log.prepareStandardFull(message);\n console.log(message.standardFull);\n };\n logger = forge.log.makeLogger(f);\n }\n forge.log.setLevel(logger, 'debug');\n forge.log.addLogger(logger);\n sConsoleLogger = logger;\n} else {\n // define fake console.log to avoid potential script errors on\n // browsers that do not have console logging\n console = {\n log: function() {}\n };\n}\n\n/*\n * Check for logging control query vars.\n *\n * console.level=<level-name>\n * Set's the console log level by name. Useful to override defaults and\n * allow more verbose logging before a user config is loaded.\n *\n * console.lock=<true|false>\n * Lock the console log level at whatever level it is set at. This is run\n * after console.level is processed. Useful to force a level of verbosity\n * that could otherwise be limited by a user config.\n */\nif(sConsoleLogger !== null) {\n var query = forge.util.getQueryVariables();\n if('console.level' in query) {\n // set with last value\n forge.log.setLevel(\n sConsoleLogger, query['console.level'].slice(-1)[0]);\n }\n if('console.lock' in query) {\n // set with last value\n var lock = query['console.lock'].slice(-1)[0];\n if(lock == 'true') {\n forge.log.lock(sConsoleLogger);\n }\n }\n}\n\n// provide public access to console logger\nforge.log.consoleLogger = sConsoleLogger;\n","\"use strict\";\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar form_data_1 = __importDefault(require(\"form-data\"));\nvar DEFAULT_METHOD = \"POST\";\nexports.submitFormData = function (formActionUrl, formData, fetchRequestInit) {\n if (fetchRequestInit === void 0) { fetchRequestInit = {}; }\n return new Promise(function (resolve, reject) {\n var mergedFetchRequestInit = __assign({ body: formData, method: DEFAULT_METHOD }, fetchRequestInit);\n fetch(formActionUrl, mergedFetchRequestInit)\n .then(function (response) {\n resolve(response);\n })\n .catch(function (err) {\n reject(err);\n });\n });\n};\nexports.submitForm = function (formActionUrl, form, fetchRequestInit) {\n if (fetchRequestInit === void 0) { fetchRequestInit = {}; }\n return exports.submitFormData(formActionUrl, new form_data_1.default(form), fetchRequestInit);\n};\nexports.default = {\n submitFormData: exports.submitFormData,\n submitForm: exports.submitForm\n};\n","import 'jquery';\nimport 'bootstrap';\nimport 'jquery-form'\nimport {ConfirmDialog} from './confirm-modal.js';\n\njQuery = window.$ = window.jQuery = require('jquery');\nvar forge = require('node-forge');\nvar QRCode = require(\"qrcode-svg\");\nvar pki = require('node-forge/lib/pki');\nvar asn1 = require('node-forge/lib/asn1');\nvar pkcs12 = require('node-forge/lib/pkcs12');\nvar util = require('node-forge/lib/util');\nimport SimpleFormSubmit from \"simple-form-submit\";\n\nconst $ = document.querySelector.bind(document);\nconst $$ = document.querySelectorAll.bind(document);\n\n\n/*\nConvert an ArrayBuffer into a string\nfrom https://developers.google.com/web/updates/2012/06/How-to-convert-ArrayBuffer-to-and-from-String\n*/\nfunction ab2str(buf) {\n\treturn String.fromCharCode.apply(null, new Uint8Array(buf));\n}\n\n\nfunction randBase32() {\n\t// src: https://en.wikipedia.org/wiki/Base32 RFC4648\n\tconst alphabet = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y','Z','2', '3', '4', '5', '6', '7'];\n\tvar result = '';\n\tvar buf = new Uint8Array(1);\n\tfor ( var i = 0; i < 16; i++ ) {\n\t\twindow.crypto.getRandomValues(buf);\n\t\tvar rand_val = buf[0] & 31;\n\t\tresult += alphabet[rand_val];\n\t}\n\treturn result;\n}\n\nwindow.ConfirmDialog = ConfirmDialog;\n\nwindow.$(document).ready(function () {\n\t$('#sidebarCollapse').onclick = function () {\n\t\t$('nav.sidebar').classList.toggle('d-none');\n\t};\n});\n\nwindow.totp = {\n\tinit_list: function(){\n\t},\n\tinit_new: function() {\n\t\t//create new TOTP secret, create qrcode and ask for token.\n\t\tvar form = $('form');\n\t\tvar secret = randBase32();\n\t\tvar input_secret = form.querySelector('#secret')\n\t\tif(input_secret.value == '') {\n\t\t\tinput_secret.value = secret;\n\t\t}\n\n\t\tform.querySelector('#name').on('change',window.totp.generate_qrcode);\n\t\twindow.totp.generate_qrcode();\n\t},\n\tgenerate_qrcode: function(){\n\t\tvar form = $('form');\n\t\tvar secret = form.querySelector('#secret').value;\n\t\tvar name = form.querySelector('#name').value;\n\t\tvar issuer = 'Lenticular%20Cloud';\n\t\tvar svg_container = $('#svg-container')\n\t\tvar svg = new QRCode(`otpauth://totp/${issuer}:${name}?secret=${secret}&issuer=${issuer}`).svg();\n\t\tsvg_container.html(svg);\n\t}\n}\n\nwindow.fido2 = {\n\tinit: function() {\n\n\t}\n}\n\n\nwindow.client_cert = {\n\tinit_list: function() {\n\t\t// do fancy cert stats stuff\n\t},\n\tinit_new: function() {\n\t\t// create localy key or import public key\n\n\t\tvar form = $('form#gen-key-form');\n\n\t},\n\tgenerate_private_key: function() {\n\t\tvar form = $('form#gen-key-form');\n\t\tvar key_size = form.querySelector('#key-size').value;\n\t\tvar valid_time = form.querySelector('input[name=valid_time]').value;\n\t\t$('button#generate-key').style['display'] = 'none';\n\t\tpki.rsa.generateKeyPair({bits: key_size, workers: 2}, function(err, keypair) {\n\t\t\tconsole.log(keypair);\n\n\t\t\t//returns the exported key to a hidden form\n\t\t\tvar form_sign_key = $('#gen-key-sign form');\n\t\t\tform_sign_key.querySelector('textarea[name=publickey]').value = pki.publicKeyToPem(keypair.publicKey);\n\t\t\tform_sign_key.querySelector('input[name=valid_time]').value = valid_time;\n\n\t\t\tSimpleFormSubmit.submitForm(form_sign_key.action, form_sign_key)\n\t\t\t\t.then(response => {\n\t\t\t\t\tresponse.json().then( response => {\n\t\t\t\t\t\t// get certificate\n\t\t\t\t\t\tvar data = response.data;\n\t\t\t\t\t\tvar certs = [\n\t\t\t\t\t\t\tpki.certificateFromPem(data.cert),\n\t\t\t\t\t\t\tpki.certificateFromPem(data.ca_cert)\n\t\t\t\t\t\t];\n\t\t\t\t\t\tvar password = form.querySelector('#cert-password').value;\n\t\t\t\t\t\tvar p12Asn1;\n\t\t\t\t\t\tif (password == '') {\n\t\t\t\t\t\t\tp12Asn1 = pkcs12.toPkcs12Asn1(keypair.privateKey, certs, null, {algorithm: '3des'}); // without password\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tp12Asn1 = pkcs12.toPkcs12Asn1(keypair.privateKey, certs, password, {algorithm: '3des'}); // without password\n\t\t\t\t\t\t}\n\t\t\t\t\t\tvar p12Der = asn1.toDer(p12Asn1).getBytes();\n\t\t\t\t\t\tvar p12b64 = util.encode64(p12Der);\n\n\n\t\t\t\t\t\tvar button = $('#save-button');\n\t\t\t\t\t\tbutton.href= \"data:application/x-pkcs12;base64,\" + p12b64\n\t\t\t\t\t\tbutton.style['display'] ='block';\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t});\n\t},\n\trevoke_certificate: function(href, id){\n\t\tvar dialog = new ConfirmDialog(`Are you sure to revoke the certificate with the fingerprint ${id}?`);\n\t\tdialog.show().then(()=>{\n\t\t\tfetch(href, {\n\t\t\t\tmethod: 'DELETE'\n\t\t\t});\n\t\t});\n\t\treturn false;\n\t}\n};\n\n","/*!\n * Bootstrap v4.4.1 (https://getbootstrap.com/)\n * Copyright 2011-2019 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n */\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('jquery'), require('popper.js')) :\n typeof define === 'function' && define.amd ? define(['exports', 'jquery', 'popper.js'], factory) :\n (global = global || self, factory(global.bootstrap = {}, global.jQuery, global.Popper));\n}(this, (function (exports, $, Popper) { 'use strict';\n\n $ = $ && $.hasOwnProperty('default') ? $['default'] : $;\n Popper = Popper && Popper.hasOwnProperty('default') ? Popper['default'] : Popper;\n\n function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n }\n\n function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n }\n\n function ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n if (enumerableOnly) symbols = symbols.filter(function (sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n keys.push.apply(keys, symbols);\n }\n\n return keys;\n }\n\n function _objectSpread2(target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i] != null ? arguments[i] : {};\n\n if (i % 2) {\n ownKeys(Object(source), true).forEach(function (key) {\n _defineProperty(target, key, source[key]);\n });\n } else if (Object.getOwnPropertyDescriptors) {\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n } else {\n ownKeys(Object(source)).forEach(function (key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n }\n\n return target;\n }\n\n function _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n }\n\n /**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.4.1): util.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n /**\n * ------------------------------------------------------------------------\n * Private TransitionEnd Helpers\n * ------------------------------------------------------------------------\n */\n\n var TRANSITION_END = 'transitionend';\n var MAX_UID = 1000000;\n var MILLISECONDS_MULTIPLIER = 1000; // Shoutout AngusCroll (https://goo.gl/pxwQGp)\n\n function toType(obj) {\n return {}.toString.call(obj).match(/\\s([a-z]+)/i)[1].toLowerCase();\n }\n\n function getSpecialTransitionEndEvent() {\n return {\n bindType: TRANSITION_END,\n delegateType: TRANSITION_END,\n handle: function handle(event) {\n if ($(event.target).is(this)) {\n return event.handleObj.handler.apply(this, arguments); // eslint-disable-line prefer-rest-params\n }\n\n return undefined; // eslint-disable-line no-undefined\n }\n };\n }\n\n function transitionEndEmulator(duration) {\n var _this = this;\n\n var called = false;\n $(this).one(Util.TRANSITION_END, function () {\n called = true;\n });\n setTimeout(function () {\n if (!called) {\n Util.triggerTransitionEnd(_this);\n }\n }, duration);\n return this;\n }\n\n function setTransitionEndSupport() {\n $.fn.emulateTransitionEnd = transitionEndEmulator;\n $.event.special[Util.TRANSITION_END] = getSpecialTransitionEndEvent();\n }\n /**\n * --------------------------------------------------------------------------\n * Public Util Api\n * --------------------------------------------------------------------------\n */\n\n\n var Util = {\n TRANSITION_END: 'bsTransitionEnd',\n getUID: function getUID(prefix) {\n do {\n // eslint-disable-next-line no-bitwise\n prefix += ~~(Math.random() * MAX_UID); // \"~~\" acts like a faster Math.floor() here\n } while (document.getElementById(prefix));\n\n return prefix;\n },\n getSelectorFromElement: function getSelectorFromElement(element) {\n var selector = element.getAttribute('data-target');\n\n if (!selector || selector === '#') {\n var hrefAttr = element.getAttribute('href');\n selector = hrefAttr && hrefAttr !== '#' ? hrefAttr.trim() : '';\n }\n\n try {\n return document.querySelector(selector) ? selector : null;\n } catch (err) {\n return null;\n }\n },\n getTransitionDurationFromElement: function getTransitionDurationFromElement(element) {\n if (!element) {\n return 0;\n } // Get transition-duration of the element\n\n\n var transitionDuration = $(element).css('transition-duration');\n var transitionDelay = $(element).css('transition-delay');\n var floatTransitionDuration = parseFloat(transitionDuration);\n var floatTransitionDelay = parseFloat(transitionDelay); // Return 0 if element or transition duration is not found\n\n if (!floatTransitionDuration && !floatTransitionDelay) {\n return 0;\n } // If multiple durations are defined, take the first\n\n\n transitionDuration = transitionDuration.split(',')[0];\n transitionDelay = transitionDelay.split(',')[0];\n return (parseFloat(transitionDuration) + parseFloat(transitionDelay)) * MILLISECONDS_MULTIPLIER;\n },\n reflow: function reflow(element) {\n return element.offsetHeight;\n },\n triggerTransitionEnd: function triggerTransitionEnd(element) {\n $(element).trigger(TRANSITION_END);\n },\n // TODO: Remove in v5\n supportsTransitionEnd: function supportsTransitionEnd() {\n return Boolean(TRANSITION_END);\n },\n isElement: function isElement(obj) {\n return (obj[0] || obj).nodeType;\n },\n typeCheckConfig: function typeCheckConfig(componentName, config, configTypes) {\n for (var property in configTypes) {\n if (Object.prototype.hasOwnProperty.call(configTypes, property)) {\n var expectedTypes = configTypes[property];\n var value = config[property];\n var valueType = value && Util.isElement(value) ? 'element' : toType(value);\n\n if (!new RegExp(expectedTypes).test(valueType)) {\n throw new Error(componentName.toUpperCase() + \": \" + (\"Option \\\"\" + property + \"\\\" provided type \\\"\" + valueType + \"\\\" \") + (\"but expected type \\\"\" + expectedTypes + \"\\\".\"));\n }\n }\n }\n },\n findShadowRoot: function findShadowRoot(element) {\n if (!document.documentElement.attachShadow) {\n return null;\n } // Can find the shadow root otherwise it'll return the document\n\n\n if (typeof element.getRootNode === 'function') {\n var root = element.getRootNode();\n return root instanceof ShadowRoot ? root : null;\n }\n\n if (element instanceof ShadowRoot) {\n return element;\n } // when we don't find a shadow root\n\n\n if (!element.parentNode) {\n return null;\n }\n\n return Util.findShadowRoot(element.parentNode);\n },\n jQueryDetection: function jQueryDetection() {\n if (typeof $ === 'undefined') {\n throw new TypeError('Bootstrap\\'s JavaScript requires jQuery. jQuery must be included before Bootstrap\\'s JavaScript.');\n }\n\n var version = $.fn.jquery.split(' ')[0].split('.');\n var minMajor = 1;\n var ltMajor = 2;\n var minMinor = 9;\n var minPatch = 1;\n var maxMajor = 4;\n\n if (version[0] < ltMajor && version[1] < minMinor || version[0] === minMajor && version[1] === minMinor && version[2] < minPatch || version[0] >= maxMajor) {\n throw new Error('Bootstrap\\'s JavaScript requires at least jQuery v1.9.1 but less than v4.0.0');\n }\n }\n };\n Util.jQueryDetection();\n setTransitionEndSupport();\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME = 'alert';\n var VERSION = '4.4.1';\n var DATA_KEY = 'bs.alert';\n var EVENT_KEY = \".\" + DATA_KEY;\n var DATA_API_KEY = '.data-api';\n var JQUERY_NO_CONFLICT = $.fn[NAME];\n var Selector = {\n DISMISS: '[data-dismiss=\"alert\"]'\n };\n var Event = {\n CLOSE: \"close\" + EVENT_KEY,\n CLOSED: \"closed\" + EVENT_KEY,\n CLICK_DATA_API: \"click\" + EVENT_KEY + DATA_API_KEY\n };\n var ClassName = {\n ALERT: 'alert',\n FADE: 'fade',\n SHOW: 'show'\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Alert =\n /*#__PURE__*/\n function () {\n function Alert(element) {\n this._element = element;\n } // Getters\n\n\n var _proto = Alert.prototype;\n\n // Public\n _proto.close = function close(element) {\n var rootElement = this._element;\n\n if (element) {\n rootElement = this._getRootElement(element);\n }\n\n var customEvent = this._triggerCloseEvent(rootElement);\n\n if (customEvent.isDefaultPrevented()) {\n return;\n }\n\n this._removeElement(rootElement);\n };\n\n _proto.dispose = function dispose() {\n $.removeData(this._element, DATA_KEY);\n this._element = null;\n } // Private\n ;\n\n _proto._getRootElement = function _getRootElement(element) {\n var selector = Util.getSelectorFromElement(element);\n var parent = false;\n\n if (selector) {\n parent = document.querySelector(selector);\n }\n\n if (!parent) {\n parent = $(element).closest(\".\" + ClassName.ALERT)[0];\n }\n\n return parent;\n };\n\n _proto._triggerCloseEvent = function _triggerCloseEvent(element) {\n var closeEvent = $.Event(Event.CLOSE);\n $(element).trigger(closeEvent);\n return closeEvent;\n };\n\n _proto._removeElement = function _removeElement(element) {\n var _this = this;\n\n $(element).removeClass(ClassName.SHOW);\n\n if (!$(element).hasClass(ClassName.FADE)) {\n this._destroyElement(element);\n\n return;\n }\n\n var transitionDuration = Util.getTransitionDurationFromElement(element);\n $(element).one(Util.TRANSITION_END, function (event) {\n return _this._destroyElement(element, event);\n }).emulateTransitionEnd(transitionDuration);\n };\n\n _proto._destroyElement = function _destroyElement(element) {\n $(element).detach().trigger(Event.CLOSED).remove();\n } // Static\n ;\n\n Alert._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var $element = $(this);\n var data = $element.data(DATA_KEY);\n\n if (!data) {\n data = new Alert(this);\n $element.data(DATA_KEY, data);\n }\n\n if (config === 'close') {\n data[config](this);\n }\n });\n };\n\n Alert._handleDismiss = function _handleDismiss(alertInstance) {\n return function (event) {\n if (event) {\n event.preventDefault();\n }\n\n alertInstance.close(this);\n };\n };\n\n _createClass(Alert, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION;\n }\n }]);\n\n return Alert;\n }();\n /**\n * ------------------------------------------------------------------------\n * Data Api implementation\n * ------------------------------------------------------------------------\n */\n\n\n $(document).on(Event.CLICK_DATA_API, Selector.DISMISS, Alert._handleDismiss(new Alert()));\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n $.fn[NAME] = Alert._jQueryInterface;\n $.fn[NAME].Constructor = Alert;\n\n $.fn[NAME].noConflict = function () {\n $.fn[NAME] = JQUERY_NO_CONFLICT;\n return Alert._jQueryInterface;\n };\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$1 = 'button';\n var VERSION$1 = '4.4.1';\n var DATA_KEY$1 = 'bs.button';\n var EVENT_KEY$1 = \".\" + DATA_KEY$1;\n var DATA_API_KEY$1 = '.data-api';\n var JQUERY_NO_CONFLICT$1 = $.fn[NAME$1];\n var ClassName$1 = {\n ACTIVE: 'active',\n BUTTON: 'btn',\n FOCUS: 'focus'\n };\n var Selector$1 = {\n DATA_TOGGLE_CARROT: '[data-toggle^=\"button\"]',\n DATA_TOGGLES: '[data-toggle=\"buttons\"]',\n DATA_TOGGLE: '[data-toggle=\"button\"]',\n DATA_TOGGLES_BUTTONS: '[data-toggle=\"buttons\"] .btn',\n INPUT: 'input:not([type=\"hidden\"])',\n ACTIVE: '.active',\n BUTTON: '.btn'\n };\n var Event$1 = {\n CLICK_DATA_API: \"click\" + EVENT_KEY$1 + DATA_API_KEY$1,\n FOCUS_BLUR_DATA_API: \"focus\" + EVENT_KEY$1 + DATA_API_KEY$1 + \" \" + (\"blur\" + EVENT_KEY$1 + DATA_API_KEY$1),\n LOAD_DATA_API: \"load\" + EVENT_KEY$1 + DATA_API_KEY$1\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Button =\n /*#__PURE__*/\n function () {\n function Button(element) {\n this._element = element;\n } // Getters\n\n\n var _proto = Button.prototype;\n\n // Public\n _proto.toggle = function toggle() {\n var triggerChangeEvent = true;\n var addAriaPressed = true;\n var rootElement = $(this._element).closest(Selector$1.DATA_TOGGLES)[0];\n\n if (rootElement) {\n var input = this._element.querySelector(Selector$1.INPUT);\n\n if (input) {\n if (input.type === 'radio') {\n if (input.checked && this._element.classList.contains(ClassName$1.ACTIVE)) {\n triggerChangeEvent = false;\n } else {\n var activeElement = rootElement.querySelector(Selector$1.ACTIVE);\n\n if (activeElement) {\n $(activeElement).removeClass(ClassName$1.ACTIVE);\n }\n }\n } else if (input.type === 'checkbox') {\n if (this._element.tagName === 'LABEL' && input.checked === this._element.classList.contains(ClassName$1.ACTIVE)) {\n triggerChangeEvent = false;\n }\n } else {\n // if it's not a radio button or checkbox don't add a pointless/invalid checked property to the input\n triggerChangeEvent = false;\n }\n\n if (triggerChangeEvent) {\n input.checked = !this._element.classList.contains(ClassName$1.ACTIVE);\n $(input).trigger('change');\n }\n\n input.focus();\n addAriaPressed = false;\n }\n }\n\n if (!(this._element.hasAttribute('disabled') || this._element.classList.contains('disabled'))) {\n if (addAriaPressed) {\n this._element.setAttribute('aria-pressed', !this._element.classList.contains(ClassName$1.ACTIVE));\n }\n\n if (triggerChangeEvent) {\n $(this._element).toggleClass(ClassName$1.ACTIVE);\n }\n }\n };\n\n _proto.dispose = function dispose() {\n $.removeData(this._element, DATA_KEY$1);\n this._element = null;\n } // Static\n ;\n\n Button._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var data = $(this).data(DATA_KEY$1);\n\n if (!data) {\n data = new Button(this);\n $(this).data(DATA_KEY$1, data);\n }\n\n if (config === 'toggle') {\n data[config]();\n }\n });\n };\n\n _createClass(Button, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION$1;\n }\n }]);\n\n return Button;\n }();\n /**\n * ------------------------------------------------------------------------\n * Data Api implementation\n * ------------------------------------------------------------------------\n */\n\n\n $(document).on(Event$1.CLICK_DATA_API, Selector$1.DATA_TOGGLE_CARROT, function (event) {\n var button = event.target;\n\n if (!$(button).hasClass(ClassName$1.BUTTON)) {\n button = $(button).closest(Selector$1.BUTTON)[0];\n }\n\n if (!button || button.hasAttribute('disabled') || button.classList.contains('disabled')) {\n event.preventDefault(); // work around Firefox bug #1540995\n } else {\n var inputBtn = button.querySelector(Selector$1.INPUT);\n\n if (inputBtn && (inputBtn.hasAttribute('disabled') || inputBtn.classList.contains('disabled'))) {\n event.preventDefault(); // work around Firefox bug #1540995\n\n return;\n }\n\n Button._jQueryInterface.call($(button), 'toggle');\n }\n }).on(Event$1.FOCUS_BLUR_DATA_API, Selector$1.DATA_TOGGLE_CARROT, function (event) {\n var button = $(event.target).closest(Selector$1.BUTTON)[0];\n $(button).toggleClass(ClassName$1.FOCUS, /^focus(in)?$/.test(event.type));\n });\n $(window).on(Event$1.LOAD_DATA_API, function () {\n // ensure correct active class is set to match the controls' actual values/states\n // find all checkboxes/readio buttons inside data-toggle groups\n var buttons = [].slice.call(document.querySelectorAll(Selector$1.DATA_TOGGLES_BUTTONS));\n\n for (var i = 0, len = buttons.length; i < len; i++) {\n var button = buttons[i];\n var input = button.querySelector(Selector$1.INPUT);\n\n if (input.checked || input.hasAttribute('checked')) {\n button.classList.add(ClassName$1.ACTIVE);\n } else {\n button.classList.remove(ClassName$1.ACTIVE);\n }\n } // find all button toggles\n\n\n buttons = [].slice.call(document.querySelectorAll(Selector$1.DATA_TOGGLE));\n\n for (var _i = 0, _len = buttons.length; _i < _len; _i++) {\n var _button = buttons[_i];\n\n if (_button.getAttribute('aria-pressed') === 'true') {\n _button.classList.add(ClassName$1.ACTIVE);\n } else {\n _button.classList.remove(ClassName$1.ACTIVE);\n }\n }\n });\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n $.fn[NAME$1] = Button._jQueryInterface;\n $.fn[NAME$1].Constructor = Button;\n\n $.fn[NAME$1].noConflict = function () {\n $.fn[NAME$1] = JQUERY_NO_CONFLICT$1;\n return Button._jQueryInterface;\n };\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$2 = 'carousel';\n var VERSION$2 = '4.4.1';\n var DATA_KEY$2 = 'bs.carousel';\n var EVENT_KEY$2 = \".\" + DATA_KEY$2;\n var DATA_API_KEY$2 = '.data-api';\n var JQUERY_NO_CONFLICT$2 = $.fn[NAME$2];\n var ARROW_LEFT_KEYCODE = 37; // KeyboardEvent.which value for left arrow key\n\n var ARROW_RIGHT_KEYCODE = 39; // KeyboardEvent.which value for right arrow key\n\n var TOUCHEVENT_COMPAT_WAIT = 500; // Time for mouse compat events to fire after touch\n\n var SWIPE_THRESHOLD = 40;\n var Default = {\n interval: 5000,\n keyboard: true,\n slide: false,\n pause: 'hover',\n wrap: true,\n touch: true\n };\n var DefaultType = {\n interval: '(number|boolean)',\n keyboard: 'boolean',\n slide: '(boolean|string)',\n pause: '(string|boolean)',\n wrap: 'boolean',\n touch: 'boolean'\n };\n var Direction = {\n NEXT: 'next',\n PREV: 'prev',\n LEFT: 'left',\n RIGHT: 'right'\n };\n var Event$2 = {\n SLIDE: \"slide\" + EVENT_KEY$2,\n SLID: \"slid\" + EVENT_KEY$2,\n KEYDOWN: \"keydown\" + EVENT_KEY$2,\n MOUSEENTER: \"mouseenter\" + EVENT_KEY$2,\n MOUSELEAVE: \"mouseleave\" + EVENT_KEY$2,\n TOUCHSTART: \"touchstart\" + EVENT_KEY$2,\n TOUCHMOVE: \"touchmove\" + EVENT_KEY$2,\n TOUCHEND: \"touchend\" + EVENT_KEY$2,\n POINTERDOWN: \"pointerdown\" + EVENT_KEY$2,\n POINTERUP: \"pointerup\" + EVENT_KEY$2,\n DRAG_START: \"dragstart\" + EVENT_KEY$2,\n LOAD_DATA_API: \"load\" + EVENT_KEY$2 + DATA_API_KEY$2,\n CLICK_DATA_API: \"click\" + EVENT_KEY$2 + DATA_API_KEY$2\n };\n var ClassName$2 = {\n CAROUSEL: 'carousel',\n ACTIVE: 'active',\n SLIDE: 'slide',\n RIGHT: 'carousel-item-right',\n LEFT: 'carousel-item-left',\n NEXT: 'carousel-item-next',\n PREV: 'carousel-item-prev',\n ITEM: 'carousel-item',\n POINTER_EVENT: 'pointer-event'\n };\n var Selector$2 = {\n ACTIVE: '.active',\n ACTIVE_ITEM: '.active.carousel-item',\n ITEM: '.carousel-item',\n ITEM_IMG: '.carousel-item img',\n NEXT_PREV: '.carousel-item-next, .carousel-item-prev',\n INDICATORS: '.carousel-indicators',\n DATA_SLIDE: '[data-slide], [data-slide-to]',\n DATA_RIDE: '[data-ride=\"carousel\"]'\n };\n var PointerType = {\n TOUCH: 'touch',\n PEN: 'pen'\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Carousel =\n /*#__PURE__*/\n function () {\n function Carousel(element, config) {\n this._items = null;\n this._interval = null;\n this._activeElement = null;\n this._isPaused = false;\n this._isSliding = false;\n this.touchTimeout = null;\n this.touchStartX = 0;\n this.touchDeltaX = 0;\n this._config = this._getConfig(config);\n this._element = element;\n this._indicatorsElement = this._element.querySelector(Selector$2.INDICATORS);\n this._touchSupported = 'ontouchstart' in document.documentElement || navigator.maxTouchPoints > 0;\n this._pointerEvent = Boolean(window.PointerEvent || window.MSPointerEvent);\n\n this._addEventListeners();\n } // Getters\n\n\n var _proto = Carousel.prototype;\n\n // Public\n _proto.next = function next() {\n if (!this._isSliding) {\n this._slide(Direction.NEXT);\n }\n };\n\n _proto.nextWhenVisible = function nextWhenVisible() {\n // Don't call next when the page isn't visible\n // or the carousel or its parent isn't visible\n if (!document.hidden && $(this._element).is(':visible') && $(this._element).css('visibility') !== 'hidden') {\n this.next();\n }\n };\n\n _proto.prev = function prev() {\n if (!this._isSliding) {\n this._slide(Direction.PREV);\n }\n };\n\n _proto.pause = function pause(event) {\n if (!event) {\n this._isPaused = true;\n }\n\n if (this._element.querySelector(Selector$2.NEXT_PREV)) {\n Util.triggerTransitionEnd(this._element);\n this.cycle(true);\n }\n\n clearInterval(this._interval);\n this._interval = null;\n };\n\n _proto.cycle = function cycle(event) {\n if (!event) {\n this._isPaused = false;\n }\n\n if (this._interval) {\n clearInterval(this._interval);\n this._interval = null;\n }\n\n if (this._config.interval && !this._isPaused) {\n this._interval = setInterval((document.visibilityState ? this.nextWhenVisible : this.next).bind(this), this._config.interval);\n }\n };\n\n _proto.to = function to(index) {\n var _this = this;\n\n this._activeElement = this._element.querySelector(Selector$2.ACTIVE_ITEM);\n\n var activeIndex = this._getItemIndex(this._activeElement);\n\n if (index > this._items.length - 1 || index < 0) {\n return;\n }\n\n if (this._isSliding) {\n $(this._element).one(Event$2.SLID, function () {\n return _this.to(index);\n });\n return;\n }\n\n if (activeIndex === index) {\n this.pause();\n this.cycle();\n return;\n }\n\n var direction = index > activeIndex ? Direction.NEXT : Direction.PREV;\n\n this._slide(direction, this._items[index]);\n };\n\n _proto.dispose = function dispose() {\n $(this._element).off(EVENT_KEY$2);\n $.removeData(this._element, DATA_KEY$2);\n this._items = null;\n this._config = null;\n this._element = null;\n this._interval = null;\n this._isPaused = null;\n this._isSliding = null;\n this._activeElement = null;\n this._indicatorsElement = null;\n } // Private\n ;\n\n _proto._getConfig = function _getConfig(config) {\n config = _objectSpread2({}, Default, {}, config);\n Util.typeCheckConfig(NAME$2, config, DefaultType);\n return config;\n };\n\n _proto._handleSwipe = function _handleSwipe() {\n var absDeltax = Math.abs(this.touchDeltaX);\n\n if (absDeltax <= SWIPE_THRESHOLD) {\n return;\n }\n\n var direction = absDeltax / this.touchDeltaX;\n this.touchDeltaX = 0; // swipe left\n\n if (direction > 0) {\n this.prev();\n } // swipe right\n\n\n if (direction < 0) {\n this.next();\n }\n };\n\n _proto._addEventListeners = function _addEventListeners() {\n var _this2 = this;\n\n if (this._config.keyboard) {\n $(this._element).on(Event$2.KEYDOWN, function (event) {\n return _this2._keydown(event);\n });\n }\n\n if (this._config.pause === 'hover') {\n $(this._element).on(Event$2.MOUSEENTER, function (event) {\n return _this2.pause(event);\n }).on(Event$2.MOUSELEAVE, function (event) {\n return _this2.cycle(event);\n });\n }\n\n if (this._config.touch) {\n this._addTouchEventListeners();\n }\n };\n\n _proto._addTouchEventListeners = function _addTouchEventListeners() {\n var _this3 = this;\n\n if (!this._touchSupported) {\n return;\n }\n\n var start = function start(event) {\n if (_this3._pointerEvent && PointerType[event.originalEvent.pointerType.toUpperCase()]) {\n _this3.touchStartX = event.originalEvent.clientX;\n } else if (!_this3._pointerEvent) {\n _this3.touchStartX = event.originalEvent.touches[0].clientX;\n }\n };\n\n var move = function move(event) {\n // ensure swiping with one touch and not pinching\n if (event.originalEvent.touches && event.originalEvent.touches.length > 1) {\n _this3.touchDeltaX = 0;\n } else {\n _this3.touchDeltaX = event.originalEvent.touches[0].clientX - _this3.touchStartX;\n }\n };\n\n var end = function end(event) {\n if (_this3._pointerEvent && PointerType[event.originalEvent.pointerType.toUpperCase()]) {\n _this3.touchDeltaX = event.originalEvent.clientX - _this3.touchStartX;\n }\n\n _this3._handleSwipe();\n\n if (_this3._config.pause === 'hover') {\n // If it's a touch-enabled device, mouseenter/leave are fired as\n // part of the mouse compatibility events on first tap - the carousel\n // would stop cycling until user tapped out of it;\n // here, we listen for touchend, explicitly pause the carousel\n // (as if it's the second time we tap on it, mouseenter compat event\n // is NOT fired) and after a timeout (to allow for mouse compatibility\n // events to fire) we explicitly restart cycling\n _this3.pause();\n\n if (_this3.touchTimeout) {\n clearTimeout(_this3.touchTimeout);\n }\n\n _this3.touchTimeout = setTimeout(function (event) {\n return _this3.cycle(event);\n }, TOUCHEVENT_COMPAT_WAIT + _this3._config.interval);\n }\n };\n\n $(this._element.querySelectorAll(Selector$2.ITEM_IMG)).on(Event$2.DRAG_START, function (e) {\n return e.preventDefault();\n });\n\n if (this._pointerEvent) {\n $(this._element).on(Event$2.POINTERDOWN, function (event) {\n return start(event);\n });\n $(this._element).on(Event$2.POINTERUP, function (event) {\n return end(event);\n });\n\n this._element.classList.add(ClassName$2.POINTER_EVENT);\n } else {\n $(this._element).on(Event$2.TOUCHSTART, function (event) {\n return start(event);\n });\n $(this._element).on(Event$2.TOUCHMOVE, function (event) {\n return move(event);\n });\n $(this._element).on(Event$2.TOUCHEND, function (event) {\n return end(event);\n });\n }\n };\n\n _proto._keydown = function _keydown(event) {\n if (/input|textarea/i.test(event.target.tagName)) {\n return;\n }\n\n switch (event.which) {\n case ARROW_LEFT_KEYCODE:\n event.preventDefault();\n this.prev();\n break;\n\n case ARROW_RIGHT_KEYCODE:\n event.preventDefault();\n this.next();\n break;\n }\n };\n\n _proto._getItemIndex = function _getItemIndex(element) {\n this._items = element && element.parentNode ? [].slice.call(element.parentNode.querySelectorAll(Selector$2.ITEM)) : [];\n return this._items.indexOf(element);\n };\n\n _proto._getItemByDirection = function _getItemByDirection(direction, activeElement) {\n var isNextDirection = direction === Direction.NEXT;\n var isPrevDirection = direction === Direction.PREV;\n\n var activeIndex = this._getItemIndex(activeElement);\n\n var lastItemIndex = this._items.length - 1;\n var isGoingToWrap = isPrevDirection && activeIndex === 0 || isNextDirection && activeIndex === lastItemIndex;\n\n if (isGoingToWrap && !this._config.wrap) {\n return activeElement;\n }\n\n var delta = direction === Direction.PREV ? -1 : 1;\n var itemIndex = (activeIndex + delta) % this._items.length;\n return itemIndex === -1 ? this._items[this._items.length - 1] : this._items[itemIndex];\n };\n\n _proto._triggerSlideEvent = function _triggerSlideEvent(relatedTarget, eventDirectionName) {\n var targetIndex = this._getItemIndex(relatedTarget);\n\n var fromIndex = this._getItemIndex(this._element.querySelector(Selector$2.ACTIVE_ITEM));\n\n var slideEvent = $.Event(Event$2.SLIDE, {\n relatedTarget: relatedTarget,\n direction: eventDirectionName,\n from: fromIndex,\n to: targetIndex\n });\n $(this._element).trigger(slideEvent);\n return slideEvent;\n };\n\n _proto._setActiveIndicatorElement = function _setActiveIndicatorElement(element) {\n if (this._indicatorsElement) {\n var indicators = [].slice.call(this._indicatorsElement.querySelectorAll(Selector$2.ACTIVE));\n $(indicators).removeClass(ClassName$2.ACTIVE);\n\n var nextIndicator = this._indicatorsElement.children[this._getItemIndex(element)];\n\n if (nextIndicator) {\n $(nextIndicator).addClass(ClassName$2.ACTIVE);\n }\n }\n };\n\n _proto._slide = function _slide(direction, element) {\n var _this4 = this;\n\n var activeElement = this._element.querySelector(Selector$2.ACTIVE_ITEM);\n\n var activeElementIndex = this._getItemIndex(activeElement);\n\n var nextElement = element || activeElement && this._getItemByDirection(direction, activeElement);\n\n var nextElementIndex = this._getItemIndex(nextElement);\n\n var isCycling = Boolean(this._interval);\n var directionalClassName;\n var orderClassName;\n var eventDirectionName;\n\n if (direction === Direction.NEXT) {\n directionalClassName = ClassName$2.LEFT;\n orderClassName = ClassName$2.NEXT;\n eventDirectionName = Direction.LEFT;\n } else {\n directionalClassName = ClassName$2.RIGHT;\n orderClassName = ClassName$2.PREV;\n eventDirectionName = Direction.RIGHT;\n }\n\n if (nextElement && $(nextElement).hasClass(ClassName$2.ACTIVE)) {\n this._isSliding = false;\n return;\n }\n\n var slideEvent = this._triggerSlideEvent(nextElement, eventDirectionName);\n\n if (slideEvent.isDefaultPrevented()) {\n return;\n }\n\n if (!activeElement || !nextElement) {\n // Some weirdness is happening, so we bail\n return;\n }\n\n this._isSliding = true;\n\n if (isCycling) {\n this.pause();\n }\n\n this._setActiveIndicatorElement(nextElement);\n\n var slidEvent = $.Event(Event$2.SLID, {\n relatedTarget: nextElement,\n direction: eventDirectionName,\n from: activeElementIndex,\n to: nextElementIndex\n });\n\n if ($(this._element).hasClass(ClassName$2.SLIDE)) {\n $(nextElement).addClass(orderClassName);\n Util.reflow(nextElement);\n $(activeElement).addClass(directionalClassName);\n $(nextElement).addClass(directionalClassName);\n var nextElementInterval = parseInt(nextElement.getAttribute('data-interval'), 10);\n\n if (nextElementInterval) {\n this._config.defaultInterval = this._config.defaultInterval || this._config.interval;\n this._config.interval = nextElementInterval;\n } else {\n this._config.interval = this._config.defaultInterval || this._config.interval;\n }\n\n var transitionDuration = Util.getTransitionDurationFromElement(activeElement);\n $(activeElement).one(Util.TRANSITION_END, function () {\n $(nextElement).removeClass(directionalClassName + \" \" + orderClassName).addClass(ClassName$2.ACTIVE);\n $(activeElement).removeClass(ClassName$2.ACTIVE + \" \" + orderClassName + \" \" + directionalClassName);\n _this4._isSliding = false;\n setTimeout(function () {\n return $(_this4._element).trigger(slidEvent);\n }, 0);\n }).emulateTransitionEnd(transitionDuration);\n } else {\n $(activeElement).removeClass(ClassName$2.ACTIVE);\n $(nextElement).addClass(ClassName$2.ACTIVE);\n this._isSliding = false;\n $(this._element).trigger(slidEvent);\n }\n\n if (isCycling) {\n this.cycle();\n }\n } // Static\n ;\n\n Carousel._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var data = $(this).data(DATA_KEY$2);\n\n var _config = _objectSpread2({}, Default, {}, $(this).data());\n\n if (typeof config === 'object') {\n _config = _objectSpread2({}, _config, {}, config);\n }\n\n var action = typeof config === 'string' ? config : _config.slide;\n\n if (!data) {\n data = new Carousel(this, _config);\n $(this).data(DATA_KEY$2, data);\n }\n\n if (typeof config === 'number') {\n data.to(config);\n } else if (typeof action === 'string') {\n if (typeof data[action] === 'undefined') {\n throw new TypeError(\"No method named \\\"\" + action + \"\\\"\");\n }\n\n data[action]();\n } else if (_config.interval && _config.ride) {\n data.pause();\n data.cycle();\n }\n });\n };\n\n Carousel._dataApiClickHandler = function _dataApiClickHandler(event) {\n var selector = Util.getSelectorFromElement(this);\n\n if (!selector) {\n return;\n }\n\n var target = $(selector)[0];\n\n if (!target || !$(target).hasClass(ClassName$2.CAROUSEL)) {\n return;\n }\n\n var config = _objectSpread2({}, $(target).data(), {}, $(this).data());\n\n var slideIndex = this.getAttribute('data-slide-to');\n\n if (slideIndex) {\n config.interval = false;\n }\n\n Carousel._jQueryInterface.call($(target), config);\n\n if (slideIndex) {\n $(target).data(DATA_KEY$2).to(slideIndex);\n }\n\n event.preventDefault();\n };\n\n _createClass(Carousel, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION$2;\n }\n }, {\n key: \"Default\",\n get: function get() {\n return Default;\n }\n }]);\n\n return Carousel;\n }();\n /**\n * ------------------------------------------------------------------------\n * Data Api implementation\n * ------------------------------------------------------------------------\n */\n\n\n $(document).on(Event$2.CLICK_DATA_API, Selector$2.DATA_SLIDE, Carousel._dataApiClickHandler);\n $(window).on(Event$2.LOAD_DATA_API, function () {\n var carousels = [].slice.call(document.querySelectorAll(Selector$2.DATA_RIDE));\n\n for (var i = 0, len = carousels.length; i < len; i++) {\n var $carousel = $(carousels[i]);\n\n Carousel._jQueryInterface.call($carousel, $carousel.data());\n }\n });\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n $.fn[NAME$2] = Carousel._jQueryInterface;\n $.fn[NAME$2].Constructor = Carousel;\n\n $.fn[NAME$2].noConflict = function () {\n $.fn[NAME$2] = JQUERY_NO_CONFLICT$2;\n return Carousel._jQueryInterface;\n };\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$3 = 'collapse';\n var VERSION$3 = '4.4.1';\n var DATA_KEY$3 = 'bs.collapse';\n var EVENT_KEY$3 = \".\" + DATA_KEY$3;\n var DATA_API_KEY$3 = '.data-api';\n var JQUERY_NO_CONFLICT$3 = $.fn[NAME$3];\n var Default$1 = {\n toggle: true,\n parent: ''\n };\n var DefaultType$1 = {\n toggle: 'boolean',\n parent: '(string|element)'\n };\n var Event$3 = {\n SHOW: \"show\" + EVENT_KEY$3,\n SHOWN: \"shown\" + EVENT_KEY$3,\n HIDE: \"hide\" + EVENT_KEY$3,\n HIDDEN: \"hidden\" + EVENT_KEY$3,\n CLICK_DATA_API: \"click\" + EVENT_KEY$3 + DATA_API_KEY$3\n };\n var ClassName$3 = {\n SHOW: 'show',\n COLLAPSE: 'collapse',\n COLLAPSING: 'collapsing',\n COLLAPSED: 'collapsed'\n };\n var Dimension = {\n WIDTH: 'width',\n HEIGHT: 'height'\n };\n var Selector$3 = {\n ACTIVES: '.show, .collapsing',\n DATA_TOGGLE: '[data-toggle=\"collapse\"]'\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Collapse =\n /*#__PURE__*/\n function () {\n function Collapse(element, config) {\n this._isTransitioning = false;\n this._element = element;\n this._config = this._getConfig(config);\n this._triggerArray = [].slice.call(document.querySelectorAll(\"[data-toggle=\\\"collapse\\\"][href=\\\"#\" + element.id + \"\\\"],\" + (\"[data-toggle=\\\"collapse\\\"][data-target=\\\"#\" + element.id + \"\\\"]\")));\n var toggleList = [].slice.call(document.querySelectorAll(Selector$3.DATA_TOGGLE));\n\n for (var i = 0, len = toggleList.length; i < len; i++) {\n var elem = toggleList[i];\n var selector = Util.getSelectorFromElement(elem);\n var filterElement = [].slice.call(document.querySelectorAll(selector)).filter(function (foundElem) {\n return foundElem === element;\n });\n\n if (selector !== null && filterElement.length > 0) {\n this._selector = selector;\n\n this._triggerArray.push(elem);\n }\n }\n\n this._parent = this._config.parent ? this._getParent() : null;\n\n if (!this._config.parent) {\n this._addAriaAndCollapsedClass(this._element, this._triggerArray);\n }\n\n if (this._config.toggle) {\n this.toggle();\n }\n } // Getters\n\n\n var _proto = Collapse.prototype;\n\n // Public\n _proto.toggle = function toggle() {\n if ($(this._element).hasClass(ClassName$3.SHOW)) {\n this.hide();\n } else {\n this.show();\n }\n };\n\n _proto.show = function show() {\n var _this = this;\n\n if (this._isTransitioning || $(this._element).hasClass(ClassName$3.SHOW)) {\n return;\n }\n\n var actives;\n var activesData;\n\n if (this._parent) {\n actives = [].slice.call(this._parent.querySelectorAll(Selector$3.ACTIVES)).filter(function (elem) {\n if (typeof _this._config.parent === 'string') {\n return elem.getAttribute('data-parent') === _this._config.parent;\n }\n\n return elem.classList.contains(ClassName$3.COLLAPSE);\n });\n\n if (actives.length === 0) {\n actives = null;\n }\n }\n\n if (actives) {\n activesData = $(actives).not(this._selector).data(DATA_KEY$3);\n\n if (activesData && activesData._isTransitioning) {\n return;\n }\n }\n\n var startEvent = $.Event(Event$3.SHOW);\n $(this._element).trigger(startEvent);\n\n if (startEvent.isDefaultPrevented()) {\n return;\n }\n\n if (actives) {\n Collapse._jQueryInterface.call($(actives).not(this._selector), 'hide');\n\n if (!activesData) {\n $(actives).data(DATA_KEY$3, null);\n }\n }\n\n var dimension = this._getDimension();\n\n $(this._element).removeClass(ClassName$3.COLLAPSE).addClass(ClassName$3.COLLAPSING);\n this._element.style[dimension] = 0;\n\n if (this._triggerArray.length) {\n $(this._triggerArray).removeClass(ClassName$3.COLLAPSED).attr('aria-expanded', true);\n }\n\n this.setTransitioning(true);\n\n var complete = function complete() {\n $(_this._element).removeClass(ClassName$3.COLLAPSING).addClass(ClassName$3.COLLAPSE).addClass(ClassName$3.SHOW);\n _this._element.style[dimension] = '';\n\n _this.setTransitioning(false);\n\n $(_this._element).trigger(Event$3.SHOWN);\n };\n\n var capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1);\n var scrollSize = \"scroll\" + capitalizedDimension;\n var transitionDuration = Util.getTransitionDurationFromElement(this._element);\n $(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(transitionDuration);\n this._element.style[dimension] = this._element[scrollSize] + \"px\";\n };\n\n _proto.hide = function hide() {\n var _this2 = this;\n\n if (this._isTransitioning || !$(this._element).hasClass(ClassName$3.SHOW)) {\n return;\n }\n\n var startEvent = $.Event(Event$3.HIDE);\n $(this._element).trigger(startEvent);\n\n if (startEvent.isDefaultPrevented()) {\n return;\n }\n\n var dimension = this._getDimension();\n\n this._element.style[dimension] = this._element.getBoundingClientRect()[dimension] + \"px\";\n Util.reflow(this._element);\n $(this._element).addClass(ClassName$3.COLLAPSING).removeClass(ClassName$3.COLLAPSE).removeClass(ClassName$3.SHOW);\n var triggerArrayLength = this._triggerArray.length;\n\n if (triggerArrayLength > 0) {\n for (var i = 0; i < triggerArrayLength; i++) {\n var trigger = this._triggerArray[i];\n var selector = Util.getSelectorFromElement(trigger);\n\n if (selector !== null) {\n var $elem = $([].slice.call(document.querySelectorAll(selector)));\n\n if (!$elem.hasClass(ClassName$3.SHOW)) {\n $(trigger).addClass(ClassName$3.COLLAPSED).attr('aria-expanded', false);\n }\n }\n }\n }\n\n this.setTransitioning(true);\n\n var complete = function complete() {\n _this2.setTransitioning(false);\n\n $(_this2._element).removeClass(ClassName$3.COLLAPSING).addClass(ClassName$3.COLLAPSE).trigger(Event$3.HIDDEN);\n };\n\n this._element.style[dimension] = '';\n var transitionDuration = Util.getTransitionDurationFromElement(this._element);\n $(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(transitionDuration);\n };\n\n _proto.setTransitioning = function setTransitioning(isTransitioning) {\n this._isTransitioning = isTransitioning;\n };\n\n _proto.dispose = function dispose() {\n $.removeData(this._element, DATA_KEY$3);\n this._config = null;\n this._parent = null;\n this._element = null;\n this._triggerArray = null;\n this._isTransitioning = null;\n } // Private\n ;\n\n _proto._getConfig = function _getConfig(config) {\n config = _objectSpread2({}, Default$1, {}, config);\n config.toggle = Boolean(config.toggle); // Coerce string values\n\n Util.typeCheckConfig(NAME$3, config, DefaultType$1);\n return config;\n };\n\n _proto._getDimension = function _getDimension() {\n var hasWidth = $(this._element).hasClass(Dimension.WIDTH);\n return hasWidth ? Dimension.WIDTH : Dimension.HEIGHT;\n };\n\n _proto._getParent = function _getParent() {\n var _this3 = this;\n\n var parent;\n\n if (Util.isElement(this._config.parent)) {\n parent = this._config.parent; // It's a jQuery object\n\n if (typeof this._config.parent.jquery !== 'undefined') {\n parent = this._config.parent[0];\n }\n } else {\n parent = document.querySelector(this._config.parent);\n }\n\n var selector = \"[data-toggle=\\\"collapse\\\"][data-parent=\\\"\" + this._config.parent + \"\\\"]\";\n var children = [].slice.call(parent.querySelectorAll(selector));\n $(children).each(function (i, element) {\n _this3._addAriaAndCollapsedClass(Collapse._getTargetFromElement(element), [element]);\n });\n return parent;\n };\n\n _proto._addAriaAndCollapsedClass = function _addAriaAndCollapsedClass(element, triggerArray) {\n var isOpen = $(element).hasClass(ClassName$3.SHOW);\n\n if (triggerArray.length) {\n $(triggerArray).toggleClass(ClassName$3.COLLAPSED, !isOpen).attr('aria-expanded', isOpen);\n }\n } // Static\n ;\n\n Collapse._getTargetFromElement = function _getTargetFromElement(element) {\n var selector = Util.getSelectorFromElement(element);\n return selector ? document.querySelector(selector) : null;\n };\n\n Collapse._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var $this = $(this);\n var data = $this.data(DATA_KEY$3);\n\n var _config = _objectSpread2({}, Default$1, {}, $this.data(), {}, typeof config === 'object' && config ? config : {});\n\n if (!data && _config.toggle && /show|hide/.test(config)) {\n _config.toggle = false;\n }\n\n if (!data) {\n data = new Collapse(this, _config);\n $this.data(DATA_KEY$3, data);\n }\n\n if (typeof config === 'string') {\n if (typeof data[config] === 'undefined') {\n throw new TypeError(\"No method named \\\"\" + config + \"\\\"\");\n }\n\n data[config]();\n }\n });\n };\n\n _createClass(Collapse, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION$3;\n }\n }, {\n key: \"Default\",\n get: function get() {\n return Default$1;\n }\n }]);\n\n return Collapse;\n }();\n /**\n * ------------------------------------------------------------------------\n * Data Api implementation\n * ------------------------------------------------------------------------\n */\n\n\n $(document).on(Event$3.CLICK_DATA_API, Selector$3.DATA_TOGGLE, function (event) {\n // preventDefault only for <a> elements (which change the URL) not inside the collapsible element\n if (event.currentTarget.tagName === 'A') {\n event.preventDefault();\n }\n\n var $trigger = $(this);\n var selector = Util.getSelectorFromElement(this);\n var selectors = [].slice.call(document.querySelectorAll(selector));\n $(selectors).each(function () {\n var $target = $(this);\n var data = $target.data(DATA_KEY$3);\n var config = data ? 'toggle' : $trigger.data();\n\n Collapse._jQueryInterface.call($target, config);\n });\n });\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n $.fn[NAME$3] = Collapse._jQueryInterface;\n $.fn[NAME$3].Constructor = Collapse;\n\n $.fn[NAME$3].noConflict = function () {\n $.fn[NAME$3] = JQUERY_NO_CONFLICT$3;\n return Collapse._jQueryInterface;\n };\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$4 = 'dropdown';\n var VERSION$4 = '4.4.1';\n var DATA_KEY$4 = 'bs.dropdown';\n var EVENT_KEY$4 = \".\" + DATA_KEY$4;\n var DATA_API_KEY$4 = '.data-api';\n var JQUERY_NO_CONFLICT$4 = $.fn[NAME$4];\n var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key\n\n var SPACE_KEYCODE = 32; // KeyboardEvent.which value for space key\n\n var TAB_KEYCODE = 9; // KeyboardEvent.which value for tab key\n\n var ARROW_UP_KEYCODE = 38; // KeyboardEvent.which value for up arrow key\n\n var ARROW_DOWN_KEYCODE = 40; // KeyboardEvent.which value for down arrow key\n\n var RIGHT_MOUSE_BUTTON_WHICH = 3; // MouseEvent.which value for the right button (assuming a right-handed mouse)\n\n var REGEXP_KEYDOWN = new RegExp(ARROW_UP_KEYCODE + \"|\" + ARROW_DOWN_KEYCODE + \"|\" + ESCAPE_KEYCODE);\n var Event$4 = {\n HIDE: \"hide\" + EVENT_KEY$4,\n HIDDEN: \"hidden\" + EVENT_KEY$4,\n SHOW: \"show\" + EVENT_KEY$4,\n SHOWN: \"shown\" + EVENT_KEY$4,\n CLICK: \"click\" + EVENT_KEY$4,\n CLICK_DATA_API: \"click\" + EVENT_KEY$4 + DATA_API_KEY$4,\n KEYDOWN_DATA_API: \"keydown\" + EVENT_KEY$4 + DATA_API_KEY$4,\n KEYUP_DATA_API: \"keyup\" + EVENT_KEY$4 + DATA_API_KEY$4\n };\n var ClassName$4 = {\n DISABLED: 'disabled',\n SHOW: 'show',\n DROPUP: 'dropup',\n DROPRIGHT: 'dropright',\n DROPLEFT: 'dropleft',\n MENURIGHT: 'dropdown-menu-right',\n MENULEFT: 'dropdown-menu-left',\n POSITION_STATIC: 'position-static'\n };\n var Selector$4 = {\n DATA_TOGGLE: '[data-toggle=\"dropdown\"]',\n FORM_CHILD: '.dropdown form',\n MENU: '.dropdown-menu',\n NAVBAR_NAV: '.navbar-nav',\n VISIBLE_ITEMS: '.dropdown-menu .dropdown-item:not(.disabled):not(:disabled)'\n };\n var AttachmentMap = {\n TOP: 'top-start',\n TOPEND: 'top-end',\n BOTTOM: 'bottom-start',\n BOTTOMEND: 'bottom-end',\n RIGHT: 'right-start',\n RIGHTEND: 'right-end',\n LEFT: 'left-start',\n LEFTEND: 'left-end'\n };\n var Default$2 = {\n offset: 0,\n flip: true,\n boundary: 'scrollParent',\n reference: 'toggle',\n display: 'dynamic',\n popperConfig: null\n };\n var DefaultType$2 = {\n offset: '(number|string|function)',\n flip: 'boolean',\n boundary: '(string|element)',\n reference: '(string|element)',\n display: 'string',\n popperConfig: '(null|object)'\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Dropdown =\n /*#__PURE__*/\n function () {\n function Dropdown(element, config) {\n this._element = element;\n this._popper = null;\n this._config = this._getConfig(config);\n this._menu = this._getMenuElement();\n this._inNavbar = this._detectNavbar();\n\n this._addEventListeners();\n } // Getters\n\n\n var _proto = Dropdown.prototype;\n\n // Public\n _proto.toggle = function toggle() {\n if (this._element.disabled || $(this._element).hasClass(ClassName$4.DISABLED)) {\n return;\n }\n\n var isActive = $(this._menu).hasClass(ClassName$4.SHOW);\n\n Dropdown._clearMenus();\n\n if (isActive) {\n return;\n }\n\n this.show(true);\n };\n\n _proto.show = function show(usePopper) {\n if (usePopper === void 0) {\n usePopper = false;\n }\n\n if (this._element.disabled || $(this._element).hasClass(ClassName$4.DISABLED) || $(this._menu).hasClass(ClassName$4.SHOW)) {\n return;\n }\n\n var relatedTarget = {\n relatedTarget: this._element\n };\n var showEvent = $.Event(Event$4.SHOW, relatedTarget);\n\n var parent = Dropdown._getParentFromElement(this._element);\n\n $(parent).trigger(showEvent);\n\n if (showEvent.isDefaultPrevented()) {\n return;\n } // Disable totally Popper.js for Dropdown in Navbar\n\n\n if (!this._inNavbar && usePopper) {\n /**\n * Check for Popper dependency\n * Popper - https://popper.js.org\n */\n if (typeof Popper === 'undefined') {\n throw new TypeError('Bootstrap\\'s dropdowns require Popper.js (https://popper.js.org/)');\n }\n\n var referenceElement = this._element;\n\n if (this._config.reference === 'parent') {\n referenceElement = parent;\n } else if (Util.isElement(this._config.reference)) {\n referenceElement = this._config.reference; // Check if it's jQuery element\n\n if (typeof this._config.reference.jquery !== 'undefined') {\n referenceElement = this._config.reference[0];\n }\n } // If boundary is not `scrollParent`, then set position to `static`\n // to allow the menu to \"escape\" the scroll parent's boundaries\n // https://github.com/twbs/bootstrap/issues/24251\n\n\n if (this._config.boundary !== 'scrollParent') {\n $(parent).addClass(ClassName$4.POSITION_STATIC);\n }\n\n this._popper = new Popper(referenceElement, this._menu, this._getPopperConfig());\n } // If this is a touch-enabled device we add extra\n // empty mouseover listeners to the body's immediate children;\n // only needed because of broken event delegation on iOS\n // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html\n\n\n if ('ontouchstart' in document.documentElement && $(parent).closest(Selector$4.NAVBAR_NAV).length === 0) {\n $(document.body).children().on('mouseover', null, $.noop);\n }\n\n this._element.focus();\n\n this._element.setAttribute('aria-expanded', true);\n\n $(this._menu).toggleClass(ClassName$4.SHOW);\n $(parent).toggleClass(ClassName$4.SHOW).trigger($.Event(Event$4.SHOWN, relatedTarget));\n };\n\n _proto.hide = function hide() {\n if (this._element.disabled || $(this._element).hasClass(ClassName$4.DISABLED) || !$(this._menu).hasClass(ClassName$4.SHOW)) {\n return;\n }\n\n var relatedTarget = {\n relatedTarget: this._element\n };\n var hideEvent = $.Event(Event$4.HIDE, relatedTarget);\n\n var parent = Dropdown._getParentFromElement(this._element);\n\n $(parent).trigger(hideEvent);\n\n if (hideEvent.isDefaultPrevented()) {\n return;\n }\n\n if (this._popper) {\n this._popper.destroy();\n }\n\n $(this._menu).toggleClass(ClassName$4.SHOW);\n $(parent).toggleClass(ClassName$4.SHOW).trigger($.Event(Event$4.HIDDEN, relatedTarget));\n };\n\n _proto.dispose = function dispose() {\n $.removeData(this._element, DATA_KEY$4);\n $(this._element).off(EVENT_KEY$4);\n this._element = null;\n this._menu = null;\n\n if (this._popper !== null) {\n this._popper.destroy();\n\n this._popper = null;\n }\n };\n\n _proto.update = function update() {\n this._inNavbar = this._detectNavbar();\n\n if (this._popper !== null) {\n this._popper.scheduleUpdate();\n }\n } // Private\n ;\n\n _proto._addEventListeners = function _addEventListeners() {\n var _this = this;\n\n $(this._element).on(Event$4.CLICK, function (event) {\n event.preventDefault();\n event.stopPropagation();\n\n _this.toggle();\n });\n };\n\n _proto._getConfig = function _getConfig(config) {\n config = _objectSpread2({}, this.constructor.Default, {}, $(this._element).data(), {}, config);\n Util.typeCheckConfig(NAME$4, config, this.constructor.DefaultType);\n return config;\n };\n\n _proto._getMenuElement = function _getMenuElement() {\n if (!this._menu) {\n var parent = Dropdown._getParentFromElement(this._element);\n\n if (parent) {\n this._menu = parent.querySelector(Selector$4.MENU);\n }\n }\n\n return this._menu;\n };\n\n _proto._getPlacement = function _getPlacement() {\n var $parentDropdown = $(this._element.parentNode);\n var placement = AttachmentMap.BOTTOM; // Handle dropup\n\n if ($parentDropdown.hasClass(ClassName$4.DROPUP)) {\n placement = AttachmentMap.TOP;\n\n if ($(this._menu).hasClass(ClassName$4.MENURIGHT)) {\n placement = AttachmentMap.TOPEND;\n }\n } else if ($parentDropdown.hasClass(ClassName$4.DROPRIGHT)) {\n placement = AttachmentMap.RIGHT;\n } else if ($parentDropdown.hasClass(ClassName$4.DROPLEFT)) {\n placement = AttachmentMap.LEFT;\n } else if ($(this._menu).hasClass(ClassName$4.MENURIGHT)) {\n placement = AttachmentMap.BOTTOMEND;\n }\n\n return placement;\n };\n\n _proto._detectNavbar = function _detectNavbar() {\n return $(this._element).closest('.navbar').length > 0;\n };\n\n _proto._getOffset = function _getOffset() {\n var _this2 = this;\n\n var offset = {};\n\n if (typeof this._config.offset === 'function') {\n offset.fn = function (data) {\n data.offsets = _objectSpread2({}, data.offsets, {}, _this2._config.offset(data.offsets, _this2._element) || {});\n return data;\n };\n } else {\n offset.offset = this._config.offset;\n }\n\n return offset;\n };\n\n _proto._getPopperConfig = function _getPopperConfig() {\n var popperConfig = {\n placement: this._getPlacement(),\n modifiers: {\n offset: this._getOffset(),\n flip: {\n enabled: this._config.flip\n },\n preventOverflow: {\n boundariesElement: this._config.boundary\n }\n }\n }; // Disable Popper.js if we have a static display\n\n if (this._config.display === 'static') {\n popperConfig.modifiers.applyStyle = {\n enabled: false\n };\n }\n\n return _objectSpread2({}, popperConfig, {}, this._config.popperConfig);\n } // Static\n ;\n\n Dropdown._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var data = $(this).data(DATA_KEY$4);\n\n var _config = typeof config === 'object' ? config : null;\n\n if (!data) {\n data = new Dropdown(this, _config);\n $(this).data(DATA_KEY$4, data);\n }\n\n if (typeof config === 'string') {\n if (typeof data[config] === 'undefined') {\n throw new TypeError(\"No method named \\\"\" + config + \"\\\"\");\n }\n\n data[config]();\n }\n });\n };\n\n Dropdown._clearMenus = function _clearMenus(event) {\n if (event && (event.which === RIGHT_MOUSE_BUTTON_WHICH || event.type === 'keyup' && event.which !== TAB_KEYCODE)) {\n return;\n }\n\n var toggles = [].slice.call(document.querySelectorAll(Selector$4.DATA_TOGGLE));\n\n for (var i = 0, len = toggles.length; i < len; i++) {\n var parent = Dropdown._getParentFromElement(toggles[i]);\n\n var context = $(toggles[i]).data(DATA_KEY$4);\n var relatedTarget = {\n relatedTarget: toggles[i]\n };\n\n if (event && event.type === 'click') {\n relatedTarget.clickEvent = event;\n }\n\n if (!context) {\n continue;\n }\n\n var dropdownMenu = context._menu;\n\n if (!$(parent).hasClass(ClassName$4.SHOW)) {\n continue;\n }\n\n if (event && (event.type === 'click' && /input|textarea/i.test(event.target.tagName) || event.type === 'keyup' && event.which === TAB_KEYCODE) && $.contains(parent, event.target)) {\n continue;\n }\n\n var hideEvent = $.Event(Event$4.HIDE, relatedTarget);\n $(parent).trigger(hideEvent);\n\n if (hideEvent.isDefaultPrevented()) {\n continue;\n } // If this is a touch-enabled device we remove the extra\n // empty mouseover listeners we added for iOS support\n\n\n if ('ontouchstart' in document.documentElement) {\n $(document.body).children().off('mouseover', null, $.noop);\n }\n\n toggles[i].setAttribute('aria-expanded', 'false');\n\n if (context._popper) {\n context._popper.destroy();\n }\n\n $(dropdownMenu).removeClass(ClassName$4.SHOW);\n $(parent).removeClass(ClassName$4.SHOW).trigger($.Event(Event$4.HIDDEN, relatedTarget));\n }\n };\n\n Dropdown._getParentFromElement = function _getParentFromElement(element) {\n var parent;\n var selector = Util.getSelectorFromElement(element);\n\n if (selector) {\n parent = document.querySelector(selector);\n }\n\n return parent || element.parentNode;\n } // eslint-disable-next-line complexity\n ;\n\n Dropdown._dataApiKeydownHandler = function _dataApiKeydownHandler(event) {\n // If not input/textarea:\n // - And not a key in REGEXP_KEYDOWN => not a dropdown command\n // If input/textarea:\n // - If space key => not a dropdown command\n // - If key is other than escape\n // - If key is not up or down => not a dropdown command\n // - If trigger inside the menu => not a dropdown command\n if (/input|textarea/i.test(event.target.tagName) ? event.which === SPACE_KEYCODE || event.which !== ESCAPE_KEYCODE && (event.which !== ARROW_DOWN_KEYCODE && event.which !== ARROW_UP_KEYCODE || $(event.target).closest(Selector$4.MENU).length) : !REGEXP_KEYDOWN.test(event.which)) {\n return;\n }\n\n event.preventDefault();\n event.stopPropagation();\n\n if (this.disabled || $(this).hasClass(ClassName$4.DISABLED)) {\n return;\n }\n\n var parent = Dropdown._getParentFromElement(this);\n\n var isActive = $(parent).hasClass(ClassName$4.SHOW);\n\n if (!isActive && event.which === ESCAPE_KEYCODE) {\n return;\n }\n\n if (!isActive || isActive && (event.which === ESCAPE_KEYCODE || event.which === SPACE_KEYCODE)) {\n if (event.which === ESCAPE_KEYCODE) {\n var toggle = parent.querySelector(Selector$4.DATA_TOGGLE);\n $(toggle).trigger('focus');\n }\n\n $(this).trigger('click');\n return;\n }\n\n var items = [].slice.call(parent.querySelectorAll(Selector$4.VISIBLE_ITEMS)).filter(function (item) {\n return $(item).is(':visible');\n });\n\n if (items.length === 0) {\n return;\n }\n\n var index = items.indexOf(event.target);\n\n if (event.which === ARROW_UP_KEYCODE && index > 0) {\n // Up\n index--;\n }\n\n if (event.which === ARROW_DOWN_KEYCODE && index < items.length - 1) {\n // Down\n index++;\n }\n\n if (index < 0) {\n index = 0;\n }\n\n items[index].focus();\n };\n\n _createClass(Dropdown, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION$4;\n }\n }, {\n key: \"Default\",\n get: function get() {\n return Default$2;\n }\n }, {\n key: \"DefaultType\",\n get: function get() {\n return DefaultType$2;\n }\n }]);\n\n return Dropdown;\n }();\n /**\n * ------------------------------------------------------------------------\n * Data Api implementation\n * ------------------------------------------------------------------------\n */\n\n\n $(document).on(Event$4.KEYDOWN_DATA_API, Selector$4.DATA_TOGGLE, Dropdown._dataApiKeydownHandler).on(Event$4.KEYDOWN_DATA_API, Selector$4.MENU, Dropdown._dataApiKeydownHandler).on(Event$4.CLICK_DATA_API + \" \" + Event$4.KEYUP_DATA_API, Dropdown._clearMenus).on(Event$4.CLICK_DATA_API, Selector$4.DATA_TOGGLE, function (event) {\n event.preventDefault();\n event.stopPropagation();\n\n Dropdown._jQueryInterface.call($(this), 'toggle');\n }).on(Event$4.CLICK_DATA_API, Selector$4.FORM_CHILD, function (e) {\n e.stopPropagation();\n });\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n $.fn[NAME$4] = Dropdown._jQueryInterface;\n $.fn[NAME$4].Constructor = Dropdown;\n\n $.fn[NAME$4].noConflict = function () {\n $.fn[NAME$4] = JQUERY_NO_CONFLICT$4;\n return Dropdown._jQueryInterface;\n };\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$5 = 'modal';\n var VERSION$5 = '4.4.1';\n var DATA_KEY$5 = 'bs.modal';\n var EVENT_KEY$5 = \".\" + DATA_KEY$5;\n var DATA_API_KEY$5 = '.data-api';\n var JQUERY_NO_CONFLICT$5 = $.fn[NAME$5];\n var ESCAPE_KEYCODE$1 = 27; // KeyboardEvent.which value for Escape (Esc) key\n\n var Default$3 = {\n backdrop: true,\n keyboard: true,\n focus: true,\n show: true\n };\n var DefaultType$3 = {\n backdrop: '(boolean|string)',\n keyboard: 'boolean',\n focus: 'boolean',\n show: 'boolean'\n };\n var Event$5 = {\n HIDE: \"hide\" + EVENT_KEY$5,\n HIDE_PREVENTED: \"hidePrevented\" + EVENT_KEY$5,\n HIDDEN: \"hidden\" + EVENT_KEY$5,\n SHOW: \"show\" + EVENT_KEY$5,\n SHOWN: \"shown\" + EVENT_KEY$5,\n FOCUSIN: \"focusin\" + EVENT_KEY$5,\n RESIZE: \"resize\" + EVENT_KEY$5,\n CLICK_DISMISS: \"click.dismiss\" + EVENT_KEY$5,\n KEYDOWN_DISMISS: \"keydown.dismiss\" + EVENT_KEY$5,\n MOUSEUP_DISMISS: \"mouseup.dismiss\" + EVENT_KEY$5,\n MOUSEDOWN_DISMISS: \"mousedown.dismiss\" + EVENT_KEY$5,\n CLICK_DATA_API: \"click\" + EVENT_KEY$5 + DATA_API_KEY$5\n };\n var ClassName$5 = {\n SCROLLABLE: 'modal-dialog-scrollable',\n SCROLLBAR_MEASURER: 'modal-scrollbar-measure',\n BACKDROP: 'modal-backdrop',\n OPEN: 'modal-open',\n FADE: 'fade',\n SHOW: 'show',\n STATIC: 'modal-static'\n };\n var Selector$5 = {\n DIALOG: '.modal-dialog',\n MODAL_BODY: '.modal-body',\n DATA_TOGGLE: '[data-toggle=\"modal\"]',\n DATA_DISMISS: '[data-dismiss=\"modal\"]',\n FIXED_CONTENT: '.fixed-top, .fixed-bottom, .is-fixed, .sticky-top',\n STICKY_CONTENT: '.sticky-top'\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Modal =\n /*#__PURE__*/\n function () {\n function Modal(element, config) {\n this._config = this._getConfig(config);\n this._element = element;\n this._dialog = element.querySelector(Selector$5.DIALOG);\n this._backdrop = null;\n this._isShown = false;\n this._isBodyOverflowing = false;\n this._ignoreBackdropClick = false;\n this._isTransitioning = false;\n this._scrollbarWidth = 0;\n } // Getters\n\n\n var _proto = Modal.prototype;\n\n // Public\n _proto.toggle = function toggle(relatedTarget) {\n return this._isShown ? this.hide() : this.show(relatedTarget);\n };\n\n _proto.show = function show(relatedTarget) {\n var _this = this;\n\n if (this._isShown || this._isTransitioning) {\n return;\n }\n\n if ($(this._element).hasClass(ClassName$5.FADE)) {\n this._isTransitioning = true;\n }\n\n var showEvent = $.Event(Event$5.SHOW, {\n relatedTarget: relatedTarget\n });\n $(this._element).trigger(showEvent);\n\n if (this._isShown || showEvent.isDefaultPrevented()) {\n return;\n }\n\n this._isShown = true;\n\n this._checkScrollbar();\n\n this._setScrollbar();\n\n this._adjustDialog();\n\n this._setEscapeEvent();\n\n this._setResizeEvent();\n\n $(this._element).on(Event$5.CLICK_DISMISS, Selector$5.DATA_DISMISS, function (event) {\n return _this.hide(event);\n });\n $(this._dialog).on(Event$5.MOUSEDOWN_DISMISS, function () {\n $(_this._element).one(Event$5.MOUSEUP_DISMISS, function (event) {\n if ($(event.target).is(_this._element)) {\n _this._ignoreBackdropClick = true;\n }\n });\n });\n\n this._showBackdrop(function () {\n return _this._showElement(relatedTarget);\n });\n };\n\n _proto.hide = function hide(event) {\n var _this2 = this;\n\n if (event) {\n event.preventDefault();\n }\n\n if (!this._isShown || this._isTransitioning) {\n return;\n }\n\n var hideEvent = $.Event(Event$5.HIDE);\n $(this._element).trigger(hideEvent);\n\n if (!this._isShown || hideEvent.isDefaultPrevented()) {\n return;\n }\n\n this._isShown = false;\n var transition = $(this._element).hasClass(ClassName$5.FADE);\n\n if (transition) {\n this._isTransitioning = true;\n }\n\n this._setEscapeEvent();\n\n this._setResizeEvent();\n\n $(document).off(Event$5.FOCUSIN);\n $(this._element).removeClass(ClassName$5.SHOW);\n $(this._element).off(Event$5.CLICK_DISMISS);\n $(this._dialog).off(Event$5.MOUSEDOWN_DISMISS);\n\n if (transition) {\n var transitionDuration = Util.getTransitionDurationFromElement(this._element);\n $(this._element).one(Util.TRANSITION_END, function (event) {\n return _this2._hideModal(event);\n }).emulateTransitionEnd(transitionDuration);\n } else {\n this._hideModal();\n }\n };\n\n _proto.dispose = function dispose() {\n [window, this._element, this._dialog].forEach(function (htmlElement) {\n return $(htmlElement).off(EVENT_KEY$5);\n });\n /**\n * `document` has 2 events `Event.FOCUSIN` and `Event.CLICK_DATA_API`\n * Do not move `document` in `htmlElements` array\n * It will remove `Event.CLICK_DATA_API` event that should remain\n */\n\n $(document).off(Event$5.FOCUSIN);\n $.removeData(this._element, DATA_KEY$5);\n this._config = null;\n this._element = null;\n this._dialog = null;\n this._backdrop = null;\n this._isShown = null;\n this._isBodyOverflowing = null;\n this._ignoreBackdropClick = null;\n this._isTransitioning = null;\n this._scrollbarWidth = null;\n };\n\n _proto.handleUpdate = function handleUpdate() {\n this._adjustDialog();\n } // Private\n ;\n\n _proto._getConfig = function _getConfig(config) {\n config = _objectSpread2({}, Default$3, {}, config);\n Util.typeCheckConfig(NAME$5, config, DefaultType$3);\n return config;\n };\n\n _proto._triggerBackdropTransition = function _triggerBackdropTransition() {\n var _this3 = this;\n\n if (this._config.backdrop === 'static') {\n var hideEventPrevented = $.Event(Event$5.HIDE_PREVENTED);\n $(this._element).trigger(hideEventPrevented);\n\n if (hideEventPrevented.defaultPrevented) {\n return;\n }\n\n this._element.classList.add(ClassName$5.STATIC);\n\n var modalTransitionDuration = Util.getTransitionDurationFromElement(this._element);\n $(this._element).one(Util.TRANSITION_END, function () {\n _this3._element.classList.remove(ClassName$5.STATIC);\n }).emulateTransitionEnd(modalTransitionDuration);\n\n this._element.focus();\n } else {\n this.hide();\n }\n };\n\n _proto._showElement = function _showElement(relatedTarget) {\n var _this4 = this;\n\n var transition = $(this._element).hasClass(ClassName$5.FADE);\n var modalBody = this._dialog ? this._dialog.querySelector(Selector$5.MODAL_BODY) : null;\n\n if (!this._element.parentNode || this._element.parentNode.nodeType !== Node.ELEMENT_NODE) {\n // Don't move modal's DOM position\n document.body.appendChild(this._element);\n }\n\n this._element.style.display = 'block';\n\n this._element.removeAttribute('aria-hidden');\n\n this._element.setAttribute('aria-modal', true);\n\n if ($(this._dialog).hasClass(ClassName$5.SCROLLABLE) && modalBody) {\n modalBody.scrollTop = 0;\n } else {\n this._element.scrollTop = 0;\n }\n\n if (transition) {\n Util.reflow(this._element);\n }\n\n $(this._element).addClass(ClassName$5.SHOW);\n\n if (this._config.focus) {\n this._enforceFocus();\n }\n\n var shownEvent = $.Event(Event$5.SHOWN, {\n relatedTarget: relatedTarget\n });\n\n var transitionComplete = function transitionComplete() {\n if (_this4._config.focus) {\n _this4._element.focus();\n }\n\n _this4._isTransitioning = false;\n $(_this4._element).trigger(shownEvent);\n };\n\n if (transition) {\n var transitionDuration = Util.getTransitionDurationFromElement(this._dialog);\n $(this._dialog).one(Util.TRANSITION_END, transitionComplete).emulateTransitionEnd(transitionDuration);\n } else {\n transitionComplete();\n }\n };\n\n _proto._enforceFocus = function _enforceFocus() {\n var _this5 = this;\n\n $(document).off(Event$5.FOCUSIN) // Guard against infinite focus loop\n .on(Event$5.FOCUSIN, function (event) {\n if (document !== event.target && _this5._element !== event.target && $(_this5._element).has(event.target).length === 0) {\n _this5._element.focus();\n }\n });\n };\n\n _proto._setEscapeEvent = function _setEscapeEvent() {\n var _this6 = this;\n\n if (this._isShown && this._config.keyboard) {\n $(this._element).on(Event$5.KEYDOWN_DISMISS, function (event) {\n if (event.which === ESCAPE_KEYCODE$1) {\n _this6._triggerBackdropTransition();\n }\n });\n } else if (!this._isShown) {\n $(this._element).off(Event$5.KEYDOWN_DISMISS);\n }\n };\n\n _proto._setResizeEvent = function _setResizeEvent() {\n var _this7 = this;\n\n if (this._isShown) {\n $(window).on(Event$5.RESIZE, function (event) {\n return _this7.handleUpdate(event);\n });\n } else {\n $(window).off(Event$5.RESIZE);\n }\n };\n\n _proto._hideModal = function _hideModal() {\n var _this8 = this;\n\n this._element.style.display = 'none';\n\n this._element.setAttribute('aria-hidden', true);\n\n this._element.removeAttribute('aria-modal');\n\n this._isTransitioning = false;\n\n this._showBackdrop(function () {\n $(document.body).removeClass(ClassName$5.OPEN);\n\n _this8._resetAdjustments();\n\n _this8._resetScrollbar();\n\n $(_this8._element).trigger(Event$5.HIDDEN);\n });\n };\n\n _proto._removeBackdrop = function _removeBackdrop() {\n if (this._backdrop) {\n $(this._backdrop).remove();\n this._backdrop = null;\n }\n };\n\n _proto._showBackdrop = function _showBackdrop(callback) {\n var _this9 = this;\n\n var animate = $(this._element).hasClass(ClassName$5.FADE) ? ClassName$5.FADE : '';\n\n if (this._isShown && this._config.backdrop) {\n this._backdrop = document.createElement('div');\n this._backdrop.className = ClassName$5.BACKDROP;\n\n if (animate) {\n this._backdrop.classList.add(animate);\n }\n\n $(this._backdrop).appendTo(document.body);\n $(this._element).on(Event$5.CLICK_DISMISS, function (event) {\n if (_this9._ignoreBackdropClick) {\n _this9._ignoreBackdropClick = false;\n return;\n }\n\n if (event.target !== event.currentTarget) {\n return;\n }\n\n _this9._triggerBackdropTransition();\n });\n\n if (animate) {\n Util.reflow(this._backdrop);\n }\n\n $(this._backdrop).addClass(ClassName$5.SHOW);\n\n if (!callback) {\n return;\n }\n\n if (!animate) {\n callback();\n return;\n }\n\n var backdropTransitionDuration = Util.getTransitionDurationFromElement(this._backdrop);\n $(this._backdrop).one(Util.TRANSITION_END, callback).emulateTransitionEnd(backdropTransitionDuration);\n } else if (!this._isShown && this._backdrop) {\n $(this._backdrop).removeClass(ClassName$5.SHOW);\n\n var callbackRemove = function callbackRemove() {\n _this9._removeBackdrop();\n\n if (callback) {\n callback();\n }\n };\n\n if ($(this._element).hasClass(ClassName$5.FADE)) {\n var _backdropTransitionDuration = Util.getTransitionDurationFromElement(this._backdrop);\n\n $(this._backdrop).one(Util.TRANSITION_END, callbackRemove).emulateTransitionEnd(_backdropTransitionDuration);\n } else {\n callbackRemove();\n }\n } else if (callback) {\n callback();\n }\n } // ----------------------------------------------------------------------\n // the following methods are used to handle overflowing modals\n // todo (fat): these should probably be refactored out of modal.js\n // ----------------------------------------------------------------------\n ;\n\n _proto._adjustDialog = function _adjustDialog() {\n var isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;\n\n if (!this._isBodyOverflowing && isModalOverflowing) {\n this._element.style.paddingLeft = this._scrollbarWidth + \"px\";\n }\n\n if (this._isBodyOverflowing && !isModalOverflowing) {\n this._element.style.paddingRight = this._scrollbarWidth + \"px\";\n }\n };\n\n _proto._resetAdjustments = function _resetAdjustments() {\n this._element.style.paddingLeft = '';\n this._element.style.paddingRight = '';\n };\n\n _proto._checkScrollbar = function _checkScrollbar() {\n var rect = document.body.getBoundingClientRect();\n this._isBodyOverflowing = rect.left + rect.right < window.innerWidth;\n this._scrollbarWidth = this._getScrollbarWidth();\n };\n\n _proto._setScrollbar = function _setScrollbar() {\n var _this10 = this;\n\n if (this._isBodyOverflowing) {\n // Note: DOMNode.style.paddingRight returns the actual value or '' if not set\n // while $(DOMNode).css('padding-right') returns the calculated value or 0 if not set\n var fixedContent = [].slice.call(document.querySelectorAll(Selector$5.FIXED_CONTENT));\n var stickyContent = [].slice.call(document.querySelectorAll(Selector$5.STICKY_CONTENT)); // Adjust fixed content padding\n\n $(fixedContent).each(function (index, element) {\n var actualPadding = element.style.paddingRight;\n var calculatedPadding = $(element).css('padding-right');\n $(element).data('padding-right', actualPadding).css('padding-right', parseFloat(calculatedPadding) + _this10._scrollbarWidth + \"px\");\n }); // Adjust sticky content margin\n\n $(stickyContent).each(function (index, element) {\n var actualMargin = element.style.marginRight;\n var calculatedMargin = $(element).css('margin-right');\n $(element).data('margin-right', actualMargin).css('margin-right', parseFloat(calculatedMargin) - _this10._scrollbarWidth + \"px\");\n }); // Adjust body padding\n\n var actualPadding = document.body.style.paddingRight;\n var calculatedPadding = $(document.body).css('padding-right');\n $(document.body).data('padding-right', actualPadding).css('padding-right', parseFloat(calculatedPadding) + this._scrollbarWidth + \"px\");\n }\n\n $(document.body).addClass(ClassName$5.OPEN);\n };\n\n _proto._resetScrollbar = function _resetScrollbar() {\n // Restore fixed content padding\n var fixedContent = [].slice.call(document.querySelectorAll(Selector$5.FIXED_CONTENT));\n $(fixedContent).each(function (index, element) {\n var padding = $(element).data('padding-right');\n $(element).removeData('padding-right');\n element.style.paddingRight = padding ? padding : '';\n }); // Restore sticky content\n\n var elements = [].slice.call(document.querySelectorAll(\"\" + Selector$5.STICKY_CONTENT));\n $(elements).each(function (index, element) {\n var margin = $(element).data('margin-right');\n\n if (typeof margin !== 'undefined') {\n $(element).css('margin-right', margin).removeData('margin-right');\n }\n }); // Restore body padding\n\n var padding = $(document.body).data('padding-right');\n $(document.body).removeData('padding-right');\n document.body.style.paddingRight = padding ? padding : '';\n };\n\n _proto._getScrollbarWidth = function _getScrollbarWidth() {\n // thx d.walsh\n var scrollDiv = document.createElement('div');\n scrollDiv.className = ClassName$5.SCROLLBAR_MEASURER;\n document.body.appendChild(scrollDiv);\n var scrollbarWidth = scrollDiv.getBoundingClientRect().width - scrollDiv.clientWidth;\n document.body.removeChild(scrollDiv);\n return scrollbarWidth;\n } // Static\n ;\n\n Modal._jQueryInterface = function _jQueryInterface(config, relatedTarget) {\n return this.each(function () {\n var data = $(this).data(DATA_KEY$5);\n\n var _config = _objectSpread2({}, Default$3, {}, $(this).data(), {}, typeof config === 'object' && config ? config : {});\n\n if (!data) {\n data = new Modal(this, _config);\n $(this).data(DATA_KEY$5, data);\n }\n\n if (typeof config === 'string') {\n if (typeof data[config] === 'undefined') {\n throw new TypeError(\"No method named \\\"\" + config + \"\\\"\");\n }\n\n data[config](relatedTarget);\n } else if (_config.show) {\n data.show(relatedTarget);\n }\n });\n };\n\n _createClass(Modal, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION$5;\n }\n }, {\n key: \"Default\",\n get: function get() {\n return Default$3;\n }\n }]);\n\n return Modal;\n }();\n /**\n * ------------------------------------------------------------------------\n * Data Api implementation\n * ------------------------------------------------------------------------\n */\n\n\n $(document).on(Event$5.CLICK_DATA_API, Selector$5.DATA_TOGGLE, function (event) {\n var _this11 = this;\n\n var target;\n var selector = Util.getSelectorFromElement(this);\n\n if (selector) {\n target = document.querySelector(selector);\n }\n\n var config = $(target).data(DATA_KEY$5) ? 'toggle' : _objectSpread2({}, $(target).data(), {}, $(this).data());\n\n if (this.tagName === 'A' || this.tagName === 'AREA') {\n event.preventDefault();\n }\n\n var $target = $(target).one(Event$5.SHOW, function (showEvent) {\n if (showEvent.isDefaultPrevented()) {\n // Only register focus restorer if modal will actually get shown\n return;\n }\n\n $target.one(Event$5.HIDDEN, function () {\n if ($(_this11).is(':visible')) {\n _this11.focus();\n }\n });\n });\n\n Modal._jQueryInterface.call($(target), config, this);\n });\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n $.fn[NAME$5] = Modal._jQueryInterface;\n $.fn[NAME$5].Constructor = Modal;\n\n $.fn[NAME$5].noConflict = function () {\n $.fn[NAME$5] = JQUERY_NO_CONFLICT$5;\n return Modal._jQueryInterface;\n };\n\n /**\n * --------------------------------------------------------------------------\n * Bootstrap (v4.4.1): tools/sanitizer.js\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)\n * --------------------------------------------------------------------------\n */\n var uriAttrs = ['background', 'cite', 'href', 'itemtype', 'longdesc', 'poster', 'src', 'xlink:href'];\n var ARIA_ATTRIBUTE_PATTERN = /^aria-[\\w-]*$/i;\n var DefaultWhitelist = {\n // Global attributes allowed on any supplied element below.\n '*': ['class', 'dir', 'id', 'lang', 'role', ARIA_ATTRIBUTE_PATTERN],\n a: ['target', 'href', 'title', 'rel'],\n area: [],\n b: [],\n br: [],\n col: [],\n code: [],\n div: [],\n em: [],\n hr: [],\n h1: [],\n h2: [],\n h3: [],\n h4: [],\n h5: [],\n h6: [],\n i: [],\n img: ['src', 'alt', 'title', 'width', 'height'],\n li: [],\n ol: [],\n p: [],\n pre: [],\n s: [],\n small: [],\n span: [],\n sub: [],\n sup: [],\n strong: [],\n u: [],\n ul: []\n };\n /**\n * A pattern that recognizes a commonly useful subset of URLs that are safe.\n *\n * Shoutout to Angular 7 https://github.com/angular/angular/blob/7.2.4/packages/core/src/sanitization/url_sanitizer.ts\n */\n\n var SAFE_URL_PATTERN = /^(?:(?:https?|mailto|ftp|tel|file):|[^&:/?#]*(?:[/?#]|$))/gi;\n /**\n * A pattern that matches safe data URLs. Only matches image, video and audio types.\n *\n * Shoutout to Angular 7 https://github.com/angular/angular/blob/7.2.4/packages/core/src/sanitization/url_sanitizer.ts\n */\n\n var DATA_URL_PATTERN = /^data:(?:image\\/(?:bmp|gif|jpeg|jpg|png|tiff|webp)|video\\/(?:mpeg|mp4|ogg|webm)|audio\\/(?:mp3|oga|ogg|opus));base64,[a-z0-9+/]+=*$/i;\n\n function allowedAttribute(attr, allowedAttributeList) {\n var attrName = attr.nodeName.toLowerCase();\n\n if (allowedAttributeList.indexOf(attrName) !== -1) {\n if (uriAttrs.indexOf(attrName) !== -1) {\n return Boolean(attr.nodeValue.match(SAFE_URL_PATTERN) || attr.nodeValue.match(DATA_URL_PATTERN));\n }\n\n return true;\n }\n\n var regExp = allowedAttributeList.filter(function (attrRegex) {\n return attrRegex instanceof RegExp;\n }); // Check if a regular expression validates the attribute.\n\n for (var i = 0, l = regExp.length; i < l; i++) {\n if (attrName.match(regExp[i])) {\n return true;\n }\n }\n\n return false;\n }\n\n function sanitizeHtml(unsafeHtml, whiteList, sanitizeFn) {\n if (unsafeHtml.length === 0) {\n return unsafeHtml;\n }\n\n if (sanitizeFn && typeof sanitizeFn === 'function') {\n return sanitizeFn(unsafeHtml);\n }\n\n var domParser = new window.DOMParser();\n var createdDocument = domParser.parseFromString(unsafeHtml, 'text/html');\n var whitelistKeys = Object.keys(whiteList);\n var elements = [].slice.call(createdDocument.body.querySelectorAll('*'));\n\n var _loop = function _loop(i, len) {\n var el = elements[i];\n var elName = el.nodeName.toLowerCase();\n\n if (whitelistKeys.indexOf(el.nodeName.toLowerCase()) === -1) {\n el.parentNode.removeChild(el);\n return \"continue\";\n }\n\n var attributeList = [].slice.call(el.attributes);\n var whitelistedAttributes = [].concat(whiteList['*'] || [], whiteList[elName] || []);\n attributeList.forEach(function (attr) {\n if (!allowedAttribute(attr, whitelistedAttributes)) {\n el.removeAttribute(attr.nodeName);\n }\n });\n };\n\n for (var i = 0, len = elements.length; i < len; i++) {\n var _ret = _loop(i);\n\n if (_ret === \"continue\") continue;\n }\n\n return createdDocument.body.innerHTML;\n }\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$6 = 'tooltip';\n var VERSION$6 = '4.4.1';\n var DATA_KEY$6 = 'bs.tooltip';\n var EVENT_KEY$6 = \".\" + DATA_KEY$6;\n var JQUERY_NO_CONFLICT$6 = $.fn[NAME$6];\n var CLASS_PREFIX = 'bs-tooltip';\n var BSCLS_PREFIX_REGEX = new RegExp(\"(^|\\\\s)\" + CLASS_PREFIX + \"\\\\S+\", 'g');\n var DISALLOWED_ATTRIBUTES = ['sanitize', 'whiteList', 'sanitizeFn'];\n var DefaultType$4 = {\n animation: 'boolean',\n template: 'string',\n title: '(string|element|function)',\n trigger: 'string',\n delay: '(number|object)',\n html: 'boolean',\n selector: '(string|boolean)',\n placement: '(string|function)',\n offset: '(number|string|function)',\n container: '(string|element|boolean)',\n fallbackPlacement: '(string|array)',\n boundary: '(string|element)',\n sanitize: 'boolean',\n sanitizeFn: '(null|function)',\n whiteList: 'object',\n popperConfig: '(null|object)'\n };\n var AttachmentMap$1 = {\n AUTO: 'auto',\n TOP: 'top',\n RIGHT: 'right',\n BOTTOM: 'bottom',\n LEFT: 'left'\n };\n var Default$4 = {\n animation: true,\n template: '<div class=\"tooltip\" role=\"tooltip\">' + '<div class=\"arrow\"></div>' + '<div class=\"tooltip-inner\"></div></div>',\n trigger: 'hover focus',\n title: '',\n delay: 0,\n html: false,\n selector: false,\n placement: 'top',\n offset: 0,\n container: false,\n fallbackPlacement: 'flip',\n boundary: 'scrollParent',\n sanitize: true,\n sanitizeFn: null,\n whiteList: DefaultWhitelist,\n popperConfig: null\n };\n var HoverState = {\n SHOW: 'show',\n OUT: 'out'\n };\n var Event$6 = {\n HIDE: \"hide\" + EVENT_KEY$6,\n HIDDEN: \"hidden\" + EVENT_KEY$6,\n SHOW: \"show\" + EVENT_KEY$6,\n SHOWN: \"shown\" + EVENT_KEY$6,\n INSERTED: \"inserted\" + EVENT_KEY$6,\n CLICK: \"click\" + EVENT_KEY$6,\n FOCUSIN: \"focusin\" + EVENT_KEY$6,\n FOCUSOUT: \"focusout\" + EVENT_KEY$6,\n MOUSEENTER: \"mouseenter\" + EVENT_KEY$6,\n MOUSELEAVE: \"mouseleave\" + EVENT_KEY$6\n };\n var ClassName$6 = {\n FADE: 'fade',\n SHOW: 'show'\n };\n var Selector$6 = {\n TOOLTIP: '.tooltip',\n TOOLTIP_INNER: '.tooltip-inner',\n ARROW: '.arrow'\n };\n var Trigger = {\n HOVER: 'hover',\n FOCUS: 'focus',\n CLICK: 'click',\n MANUAL: 'manual'\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Tooltip =\n /*#__PURE__*/\n function () {\n function Tooltip(element, config) {\n if (typeof Popper === 'undefined') {\n throw new TypeError('Bootstrap\\'s tooltips require Popper.js (https://popper.js.org/)');\n } // private\n\n\n this._isEnabled = true;\n this._timeout = 0;\n this._hoverState = '';\n this._activeTrigger = {};\n this._popper = null; // Protected\n\n this.element = element;\n this.config = this._getConfig(config);\n this.tip = null;\n\n this._setListeners();\n } // Getters\n\n\n var _proto = Tooltip.prototype;\n\n // Public\n _proto.enable = function enable() {\n this._isEnabled = true;\n };\n\n _proto.disable = function disable() {\n this._isEnabled = false;\n };\n\n _proto.toggleEnabled = function toggleEnabled() {\n this._isEnabled = !this._isEnabled;\n };\n\n _proto.toggle = function toggle(event) {\n if (!this._isEnabled) {\n return;\n }\n\n if (event) {\n var dataKey = this.constructor.DATA_KEY;\n var context = $(event.currentTarget).data(dataKey);\n\n if (!context) {\n context = new this.constructor(event.currentTarget, this._getDelegateConfig());\n $(event.currentTarget).data(dataKey, context);\n }\n\n context._activeTrigger.click = !context._activeTrigger.click;\n\n if (context._isWithActiveTrigger()) {\n context._enter(null, context);\n } else {\n context._leave(null, context);\n }\n } else {\n if ($(this.getTipElement()).hasClass(ClassName$6.SHOW)) {\n this._leave(null, this);\n\n return;\n }\n\n this._enter(null, this);\n }\n };\n\n _proto.dispose = function dispose() {\n clearTimeout(this._timeout);\n $.removeData(this.element, this.constructor.DATA_KEY);\n $(this.element).off(this.constructor.EVENT_KEY);\n $(this.element).closest('.modal').off('hide.bs.modal', this._hideModalHandler);\n\n if (this.tip) {\n $(this.tip).remove();\n }\n\n this._isEnabled = null;\n this._timeout = null;\n this._hoverState = null;\n this._activeTrigger = null;\n\n if (this._popper) {\n this._popper.destroy();\n }\n\n this._popper = null;\n this.element = null;\n this.config = null;\n this.tip = null;\n };\n\n _proto.show = function show() {\n var _this = this;\n\n if ($(this.element).css('display') === 'none') {\n throw new Error('Please use show on visible elements');\n }\n\n var showEvent = $.Event(this.constructor.Event.SHOW);\n\n if (this.isWithContent() && this._isEnabled) {\n $(this.element).trigger(showEvent);\n var shadowRoot = Util.findShadowRoot(this.element);\n var isInTheDom = $.contains(shadowRoot !== null ? shadowRoot : this.element.ownerDocument.documentElement, this.element);\n\n if (showEvent.isDefaultPrevented() || !isInTheDom) {\n return;\n }\n\n var tip = this.getTipElement();\n var tipId = Util.getUID(this.constructor.NAME);\n tip.setAttribute('id', tipId);\n this.element.setAttribute('aria-describedby', tipId);\n this.setContent();\n\n if (this.config.animation) {\n $(tip).addClass(ClassName$6.FADE);\n }\n\n var placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this.element) : this.config.placement;\n\n var attachment = this._getAttachment(placement);\n\n this.addAttachmentClass(attachment);\n\n var container = this._getContainer();\n\n $(tip).data(this.constructor.DATA_KEY, this);\n\n if (!$.contains(this.element.ownerDocument.documentElement, this.tip)) {\n $(tip).appendTo(container);\n }\n\n $(this.element).trigger(this.constructor.Event.INSERTED);\n this._popper = new Popper(this.element, tip, this._getPopperConfig(attachment));\n $(tip).addClass(ClassName$6.SHOW); // If this is a touch-enabled device we add extra\n // empty mouseover listeners to the body's immediate children;\n // only needed because of broken event delegation on iOS\n // https://www.quirksmode.org/blog/archives/2014/02/mouse_event_bub.html\n\n if ('ontouchstart' in document.documentElement) {\n $(document.body).children().on('mouseover', null, $.noop);\n }\n\n var complete = function complete() {\n if (_this.config.animation) {\n _this._fixTransition();\n }\n\n var prevHoverState = _this._hoverState;\n _this._hoverState = null;\n $(_this.element).trigger(_this.constructor.Event.SHOWN);\n\n if (prevHoverState === HoverState.OUT) {\n _this._leave(null, _this);\n }\n };\n\n if ($(this.tip).hasClass(ClassName$6.FADE)) {\n var transitionDuration = Util.getTransitionDurationFromElement(this.tip);\n $(this.tip).one(Util.TRANSITION_END, complete).emulateTransitionEnd(transitionDuration);\n } else {\n complete();\n }\n }\n };\n\n _proto.hide = function hide(callback) {\n var _this2 = this;\n\n var tip = this.getTipElement();\n var hideEvent = $.Event(this.constructor.Event.HIDE);\n\n var complete = function complete() {\n if (_this2._hoverState !== HoverState.SHOW && tip.parentNode) {\n tip.parentNode.removeChild(tip);\n }\n\n _this2._cleanTipClass();\n\n _this2.element.removeAttribute('aria-describedby');\n\n $(_this2.element).trigger(_this2.constructor.Event.HIDDEN);\n\n if (_this2._popper !== null) {\n _this2._popper.destroy();\n }\n\n if (callback) {\n callback();\n }\n };\n\n $(this.element).trigger(hideEvent);\n\n if (hideEvent.isDefaultPrevented()) {\n return;\n }\n\n $(tip).removeClass(ClassName$6.SHOW); // If this is a touch-enabled device we remove the extra\n // empty mouseover listeners we added for iOS support\n\n if ('ontouchstart' in document.documentElement) {\n $(document.body).children().off('mouseover', null, $.noop);\n }\n\n this._activeTrigger[Trigger.CLICK] = false;\n this._activeTrigger[Trigger.FOCUS] = false;\n this._activeTrigger[Trigger.HOVER] = false;\n\n if ($(this.tip).hasClass(ClassName$6.FADE)) {\n var transitionDuration = Util.getTransitionDurationFromElement(tip);\n $(tip).one(Util.TRANSITION_END, complete).emulateTransitionEnd(transitionDuration);\n } else {\n complete();\n }\n\n this._hoverState = '';\n };\n\n _proto.update = function update() {\n if (this._popper !== null) {\n this._popper.scheduleUpdate();\n }\n } // Protected\n ;\n\n _proto.isWithContent = function isWithContent() {\n return Boolean(this.getTitle());\n };\n\n _proto.addAttachmentClass = function addAttachmentClass(attachment) {\n $(this.getTipElement()).addClass(CLASS_PREFIX + \"-\" + attachment);\n };\n\n _proto.getTipElement = function getTipElement() {\n this.tip = this.tip || $(this.config.template)[0];\n return this.tip;\n };\n\n _proto.setContent = function setContent() {\n var tip = this.getTipElement();\n this.setElementContent($(tip.querySelectorAll(Selector$6.TOOLTIP_INNER)), this.getTitle());\n $(tip).removeClass(ClassName$6.FADE + \" \" + ClassName$6.SHOW);\n };\n\n _proto.setElementContent = function setElementContent($element, content) {\n if (typeof content === 'object' && (content.nodeType || content.jquery)) {\n // Content is a DOM node or a jQuery\n if (this.config.html) {\n if (!$(content).parent().is($element)) {\n $element.empty().append(content);\n }\n } else {\n $element.text($(content).text());\n }\n\n return;\n }\n\n if (this.config.html) {\n if (this.config.sanitize) {\n content = sanitizeHtml(content, this.config.whiteList, this.config.sanitizeFn);\n }\n\n $element.html(content);\n } else {\n $element.text(content);\n }\n };\n\n _proto.getTitle = function getTitle() {\n var title = this.element.getAttribute('data-original-title');\n\n if (!title) {\n title = typeof this.config.title === 'function' ? this.config.title.call(this.element) : this.config.title;\n }\n\n return title;\n } // Private\n ;\n\n _proto._getPopperConfig = function _getPopperConfig(attachment) {\n var _this3 = this;\n\n var defaultBsConfig = {\n placement: attachment,\n modifiers: {\n offset: this._getOffset(),\n flip: {\n behavior: this.config.fallbackPlacement\n },\n arrow: {\n element: Selector$6.ARROW\n },\n preventOverflow: {\n boundariesElement: this.config.boundary\n }\n },\n onCreate: function onCreate(data) {\n if (data.originalPlacement !== data.placement) {\n _this3._handlePopperPlacementChange(data);\n }\n },\n onUpdate: function onUpdate(data) {\n return _this3._handlePopperPlacementChange(data);\n }\n };\n return _objectSpread2({}, defaultBsConfig, {}, this.config.popperConfig);\n };\n\n _proto._getOffset = function _getOffset() {\n var _this4 = this;\n\n var offset = {};\n\n if (typeof this.config.offset === 'function') {\n offset.fn = function (data) {\n data.offsets = _objectSpread2({}, data.offsets, {}, _this4.config.offset(data.offsets, _this4.element) || {});\n return data;\n };\n } else {\n offset.offset = this.config.offset;\n }\n\n return offset;\n };\n\n _proto._getContainer = function _getContainer() {\n if (this.config.container === false) {\n return document.body;\n }\n\n if (Util.isElement(this.config.container)) {\n return $(this.config.container);\n }\n\n return $(document).find(this.config.container);\n };\n\n _proto._getAttachment = function _getAttachment(placement) {\n return AttachmentMap$1[placement.toUpperCase()];\n };\n\n _proto._setListeners = function _setListeners() {\n var _this5 = this;\n\n var triggers = this.config.trigger.split(' ');\n triggers.forEach(function (trigger) {\n if (trigger === 'click') {\n $(_this5.element).on(_this5.constructor.Event.CLICK, _this5.config.selector, function (event) {\n return _this5.toggle(event);\n });\n } else if (trigger !== Trigger.MANUAL) {\n var eventIn = trigger === Trigger.HOVER ? _this5.constructor.Event.MOUSEENTER : _this5.constructor.Event.FOCUSIN;\n var eventOut = trigger === Trigger.HOVER ? _this5.constructor.Event.MOUSELEAVE : _this5.constructor.Event.FOCUSOUT;\n $(_this5.element).on(eventIn, _this5.config.selector, function (event) {\n return _this5._enter(event);\n }).on(eventOut, _this5.config.selector, function (event) {\n return _this5._leave(event);\n });\n }\n });\n\n this._hideModalHandler = function () {\n if (_this5.element) {\n _this5.hide();\n }\n };\n\n $(this.element).closest('.modal').on('hide.bs.modal', this._hideModalHandler);\n\n if (this.config.selector) {\n this.config = _objectSpread2({}, this.config, {\n trigger: 'manual',\n selector: ''\n });\n } else {\n this._fixTitle();\n }\n };\n\n _proto._fixTitle = function _fixTitle() {\n var titleType = typeof this.element.getAttribute('data-original-title');\n\n if (this.element.getAttribute('title') || titleType !== 'string') {\n this.element.setAttribute('data-original-title', this.element.getAttribute('title') || '');\n this.element.setAttribute('title', '');\n }\n };\n\n _proto._enter = function _enter(event, context) {\n var dataKey = this.constructor.DATA_KEY;\n context = context || $(event.currentTarget).data(dataKey);\n\n if (!context) {\n context = new this.constructor(event.currentTarget, this._getDelegateConfig());\n $(event.currentTarget).data(dataKey, context);\n }\n\n if (event) {\n context._activeTrigger[event.type === 'focusin' ? Trigger.FOCUS : Trigger.HOVER] = true;\n }\n\n if ($(context.getTipElement()).hasClass(ClassName$6.SHOW) || context._hoverState === HoverState.SHOW) {\n context._hoverState = HoverState.SHOW;\n return;\n }\n\n clearTimeout(context._timeout);\n context._hoverState = HoverState.SHOW;\n\n if (!context.config.delay || !context.config.delay.show) {\n context.show();\n return;\n }\n\n context._timeout = setTimeout(function () {\n if (context._hoverState === HoverState.SHOW) {\n context.show();\n }\n }, context.config.delay.show);\n };\n\n _proto._leave = function _leave(event, context) {\n var dataKey = this.constructor.DATA_KEY;\n context = context || $(event.currentTarget).data(dataKey);\n\n if (!context) {\n context = new this.constructor(event.currentTarget, this._getDelegateConfig());\n $(event.currentTarget).data(dataKey, context);\n }\n\n if (event) {\n context._activeTrigger[event.type === 'focusout' ? Trigger.FOCUS : Trigger.HOVER] = false;\n }\n\n if (context._isWithActiveTrigger()) {\n return;\n }\n\n clearTimeout(context._timeout);\n context._hoverState = HoverState.OUT;\n\n if (!context.config.delay || !context.config.delay.hide) {\n context.hide();\n return;\n }\n\n context._timeout = setTimeout(function () {\n if (context._hoverState === HoverState.OUT) {\n context.hide();\n }\n }, context.config.delay.hide);\n };\n\n _proto._isWithActiveTrigger = function _isWithActiveTrigger() {\n for (var trigger in this._activeTrigger) {\n if (this._activeTrigger[trigger]) {\n return true;\n }\n }\n\n return false;\n };\n\n _proto._getConfig = function _getConfig(config) {\n var dataAttributes = $(this.element).data();\n Object.keys(dataAttributes).forEach(function (dataAttr) {\n if (DISALLOWED_ATTRIBUTES.indexOf(dataAttr) !== -1) {\n delete dataAttributes[dataAttr];\n }\n });\n config = _objectSpread2({}, this.constructor.Default, {}, dataAttributes, {}, typeof config === 'object' && config ? config : {});\n\n if (typeof config.delay === 'number') {\n config.delay = {\n show: config.delay,\n hide: config.delay\n };\n }\n\n if (typeof config.title === 'number') {\n config.title = config.title.toString();\n }\n\n if (typeof config.content === 'number') {\n config.content = config.content.toString();\n }\n\n Util.typeCheckConfig(NAME$6, config, this.constructor.DefaultType);\n\n if (config.sanitize) {\n config.template = sanitizeHtml(config.template, config.whiteList, config.sanitizeFn);\n }\n\n return config;\n };\n\n _proto._getDelegateConfig = function _getDelegateConfig() {\n var config = {};\n\n if (this.config) {\n for (var key in this.config) {\n if (this.constructor.Default[key] !== this.config[key]) {\n config[key] = this.config[key];\n }\n }\n }\n\n return config;\n };\n\n _proto._cleanTipClass = function _cleanTipClass() {\n var $tip = $(this.getTipElement());\n var tabClass = $tip.attr('class').match(BSCLS_PREFIX_REGEX);\n\n if (tabClass !== null && tabClass.length) {\n $tip.removeClass(tabClass.join(''));\n }\n };\n\n _proto._handlePopperPlacementChange = function _handlePopperPlacementChange(popperData) {\n var popperInstance = popperData.instance;\n this.tip = popperInstance.popper;\n\n this._cleanTipClass();\n\n this.addAttachmentClass(this._getAttachment(popperData.placement));\n };\n\n _proto._fixTransition = function _fixTransition() {\n var tip = this.getTipElement();\n var initConfigAnimation = this.config.animation;\n\n if (tip.getAttribute('x-placement') !== null) {\n return;\n }\n\n $(tip).removeClass(ClassName$6.FADE);\n this.config.animation = false;\n this.hide();\n this.show();\n this.config.animation = initConfigAnimation;\n } // Static\n ;\n\n Tooltip._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var data = $(this).data(DATA_KEY$6);\n\n var _config = typeof config === 'object' && config;\n\n if (!data && /dispose|hide/.test(config)) {\n return;\n }\n\n if (!data) {\n data = new Tooltip(this, _config);\n $(this).data(DATA_KEY$6, data);\n }\n\n if (typeof config === 'string') {\n if (typeof data[config] === 'undefined') {\n throw new TypeError(\"No method named \\\"\" + config + \"\\\"\");\n }\n\n data[config]();\n }\n });\n };\n\n _createClass(Tooltip, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION$6;\n }\n }, {\n key: \"Default\",\n get: function get() {\n return Default$4;\n }\n }, {\n key: \"NAME\",\n get: function get() {\n return NAME$6;\n }\n }, {\n key: \"DATA_KEY\",\n get: function get() {\n return DATA_KEY$6;\n }\n }, {\n key: \"Event\",\n get: function get() {\n return Event$6;\n }\n }, {\n key: \"EVENT_KEY\",\n get: function get() {\n return EVENT_KEY$6;\n }\n }, {\n key: \"DefaultType\",\n get: function get() {\n return DefaultType$4;\n }\n }]);\n\n return Tooltip;\n }();\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n\n $.fn[NAME$6] = Tooltip._jQueryInterface;\n $.fn[NAME$6].Constructor = Tooltip;\n\n $.fn[NAME$6].noConflict = function () {\n $.fn[NAME$6] = JQUERY_NO_CONFLICT$6;\n return Tooltip._jQueryInterface;\n };\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$7 = 'popover';\n var VERSION$7 = '4.4.1';\n var DATA_KEY$7 = 'bs.popover';\n var EVENT_KEY$7 = \".\" + DATA_KEY$7;\n var JQUERY_NO_CONFLICT$7 = $.fn[NAME$7];\n var CLASS_PREFIX$1 = 'bs-popover';\n var BSCLS_PREFIX_REGEX$1 = new RegExp(\"(^|\\\\s)\" + CLASS_PREFIX$1 + \"\\\\S+\", 'g');\n\n var Default$5 = _objectSpread2({}, Tooltip.Default, {\n placement: 'right',\n trigger: 'click',\n content: '',\n template: '<div class=\"popover\" role=\"tooltip\">' + '<div class=\"arrow\"></div>' + '<h3 class=\"popover-header\"></h3>' + '<div class=\"popover-body\"></div></div>'\n });\n\n var DefaultType$5 = _objectSpread2({}, Tooltip.DefaultType, {\n content: '(string|element|function)'\n });\n\n var ClassName$7 = {\n FADE: 'fade',\n SHOW: 'show'\n };\n var Selector$7 = {\n TITLE: '.popover-header',\n CONTENT: '.popover-body'\n };\n var Event$7 = {\n HIDE: \"hide\" + EVENT_KEY$7,\n HIDDEN: \"hidden\" + EVENT_KEY$7,\n SHOW: \"show\" + EVENT_KEY$7,\n SHOWN: \"shown\" + EVENT_KEY$7,\n INSERTED: \"inserted\" + EVENT_KEY$7,\n CLICK: \"click\" + EVENT_KEY$7,\n FOCUSIN: \"focusin\" + EVENT_KEY$7,\n FOCUSOUT: \"focusout\" + EVENT_KEY$7,\n MOUSEENTER: \"mouseenter\" + EVENT_KEY$7,\n MOUSELEAVE: \"mouseleave\" + EVENT_KEY$7\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Popover =\n /*#__PURE__*/\n function (_Tooltip) {\n _inheritsLoose(Popover, _Tooltip);\n\n function Popover() {\n return _Tooltip.apply(this, arguments) || this;\n }\n\n var _proto = Popover.prototype;\n\n // Overrides\n _proto.isWithContent = function isWithContent() {\n return this.getTitle() || this._getContent();\n };\n\n _proto.addAttachmentClass = function addAttachmentClass(attachment) {\n $(this.getTipElement()).addClass(CLASS_PREFIX$1 + \"-\" + attachment);\n };\n\n _proto.getTipElement = function getTipElement() {\n this.tip = this.tip || $(this.config.template)[0];\n return this.tip;\n };\n\n _proto.setContent = function setContent() {\n var $tip = $(this.getTipElement()); // We use append for html objects to maintain js events\n\n this.setElementContent($tip.find(Selector$7.TITLE), this.getTitle());\n\n var content = this._getContent();\n\n if (typeof content === 'function') {\n content = content.call(this.element);\n }\n\n this.setElementContent($tip.find(Selector$7.CONTENT), content);\n $tip.removeClass(ClassName$7.FADE + \" \" + ClassName$7.SHOW);\n } // Private\n ;\n\n _proto._getContent = function _getContent() {\n return this.element.getAttribute('data-content') || this.config.content;\n };\n\n _proto._cleanTipClass = function _cleanTipClass() {\n var $tip = $(this.getTipElement());\n var tabClass = $tip.attr('class').match(BSCLS_PREFIX_REGEX$1);\n\n if (tabClass !== null && tabClass.length > 0) {\n $tip.removeClass(tabClass.join(''));\n }\n } // Static\n ;\n\n Popover._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var data = $(this).data(DATA_KEY$7);\n\n var _config = typeof config === 'object' ? config : null;\n\n if (!data && /dispose|hide/.test(config)) {\n return;\n }\n\n if (!data) {\n data = new Popover(this, _config);\n $(this).data(DATA_KEY$7, data);\n }\n\n if (typeof config === 'string') {\n if (typeof data[config] === 'undefined') {\n throw new TypeError(\"No method named \\\"\" + config + \"\\\"\");\n }\n\n data[config]();\n }\n });\n };\n\n _createClass(Popover, null, [{\n key: \"VERSION\",\n // Getters\n get: function get() {\n return VERSION$7;\n }\n }, {\n key: \"Default\",\n get: function get() {\n return Default$5;\n }\n }, {\n key: \"NAME\",\n get: function get() {\n return NAME$7;\n }\n }, {\n key: \"DATA_KEY\",\n get: function get() {\n return DATA_KEY$7;\n }\n }, {\n key: \"Event\",\n get: function get() {\n return Event$7;\n }\n }, {\n key: \"EVENT_KEY\",\n get: function get() {\n return EVENT_KEY$7;\n }\n }, {\n key: \"DefaultType\",\n get: function get() {\n return DefaultType$5;\n }\n }]);\n\n return Popover;\n }(Tooltip);\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n\n $.fn[NAME$7] = Popover._jQueryInterface;\n $.fn[NAME$7].Constructor = Popover;\n\n $.fn[NAME$7].noConflict = function () {\n $.fn[NAME$7] = JQUERY_NO_CONFLICT$7;\n return Popover._jQueryInterface;\n };\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$8 = 'scrollspy';\n var VERSION$8 = '4.4.1';\n var DATA_KEY$8 = 'bs.scrollspy';\n var EVENT_KEY$8 = \".\" + DATA_KEY$8;\n var DATA_API_KEY$6 = '.data-api';\n var JQUERY_NO_CONFLICT$8 = $.fn[NAME$8];\n var Default$6 = {\n offset: 10,\n method: 'auto',\n target: ''\n };\n var DefaultType$6 = {\n offset: 'number',\n method: 'string',\n target: '(string|element)'\n };\n var Event$8 = {\n ACTIVATE: \"activate\" + EVENT_KEY$8,\n SCROLL: \"scroll\" + EVENT_KEY$8,\n LOAD_DATA_API: \"load\" + EVENT_KEY$8 + DATA_API_KEY$6\n };\n var ClassName$8 = {\n DROPDOWN_ITEM: 'dropdown-item',\n DROPDOWN_MENU: 'dropdown-menu',\n ACTIVE: 'active'\n };\n var Selector$8 = {\n DATA_SPY: '[data-spy=\"scroll\"]',\n ACTIVE: '.active',\n NAV_LIST_GROUP: '.nav, .list-group',\n NAV_LINKS: '.nav-link',\n NAV_ITEMS: '.nav-item',\n LIST_ITEMS: '.list-group-item',\n DROPDOWN: '.dropdown',\n DROPDOWN_ITEMS: '.dropdown-item',\n DROPDOWN_TOGGLE: '.dropdown-toggle'\n };\n var OffsetMethod = {\n OFFSET: 'offset',\n POSITION: 'position'\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var ScrollSpy =\n /*#__PURE__*/\n function () {\n function ScrollSpy(element, config) {\n var _this = this;\n\n this._element = element;\n this._scrollElement = element.tagName === 'BODY' ? window : element;\n this._config = this._getConfig(config);\n this._selector = this._config.target + \" \" + Selector$8.NAV_LINKS + \",\" + (this._config.target + \" \" + Selector$8.LIST_ITEMS + \",\") + (this._config.target + \" \" + Selector$8.DROPDOWN_ITEMS);\n this._offsets = [];\n this._targets = [];\n this._activeTarget = null;\n this._scrollHeight = 0;\n $(this._scrollElement).on(Event$8.SCROLL, function (event) {\n return _this._process(event);\n });\n this.refresh();\n\n this._process();\n } // Getters\n\n\n var _proto = ScrollSpy.prototype;\n\n // Public\n _proto.refresh = function refresh() {\n var _this2 = this;\n\n var autoMethod = this._scrollElement === this._scrollElement.window ? OffsetMethod.OFFSET : OffsetMethod.POSITION;\n var offsetMethod = this._config.method === 'auto' ? autoMethod : this._config.method;\n var offsetBase = offsetMethod === OffsetMethod.POSITION ? this._getScrollTop() : 0;\n this._offsets = [];\n this._targets = [];\n this._scrollHeight = this._getScrollHeight();\n var targets = [].slice.call(document.querySelectorAll(this._selector));\n targets.map(function (element) {\n var target;\n var targetSelector = Util.getSelectorFromElement(element);\n\n if (targetSelector) {\n target = document.querySelector(targetSelector);\n }\n\n if (target) {\n var targetBCR = target.getBoundingClientRect();\n\n if (targetBCR.width || targetBCR.height) {\n // TODO (fat): remove sketch reliance on jQuery position/offset\n return [$(target)[offsetMethod]().top + offsetBase, targetSelector];\n }\n }\n\n return null;\n }).filter(function (item) {\n return item;\n }).sort(function (a, b) {\n return a[0] - b[0];\n }).forEach(function (item) {\n _this2._offsets.push(item[0]);\n\n _this2._targets.push(item[1]);\n });\n };\n\n _proto.dispose = function dispose() {\n $.removeData(this._element, DATA_KEY$8);\n $(this._scrollElement).off(EVENT_KEY$8);\n this._element = null;\n this._scrollElement = null;\n this._config = null;\n this._selector = null;\n this._offsets = null;\n this._targets = null;\n this._activeTarget = null;\n this._scrollHeight = null;\n } // Private\n ;\n\n _proto._getConfig = function _getConfig(config) {\n config = _objectSpread2({}, Default$6, {}, typeof config === 'object' && config ? config : {});\n\n if (typeof config.target !== 'string') {\n var id = $(config.target).attr('id');\n\n if (!id) {\n id = Util.getUID(NAME$8);\n $(config.target).attr('id', id);\n }\n\n config.target = \"#\" + id;\n }\n\n Util.typeCheckConfig(NAME$8, config, DefaultType$6);\n return config;\n };\n\n _proto._getScrollTop = function _getScrollTop() {\n return this._scrollElement === window ? this._scrollElement.pageYOffset : this._scrollElement.scrollTop;\n };\n\n _proto._getScrollHeight = function _getScrollHeight() {\n return this._scrollElement.scrollHeight || Math.max(document.body.scrollHeight, document.documentElement.scrollHeight);\n };\n\n _proto._getOffsetHeight = function _getOffsetHeight() {\n return this._scrollElement === window ? window.innerHeight : this._scrollElement.getBoundingClientRect().height;\n };\n\n _proto._process = function _process() {\n var scrollTop = this._getScrollTop() + this._config.offset;\n\n var scrollHeight = this._getScrollHeight();\n\n var maxScroll = this._config.offset + scrollHeight - this._getOffsetHeight();\n\n if (this._scrollHeight !== scrollHeight) {\n this.refresh();\n }\n\n if (scrollTop >= maxScroll) {\n var target = this._targets[this._targets.length - 1];\n\n if (this._activeTarget !== target) {\n this._activate(target);\n }\n\n return;\n }\n\n if (this._activeTarget && scrollTop < this._offsets[0] && this._offsets[0] > 0) {\n this._activeTarget = null;\n\n this._clear();\n\n return;\n }\n\n var offsetLength = this._offsets.length;\n\n for (var i = offsetLength; i--;) {\n var isActiveTarget = this._activeTarget !== this._targets[i] && scrollTop >= this._offsets[i] && (typeof this._offsets[i + 1] === 'undefined' || scrollTop < this._offsets[i + 1]);\n\n if (isActiveTarget) {\n this._activate(this._targets[i]);\n }\n }\n };\n\n _proto._activate = function _activate(target) {\n this._activeTarget = target;\n\n this._clear();\n\n var queries = this._selector.split(',').map(function (selector) {\n return selector + \"[data-target=\\\"\" + target + \"\\\"],\" + selector + \"[href=\\\"\" + target + \"\\\"]\";\n });\n\n var $link = $([].slice.call(document.querySelectorAll(queries.join(','))));\n\n if ($link.hasClass(ClassName$8.DROPDOWN_ITEM)) {\n $link.closest(Selector$8.DROPDOWN).find(Selector$8.DROPDOWN_TOGGLE).addClass(ClassName$8.ACTIVE);\n $link.addClass(ClassName$8.ACTIVE);\n } else {\n // Set triggered link as active\n $link.addClass(ClassName$8.ACTIVE); // Set triggered links parents as active\n // With both <ul> and <nav> markup a parent is the previous sibling of any nav ancestor\n\n $link.parents(Selector$8.NAV_LIST_GROUP).prev(Selector$8.NAV_LINKS + \", \" + Selector$8.LIST_ITEMS).addClass(ClassName$8.ACTIVE); // Handle special case when .nav-link is inside .nav-item\n\n $link.parents(Selector$8.NAV_LIST_GROUP).prev(Selector$8.NAV_ITEMS).children(Selector$8.NAV_LINKS).addClass(ClassName$8.ACTIVE);\n }\n\n $(this._scrollElement).trigger(Event$8.ACTIVATE, {\n relatedTarget: target\n });\n };\n\n _proto._clear = function _clear() {\n [].slice.call(document.querySelectorAll(this._selector)).filter(function (node) {\n return node.classList.contains(ClassName$8.ACTIVE);\n }).forEach(function (node) {\n return node.classList.remove(ClassName$8.ACTIVE);\n });\n } // Static\n ;\n\n ScrollSpy._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var data = $(this).data(DATA_KEY$8);\n\n var _config = typeof config === 'object' && config;\n\n if (!data) {\n data = new ScrollSpy(this, _config);\n $(this).data(DATA_KEY$8, data);\n }\n\n if (typeof config === 'string') {\n if (typeof data[config] === 'undefined') {\n throw new TypeError(\"No method named \\\"\" + config + \"\\\"\");\n }\n\n data[config]();\n }\n });\n };\n\n _createClass(ScrollSpy, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION$8;\n }\n }, {\n key: \"Default\",\n get: function get() {\n return Default$6;\n }\n }]);\n\n return ScrollSpy;\n }();\n /**\n * ------------------------------------------------------------------------\n * Data Api implementation\n * ------------------------------------------------------------------------\n */\n\n\n $(window).on(Event$8.LOAD_DATA_API, function () {\n var scrollSpys = [].slice.call(document.querySelectorAll(Selector$8.DATA_SPY));\n var scrollSpysLength = scrollSpys.length;\n\n for (var i = scrollSpysLength; i--;) {\n var $spy = $(scrollSpys[i]);\n\n ScrollSpy._jQueryInterface.call($spy, $spy.data());\n }\n });\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n $.fn[NAME$8] = ScrollSpy._jQueryInterface;\n $.fn[NAME$8].Constructor = ScrollSpy;\n\n $.fn[NAME$8].noConflict = function () {\n $.fn[NAME$8] = JQUERY_NO_CONFLICT$8;\n return ScrollSpy._jQueryInterface;\n };\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$9 = 'tab';\n var VERSION$9 = '4.4.1';\n var DATA_KEY$9 = 'bs.tab';\n var EVENT_KEY$9 = \".\" + DATA_KEY$9;\n var DATA_API_KEY$7 = '.data-api';\n var JQUERY_NO_CONFLICT$9 = $.fn[NAME$9];\n var Event$9 = {\n HIDE: \"hide\" + EVENT_KEY$9,\n HIDDEN: \"hidden\" + EVENT_KEY$9,\n SHOW: \"show\" + EVENT_KEY$9,\n SHOWN: \"shown\" + EVENT_KEY$9,\n CLICK_DATA_API: \"click\" + EVENT_KEY$9 + DATA_API_KEY$7\n };\n var ClassName$9 = {\n DROPDOWN_MENU: 'dropdown-menu',\n ACTIVE: 'active',\n DISABLED: 'disabled',\n FADE: 'fade',\n SHOW: 'show'\n };\n var Selector$9 = {\n DROPDOWN: '.dropdown',\n NAV_LIST_GROUP: '.nav, .list-group',\n ACTIVE: '.active',\n ACTIVE_UL: '> li > .active',\n DATA_TOGGLE: '[data-toggle=\"tab\"], [data-toggle=\"pill\"], [data-toggle=\"list\"]',\n DROPDOWN_TOGGLE: '.dropdown-toggle',\n DROPDOWN_ACTIVE_CHILD: '> .dropdown-menu .active'\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Tab =\n /*#__PURE__*/\n function () {\n function Tab(element) {\n this._element = element;\n } // Getters\n\n\n var _proto = Tab.prototype;\n\n // Public\n _proto.show = function show() {\n var _this = this;\n\n if (this._element.parentNode && this._element.parentNode.nodeType === Node.ELEMENT_NODE && $(this._element).hasClass(ClassName$9.ACTIVE) || $(this._element).hasClass(ClassName$9.DISABLED)) {\n return;\n }\n\n var target;\n var previous;\n var listElement = $(this._element).closest(Selector$9.NAV_LIST_GROUP)[0];\n var selector = Util.getSelectorFromElement(this._element);\n\n if (listElement) {\n var itemSelector = listElement.nodeName === 'UL' || listElement.nodeName === 'OL' ? Selector$9.ACTIVE_UL : Selector$9.ACTIVE;\n previous = $.makeArray($(listElement).find(itemSelector));\n previous = previous[previous.length - 1];\n }\n\n var hideEvent = $.Event(Event$9.HIDE, {\n relatedTarget: this._element\n });\n var showEvent = $.Event(Event$9.SHOW, {\n relatedTarget: previous\n });\n\n if (previous) {\n $(previous).trigger(hideEvent);\n }\n\n $(this._element).trigger(showEvent);\n\n if (showEvent.isDefaultPrevented() || hideEvent.isDefaultPrevented()) {\n return;\n }\n\n if (selector) {\n target = document.querySelector(selector);\n }\n\n this._activate(this._element, listElement);\n\n var complete = function complete() {\n var hiddenEvent = $.Event(Event$9.HIDDEN, {\n relatedTarget: _this._element\n });\n var shownEvent = $.Event(Event$9.SHOWN, {\n relatedTarget: previous\n });\n $(previous).trigger(hiddenEvent);\n $(_this._element).trigger(shownEvent);\n };\n\n if (target) {\n this._activate(target, target.parentNode, complete);\n } else {\n complete();\n }\n };\n\n _proto.dispose = function dispose() {\n $.removeData(this._element, DATA_KEY$9);\n this._element = null;\n } // Private\n ;\n\n _proto._activate = function _activate(element, container, callback) {\n var _this2 = this;\n\n var activeElements = container && (container.nodeName === 'UL' || container.nodeName === 'OL') ? $(container).find(Selector$9.ACTIVE_UL) : $(container).children(Selector$9.ACTIVE);\n var active = activeElements[0];\n var isTransitioning = callback && active && $(active).hasClass(ClassName$9.FADE);\n\n var complete = function complete() {\n return _this2._transitionComplete(element, active, callback);\n };\n\n if (active && isTransitioning) {\n var transitionDuration = Util.getTransitionDurationFromElement(active);\n $(active).removeClass(ClassName$9.SHOW).one(Util.TRANSITION_END, complete).emulateTransitionEnd(transitionDuration);\n } else {\n complete();\n }\n };\n\n _proto._transitionComplete = function _transitionComplete(element, active, callback) {\n if (active) {\n $(active).removeClass(ClassName$9.ACTIVE);\n var dropdownChild = $(active.parentNode).find(Selector$9.DROPDOWN_ACTIVE_CHILD)[0];\n\n if (dropdownChild) {\n $(dropdownChild).removeClass(ClassName$9.ACTIVE);\n }\n\n if (active.getAttribute('role') === 'tab') {\n active.setAttribute('aria-selected', false);\n }\n }\n\n $(element).addClass(ClassName$9.ACTIVE);\n\n if (element.getAttribute('role') === 'tab') {\n element.setAttribute('aria-selected', true);\n }\n\n Util.reflow(element);\n\n if (element.classList.contains(ClassName$9.FADE)) {\n element.classList.add(ClassName$9.SHOW);\n }\n\n if (element.parentNode && $(element.parentNode).hasClass(ClassName$9.DROPDOWN_MENU)) {\n var dropdownElement = $(element).closest(Selector$9.DROPDOWN)[0];\n\n if (dropdownElement) {\n var dropdownToggleList = [].slice.call(dropdownElement.querySelectorAll(Selector$9.DROPDOWN_TOGGLE));\n $(dropdownToggleList).addClass(ClassName$9.ACTIVE);\n }\n\n element.setAttribute('aria-expanded', true);\n }\n\n if (callback) {\n callback();\n }\n } // Static\n ;\n\n Tab._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var $this = $(this);\n var data = $this.data(DATA_KEY$9);\n\n if (!data) {\n data = new Tab(this);\n $this.data(DATA_KEY$9, data);\n }\n\n if (typeof config === 'string') {\n if (typeof data[config] === 'undefined') {\n throw new TypeError(\"No method named \\\"\" + config + \"\\\"\");\n }\n\n data[config]();\n }\n });\n };\n\n _createClass(Tab, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION$9;\n }\n }]);\n\n return Tab;\n }();\n /**\n * ------------------------------------------------------------------------\n * Data Api implementation\n * ------------------------------------------------------------------------\n */\n\n\n $(document).on(Event$9.CLICK_DATA_API, Selector$9.DATA_TOGGLE, function (event) {\n event.preventDefault();\n\n Tab._jQueryInterface.call($(this), 'show');\n });\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n $.fn[NAME$9] = Tab._jQueryInterface;\n $.fn[NAME$9].Constructor = Tab;\n\n $.fn[NAME$9].noConflict = function () {\n $.fn[NAME$9] = JQUERY_NO_CONFLICT$9;\n return Tab._jQueryInterface;\n };\n\n /**\n * ------------------------------------------------------------------------\n * Constants\n * ------------------------------------------------------------------------\n */\n\n var NAME$a = 'toast';\n var VERSION$a = '4.4.1';\n var DATA_KEY$a = 'bs.toast';\n var EVENT_KEY$a = \".\" + DATA_KEY$a;\n var JQUERY_NO_CONFLICT$a = $.fn[NAME$a];\n var Event$a = {\n CLICK_DISMISS: \"click.dismiss\" + EVENT_KEY$a,\n HIDE: \"hide\" + EVENT_KEY$a,\n HIDDEN: \"hidden\" + EVENT_KEY$a,\n SHOW: \"show\" + EVENT_KEY$a,\n SHOWN: \"shown\" + EVENT_KEY$a\n };\n var ClassName$a = {\n FADE: 'fade',\n HIDE: 'hide',\n SHOW: 'show',\n SHOWING: 'showing'\n };\n var DefaultType$7 = {\n animation: 'boolean',\n autohide: 'boolean',\n delay: 'number'\n };\n var Default$7 = {\n animation: true,\n autohide: true,\n delay: 500\n };\n var Selector$a = {\n DATA_DISMISS: '[data-dismiss=\"toast\"]'\n };\n /**\n * ------------------------------------------------------------------------\n * Class Definition\n * ------------------------------------------------------------------------\n */\n\n var Toast =\n /*#__PURE__*/\n function () {\n function Toast(element, config) {\n this._element = element;\n this._config = this._getConfig(config);\n this._timeout = null;\n\n this._setListeners();\n } // Getters\n\n\n var _proto = Toast.prototype;\n\n // Public\n _proto.show = function show() {\n var _this = this;\n\n var showEvent = $.Event(Event$a.SHOW);\n $(this._element).trigger(showEvent);\n\n if (showEvent.isDefaultPrevented()) {\n return;\n }\n\n if (this._config.animation) {\n this._element.classList.add(ClassName$a.FADE);\n }\n\n var complete = function complete() {\n _this._element.classList.remove(ClassName$a.SHOWING);\n\n _this._element.classList.add(ClassName$a.SHOW);\n\n $(_this._element).trigger(Event$a.SHOWN);\n\n if (_this._config.autohide) {\n _this._timeout = setTimeout(function () {\n _this.hide();\n }, _this._config.delay);\n }\n };\n\n this._element.classList.remove(ClassName$a.HIDE);\n\n Util.reflow(this._element);\n\n this._element.classList.add(ClassName$a.SHOWING);\n\n if (this._config.animation) {\n var transitionDuration = Util.getTransitionDurationFromElement(this._element);\n $(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(transitionDuration);\n } else {\n complete();\n }\n };\n\n _proto.hide = function hide() {\n if (!this._element.classList.contains(ClassName$a.SHOW)) {\n return;\n }\n\n var hideEvent = $.Event(Event$a.HIDE);\n $(this._element).trigger(hideEvent);\n\n if (hideEvent.isDefaultPrevented()) {\n return;\n }\n\n this._close();\n };\n\n _proto.dispose = function dispose() {\n clearTimeout(this._timeout);\n this._timeout = null;\n\n if (this._element.classList.contains(ClassName$a.SHOW)) {\n this._element.classList.remove(ClassName$a.SHOW);\n }\n\n $(this._element).off(Event$a.CLICK_DISMISS);\n $.removeData(this._element, DATA_KEY$a);\n this._element = null;\n this._config = null;\n } // Private\n ;\n\n _proto._getConfig = function _getConfig(config) {\n config = _objectSpread2({}, Default$7, {}, $(this._element).data(), {}, typeof config === 'object' && config ? config : {});\n Util.typeCheckConfig(NAME$a, config, this.constructor.DefaultType);\n return config;\n };\n\n _proto._setListeners = function _setListeners() {\n var _this2 = this;\n\n $(this._element).on(Event$a.CLICK_DISMISS, Selector$a.DATA_DISMISS, function () {\n return _this2.hide();\n });\n };\n\n _proto._close = function _close() {\n var _this3 = this;\n\n var complete = function complete() {\n _this3._element.classList.add(ClassName$a.HIDE);\n\n $(_this3._element).trigger(Event$a.HIDDEN);\n };\n\n this._element.classList.remove(ClassName$a.SHOW);\n\n if (this._config.animation) {\n var transitionDuration = Util.getTransitionDurationFromElement(this._element);\n $(this._element).one(Util.TRANSITION_END, complete).emulateTransitionEnd(transitionDuration);\n } else {\n complete();\n }\n } // Static\n ;\n\n Toast._jQueryInterface = function _jQueryInterface(config) {\n return this.each(function () {\n var $element = $(this);\n var data = $element.data(DATA_KEY$a);\n\n var _config = typeof config === 'object' && config;\n\n if (!data) {\n data = new Toast(this, _config);\n $element.data(DATA_KEY$a, data);\n }\n\n if (typeof config === 'string') {\n if (typeof data[config] === 'undefined') {\n throw new TypeError(\"No method named \\\"\" + config + \"\\\"\");\n }\n\n data[config](this);\n }\n });\n };\n\n _createClass(Toast, null, [{\n key: \"VERSION\",\n get: function get() {\n return VERSION$a;\n }\n }, {\n key: \"DefaultType\",\n get: function get() {\n return DefaultType$7;\n }\n }, {\n key: \"Default\",\n get: function get() {\n return Default$7;\n }\n }]);\n\n return Toast;\n }();\n /**\n * ------------------------------------------------------------------------\n * jQuery\n * ------------------------------------------------------------------------\n */\n\n\n $.fn[NAME$a] = Toast._jQueryInterface;\n $.fn[NAME$a].Constructor = Toast;\n\n $.fn[NAME$a].noConflict = function () {\n $.fn[NAME$a] = JQUERY_NO_CONFLICT$a;\n return Toast._jQueryInterface;\n };\n\n exports.Alert = Alert;\n exports.Button = Button;\n exports.Carousel = Carousel;\n exports.Collapse = Collapse;\n exports.Dropdown = Dropdown;\n exports.Modal = Modal;\n exports.Popover = Popover;\n exports.Scrollspy = ScrollSpy;\n exports.Tab = Tab;\n exports.Toast = Toast;\n exports.Tooltip = Tooltip;\n exports.Util = Util;\n\n Object.defineProperty(exports, '__esModule', { value: true });\n\n})));\n//# sourceMappingURL=bootstrap.js.map\n","/**!\n * @fileOverview Kickass library to create and place poppers near their reference elements.\n * @version 1.16.1\n * @license\n * Copyright (c) 2016 Federico Zivolo and contributors\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\n * SOFTWARE.\n */\nvar isBrowser = typeof window !== 'undefined' && typeof document !== 'undefined' && typeof navigator !== 'undefined';\n\nvar timeoutDuration = function () {\n var longerTimeoutBrowsers = ['Edge', 'Trident', 'Firefox'];\n for (var i = 0; i < longerTimeoutBrowsers.length; i += 1) {\n if (isBrowser && navigator.userAgent.indexOf(longerTimeoutBrowsers[i]) >= 0) {\n return 1;\n }\n }\n return 0;\n}();\n\nfunction microtaskDebounce(fn) {\n var called = false;\n return function () {\n if (called) {\n return;\n }\n called = true;\n window.Promise.resolve().then(function () {\n called = false;\n fn();\n });\n };\n}\n\nfunction taskDebounce(fn) {\n var scheduled = false;\n return function () {\n if (!scheduled) {\n scheduled = true;\n setTimeout(function () {\n scheduled = false;\n fn();\n }, timeoutDuration);\n }\n };\n}\n\nvar supportsMicroTasks = isBrowser && window.Promise;\n\n/**\n* Create a debounced version of a method, that's asynchronously deferred\n* but called in the minimum time possible.\n*\n* @method\n* @memberof Popper.Utils\n* @argument {Function} fn\n* @returns {Function}\n*/\nvar debounce = supportsMicroTasks ? microtaskDebounce : taskDebounce;\n\n/**\n * Check if the given variable is a function\n * @method\n * @memberof Popper.Utils\n * @argument {Any} functionToCheck - variable to check\n * @returns {Boolean} answer to: is a function?\n */\nfunction isFunction(functionToCheck) {\n var getType = {};\n return functionToCheck && getType.toString.call(functionToCheck) === '[object Function]';\n}\n\n/**\n * Get CSS computed property of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Eement} element\n * @argument {String} property\n */\nfunction getStyleComputedProperty(element, property) {\n if (element.nodeType !== 1) {\n return [];\n }\n // NOTE: 1 DOM access here\n var window = element.ownerDocument.defaultView;\n var css = window.getComputedStyle(element, null);\n return property ? css[property] : css;\n}\n\n/**\n * Returns the parentNode or the host of the element\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Element} parent\n */\nfunction getParentNode(element) {\n if (element.nodeName === 'HTML') {\n return element;\n }\n return element.parentNode || element.host;\n}\n\n/**\n * Returns the scrolling parent of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Element} scroll parent\n */\nfunction getScrollParent(element) {\n // Return body, `getScroll` will take care to get the correct `scrollTop` from it\n if (!element) {\n return document.body;\n }\n\n switch (element.nodeName) {\n case 'HTML':\n case 'BODY':\n return element.ownerDocument.body;\n case '#document':\n return element.body;\n }\n\n // Firefox want us to check `-x` and `-y` variations as well\n\n var _getStyleComputedProp = getStyleComputedProperty(element),\n overflow = _getStyleComputedProp.overflow,\n overflowX = _getStyleComputedProp.overflowX,\n overflowY = _getStyleComputedProp.overflowY;\n\n if (/(auto|scroll|overlay)/.test(overflow + overflowY + overflowX)) {\n return element;\n }\n\n return getScrollParent(getParentNode(element));\n}\n\n/**\n * Returns the reference node of the reference object, or the reference object itself.\n * @method\n * @memberof Popper.Utils\n * @param {Element|Object} reference - the reference element (the popper will be relative to this)\n * @returns {Element} parent\n */\nfunction getReferenceNode(reference) {\n return reference && reference.referenceNode ? reference.referenceNode : reference;\n}\n\nvar isIE11 = isBrowser && !!(window.MSInputMethodContext && document.documentMode);\nvar isIE10 = isBrowser && /MSIE 10/.test(navigator.userAgent);\n\n/**\n * Determines if the browser is Internet Explorer\n * @method\n * @memberof Popper.Utils\n * @param {Number} version to check\n * @returns {Boolean} isIE\n */\nfunction isIE(version) {\n if (version === 11) {\n return isIE11;\n }\n if (version === 10) {\n return isIE10;\n }\n return isIE11 || isIE10;\n}\n\n/**\n * Returns the offset parent of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Element} offset parent\n */\nfunction getOffsetParent(element) {\n if (!element) {\n return document.documentElement;\n }\n\n var noOffsetParent = isIE(10) ? document.body : null;\n\n // NOTE: 1 DOM access here\n var offsetParent = element.offsetParent || null;\n // Skip hidden elements which don't have an offsetParent\n while (offsetParent === noOffsetParent && element.nextElementSibling) {\n offsetParent = (element = element.nextElementSibling).offsetParent;\n }\n\n var nodeName = offsetParent && offsetParent.nodeName;\n\n if (!nodeName || nodeName === 'BODY' || nodeName === 'HTML') {\n return element ? element.ownerDocument.documentElement : document.documentElement;\n }\n\n // .offsetParent will return the closest TH, TD or TABLE in case\n // no offsetParent is present, I hate this job...\n if (['TH', 'TD', 'TABLE'].indexOf(offsetParent.nodeName) !== -1 && getStyleComputedProperty(offsetParent, 'position') === 'static') {\n return getOffsetParent(offsetParent);\n }\n\n return offsetParent;\n}\n\nfunction isOffsetContainer(element) {\n var nodeName = element.nodeName;\n\n if (nodeName === 'BODY') {\n return false;\n }\n return nodeName === 'HTML' || getOffsetParent(element.firstElementChild) === element;\n}\n\n/**\n * Finds the root node (document, shadowDOM root) of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Element} node\n * @returns {Element} root node\n */\nfunction getRoot(node) {\n if (node.parentNode !== null) {\n return getRoot(node.parentNode);\n }\n\n return node;\n}\n\n/**\n * Finds the offset parent common to the two provided nodes\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element1\n * @argument {Element} element2\n * @returns {Element} common offset parent\n */\nfunction findCommonOffsetParent(element1, element2) {\n // This check is needed to avoid errors in case one of the elements isn't defined for any reason\n if (!element1 || !element1.nodeType || !element2 || !element2.nodeType) {\n return document.documentElement;\n }\n\n // Here we make sure to give as \"start\" the element that comes first in the DOM\n var order = element1.compareDocumentPosition(element2) & Node.DOCUMENT_POSITION_FOLLOWING;\n var start = order ? element1 : element2;\n var end = order ? element2 : element1;\n\n // Get common ancestor container\n var range = document.createRange();\n range.setStart(start, 0);\n range.setEnd(end, 0);\n var commonAncestorContainer = range.commonAncestorContainer;\n\n // Both nodes are inside #document\n\n if (element1 !== commonAncestorContainer && element2 !== commonAncestorContainer || start.contains(end)) {\n if (isOffsetContainer(commonAncestorContainer)) {\n return commonAncestorContainer;\n }\n\n return getOffsetParent(commonAncestorContainer);\n }\n\n // one of the nodes is inside shadowDOM, find which one\n var element1root = getRoot(element1);\n if (element1root.host) {\n return findCommonOffsetParent(element1root.host, element2);\n } else {\n return findCommonOffsetParent(element1, getRoot(element2).host);\n }\n}\n\n/**\n * Gets the scroll value of the given element in the given side (top and left)\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @argument {String} side `top` or `left`\n * @returns {number} amount of scrolled pixels\n */\nfunction getScroll(element) {\n var side = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'top';\n\n var upperSide = side === 'top' ? 'scrollTop' : 'scrollLeft';\n var nodeName = element.nodeName;\n\n if (nodeName === 'BODY' || nodeName === 'HTML') {\n var html = element.ownerDocument.documentElement;\n var scrollingElement = element.ownerDocument.scrollingElement || html;\n return scrollingElement[upperSide];\n }\n\n return element[upperSide];\n}\n\n/*\n * Sum or subtract the element scroll values (left and top) from a given rect object\n * @method\n * @memberof Popper.Utils\n * @param {Object} rect - Rect object you want to change\n * @param {HTMLElement} element - The element from the function reads the scroll values\n * @param {Boolean} subtract - set to true if you want to subtract the scroll values\n * @return {Object} rect - The modifier rect object\n */\nfunction includeScroll(rect, element) {\n var subtract = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n\n var scrollTop = getScroll(element, 'top');\n var scrollLeft = getScroll(element, 'left');\n var modifier = subtract ? -1 : 1;\n rect.top += scrollTop * modifier;\n rect.bottom += scrollTop * modifier;\n rect.left += scrollLeft * modifier;\n rect.right += scrollLeft * modifier;\n return rect;\n}\n\n/*\n * Helper to detect borders of a given element\n * @method\n * @memberof Popper.Utils\n * @param {CSSStyleDeclaration} styles\n * Result of `getStyleComputedProperty` on the given element\n * @param {String} axis - `x` or `y`\n * @return {number} borders - The borders size of the given axis\n */\n\nfunction getBordersSize(styles, axis) {\n var sideA = axis === 'x' ? 'Left' : 'Top';\n var sideB = sideA === 'Left' ? 'Right' : 'Bottom';\n\n return parseFloat(styles['border' + sideA + 'Width']) + parseFloat(styles['border' + sideB + 'Width']);\n}\n\nfunction getSize(axis, body, html, computedStyle) {\n return Math.max(body['offset' + axis], body['scroll' + axis], html['client' + axis], html['offset' + axis], html['scroll' + axis], isIE(10) ? parseInt(html['offset' + axis]) + parseInt(computedStyle['margin' + (axis === 'Height' ? 'Top' : 'Left')]) + parseInt(computedStyle['margin' + (axis === 'Height' ? 'Bottom' : 'Right')]) : 0);\n}\n\nfunction getWindowSizes(document) {\n var body = document.body;\n var html = document.documentElement;\n var computedStyle = isIE(10) && getComputedStyle(html);\n\n return {\n height: getSize('Height', body, html, computedStyle),\n width: getSize('Width', body, html, computedStyle)\n };\n}\n\nvar classCallCheck = function (instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n};\n\nvar createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\n\n\n\n\n\nvar defineProperty = function (obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n};\n\nvar _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n};\n\n/**\n * Given element offsets, generate an output similar to getBoundingClientRect\n * @method\n * @memberof Popper.Utils\n * @argument {Object} offsets\n * @returns {Object} ClientRect like output\n */\nfunction getClientRect(offsets) {\n return _extends({}, offsets, {\n right: offsets.left + offsets.width,\n bottom: offsets.top + offsets.height\n });\n}\n\n/**\n * Get bounding client rect of given element\n * @method\n * @memberof Popper.Utils\n * @param {HTMLElement} element\n * @return {Object} client rect\n */\nfunction getBoundingClientRect(element) {\n var rect = {};\n\n // IE10 10 FIX: Please, don't ask, the element isn't\n // considered in DOM in some circumstances...\n // This isn't reproducible in IE10 compatibility mode of IE11\n try {\n if (isIE(10)) {\n rect = element.getBoundingClientRect();\n var scrollTop = getScroll(element, 'top');\n var scrollLeft = getScroll(element, 'left');\n rect.top += scrollTop;\n rect.left += scrollLeft;\n rect.bottom += scrollTop;\n rect.right += scrollLeft;\n } else {\n rect = element.getBoundingClientRect();\n }\n } catch (e) {}\n\n var result = {\n left: rect.left,\n top: rect.top,\n width: rect.right - rect.left,\n height: rect.bottom - rect.top\n };\n\n // subtract scrollbar size from sizes\n var sizes = element.nodeName === 'HTML' ? getWindowSizes(element.ownerDocument) : {};\n var width = sizes.width || element.clientWidth || result.width;\n var height = sizes.height || element.clientHeight || result.height;\n\n var horizScrollbar = element.offsetWidth - width;\n var vertScrollbar = element.offsetHeight - height;\n\n // if an hypothetical scrollbar is detected, we must be sure it's not a `border`\n // we make this check conditional for performance reasons\n if (horizScrollbar || vertScrollbar) {\n var styles = getStyleComputedProperty(element);\n horizScrollbar -= getBordersSize(styles, 'x');\n vertScrollbar -= getBordersSize(styles, 'y');\n\n result.width -= horizScrollbar;\n result.height -= vertScrollbar;\n }\n\n return getClientRect(result);\n}\n\nfunction getOffsetRectRelativeToArbitraryNode(children, parent) {\n var fixedPosition = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n\n var isIE10 = isIE(10);\n var isHTML = parent.nodeName === 'HTML';\n var childrenRect = getBoundingClientRect(children);\n var parentRect = getBoundingClientRect(parent);\n var scrollParent = getScrollParent(children);\n\n var styles = getStyleComputedProperty(parent);\n var borderTopWidth = parseFloat(styles.borderTopWidth);\n var borderLeftWidth = parseFloat(styles.borderLeftWidth);\n\n // In cases where the parent is fixed, we must ignore negative scroll in offset calc\n if (fixedPosition && isHTML) {\n parentRect.top = Math.max(parentRect.top, 0);\n parentRect.left = Math.max(parentRect.left, 0);\n }\n var offsets = getClientRect({\n top: childrenRect.top - parentRect.top - borderTopWidth,\n left: childrenRect.left - parentRect.left - borderLeftWidth,\n width: childrenRect.width,\n height: childrenRect.height\n });\n offsets.marginTop = 0;\n offsets.marginLeft = 0;\n\n // Subtract margins of documentElement in case it's being used as parent\n // we do this only on HTML because it's the only element that behaves\n // differently when margins are applied to it. The margins are included in\n // the box of the documentElement, in the other cases not.\n if (!isIE10 && isHTML) {\n var marginTop = parseFloat(styles.marginTop);\n var marginLeft = parseFloat(styles.marginLeft);\n\n offsets.top -= borderTopWidth - marginTop;\n offsets.bottom -= borderTopWidth - marginTop;\n offsets.left -= borderLeftWidth - marginLeft;\n offsets.right -= borderLeftWidth - marginLeft;\n\n // Attach marginTop and marginLeft because in some circumstances we may need them\n offsets.marginTop = marginTop;\n offsets.marginLeft = marginLeft;\n }\n\n if (isIE10 && !fixedPosition ? parent.contains(scrollParent) : parent === scrollParent && scrollParent.nodeName !== 'BODY') {\n offsets = includeScroll(offsets, parent);\n }\n\n return offsets;\n}\n\nfunction getViewportOffsetRectRelativeToArtbitraryNode(element) {\n var excludeScroll = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n\n var html = element.ownerDocument.documentElement;\n var relativeOffset = getOffsetRectRelativeToArbitraryNode(element, html);\n var width = Math.max(html.clientWidth, window.innerWidth || 0);\n var height = Math.max(html.clientHeight, window.innerHeight || 0);\n\n var scrollTop = !excludeScroll ? getScroll(html) : 0;\n var scrollLeft = !excludeScroll ? getScroll(html, 'left') : 0;\n\n var offset = {\n top: scrollTop - relativeOffset.top + relativeOffset.marginTop,\n left: scrollLeft - relativeOffset.left + relativeOffset.marginLeft,\n width: width,\n height: height\n };\n\n return getClientRect(offset);\n}\n\n/**\n * Check if the given element is fixed or is inside a fixed parent\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @argument {Element} customContainer\n * @returns {Boolean} answer to \"isFixed?\"\n */\nfunction isFixed(element) {\n var nodeName = element.nodeName;\n if (nodeName === 'BODY' || nodeName === 'HTML') {\n return false;\n }\n if (getStyleComputedProperty(element, 'position') === 'fixed') {\n return true;\n }\n var parentNode = getParentNode(element);\n if (!parentNode) {\n return false;\n }\n return isFixed(parentNode);\n}\n\n/**\n * Finds the first parent of an element that has a transformed property defined\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Element} first transformed parent or documentElement\n */\n\nfunction getFixedPositionOffsetParent(element) {\n // This check is needed to avoid errors in case one of the elements isn't defined for any reason\n if (!element || !element.parentElement || isIE()) {\n return document.documentElement;\n }\n var el = element.parentElement;\n while (el && getStyleComputedProperty(el, 'transform') === 'none') {\n el = el.parentElement;\n }\n return el || document.documentElement;\n}\n\n/**\n * Computed the boundaries limits and return them\n * @method\n * @memberof Popper.Utils\n * @param {HTMLElement} popper\n * @param {HTMLElement} reference\n * @param {number} padding\n * @param {HTMLElement} boundariesElement - Element used to define the boundaries\n * @param {Boolean} fixedPosition - Is in fixed position mode\n * @returns {Object} Coordinates of the boundaries\n */\nfunction getBoundaries(popper, reference, padding, boundariesElement) {\n var fixedPosition = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : false;\n\n // NOTE: 1 DOM access here\n\n var boundaries = { top: 0, left: 0 };\n var offsetParent = fixedPosition ? getFixedPositionOffsetParent(popper) : findCommonOffsetParent(popper, getReferenceNode(reference));\n\n // Handle viewport case\n if (boundariesElement === 'viewport') {\n boundaries = getViewportOffsetRectRelativeToArtbitraryNode(offsetParent, fixedPosition);\n } else {\n // Handle other cases based on DOM element used as boundaries\n var boundariesNode = void 0;\n if (boundariesElement === 'scrollParent') {\n boundariesNode = getScrollParent(getParentNode(reference));\n if (boundariesNode.nodeName === 'BODY') {\n boundariesNode = popper.ownerDocument.documentElement;\n }\n } else if (boundariesElement === 'window') {\n boundariesNode = popper.ownerDocument.documentElement;\n } else {\n boundariesNode = boundariesElement;\n }\n\n var offsets = getOffsetRectRelativeToArbitraryNode(boundariesNode, offsetParent, fixedPosition);\n\n // In case of HTML, we need a different computation\n if (boundariesNode.nodeName === 'HTML' && !isFixed(offsetParent)) {\n var _getWindowSizes = getWindowSizes(popper.ownerDocument),\n height = _getWindowSizes.height,\n width = _getWindowSizes.width;\n\n boundaries.top += offsets.top - offsets.marginTop;\n boundaries.bottom = height + offsets.top;\n boundaries.left += offsets.left - offsets.marginLeft;\n boundaries.right = width + offsets.left;\n } else {\n // for all the other DOM elements, this one is good\n boundaries = offsets;\n }\n }\n\n // Add paddings\n padding = padding || 0;\n var isPaddingNumber = typeof padding === 'number';\n boundaries.left += isPaddingNumber ? padding : padding.left || 0;\n boundaries.top += isPaddingNumber ? padding : padding.top || 0;\n boundaries.right -= isPaddingNumber ? padding : padding.right || 0;\n boundaries.bottom -= isPaddingNumber ? padding : padding.bottom || 0;\n\n return boundaries;\n}\n\nfunction getArea(_ref) {\n var width = _ref.width,\n height = _ref.height;\n\n return width * height;\n}\n\n/**\n * Utility used to transform the `auto` placement to the placement with more\n * available space.\n * @method\n * @memberof Popper.Utils\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nfunction computeAutoPlacement(placement, refRect, popper, reference, boundariesElement) {\n var padding = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 0;\n\n if (placement.indexOf('auto') === -1) {\n return placement;\n }\n\n var boundaries = getBoundaries(popper, reference, padding, boundariesElement);\n\n var rects = {\n top: {\n width: boundaries.width,\n height: refRect.top - boundaries.top\n },\n right: {\n width: boundaries.right - refRect.right,\n height: boundaries.height\n },\n bottom: {\n width: boundaries.width,\n height: boundaries.bottom - refRect.bottom\n },\n left: {\n width: refRect.left - boundaries.left,\n height: boundaries.height\n }\n };\n\n var sortedAreas = Object.keys(rects).map(function (key) {\n return _extends({\n key: key\n }, rects[key], {\n area: getArea(rects[key])\n });\n }).sort(function (a, b) {\n return b.area - a.area;\n });\n\n var filteredAreas = sortedAreas.filter(function (_ref2) {\n var width = _ref2.width,\n height = _ref2.height;\n return width >= popper.clientWidth && height >= popper.clientHeight;\n });\n\n var computedPlacement = filteredAreas.length > 0 ? filteredAreas[0].key : sortedAreas[0].key;\n\n var variation = placement.split('-')[1];\n\n return computedPlacement + (variation ? '-' + variation : '');\n}\n\n/**\n * Get offsets to the reference element\n * @method\n * @memberof Popper.Utils\n * @param {Object} state\n * @param {Element} popper - the popper element\n * @param {Element} reference - the reference element (the popper will be relative to this)\n * @param {Element} fixedPosition - is in fixed position mode\n * @returns {Object} An object containing the offsets which will be applied to the popper\n */\nfunction getReferenceOffsets(state, popper, reference) {\n var fixedPosition = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null;\n\n var commonOffsetParent = fixedPosition ? getFixedPositionOffsetParent(popper) : findCommonOffsetParent(popper, getReferenceNode(reference));\n return getOffsetRectRelativeToArbitraryNode(reference, commonOffsetParent, fixedPosition);\n}\n\n/**\n * Get the outer sizes of the given element (offset size + margins)\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Object} object containing width and height properties\n */\nfunction getOuterSizes(element) {\n var window = element.ownerDocument.defaultView;\n var styles = window.getComputedStyle(element);\n var x = parseFloat(styles.marginTop || 0) + parseFloat(styles.marginBottom || 0);\n var y = parseFloat(styles.marginLeft || 0) + parseFloat(styles.marginRight || 0);\n var result = {\n width: element.offsetWidth + y,\n height: element.offsetHeight + x\n };\n return result;\n}\n\n/**\n * Get the opposite placement of the given one\n * @method\n * @memberof Popper.Utils\n * @argument {String} placement\n * @returns {String} flipped placement\n */\nfunction getOppositePlacement(placement) {\n var hash = { left: 'right', right: 'left', bottom: 'top', top: 'bottom' };\n return placement.replace(/left|right|bottom|top/g, function (matched) {\n return hash[matched];\n });\n}\n\n/**\n * Get offsets to the popper\n * @method\n * @memberof Popper.Utils\n * @param {Object} position - CSS position the Popper will get applied\n * @param {HTMLElement} popper - the popper element\n * @param {Object} referenceOffsets - the reference offsets (the popper will be relative to this)\n * @param {String} placement - one of the valid placement options\n * @returns {Object} popperOffsets - An object containing the offsets which will be applied to the popper\n */\nfunction getPopperOffsets(popper, referenceOffsets, placement) {\n placement = placement.split('-')[0];\n\n // Get popper node sizes\n var popperRect = getOuterSizes(popper);\n\n // Add position, width and height to our offsets object\n var popperOffsets = {\n width: popperRect.width,\n height: popperRect.height\n };\n\n // depending by the popper placement we have to compute its offsets slightly differently\n var isHoriz = ['right', 'left'].indexOf(placement) !== -1;\n var mainSide = isHoriz ? 'top' : 'left';\n var secondarySide = isHoriz ? 'left' : 'top';\n var measurement = isHoriz ? 'height' : 'width';\n var secondaryMeasurement = !isHoriz ? 'height' : 'width';\n\n popperOffsets[mainSide] = referenceOffsets[mainSide] + referenceOffsets[measurement] / 2 - popperRect[measurement] / 2;\n if (placement === secondarySide) {\n popperOffsets[secondarySide] = referenceOffsets[secondarySide] - popperRect[secondaryMeasurement];\n } else {\n popperOffsets[secondarySide] = referenceOffsets[getOppositePlacement(secondarySide)];\n }\n\n return popperOffsets;\n}\n\n/**\n * Mimics the `find` method of Array\n * @method\n * @memberof Popper.Utils\n * @argument {Array} arr\n * @argument prop\n * @argument value\n * @returns index or -1\n */\nfunction find(arr, check) {\n // use native find if supported\n if (Array.prototype.find) {\n return arr.find(check);\n }\n\n // use `filter` to obtain the same behavior of `find`\n return arr.filter(check)[0];\n}\n\n/**\n * Return the index of the matching object\n * @method\n * @memberof Popper.Utils\n * @argument {Array} arr\n * @argument prop\n * @argument value\n * @returns index or -1\n */\nfunction findIndex(arr, prop, value) {\n // use native findIndex if supported\n if (Array.prototype.findIndex) {\n return arr.findIndex(function (cur) {\n return cur[prop] === value;\n });\n }\n\n // use `find` + `indexOf` if `findIndex` isn't supported\n var match = find(arr, function (obj) {\n return obj[prop] === value;\n });\n return arr.indexOf(match);\n}\n\n/**\n * Loop trough the list of modifiers and run them in order,\n * each of them will then edit the data object.\n * @method\n * @memberof Popper.Utils\n * @param {dataObject} data\n * @param {Array} modifiers\n * @param {String} ends - Optional modifier name used as stopper\n * @returns {dataObject}\n */\nfunction runModifiers(modifiers, data, ends) {\n var modifiersToRun = ends === undefined ? modifiers : modifiers.slice(0, findIndex(modifiers, 'name', ends));\n\n modifiersToRun.forEach(function (modifier) {\n if (modifier['function']) {\n // eslint-disable-line dot-notation\n console.warn('`modifier.function` is deprecated, use `modifier.fn`!');\n }\n var fn = modifier['function'] || modifier.fn; // eslint-disable-line dot-notation\n if (modifier.enabled && isFunction(fn)) {\n // Add properties to offsets to make them a complete clientRect object\n // we do this before each modifier to make sure the previous one doesn't\n // mess with these values\n data.offsets.popper = getClientRect(data.offsets.popper);\n data.offsets.reference = getClientRect(data.offsets.reference);\n\n data = fn(data, modifier);\n }\n });\n\n return data;\n}\n\n/**\n * Updates the position of the popper, computing the new offsets and applying\n * the new style.<br />\n * Prefer `scheduleUpdate` over `update` because of performance reasons.\n * @method\n * @memberof Popper\n */\nfunction update() {\n // if popper is destroyed, don't perform any further update\n if (this.state.isDestroyed) {\n return;\n }\n\n var data = {\n instance: this,\n styles: {},\n arrowStyles: {},\n attributes: {},\n flipped: false,\n offsets: {}\n };\n\n // compute reference element offsets\n data.offsets.reference = getReferenceOffsets(this.state, this.popper, this.reference, this.options.positionFixed);\n\n // compute auto placement, store placement inside the data object,\n // modifiers will be able to edit `placement` if needed\n // and refer to originalPlacement to know the original value\n data.placement = computeAutoPlacement(this.options.placement, data.offsets.reference, this.popper, this.reference, this.options.modifiers.flip.boundariesElement, this.options.modifiers.flip.padding);\n\n // store the computed placement inside `originalPlacement`\n data.originalPlacement = data.placement;\n\n data.positionFixed = this.options.positionFixed;\n\n // compute the popper offsets\n data.offsets.popper = getPopperOffsets(this.popper, data.offsets.reference, data.placement);\n\n data.offsets.popper.position = this.options.positionFixed ? 'fixed' : 'absolute';\n\n // run the modifiers\n data = runModifiers(this.modifiers, data);\n\n // the first `update` will call `onCreate` callback\n // the other ones will call `onUpdate` callback\n if (!this.state.isCreated) {\n this.state.isCreated = true;\n this.options.onCreate(data);\n } else {\n this.options.onUpdate(data);\n }\n}\n\n/**\n * Helper used to know if the given modifier is enabled.\n * @method\n * @memberof Popper.Utils\n * @returns {Boolean}\n */\nfunction isModifierEnabled(modifiers, modifierName) {\n return modifiers.some(function (_ref) {\n var name = _ref.name,\n enabled = _ref.enabled;\n return enabled && name === modifierName;\n });\n}\n\n/**\n * Get the prefixed supported property name\n * @method\n * @memberof Popper.Utils\n * @argument {String} property (camelCase)\n * @returns {String} prefixed property (camelCase or PascalCase, depending on the vendor prefix)\n */\nfunction getSupportedPropertyName(property) {\n var prefixes = [false, 'ms', 'Webkit', 'Moz', 'O'];\n var upperProp = property.charAt(0).toUpperCase() + property.slice(1);\n\n for (var i = 0; i < prefixes.length; i++) {\n var prefix = prefixes[i];\n var toCheck = prefix ? '' + prefix + upperProp : property;\n if (typeof document.body.style[toCheck] !== 'undefined') {\n return toCheck;\n }\n }\n return null;\n}\n\n/**\n * Destroys the popper.\n * @method\n * @memberof Popper\n */\nfunction destroy() {\n this.state.isDestroyed = true;\n\n // touch DOM only if `applyStyle` modifier is enabled\n if (isModifierEnabled(this.modifiers, 'applyStyle')) {\n this.popper.removeAttribute('x-placement');\n this.popper.style.position = '';\n this.popper.style.top = '';\n this.popper.style.left = '';\n this.popper.style.right = '';\n this.popper.style.bottom = '';\n this.popper.style.willChange = '';\n this.popper.style[getSupportedPropertyName('transform')] = '';\n }\n\n this.disableEventListeners();\n\n // remove the popper if user explicitly asked for the deletion on destroy\n // do not use `remove` because IE11 doesn't support it\n if (this.options.removeOnDestroy) {\n this.popper.parentNode.removeChild(this.popper);\n }\n return this;\n}\n\n/**\n * Get the window associated with the element\n * @argument {Element} element\n * @returns {Window}\n */\nfunction getWindow(element) {\n var ownerDocument = element.ownerDocument;\n return ownerDocument ? ownerDocument.defaultView : window;\n}\n\nfunction attachToScrollParents(scrollParent, event, callback, scrollParents) {\n var isBody = scrollParent.nodeName === 'BODY';\n var target = isBody ? scrollParent.ownerDocument.defaultView : scrollParent;\n target.addEventListener(event, callback, { passive: true });\n\n if (!isBody) {\n attachToScrollParents(getScrollParent(target.parentNode), event, callback, scrollParents);\n }\n scrollParents.push(target);\n}\n\n/**\n * Setup needed event listeners used to update the popper position\n * @method\n * @memberof Popper.Utils\n * @private\n */\nfunction setupEventListeners(reference, options, state, updateBound) {\n // Resize event listener on window\n state.updateBound = updateBound;\n getWindow(reference).addEventListener('resize', state.updateBound, { passive: true });\n\n // Scroll event listener on scroll parents\n var scrollElement = getScrollParent(reference);\n attachToScrollParents(scrollElement, 'scroll', state.updateBound, state.scrollParents);\n state.scrollElement = scrollElement;\n state.eventsEnabled = true;\n\n return state;\n}\n\n/**\n * It will add resize/scroll events and start recalculating\n * position of the popper element when they are triggered.\n * @method\n * @memberof Popper\n */\nfunction enableEventListeners() {\n if (!this.state.eventsEnabled) {\n this.state = setupEventListeners(this.reference, this.options, this.state, this.scheduleUpdate);\n }\n}\n\n/**\n * Remove event listeners used to update the popper position\n * @method\n * @memberof Popper.Utils\n * @private\n */\nfunction removeEventListeners(reference, state) {\n // Remove resize event listener on window\n getWindow(reference).removeEventListener('resize', state.updateBound);\n\n // Remove scroll event listener on scroll parents\n state.scrollParents.forEach(function (target) {\n target.removeEventListener('scroll', state.updateBound);\n });\n\n // Reset state\n state.updateBound = null;\n state.scrollParents = [];\n state.scrollElement = null;\n state.eventsEnabled = false;\n return state;\n}\n\n/**\n * It will remove resize/scroll events and won't recalculate popper position\n * when they are triggered. It also won't trigger `onUpdate` callback anymore,\n * unless you call `update` method manually.\n * @method\n * @memberof Popper\n */\nfunction disableEventListeners() {\n if (this.state.eventsEnabled) {\n cancelAnimationFrame(this.scheduleUpdate);\n this.state = removeEventListeners(this.reference, this.state);\n }\n}\n\n/**\n * Tells if a given input is a number\n * @method\n * @memberof Popper.Utils\n * @param {*} input to check\n * @return {Boolean}\n */\nfunction isNumeric(n) {\n return n !== '' && !isNaN(parseFloat(n)) && isFinite(n);\n}\n\n/**\n * Set the style to the given popper\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element - Element to apply the style to\n * @argument {Object} styles\n * Object with a list of properties and values which will be applied to the element\n */\nfunction setStyles(element, styles) {\n Object.keys(styles).forEach(function (prop) {\n var unit = '';\n // add unit if the value is numeric and is one of the following\n if (['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !== -1 && isNumeric(styles[prop])) {\n unit = 'px';\n }\n element.style[prop] = styles[prop] + unit;\n });\n}\n\n/**\n * Set the attributes to the given popper\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element - Element to apply the attributes to\n * @argument {Object} styles\n * Object with a list of properties and values which will be applied to the element\n */\nfunction setAttributes(element, attributes) {\n Object.keys(attributes).forEach(function (prop) {\n var value = attributes[prop];\n if (value !== false) {\n element.setAttribute(prop, attributes[prop]);\n } else {\n element.removeAttribute(prop);\n }\n });\n}\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} data.styles - List of style properties - values to apply to popper element\n * @argument {Object} data.attributes - List of attribute properties - values to apply to popper element\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The same data object\n */\nfunction applyStyle(data) {\n // any property present in `data.styles` will be applied to the popper,\n // in this way we can make the 3rd party modifiers add custom styles to it\n // Be aware, modifiers could override the properties defined in the previous\n // lines of this modifier!\n setStyles(data.instance.popper, data.styles);\n\n // any property present in `data.attributes` will be applied to the popper,\n // they will be set as HTML attributes of the element\n setAttributes(data.instance.popper, data.attributes);\n\n // if arrowElement is defined and arrowStyles has some properties\n if (data.arrowElement && Object.keys(data.arrowStyles).length) {\n setStyles(data.arrowElement, data.arrowStyles);\n }\n\n return data;\n}\n\n/**\n * Set the x-placement attribute before everything else because it could be used\n * to add margins to the popper margins needs to be calculated to get the\n * correct popper offsets.\n * @method\n * @memberof Popper.modifiers\n * @param {HTMLElement} reference - The reference element used to position the popper\n * @param {HTMLElement} popper - The HTML element used as popper\n * @param {Object} options - Popper.js options\n */\nfunction applyStyleOnLoad(reference, popper, options, modifierOptions, state) {\n // compute reference element offsets\n var referenceOffsets = getReferenceOffsets(state, popper, reference, options.positionFixed);\n\n // compute auto placement, store placement inside the data object,\n // modifiers will be able to edit `placement` if needed\n // and refer to originalPlacement to know the original value\n var placement = computeAutoPlacement(options.placement, referenceOffsets, popper, reference, options.modifiers.flip.boundariesElement, options.modifiers.flip.padding);\n\n popper.setAttribute('x-placement', placement);\n\n // Apply `position` to popper before anything else because\n // without the position applied we can't guarantee correct computations\n setStyles(popper, { position: options.positionFixed ? 'fixed' : 'absolute' });\n\n return options;\n}\n\n/**\n * @function\n * @memberof Popper.Utils\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Boolean} shouldRound - If the offsets should be rounded at all\n * @returns {Object} The popper's position offsets rounded\n *\n * The tale of pixel-perfect positioning. It's still not 100% perfect, but as\n * good as it can be within reason.\n * Discussion here: https://github.com/FezVrasta/popper.js/pull/715\n *\n * Low DPI screens cause a popper to be blurry if not using full pixels (Safari\n * as well on High DPI screens).\n *\n * Firefox prefers no rounding for positioning and does not have blurriness on\n * high DPI screens.\n *\n * Only horizontal placement and left/right values need to be considered.\n */\nfunction getRoundedOffsets(data, shouldRound) {\n var _data$offsets = data.offsets,\n popper = _data$offsets.popper,\n reference = _data$offsets.reference;\n var round = Math.round,\n floor = Math.floor;\n\n var noRound = function noRound(v) {\n return v;\n };\n\n var referenceWidth = round(reference.width);\n var popperWidth = round(popper.width);\n\n var isVertical = ['left', 'right'].indexOf(data.placement) !== -1;\n var isVariation = data.placement.indexOf('-') !== -1;\n var sameWidthParity = referenceWidth % 2 === popperWidth % 2;\n var bothOddWidth = referenceWidth % 2 === 1 && popperWidth % 2 === 1;\n\n var horizontalToInteger = !shouldRound ? noRound : isVertical || isVariation || sameWidthParity ? round : floor;\n var verticalToInteger = !shouldRound ? noRound : round;\n\n return {\n left: horizontalToInteger(bothOddWidth && !isVariation && shouldRound ? popper.left - 1 : popper.left),\n top: verticalToInteger(popper.top),\n bottom: verticalToInteger(popper.bottom),\n right: horizontalToInteger(popper.right)\n };\n}\n\nvar isFirefox = isBrowser && /Firefox/i.test(navigator.userAgent);\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nfunction computeStyle(data, options) {\n var x = options.x,\n y = options.y;\n var popper = data.offsets.popper;\n\n // Remove this legacy support in Popper.js v2\n\n var legacyGpuAccelerationOption = find(data.instance.modifiers, function (modifier) {\n return modifier.name === 'applyStyle';\n }).gpuAcceleration;\n if (legacyGpuAccelerationOption !== undefined) {\n console.warn('WARNING: `gpuAcceleration` option moved to `computeStyle` modifier and will not be supported in future versions of Popper.js!');\n }\n var gpuAcceleration = legacyGpuAccelerationOption !== undefined ? legacyGpuAccelerationOption : options.gpuAcceleration;\n\n var offsetParent = getOffsetParent(data.instance.popper);\n var offsetParentRect = getBoundingClientRect(offsetParent);\n\n // Styles\n var styles = {\n position: popper.position\n };\n\n var offsets = getRoundedOffsets(data, window.devicePixelRatio < 2 || !isFirefox);\n\n var sideA = x === 'bottom' ? 'top' : 'bottom';\n var sideB = y === 'right' ? 'left' : 'right';\n\n // if gpuAcceleration is set to `true` and transform is supported,\n // we use `translate3d` to apply the position to the popper we\n // automatically use the supported prefixed version if needed\n var prefixedProperty = getSupportedPropertyName('transform');\n\n // now, let's make a step back and look at this code closely (wtf?)\n // If the content of the popper grows once it's been positioned, it\n // may happen that the popper gets misplaced because of the new content\n // overflowing its reference element\n // To avoid this problem, we provide two options (x and y), which allow\n // the consumer to define the offset origin.\n // If we position a popper on top of a reference element, we can set\n // `x` to `top` to make the popper grow towards its top instead of\n // its bottom.\n var left = void 0,\n top = void 0;\n if (sideA === 'bottom') {\n // when offsetParent is <html> the positioning is relative to the bottom of the screen (excluding the scrollbar)\n // and not the bottom of the html element\n if (offsetParent.nodeName === 'HTML') {\n top = -offsetParent.clientHeight + offsets.bottom;\n } else {\n top = -offsetParentRect.height + offsets.bottom;\n }\n } else {\n top = offsets.top;\n }\n if (sideB === 'right') {\n if (offsetParent.nodeName === 'HTML') {\n left = -offsetParent.clientWidth + offsets.right;\n } else {\n left = -offsetParentRect.width + offsets.right;\n }\n } else {\n left = offsets.left;\n }\n if (gpuAcceleration && prefixedProperty) {\n styles[prefixedProperty] = 'translate3d(' + left + 'px, ' + top + 'px, 0)';\n styles[sideA] = 0;\n styles[sideB] = 0;\n styles.willChange = 'transform';\n } else {\n // othwerise, we use the standard `top`, `left`, `bottom` and `right` properties\n var invertTop = sideA === 'bottom' ? -1 : 1;\n var invertLeft = sideB === 'right' ? -1 : 1;\n styles[sideA] = top * invertTop;\n styles[sideB] = left * invertLeft;\n styles.willChange = sideA + ', ' + sideB;\n }\n\n // Attributes\n var attributes = {\n 'x-placement': data.placement\n };\n\n // Update `data` attributes, styles and arrowStyles\n data.attributes = _extends({}, attributes, data.attributes);\n data.styles = _extends({}, styles, data.styles);\n data.arrowStyles = _extends({}, data.offsets.arrow, data.arrowStyles);\n\n return data;\n}\n\n/**\n * Helper used to know if the given modifier depends from another one.<br />\n * It checks if the needed modifier is listed and enabled.\n * @method\n * @memberof Popper.Utils\n * @param {Array} modifiers - list of modifiers\n * @param {String} requestingName - name of requesting modifier\n * @param {String} requestedName - name of requested modifier\n * @returns {Boolean}\n */\nfunction isModifierRequired(modifiers, requestingName, requestedName) {\n var requesting = find(modifiers, function (_ref) {\n var name = _ref.name;\n return name === requestingName;\n });\n\n var isRequired = !!requesting && modifiers.some(function (modifier) {\n return modifier.name === requestedName && modifier.enabled && modifier.order < requesting.order;\n });\n\n if (!isRequired) {\n var _requesting = '`' + requestingName + '`';\n var requested = '`' + requestedName + '`';\n console.warn(requested + ' modifier is required by ' + _requesting + ' modifier in order to work, be sure to include it before ' + _requesting + '!');\n }\n return isRequired;\n}\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nfunction arrow(data, options) {\n var _data$offsets$arrow;\n\n // arrow depends on keepTogether in order to work\n if (!isModifierRequired(data.instance.modifiers, 'arrow', 'keepTogether')) {\n return data;\n }\n\n var arrowElement = options.element;\n\n // if arrowElement is a string, suppose it's a CSS selector\n if (typeof arrowElement === 'string') {\n arrowElement = data.instance.popper.querySelector(arrowElement);\n\n // if arrowElement is not found, don't run the modifier\n if (!arrowElement) {\n return data;\n }\n } else {\n // if the arrowElement isn't a query selector we must check that the\n // provided DOM node is child of its popper node\n if (!data.instance.popper.contains(arrowElement)) {\n console.warn('WARNING: `arrow.element` must be child of its popper element!');\n return data;\n }\n }\n\n var placement = data.placement.split('-')[0];\n var _data$offsets = data.offsets,\n popper = _data$offsets.popper,\n reference = _data$offsets.reference;\n\n var isVertical = ['left', 'right'].indexOf(placement) !== -1;\n\n var len = isVertical ? 'height' : 'width';\n var sideCapitalized = isVertical ? 'Top' : 'Left';\n var side = sideCapitalized.toLowerCase();\n var altSide = isVertical ? 'left' : 'top';\n var opSide = isVertical ? 'bottom' : 'right';\n var arrowElementSize = getOuterSizes(arrowElement)[len];\n\n //\n // extends keepTogether behavior making sure the popper and its\n // reference have enough pixels in conjunction\n //\n\n // top/left side\n if (reference[opSide] - arrowElementSize < popper[side]) {\n data.offsets.popper[side] -= popper[side] - (reference[opSide] - arrowElementSize);\n }\n // bottom/right side\n if (reference[side] + arrowElementSize > popper[opSide]) {\n data.offsets.popper[side] += reference[side] + arrowElementSize - popper[opSide];\n }\n data.offsets.popper = getClientRect(data.offsets.popper);\n\n // compute center of the popper\n var center = reference[side] + reference[len] / 2 - arrowElementSize / 2;\n\n // Compute the sideValue using the updated popper offsets\n // take popper margin in account because we don't have this info available\n var css = getStyleComputedProperty(data.instance.popper);\n var popperMarginSide = parseFloat(css['margin' + sideCapitalized]);\n var popperBorderSide = parseFloat(css['border' + sideCapitalized + 'Width']);\n var sideValue = center - data.offsets.popper[side] - popperMarginSide - popperBorderSide;\n\n // prevent arrowElement from being placed not contiguously to its popper\n sideValue = Math.max(Math.min(popper[len] - arrowElementSize, sideValue), 0);\n\n data.arrowElement = arrowElement;\n data.offsets.arrow = (_data$offsets$arrow = {}, defineProperty(_data$offsets$arrow, side, Math.round(sideValue)), defineProperty(_data$offsets$arrow, altSide, ''), _data$offsets$arrow);\n\n return data;\n}\n\n/**\n * Get the opposite placement variation of the given one\n * @method\n * @memberof Popper.Utils\n * @argument {String} placement variation\n * @returns {String} flipped placement variation\n */\nfunction getOppositeVariation(variation) {\n if (variation === 'end') {\n return 'start';\n } else if (variation === 'start') {\n return 'end';\n }\n return variation;\n}\n\n/**\n * List of accepted placements to use as values of the `placement` option.<br />\n * Valid placements are:\n * - `auto`\n * - `top`\n * - `right`\n * - `bottom`\n * - `left`\n *\n * Each placement can have a variation from this list:\n * - `-start`\n * - `-end`\n *\n * Variations are interpreted easily if you think of them as the left to right\n * written languages. Horizontally (`top` and `bottom`), `start` is left and `end`\n * is right.<br />\n * Vertically (`left` and `right`), `start` is top and `end` is bottom.\n *\n * Some valid examples are:\n * - `top-end` (on top of reference, right aligned)\n * - `right-start` (on right of reference, top aligned)\n * - `bottom` (on bottom, centered)\n * - `auto-end` (on the side with more space available, alignment depends by placement)\n *\n * @static\n * @type {Array}\n * @enum {String}\n * @readonly\n * @method placements\n * @memberof Popper\n */\nvar placements = ['auto-start', 'auto', 'auto-end', 'top-start', 'top', 'top-end', 'right-start', 'right', 'right-end', 'bottom-end', 'bottom', 'bottom-start', 'left-end', 'left', 'left-start'];\n\n// Get rid of `auto` `auto-start` and `auto-end`\nvar validPlacements = placements.slice(3);\n\n/**\n * Given an initial placement, returns all the subsequent placements\n * clockwise (or counter-clockwise).\n *\n * @method\n * @memberof Popper.Utils\n * @argument {String} placement - A valid placement (it accepts variations)\n * @argument {Boolean} counter - Set to true to walk the placements counterclockwise\n * @returns {Array} placements including their variations\n */\nfunction clockwise(placement) {\n var counter = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;\n\n var index = validPlacements.indexOf(placement);\n var arr = validPlacements.slice(index + 1).concat(validPlacements.slice(0, index));\n return counter ? arr.reverse() : arr;\n}\n\nvar BEHAVIORS = {\n FLIP: 'flip',\n CLOCKWISE: 'clockwise',\n COUNTERCLOCKWISE: 'counterclockwise'\n};\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nfunction flip(data, options) {\n // if `inner` modifier is enabled, we can't use the `flip` modifier\n if (isModifierEnabled(data.instance.modifiers, 'inner')) {\n return data;\n }\n\n if (data.flipped && data.placement === data.originalPlacement) {\n // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides\n return data;\n }\n\n var boundaries = getBoundaries(data.instance.popper, data.instance.reference, options.padding, options.boundariesElement, data.positionFixed);\n\n var placement = data.placement.split('-')[0];\n var placementOpposite = getOppositePlacement(placement);\n var variation = data.placement.split('-')[1] || '';\n\n var flipOrder = [];\n\n switch (options.behavior) {\n case BEHAVIORS.FLIP:\n flipOrder = [placement, placementOpposite];\n break;\n case BEHAVIORS.CLOCKWISE:\n flipOrder = clockwise(placement);\n break;\n case BEHAVIORS.COUNTERCLOCKWISE:\n flipOrder = clockwise(placement, true);\n break;\n default:\n flipOrder = options.behavior;\n }\n\n flipOrder.forEach(function (step, index) {\n if (placement !== step || flipOrder.length === index + 1) {\n return data;\n }\n\n placement = data.placement.split('-')[0];\n placementOpposite = getOppositePlacement(placement);\n\n var popperOffsets = data.offsets.popper;\n var refOffsets = data.offsets.reference;\n\n // using floor because the reference offsets may contain decimals we are not going to consider here\n var floor = Math.floor;\n var overlapsRef = placement === 'left' && floor(popperOffsets.right) > floor(refOffsets.left) || placement === 'right' && floor(popperOffsets.left) < floor(refOffsets.right) || placement === 'top' && floor(popperOffsets.bottom) > floor(refOffsets.top) || placement === 'bottom' && floor(popperOffsets.top) < floor(refOffsets.bottom);\n\n var overflowsLeft = floor(popperOffsets.left) < floor(boundaries.left);\n var overflowsRight = floor(popperOffsets.right) > floor(boundaries.right);\n var overflowsTop = floor(popperOffsets.top) < floor(boundaries.top);\n var overflowsBottom = floor(popperOffsets.bottom) > floor(boundaries.bottom);\n\n var overflowsBoundaries = placement === 'left' && overflowsLeft || placement === 'right' && overflowsRight || placement === 'top' && overflowsTop || placement === 'bottom' && overflowsBottom;\n\n // flip the variation if required\n var isVertical = ['top', 'bottom'].indexOf(placement) !== -1;\n\n // flips variation if reference element overflows boundaries\n var flippedVariationByRef = !!options.flipVariations && (isVertical && variation === 'start' && overflowsLeft || isVertical && variation === 'end' && overflowsRight || !isVertical && variation === 'start' && overflowsTop || !isVertical && variation === 'end' && overflowsBottom);\n\n // flips variation if popper content overflows boundaries\n var flippedVariationByContent = !!options.flipVariationsByContent && (isVertical && variation === 'start' && overflowsRight || isVertical && variation === 'end' && overflowsLeft || !isVertical && variation === 'start' && overflowsBottom || !isVertical && variation === 'end' && overflowsTop);\n\n var flippedVariation = flippedVariationByRef || flippedVariationByContent;\n\n if (overlapsRef || overflowsBoundaries || flippedVariation) {\n // this boolean to detect any flip loop\n data.flipped = true;\n\n if (overlapsRef || overflowsBoundaries) {\n placement = flipOrder[index + 1];\n }\n\n if (flippedVariation) {\n variation = getOppositeVariation(variation);\n }\n\n data.placement = placement + (variation ? '-' + variation : '');\n\n // this object contains `position`, we want to preserve it along with\n // any additional property we may add in the future\n data.offsets.popper = _extends({}, data.offsets.popper, getPopperOffsets(data.instance.popper, data.offsets.reference, data.placement));\n\n data = runModifiers(data.instance.modifiers, data, 'flip');\n }\n });\n return data;\n}\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nfunction keepTogether(data) {\n var _data$offsets = data.offsets,\n popper = _data$offsets.popper,\n reference = _data$offsets.reference;\n\n var placement = data.placement.split('-')[0];\n var floor = Math.floor;\n var isVertical = ['top', 'bottom'].indexOf(placement) !== -1;\n var side = isVertical ? 'right' : 'bottom';\n var opSide = isVertical ? 'left' : 'top';\n var measurement = isVertical ? 'width' : 'height';\n\n if (popper[side] < floor(reference[opSide])) {\n data.offsets.popper[opSide] = floor(reference[opSide]) - popper[measurement];\n }\n if (popper[opSide] > floor(reference[side])) {\n data.offsets.popper[opSide] = floor(reference[side]);\n }\n\n return data;\n}\n\n/**\n * Converts a string containing value + unit into a px value number\n * @function\n * @memberof {modifiers~offset}\n * @private\n * @argument {String} str - Value + unit string\n * @argument {String} measurement - `height` or `width`\n * @argument {Object} popperOffsets\n * @argument {Object} referenceOffsets\n * @returns {Number|String}\n * Value in pixels, or original string if no values were extracted\n */\nfunction toValue(str, measurement, popperOffsets, referenceOffsets) {\n // separate value from unit\n var split = str.match(/((?:\\-|\\+)?\\d*\\.?\\d*)(.*)/);\n var value = +split[1];\n var unit = split[2];\n\n // If it's not a number it's an operator, I guess\n if (!value) {\n return str;\n }\n\n if (unit.indexOf('%') === 0) {\n var element = void 0;\n switch (unit) {\n case '%p':\n element = popperOffsets;\n break;\n case '%':\n case '%r':\n default:\n element = referenceOffsets;\n }\n\n var rect = getClientRect(element);\n return rect[measurement] / 100 * value;\n } else if (unit === 'vh' || unit === 'vw') {\n // if is a vh or vw, we calculate the size based on the viewport\n var size = void 0;\n if (unit === 'vh') {\n size = Math.max(document.documentElement.clientHeight, window.innerHeight || 0);\n } else {\n size = Math.max(document.documentElement.clientWidth, window.innerWidth || 0);\n }\n return size / 100 * value;\n } else {\n // if is an explicit pixel unit, we get rid of the unit and keep the value\n // if is an implicit unit, it's px, and we return just the value\n return value;\n }\n}\n\n/**\n * Parse an `offset` string to extrapolate `x` and `y` numeric offsets.\n * @function\n * @memberof {modifiers~offset}\n * @private\n * @argument {String} offset\n * @argument {Object} popperOffsets\n * @argument {Object} referenceOffsets\n * @argument {String} basePlacement\n * @returns {Array} a two cells array with x and y offsets in numbers\n */\nfunction parseOffset(offset, popperOffsets, referenceOffsets, basePlacement) {\n var offsets = [0, 0];\n\n // Use height if placement is left or right and index is 0 otherwise use width\n // in this way the first offset will use an axis and the second one\n // will use the other one\n var useHeight = ['right', 'left'].indexOf(basePlacement) !== -1;\n\n // Split the offset string to obtain a list of values and operands\n // The regex addresses values with the plus or minus sign in front (+10, -20, etc)\n var fragments = offset.split(/(\\+|\\-)/).map(function (frag) {\n return frag.trim();\n });\n\n // Detect if the offset string contains a pair of values or a single one\n // they could be separated by comma or space\n var divider = fragments.indexOf(find(fragments, function (frag) {\n return frag.search(/,|\\s/) !== -1;\n }));\n\n if (fragments[divider] && fragments[divider].indexOf(',') === -1) {\n console.warn('Offsets separated by white space(s) are deprecated, use a comma (,) instead.');\n }\n\n // If divider is found, we divide the list of values and operands to divide\n // them by ofset X and Y.\n var splitRegex = /\\s*,\\s*|\\s+/;\n var ops = divider !== -1 ? [fragments.slice(0, divider).concat([fragments[divider].split(splitRegex)[0]]), [fragments[divider].split(splitRegex)[1]].concat(fragments.slice(divider + 1))] : [fragments];\n\n // Convert the values with units to absolute pixels to allow our computations\n ops = ops.map(function (op, index) {\n // Most of the units rely on the orientation of the popper\n var measurement = (index === 1 ? !useHeight : useHeight) ? 'height' : 'width';\n var mergeWithPrevious = false;\n return op\n // This aggregates any `+` or `-` sign that aren't considered operators\n // e.g.: 10 + +5 => [10, +, +5]\n .reduce(function (a, b) {\n if (a[a.length - 1] === '' && ['+', '-'].indexOf(b) !== -1) {\n a[a.length - 1] = b;\n mergeWithPrevious = true;\n return a;\n } else if (mergeWithPrevious) {\n a[a.length - 1] += b;\n mergeWithPrevious = false;\n return a;\n } else {\n return a.concat(b);\n }\n }, [])\n // Here we convert the string values into number values (in px)\n .map(function (str) {\n return toValue(str, measurement, popperOffsets, referenceOffsets);\n });\n });\n\n // Loop trough the offsets arrays and execute the operations\n ops.forEach(function (op, index) {\n op.forEach(function (frag, index2) {\n if (isNumeric(frag)) {\n offsets[index] += frag * (op[index2 - 1] === '-' ? -1 : 1);\n }\n });\n });\n return offsets;\n}\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @argument {Number|String} options.offset=0\n * The offset value as described in the modifier description\n * @returns {Object} The data object, properly modified\n */\nfunction offset(data, _ref) {\n var offset = _ref.offset;\n var placement = data.placement,\n _data$offsets = data.offsets,\n popper = _data$offsets.popper,\n reference = _data$offsets.reference;\n\n var basePlacement = placement.split('-')[0];\n\n var offsets = void 0;\n if (isNumeric(+offset)) {\n offsets = [+offset, 0];\n } else {\n offsets = parseOffset(offset, popper, reference, basePlacement);\n }\n\n if (basePlacement === 'left') {\n popper.top += offsets[0];\n popper.left -= offsets[1];\n } else if (basePlacement === 'right') {\n popper.top += offsets[0];\n popper.left += offsets[1];\n } else if (basePlacement === 'top') {\n popper.left += offsets[0];\n popper.top -= offsets[1];\n } else if (basePlacement === 'bottom') {\n popper.left += offsets[0];\n popper.top += offsets[1];\n }\n\n data.popper = popper;\n return data;\n}\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nfunction preventOverflow(data, options) {\n var boundariesElement = options.boundariesElement || getOffsetParent(data.instance.popper);\n\n // If offsetParent is the reference element, we really want to\n // go one step up and use the next offsetParent as reference to\n // avoid to make this modifier completely useless and look like broken\n if (data.instance.reference === boundariesElement) {\n boundariesElement = getOffsetParent(boundariesElement);\n }\n\n // NOTE: DOM access here\n // resets the popper's position so that the document size can be calculated excluding\n // the size of the popper element itself\n var transformProp = getSupportedPropertyName('transform');\n var popperStyles = data.instance.popper.style; // assignment to help minification\n var top = popperStyles.top,\n left = popperStyles.left,\n transform = popperStyles[transformProp];\n\n popperStyles.top = '';\n popperStyles.left = '';\n popperStyles[transformProp] = '';\n\n var boundaries = getBoundaries(data.instance.popper, data.instance.reference, options.padding, boundariesElement, data.positionFixed);\n\n // NOTE: DOM access here\n // restores the original style properties after the offsets have been computed\n popperStyles.top = top;\n popperStyles.left = left;\n popperStyles[transformProp] = transform;\n\n options.boundaries = boundaries;\n\n var order = options.priority;\n var popper = data.offsets.popper;\n\n var check = {\n primary: function primary(placement) {\n var value = popper[placement];\n if (popper[placement] < boundaries[placement] && !options.escapeWithReference) {\n value = Math.max(popper[placement], boundaries[placement]);\n }\n return defineProperty({}, placement, value);\n },\n secondary: function secondary(placement) {\n var mainSide = placement === 'right' ? 'left' : 'top';\n var value = popper[mainSide];\n if (popper[placement] > boundaries[placement] && !options.escapeWithReference) {\n value = Math.min(popper[mainSide], boundaries[placement] - (placement === 'right' ? popper.width : popper.height));\n }\n return defineProperty({}, mainSide, value);\n }\n };\n\n order.forEach(function (placement) {\n var side = ['left', 'top'].indexOf(placement) !== -1 ? 'primary' : 'secondary';\n popper = _extends({}, popper, check[side](placement));\n });\n\n data.offsets.popper = popper;\n\n return data;\n}\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nfunction shift(data) {\n var placement = data.placement;\n var basePlacement = placement.split('-')[0];\n var shiftvariation = placement.split('-')[1];\n\n // if shift shiftvariation is specified, run the modifier\n if (shiftvariation) {\n var _data$offsets = data.offsets,\n reference = _data$offsets.reference,\n popper = _data$offsets.popper;\n\n var isVertical = ['bottom', 'top'].indexOf(basePlacement) !== -1;\n var side = isVertical ? 'left' : 'top';\n var measurement = isVertical ? 'width' : 'height';\n\n var shiftOffsets = {\n start: defineProperty({}, side, reference[side]),\n end: defineProperty({}, side, reference[side] + reference[measurement] - popper[measurement])\n };\n\n data.offsets.popper = _extends({}, popper, shiftOffsets[shiftvariation]);\n }\n\n return data;\n}\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nfunction hide(data) {\n if (!isModifierRequired(data.instance.modifiers, 'hide', 'preventOverflow')) {\n return data;\n }\n\n var refRect = data.offsets.reference;\n var bound = find(data.instance.modifiers, function (modifier) {\n return modifier.name === 'preventOverflow';\n }).boundaries;\n\n if (refRect.bottom < bound.top || refRect.left > bound.right || refRect.top > bound.bottom || refRect.right < bound.left) {\n // Avoid unnecessary DOM access if visibility hasn't changed\n if (data.hide === true) {\n return data;\n }\n\n data.hide = true;\n data.attributes['x-out-of-boundaries'] = '';\n } else {\n // Avoid unnecessary DOM access if visibility hasn't changed\n if (data.hide === false) {\n return data;\n }\n\n data.hide = false;\n data.attributes['x-out-of-boundaries'] = false;\n }\n\n return data;\n}\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nfunction inner(data) {\n var placement = data.placement;\n var basePlacement = placement.split('-')[0];\n var _data$offsets = data.offsets,\n popper = _data$offsets.popper,\n reference = _data$offsets.reference;\n\n var isHoriz = ['left', 'right'].indexOf(basePlacement) !== -1;\n\n var subtractLength = ['top', 'left'].indexOf(basePlacement) === -1;\n\n popper[isHoriz ? 'left' : 'top'] = reference[basePlacement] - (subtractLength ? popper[isHoriz ? 'width' : 'height'] : 0);\n\n data.placement = getOppositePlacement(placement);\n data.offsets.popper = getClientRect(popper);\n\n return data;\n}\n\n/**\n * Modifier function, each modifier can have a function of this type assigned\n * to its `fn` property.<br />\n * These functions will be called on each update, this means that you must\n * make sure they are performant enough to avoid performance bottlenecks.\n *\n * @function ModifierFn\n * @argument {dataObject} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {dataObject} The data object, properly modified\n */\n\n/**\n * Modifiers are plugins used to alter the behavior of your poppers.<br />\n * Popper.js uses a set of 9 modifiers to provide all the basic functionalities\n * needed by the library.\n *\n * Usually you don't want to override the `order`, `fn` and `onLoad` props.\n * All the other properties are configurations that could be tweaked.\n * @namespace modifiers\n */\nvar modifiers = {\n /**\n * Modifier used to shift the popper on the start or end of its reference\n * element.<br />\n * It will read the variation of the `placement` property.<br />\n * It can be one either `-end` or `-start`.\n * @memberof modifiers\n * @inner\n */\n shift: {\n /** @prop {number} order=100 - Index used to define the order of execution */\n order: 100,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: shift\n },\n\n /**\n * The `offset` modifier can shift your popper on both its axis.\n *\n * It accepts the following units:\n * - `px` or unit-less, interpreted as pixels\n * - `%` or `%r`, percentage relative to the length of the reference element\n * - `%p`, percentage relative to the length of the popper element\n * - `vw`, CSS viewport width unit\n * - `vh`, CSS viewport height unit\n *\n * For length is intended the main axis relative to the placement of the popper.<br />\n * This means that if the placement is `top` or `bottom`, the length will be the\n * `width`. In case of `left` or `right`, it will be the `height`.\n *\n * You can provide a single value (as `Number` or `String`), or a pair of values\n * as `String` divided by a comma or one (or more) white spaces.<br />\n * The latter is a deprecated method because it leads to confusion and will be\n * removed in v2.<br />\n * Additionally, it accepts additions and subtractions between different units.\n * Note that multiplications and divisions aren't supported.\n *\n * Valid examples are:\n * ```\n * 10\n * '10%'\n * '10, 10'\n * '10%, 10'\n * '10 + 10%'\n * '10 - 5vh + 3%'\n * '-10px + 5vh, 5px - 6%'\n * ```\n * > **NB**: If you desire to apply offsets to your poppers in a way that may make them overlap\n * > with their reference element, unfortunately, you will have to disable the `flip` modifier.\n * > You can read more on this at this [issue](https://github.com/FezVrasta/popper.js/issues/373).\n *\n * @memberof modifiers\n * @inner\n */\n offset: {\n /** @prop {number} order=200 - Index used to define the order of execution */\n order: 200,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: offset,\n /** @prop {Number|String} offset=0\n * The offset value as described in the modifier description\n */\n offset: 0\n },\n\n /**\n * Modifier used to prevent the popper from being positioned outside the boundary.\n *\n * A scenario exists where the reference itself is not within the boundaries.<br />\n * We can say it has \"escaped the boundaries\" — or just \"escaped\".<br />\n * In this case we need to decide whether the popper should either:\n *\n * - detach from the reference and remain \"trapped\" in the boundaries, or\n * - if it should ignore the boundary and \"escape with its reference\"\n *\n * When `escapeWithReference` is set to`true` and reference is completely\n * outside its boundaries, the popper will overflow (or completely leave)\n * the boundaries in order to remain attached to the edge of the reference.\n *\n * @memberof modifiers\n * @inner\n */\n preventOverflow: {\n /** @prop {number} order=300 - Index used to define the order of execution */\n order: 300,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: preventOverflow,\n /**\n * @prop {Array} [priority=['left','right','top','bottom']]\n * Popper will try to prevent overflow following these priorities by default,\n * then, it could overflow on the left and on top of the `boundariesElement`\n */\n priority: ['left', 'right', 'top', 'bottom'],\n /**\n * @prop {number} padding=5\n * Amount of pixel used to define a minimum distance between the boundaries\n * and the popper. This makes sure the popper always has a little padding\n * between the edges of its container\n */\n padding: 5,\n /**\n * @prop {String|HTMLElement} boundariesElement='scrollParent'\n * Boundaries used by the modifier. Can be `scrollParent`, `window`,\n * `viewport` or any DOM element.\n */\n boundariesElement: 'scrollParent'\n },\n\n /**\n * Modifier used to make sure the reference and its popper stay near each other\n * without leaving any gap between the two. Especially useful when the arrow is\n * enabled and you want to ensure that it points to its reference element.\n * It cares only about the first axis. You can still have poppers with margin\n * between the popper and its reference element.\n * @memberof modifiers\n * @inner\n */\n keepTogether: {\n /** @prop {number} order=400 - Index used to define the order of execution */\n order: 400,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: keepTogether\n },\n\n /**\n * This modifier is used to move the `arrowElement` of the popper to make\n * sure it is positioned between the reference element and its popper element.\n * It will read the outer size of the `arrowElement` node to detect how many\n * pixels of conjunction are needed.\n *\n * It has no effect if no `arrowElement` is provided.\n * @memberof modifiers\n * @inner\n */\n arrow: {\n /** @prop {number} order=500 - Index used to define the order of execution */\n order: 500,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: arrow,\n /** @prop {String|HTMLElement} element='[x-arrow]' - Selector or node used as arrow */\n element: '[x-arrow]'\n },\n\n /**\n * Modifier used to flip the popper's placement when it starts to overlap its\n * reference element.\n *\n * Requires the `preventOverflow` modifier before it in order to work.\n *\n * **NOTE:** this modifier will interrupt the current update cycle and will\n * restart it if it detects the need to flip the placement.\n * @memberof modifiers\n * @inner\n */\n flip: {\n /** @prop {number} order=600 - Index used to define the order of execution */\n order: 600,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: flip,\n /**\n * @prop {String|Array} behavior='flip'\n * The behavior used to change the popper's placement. It can be one of\n * `flip`, `clockwise`, `counterclockwise` or an array with a list of valid\n * placements (with optional variations)\n */\n behavior: 'flip',\n /**\n * @prop {number} padding=5\n * The popper will flip if it hits the edges of the `boundariesElement`\n */\n padding: 5,\n /**\n * @prop {String|HTMLElement} boundariesElement='viewport'\n * The element which will define the boundaries of the popper position.\n * The popper will never be placed outside of the defined boundaries\n * (except if `keepTogether` is enabled)\n */\n boundariesElement: 'viewport',\n /**\n * @prop {Boolean} flipVariations=false\n * The popper will switch placement variation between `-start` and `-end` when\n * the reference element overlaps its boundaries.\n *\n * The original placement should have a set variation.\n */\n flipVariations: false,\n /**\n * @prop {Boolean} flipVariationsByContent=false\n * The popper will switch placement variation between `-start` and `-end` when\n * the popper element overlaps its reference boundaries.\n *\n * The original placement should have a set variation.\n */\n flipVariationsByContent: false\n },\n\n /**\n * Modifier used to make the popper flow toward the inner of the reference element.\n * By default, when this modifier is disabled, the popper will be placed outside\n * the reference element.\n * @memberof modifiers\n * @inner\n */\n inner: {\n /** @prop {number} order=700 - Index used to define the order of execution */\n order: 700,\n /** @prop {Boolean} enabled=false - Whether the modifier is enabled or not */\n enabled: false,\n /** @prop {ModifierFn} */\n fn: inner\n },\n\n /**\n * Modifier used to hide the popper when its reference element is outside of the\n * popper boundaries. It will set a `x-out-of-boundaries` attribute which can\n * be used to hide with a CSS selector the popper when its reference is\n * out of boundaries.\n *\n * Requires the `preventOverflow` modifier before it in order to work.\n * @memberof modifiers\n * @inner\n */\n hide: {\n /** @prop {number} order=800 - Index used to define the order of execution */\n order: 800,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: hide\n },\n\n /**\n * Computes the style that will be applied to the popper element to gets\n * properly positioned.\n *\n * Note that this modifier will not touch the DOM, it just prepares the styles\n * so that `applyStyle` modifier can apply it. This separation is useful\n * in case you need to replace `applyStyle` with a custom implementation.\n *\n * This modifier has `850` as `order` value to maintain backward compatibility\n * with previous versions of Popper.js. Expect the modifiers ordering method\n * to change in future major versions of the library.\n *\n * @memberof modifiers\n * @inner\n */\n computeStyle: {\n /** @prop {number} order=850 - Index used to define the order of execution */\n order: 850,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: computeStyle,\n /**\n * @prop {Boolean} gpuAcceleration=true\n * If true, it uses the CSS 3D transformation to position the popper.\n * Otherwise, it will use the `top` and `left` properties\n */\n gpuAcceleration: true,\n /**\n * @prop {string} [x='bottom']\n * Where to anchor the X axis (`bottom` or `top`). AKA X offset origin.\n * Change this if your popper should grow in a direction different from `bottom`\n */\n x: 'bottom',\n /**\n * @prop {string} [x='left']\n * Where to anchor the Y axis (`left` or `right`). AKA Y offset origin.\n * Change this if your popper should grow in a direction different from `right`\n */\n y: 'right'\n },\n\n /**\n * Applies the computed styles to the popper element.\n *\n * All the DOM manipulations are limited to this modifier. This is useful in case\n * you want to integrate Popper.js inside a framework or view library and you\n * want to delegate all the DOM manipulations to it.\n *\n * Note that if you disable this modifier, you must make sure the popper element\n * has its position set to `absolute` before Popper.js can do its work!\n *\n * Just disable this modifier and define your own to achieve the desired effect.\n *\n * @memberof modifiers\n * @inner\n */\n applyStyle: {\n /** @prop {number} order=900 - Index used to define the order of execution */\n order: 900,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: applyStyle,\n /** @prop {Function} */\n onLoad: applyStyleOnLoad,\n /**\n * @deprecated since version 1.10.0, the property moved to `computeStyle` modifier\n * @prop {Boolean} gpuAcceleration=true\n * If true, it uses the CSS 3D transformation to position the popper.\n * Otherwise, it will use the `top` and `left` properties\n */\n gpuAcceleration: undefined\n }\n};\n\n/**\n * The `dataObject` is an object containing all the information used by Popper.js.\n * This object is passed to modifiers and to the `onCreate` and `onUpdate` callbacks.\n * @name dataObject\n * @property {Object} data.instance The Popper.js instance\n * @property {String} data.placement Placement applied to popper\n * @property {String} data.originalPlacement Placement originally defined on init\n * @property {Boolean} data.flipped True if popper has been flipped by flip modifier\n * @property {Boolean} data.hide True if the reference element is out of boundaries, useful to know when to hide the popper\n * @property {HTMLElement} data.arrowElement Node used as arrow by arrow modifier\n * @property {Object} data.styles Any CSS property defined here will be applied to the popper. It expects the JavaScript nomenclature (eg. `marginBottom`)\n * @property {Object} data.arrowStyles Any CSS property defined here will be applied to the popper arrow. It expects the JavaScript nomenclature (eg. `marginBottom`)\n * @property {Object} data.boundaries Offsets of the popper boundaries\n * @property {Object} data.offsets The measurements of popper, reference and arrow elements\n * @property {Object} data.offsets.popper `top`, `left`, `width`, `height` values\n * @property {Object} data.offsets.reference `top`, `left`, `width`, `height` values\n * @property {Object} data.offsets.arrow] `top` and `left` offsets, only one of them will be different from 0\n */\n\n/**\n * Default options provided to Popper.js constructor.<br />\n * These can be overridden using the `options` argument of Popper.js.<br />\n * To override an option, simply pass an object with the same\n * structure of the `options` object, as the 3rd argument. For example:\n * ```\n * new Popper(ref, pop, {\n * modifiers: {\n * preventOverflow: { enabled: false }\n * }\n * })\n * ```\n * @type {Object}\n * @static\n * @memberof Popper\n */\nvar Defaults = {\n /**\n * Popper's placement.\n * @prop {Popper.placements} placement='bottom'\n */\n placement: 'bottom',\n\n /**\n * Set this to true if you want popper to position it self in 'fixed' mode\n * @prop {Boolean} positionFixed=false\n */\n positionFixed: false,\n\n /**\n * Whether events (resize, scroll) are initially enabled.\n * @prop {Boolean} eventsEnabled=true\n */\n eventsEnabled: true,\n\n /**\n * Set to true if you want to automatically remove the popper when\n * you call the `destroy` method.\n * @prop {Boolean} removeOnDestroy=false\n */\n removeOnDestroy: false,\n\n /**\n * Callback called when the popper is created.<br />\n * By default, it is set to no-op.<br />\n * Access Popper.js instance with `data.instance`.\n * @prop {onCreate}\n */\n onCreate: function onCreate() {},\n\n /**\n * Callback called when the popper is updated. This callback is not called\n * on the initialization/creation of the popper, but only on subsequent\n * updates.<br />\n * By default, it is set to no-op.<br />\n * Access Popper.js instance with `data.instance`.\n * @prop {onUpdate}\n */\n onUpdate: function onUpdate() {},\n\n /**\n * List of modifiers used to modify the offsets before they are applied to the popper.\n * They provide most of the functionalities of Popper.js.\n * @prop {modifiers}\n */\n modifiers: modifiers\n};\n\n/**\n * @callback onCreate\n * @param {dataObject} data\n */\n\n/**\n * @callback onUpdate\n * @param {dataObject} data\n */\n\n// Utils\n// Methods\nvar Popper = function () {\n /**\n * Creates a new Popper.js instance.\n * @class Popper\n * @param {Element|referenceObject} reference - The reference element used to position the popper\n * @param {Element} popper - The HTML / XML element used as the popper\n * @param {Object} options - Your custom options to override the ones defined in [Defaults](#defaults)\n * @return {Object} instance - The generated Popper.js instance\n */\n function Popper(reference, popper) {\n var _this = this;\n\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n classCallCheck(this, Popper);\n\n this.scheduleUpdate = function () {\n return requestAnimationFrame(_this.update);\n };\n\n // make update() debounced, so that it only runs at most once-per-tick\n this.update = debounce(this.update.bind(this));\n\n // with {} we create a new object with the options inside it\n this.options = _extends({}, Popper.Defaults, options);\n\n // init state\n this.state = {\n isDestroyed: false,\n isCreated: false,\n scrollParents: []\n };\n\n // get reference and popper elements (allow jQuery wrappers)\n this.reference = reference && reference.jquery ? reference[0] : reference;\n this.popper = popper && popper.jquery ? popper[0] : popper;\n\n // Deep merge modifiers options\n this.options.modifiers = {};\n Object.keys(_extends({}, Popper.Defaults.modifiers, options.modifiers)).forEach(function (name) {\n _this.options.modifiers[name] = _extends({}, Popper.Defaults.modifiers[name] || {}, options.modifiers ? options.modifiers[name] : {});\n });\n\n // Refactoring modifiers' list (Object => Array)\n this.modifiers = Object.keys(this.options.modifiers).map(function (name) {\n return _extends({\n name: name\n }, _this.options.modifiers[name]);\n })\n // sort the modifiers by order\n .sort(function (a, b) {\n return a.order - b.order;\n });\n\n // modifiers have the ability to execute arbitrary code when Popper.js get inited\n // such code is executed in the same order of its modifier\n // they could add new properties to their options configuration\n // BE AWARE: don't add options to `options.modifiers.name` but to `modifierOptions`!\n this.modifiers.forEach(function (modifierOptions) {\n if (modifierOptions.enabled && isFunction(modifierOptions.onLoad)) {\n modifierOptions.onLoad(_this.reference, _this.popper, _this.options, modifierOptions, _this.state);\n }\n });\n\n // fire the first update to position the popper in the right place\n this.update();\n\n var eventsEnabled = this.options.eventsEnabled;\n if (eventsEnabled) {\n // setup event listeners, they will take care of update the position in specific situations\n this.enableEventListeners();\n }\n\n this.state.eventsEnabled = eventsEnabled;\n }\n\n // We can't use class properties because they don't get listed in the\n // class prototype and break stuff like Sinon stubs\n\n\n createClass(Popper, [{\n key: 'update',\n value: function update$$1() {\n return update.call(this);\n }\n }, {\n key: 'destroy',\n value: function destroy$$1() {\n return destroy.call(this);\n }\n }, {\n key: 'enableEventListeners',\n value: function enableEventListeners$$1() {\n return enableEventListeners.call(this);\n }\n }, {\n key: 'disableEventListeners',\n value: function disableEventListeners$$1() {\n return disableEventListeners.call(this);\n }\n\n /**\n * Schedules an update. It will run on the next UI update available.\n * @method scheduleUpdate\n * @memberof Popper\n */\n\n\n /**\n * Collection of utilities useful when writing custom modifiers.\n * Starting from version 1.7, this method is available only if you\n * include `popper-utils.js` before `popper.js`.\n *\n * **DEPRECATION**: This way to access PopperUtils is deprecated\n * and will be removed in v2! Use the PopperUtils module directly instead.\n * Due to the high instability of the methods contained in Utils, we can't\n * guarantee them to follow semver. Use them at your own risk!\n * @static\n * @private\n * @type {Object}\n * @deprecated since version 1.8\n * @member Utils\n * @memberof Popper\n */\n\n }]);\n return Popper;\n}();\n\n/**\n * The `referenceObject` is an object that provides an interface compatible with Popper.js\n * and lets you use it as replacement of a real DOM node.<br />\n * You can use this method to position a popper relatively to a set of coordinates\n * in case you don't have a DOM node to use as reference.\n *\n * ```\n * new Popper(referenceObject, popperNode);\n * ```\n *\n * NB: This feature isn't supported in Internet Explorer 10.\n * @name referenceObject\n * @property {Function} data.getBoundingClientRect\n * A function that returns a set of coordinates compatible with the native `getBoundingClientRect` method.\n * @property {number} data.clientWidth\n * An ES6 getter that will return the width of the virtual reference element.\n * @property {number} data.clientHeight\n * An ES6 getter that will return the height of the virtual reference element.\n */\n\n\nPopper.Utils = (typeof window !== 'undefined' ? window : global).PopperUtils;\nPopper.placements = placements;\nPopper.Defaults = Defaults;\n\nexport default Popper;\n//# sourceMappingURL=popper.js.map\n","/*!\n * jQuery Form Plugin\n * version: 4.2.2\n * Requires jQuery v1.7.2 or later\n * Project repository: https://github.com/jquery-form/form\n\n * Copyright 2017 Kevin Morris\n * Copyright 2006 M. Alsup\n\n * Dual licensed under the LGPL-2.1+ or MIT licenses\n * https://github.com/jquery-form/form#license\n\n * This library is free software; you can redistribute it and/or\n * modify it under the terms of the GNU Lesser General Public\n * License as published by the Free Software Foundation; either\n * version 2.1 of the License, or (at your option) any later version.\n * This library is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU\n * Lesser General Public License for more details.\n */\n!function(e){\"function\"==typeof define&&define.amd?define([\"jquery\"],e):\"object\"==typeof module&&module.exports?module.exports=function(t,r){return void 0===r&&(r=\"undefined\"!=typeof window?require(\"jquery\"):require(\"jquery\")(t)),e(r),r}:e(jQuery)}(function(e){\"use strict\";function t(t){var r=t.data;t.isDefaultPrevented()||(t.preventDefault(),e(t.target).closest(\"form\").ajaxSubmit(r))}function r(t){var r=t.target,a=e(r);if(!a.is(\"[type=submit],[type=image]\")){var n=a.closest(\"[type=submit]\");if(0===n.length)return;r=n[0]}var i=r.form;if(i.clk=r,\"image\"===r.type)if(void 0!==t.offsetX)i.clk_x=t.offsetX,i.clk_y=t.offsetY;else if(\"function\"==typeof e.fn.offset){var o=a.offset();i.clk_x=t.pageX-o.left,i.clk_y=t.pageY-o.top}else i.clk_x=t.pageX-r.offsetLeft,i.clk_y=t.pageY-r.offsetTop;setTimeout(function(){i.clk=i.clk_x=i.clk_y=null},100)}function a(){if(e.fn.ajaxSubmit.debug){var t=\"[jquery.form] \"+Array.prototype.join.call(arguments,\"\");window.console&&window.console.log?window.console.log(t):window.opera&&window.opera.postError&&window.opera.postError(t)}}var n=/\\r?\\n/g,i={};i.fileapi=void 0!==e('<input type=\"file\">').get(0).files,i.formdata=void 0!==window.FormData;var o=!!e.fn.prop;e.fn.attr2=function(){if(!o)return this.attr.apply(this,arguments);var e=this.prop.apply(this,arguments);return e&&e.jquery||\"string\"==typeof e?e:this.attr.apply(this,arguments)},e.fn.ajaxSubmit=function(t,r,n,s){function u(r){var a,n,i=e.param(r,t.traditional).split(\"&\"),o=i.length,s=[];for(a=0;a<o;a++)i[a]=i[a].replace(/\\+/g,\" \"),n=i[a].split(\"=\"),s.push([decodeURIComponent(n[0]),decodeURIComponent(n[1])]);return s}function c(r){function n(e){var t=null;try{e.contentWindow&&(t=e.contentWindow.document)}catch(e){a(\"cannot get iframe.contentWindow document: \"+e)}if(t)return t;try{t=e.contentDocument?e.contentDocument:e.document}catch(r){a(\"cannot get iframe.contentDocument: \"+r),t=e.document}return t}function i(){function t(){try{var e=n(v).readyState;a(\"state = \"+e),e&&\"uninitialized\"===e.toLowerCase()&&setTimeout(t,50)}catch(e){a(\"Server abort: \",e,\" (\",e.name,\")\"),s(L),j&&clearTimeout(j),j=void 0}}var r=p.attr2(\"target\"),i=p.attr2(\"action\"),o=p.attr(\"enctype\")||p.attr(\"encoding\")||\"multipart/form-data\";w.setAttribute(\"target\",m),l&&!/post/i.test(l)||w.setAttribute(\"method\",\"POST\"),i!==f.url&&w.setAttribute(\"action\",f.url),f.skipEncodingOverride||l&&!/post/i.test(l)||p.attr({encoding:\"multipart/form-data\",enctype:\"multipart/form-data\"}),f.timeout&&(j=setTimeout(function(){T=!0,s(A)},f.timeout));var u=[];try{if(f.extraData)for(var c in f.extraData)f.extraData.hasOwnProperty(c)&&(e.isPlainObject(f.extraData[c])&&f.extraData[c].hasOwnProperty(\"name\")&&f.extraData[c].hasOwnProperty(\"value\")?u.push(e('<input type=\"hidden\" name=\"'+f.extraData[c].name+'\">',k).val(f.extraData[c].value).appendTo(w)[0]):u.push(e('<input type=\"hidden\" name=\"'+c+'\">',k).val(f.extraData[c]).appendTo(w)[0]));f.iframeTarget||h.appendTo(D),v.attachEvent?v.attachEvent(\"onload\",s):v.addEventListener(\"load\",s,!1),setTimeout(t,15);try{w.submit()}catch(e){document.createElement(\"form\").submit.apply(w)}}finally{w.setAttribute(\"action\",i),w.setAttribute(\"enctype\",o),r?w.setAttribute(\"target\",r):p.removeAttr(\"target\"),e(u).remove()}}function s(t){if(!x.aborted&&!X){if((O=n(v))||(a(\"cannot access response document\"),t=L),t===A&&x)return x.abort(\"timeout\"),void S.reject(x,\"timeout\");if(t===L&&x)return x.abort(\"server abort\"),void S.reject(x,\"error\",\"server abort\");if(O&&O.location.href!==f.iframeSrc||T){v.detachEvent?v.detachEvent(\"onload\",s):v.removeEventListener(\"load\",s,!1);var r,i=\"success\";try{if(T)throw\"timeout\";var o=\"xml\"===f.dataType||O.XMLDocument||e.isXMLDoc(O);if(a(\"isXml=\"+o),!o&&window.opera&&(null===O.body||!O.body.innerHTML)&&--C)return a(\"requeing onLoad callback, DOM not available\"),void setTimeout(s,250);var u=O.body?O.body:O.documentElement;x.responseText=u?u.innerHTML:null,x.responseXML=O.XMLDocument?O.XMLDocument:O,o&&(f.dataType=\"xml\"),x.getResponseHeader=function(e){return{\"content-type\":f.dataType}[e.toLowerCase()]},u&&(x.status=Number(u.getAttribute(\"status\"))||x.status,x.statusText=u.getAttribute(\"statusText\")||x.statusText);var c=(f.dataType||\"\").toLowerCase(),l=/(json|script|text)/.test(c);if(l||f.textarea){var p=O.getElementsByTagName(\"textarea\")[0];if(p)x.responseText=p.value,x.status=Number(p.getAttribute(\"status\"))||x.status,x.statusText=p.getAttribute(\"statusText\")||x.statusText;else if(l){var m=O.getElementsByTagName(\"pre\")[0],g=O.getElementsByTagName(\"body\")[0];m?x.responseText=m.textContent?m.textContent:m.innerText:g&&(x.responseText=g.textContent?g.textContent:g.innerText)}}else\"xml\"===c&&!x.responseXML&&x.responseText&&(x.responseXML=q(x.responseText));try{M=N(x,c,f)}catch(e){i=\"parsererror\",x.error=r=e||i}}catch(e){a(\"error caught: \",e),i=\"error\",x.error=r=e||i}x.aborted&&(a(\"upload aborted\"),i=null),x.status&&(i=x.status>=200&&x.status<300||304===x.status?\"success\":\"error\"),\"success\"===i?(f.success&&f.success.call(f.context,M,\"success\",x),S.resolve(x.responseText,\"success\",x),d&&e.event.trigger(\"ajaxSuccess\",[x,f])):i&&(void 0===r&&(r=x.statusText),f.error&&f.error.call(f.context,x,i,r),S.reject(x,\"error\",r),d&&e.event.trigger(\"ajaxError\",[x,f,r])),d&&e.event.trigger(\"ajaxComplete\",[x,f]),d&&!--e.active&&e.event.trigger(\"ajaxStop\"),f.complete&&f.complete.call(f.context,x,i),X=!0,f.timeout&&clearTimeout(j),setTimeout(function(){f.iframeTarget?h.attr(\"src\",f.iframeSrc):h.remove(),x.responseXML=null},100)}}}var u,c,f,d,m,h,v,x,y,b,T,j,w=p[0],S=e.Deferred();if(S.abort=function(e){x.abort(e)},r)for(c=0;c<g.length;c++)u=e(g[c]),o?u.prop(\"disabled\",!1):u.removeAttr(\"disabled\");(f=e.extend(!0,{},e.ajaxSettings,t)).context=f.context||f,m=\"jqFormIO\"+(new Date).getTime();var k=w.ownerDocument,D=p.closest(\"body\");if(f.iframeTarget?(b=(h=e(f.iframeTarget,k)).attr2(\"name\"))?m=b:h.attr2(\"name\",m):(h=e('<iframe name=\"'+m+'\" src=\"'+f.iframeSrc+'\" />',k)).css({position:\"absolute\",top:\"-1000px\",left:\"-1000px\"}),v=h[0],x={aborted:0,responseText:null,responseXML:null,status:0,statusText:\"n/a\",getAllResponseHeaders:function(){},getResponseHeader:function(){},setRequestHeader:function(){},abort:function(t){var r=\"timeout\"===t?\"timeout\":\"aborted\";a(\"aborting upload... \"+r),this.aborted=1;try{v.contentWindow.document.execCommand&&v.contentWindow.document.execCommand(\"Stop\")}catch(e){}h.attr(\"src\",f.iframeSrc),x.error=r,f.error&&f.error.call(f.context,x,r,t),d&&e.event.trigger(\"ajaxError\",[x,f,r]),f.complete&&f.complete.call(f.context,x,r)}},(d=f.global)&&0==e.active++&&e.event.trigger(\"ajaxStart\"),d&&e.event.trigger(\"ajaxSend\",[x,f]),f.beforeSend&&!1===f.beforeSend.call(f.context,x,f))return f.global&&e.active--,S.reject(),S;if(x.aborted)return S.reject(),S;(y=w.clk)&&(b=y.name)&&!y.disabled&&(f.extraData=f.extraData||{},f.extraData[b]=y.value,\"image\"===y.type&&(f.extraData[b+\".x\"]=w.clk_x,f.extraData[b+\".y\"]=w.clk_y));var A=1,L=2,F=e(\"meta[name=csrf-token]\").attr(\"content\"),E=e(\"meta[name=csrf-param]\").attr(\"content\");E&&F&&(f.extraData=f.extraData||{},f.extraData[E]=F),f.forceSync?i():setTimeout(i,10);var M,O,X,C=50,q=e.parseXML||function(e,t){return window.ActiveXObject?((t=new ActiveXObject(\"Microsoft.XMLDOM\")).async=\"false\",t.loadXML(e)):t=(new DOMParser).parseFromString(e,\"text/xml\"),t&&t.documentElement&&\"parsererror\"!==t.documentElement.nodeName?t:null},_=e.parseJSON||function(e){return window.eval(\"(\"+e+\")\")},N=function(t,r,a){var n=t.getResponseHeader(\"content-type\")||\"\",i=(\"xml\"===r||!r)&&n.indexOf(\"xml\")>=0,o=i?t.responseXML:t.responseText;return i&&\"parsererror\"===o.documentElement.nodeName&&e.error&&e.error(\"parsererror\"),a&&a.dataFilter&&(o=a.dataFilter(o,r)),\"string\"==typeof o&&((\"json\"===r||!r)&&n.indexOf(\"json\")>=0?o=_(o):(\"script\"===r||!r)&&n.indexOf(\"javascript\")>=0&&e.globalEval(o)),o};return S}if(!this.length)return a(\"ajaxSubmit: skipping submit process - no element selected\"),this;var l,f,d,p=this;\"function\"==typeof t?t={success:t}:\"string\"==typeof t||!1===t&&arguments.length>0?(t={url:t,data:r,dataType:n},\"function\"==typeof s&&(t.success=s)):void 0===t&&(t={}),l=t.method||t.type||this.attr2(\"method\"),(d=(d=\"string\"==typeof(f=t.url||this.attr2(\"action\"))?e.trim(f):\"\")||window.location.href||\"\")&&(d=(d.match(/^([^#]+)/)||[])[1]),t=e.extend(!0,{url:d,success:e.ajaxSettings.success,type:l||e.ajaxSettings.type,iframeSrc:/^https/i.test(window.location.href||\"\")?\"javascript:false\":\"about:blank\"},t);var m={};if(this.trigger(\"form-pre-serialize\",[this,t,m]),m.veto)return a(\"ajaxSubmit: submit vetoed via form-pre-serialize trigger\"),this;if(t.beforeSerialize&&!1===t.beforeSerialize(this,t))return a(\"ajaxSubmit: submit aborted via beforeSerialize callback\"),this;var h=t.traditional;void 0===h&&(h=e.ajaxSettings.traditional);var v,g=[],x=this.formToArray(t.semantic,g,t.filtering);if(t.data){var y=e.isFunction(t.data)?t.data(x):t.data;t.extraData=y,v=e.param(y,h)}if(t.beforeSubmit&&!1===t.beforeSubmit(x,this,t))return a(\"ajaxSubmit: submit aborted via beforeSubmit callback\"),this;if(this.trigger(\"form-submit-validate\",[x,this,t,m]),m.veto)return a(\"ajaxSubmit: submit vetoed via form-submit-validate trigger\"),this;var b=e.param(x,h);v&&(b=b?b+\"&\"+v:v),\"GET\"===t.type.toUpperCase()?(t.url+=(t.url.indexOf(\"?\")>=0?\"&\":\"?\")+b,t.data=null):t.data=b;var T=[];if(t.resetForm&&T.push(function(){p.resetForm()}),t.clearForm&&T.push(function(){p.clearForm(t.includeHidden)}),!t.dataType&&t.target){var j=t.success||function(){};T.push(function(r,a,n){var i=arguments,o=t.replaceTarget?\"replaceWith\":\"html\";e(t.target)[o](r).each(function(){j.apply(this,i)})})}else t.success&&(e.isArray(t.success)?e.merge(T,t.success):T.push(t.success));if(t.success=function(e,r,a){for(var n=t.context||this,i=0,o=T.length;i<o;i++)T[i].apply(n,[e,r,a||p,p])},t.error){var w=t.error;t.error=function(e,r,a){var n=t.context||this;w.apply(n,[e,r,a,p])}}if(t.complete){var S=t.complete;t.complete=function(e,r){var a=t.context||this;S.apply(a,[e,r,p])}}var k=e(\"input[type=file]:enabled\",this).filter(function(){return\"\"!==e(this).val()}).length>0,D=\"multipart/form-data\",A=p.attr(\"enctype\")===D||p.attr(\"encoding\")===D,L=i.fileapi&&i.formdata;a(\"fileAPI :\"+L);var F,E=(k||A)&&!L;!1!==t.iframe&&(t.iframe||E)?t.closeKeepAlive?e.get(t.closeKeepAlive,function(){F=c(x)}):F=c(x):F=(k||A)&&L?function(r){for(var a=new FormData,n=0;n<r.length;n++)a.append(r[n].name,r[n].value);if(t.extraData){var i=u(t.extraData);for(n=0;n<i.length;n++)i[n]&&a.append(i[n][0],i[n][1])}t.data=null;var o=e.extend(!0,{},e.ajaxSettings,t,{contentType:!1,processData:!1,cache:!1,type:l||\"POST\"});t.uploadProgress&&(o.xhr=function(){var r=e.ajaxSettings.xhr();return r.upload&&r.upload.addEventListener(\"progress\",function(e){var r=0,a=e.loaded||e.position,n=e.total;e.lengthComputable&&(r=Math.ceil(a/n*100)),t.uploadProgress(e,a,n,r)},!1),r}),o.data=null;var s=o.beforeSend;return o.beforeSend=function(e,r){t.formData?r.data=t.formData:r.data=a,s&&s.call(this,e,r)},e.ajax(o)}(x):e.ajax(t),p.removeData(\"jqxhr\").data(\"jqxhr\",F);for(var M=0;M<g.length;M++)g[M]=null;return this.trigger(\"form-submit-notify\",[this,t]),this},e.fn.ajaxForm=function(n,i,o,s){if((\"string\"==typeof n||!1===n&&arguments.length>0)&&(n={url:n,data:i,dataType:o},\"function\"==typeof s&&(n.success=s)),n=n||{},n.delegation=n.delegation&&e.isFunction(e.fn.on),!n.delegation&&0===this.length){var u={s:this.selector,c:this.context};return!e.isReady&&u.s?(a(\"DOM not ready, queuing ajaxForm\"),e(function(){e(u.s,u.c).ajaxForm(n)}),this):(a(\"terminating; zero elements found by selector\"+(e.isReady?\"\":\" (DOM not ready)\")),this)}return n.delegation?(e(document).off(\"submit.form-plugin\",this.selector,t).off(\"click.form-plugin\",this.selector,r).on(\"submit.form-plugin\",this.selector,n,t).on(\"click.form-plugin\",this.selector,n,r),this):this.ajaxFormUnbind().on(\"submit.form-plugin\",n,t).on(\"click.form-plugin\",n,r)},e.fn.ajaxFormUnbind=function(){return this.off(\"submit.form-plugin click.form-plugin\")},e.fn.formToArray=function(t,r,a){var n=[];if(0===this.length)return n;var o,s=this[0],u=this.attr(\"id\"),c=t||void 0===s.elements?s.getElementsByTagName(\"*\"):s.elements;if(c&&(c=e.makeArray(c)),u&&(t||/(Edge|Trident)\\//.test(navigator.userAgent))&&(o=e(':input[form=\"'+u+'\"]').get()).length&&(c=(c||[]).concat(o)),!c||!c.length)return n;e.isFunction(a)&&(c=e.map(c,a));var l,f,d,p,m,h,v;for(l=0,h=c.length;l<h;l++)if(m=c[l],(d=m.name)&&!m.disabled)if(t&&s.clk&&\"image\"===m.type)s.clk===m&&(n.push({name:d,value:e(m).val(),type:m.type}),n.push({name:d+\".x\",value:s.clk_x},{name:d+\".y\",value:s.clk_y}));else if((p=e.fieldValue(m,!0))&&p.constructor===Array)for(r&&r.push(m),f=0,v=p.length;f<v;f++)n.push({name:d,value:p[f]});else if(i.fileapi&&\"file\"===m.type){r&&r.push(m);var g=m.files;if(g.length)for(f=0;f<g.length;f++)n.push({name:d,value:g[f],type:m.type});else n.push({name:d,value:\"\",type:m.type})}else null!==p&&void 0!==p&&(r&&r.push(m),n.push({name:d,value:p,type:m.type,required:m.required}));if(!t&&s.clk){var x=e(s.clk),y=x[0];(d=y.name)&&!y.disabled&&\"image\"===y.type&&(n.push({name:d,value:x.val()}),n.push({name:d+\".x\",value:s.clk_x},{name:d+\".y\",value:s.clk_y}))}return n},e.fn.formSerialize=function(t){return e.param(this.formToArray(t))},e.fn.fieldSerialize=function(t){var r=[];return this.each(function(){var a=this.name;if(a){var n=e.fieldValue(this,t);if(n&&n.constructor===Array)for(var i=0,o=n.length;i<o;i++)r.push({name:a,value:n[i]});else null!==n&&void 0!==n&&r.push({name:this.name,value:n})}}),e.param(r)},e.fn.fieldValue=function(t){for(var r=[],a=0,n=this.length;a<n;a++){var i=this[a],o=e.fieldValue(i,t);null===o||void 0===o||o.constructor===Array&&!o.length||(o.constructor===Array?e.merge(r,o):r.push(o))}return r},e.fieldValue=function(t,r){var a=t.name,i=t.type,o=t.tagName.toLowerCase();if(void 0===r&&(r=!0),r&&(!a||t.disabled||\"reset\"===i||\"button\"===i||(\"checkbox\"===i||\"radio\"===i)&&!t.checked||(\"submit\"===i||\"image\"===i)&&t.form&&t.form.clk!==t||\"select\"===o&&-1===t.selectedIndex))return null;if(\"select\"===o){var s=t.selectedIndex;if(s<0)return null;for(var u=[],c=t.options,l=\"select-one\"===i,f=l?s+1:c.length,d=l?s:0;d<f;d++){var p=c[d];if(p.selected&&!p.disabled){var m=p.value;if(m||(m=p.attributes&&p.attributes.value&&!p.attributes.value.specified?p.text:p.value),l)return m;u.push(m)}}return u}return e(t).val().replace(n,\"\\r\\n\")},e.fn.clearForm=function(t){return this.each(function(){e(\"input,select,textarea\",this).clearFields(t)})},e.fn.clearFields=e.fn.clearInputs=function(t){var r=/^(?:color|date|datetime|email|month|number|password|range|search|tel|text|time|url|week)$/i;return this.each(function(){var a=this.type,n=this.tagName.toLowerCase();r.test(a)||\"textarea\"===n?this.value=\"\":\"checkbox\"===a||\"radio\"===a?this.checked=!1:\"select\"===n?this.selectedIndex=-1:\"file\"===a?/MSIE/.test(navigator.userAgent)?e(this).replaceWith(e(this).clone(!0)):e(this).val(\"\"):t&&(!0===t&&/hidden/.test(a)||\"string\"==typeof t&&e(this).is(t))&&(this.value=\"\")})},e.fn.resetForm=function(){return this.each(function(){var t=e(this),r=this.tagName.toLowerCase();switch(r){case\"input\":this.checked=this.defaultChecked;case\"textarea\":return this.value=this.defaultValue,!0;case\"option\":case\"optgroup\":var a=t.parents(\"select\");return a.length&&a[0].multiple?\"option\"===r?this.selected=this.defaultSelected:t.find(\"option\").resetForm():a.resetForm(),!0;case\"select\":return t.find(\"option\").each(function(e){if(this.selected=this.defaultSelected,this.defaultSelected&&!t[0].multiple)return t[0].selectedIndex=e,!1}),!0;case\"label\":var n=e(t.attr(\"for\")),i=t.find(\"input,select,textarea\");return n[0]&&i.unshift(n[0]),i.resetForm(),!0;case\"form\":return(\"function\"==typeof this.reset||\"object\"==typeof this.reset&&!this.reset.nodeType)&&this.reset(),!0;default:return t.find(\"form,input,label,select,textarea\").resetForm(),!0}})},e.fn.enable=function(e){return void 0===e&&(e=!0),this.each(function(){this.disabled=!e})},e.fn.selected=function(t){return void 0===t&&(t=!0),this.each(function(){var r=this.type;if(\"checkbox\"===r||\"radio\"===r)this.checked=t;else if(\"option\"===this.tagName.toLowerCase()){var a=e(this).parent(\"select\");t&&a[0]&&\"select-one\"===a[0].type&&a.find(\"option\").selected(!1),this.selected=t}})},e.fn.ajaxSubmit.debug=!1});\n//# sourceMappingURL=jquery.form.min.js.map\n","/**\n * Node.js module for Forge.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2016 Digital Bazaar, Inc.\n */\nmodule.exports = require('./forge');\nrequire('./aes');\nrequire('./aesCipherSuites');\nrequire('./asn1');\nrequire('./cipher');\nrequire('./debug');\nrequire('./des');\nrequire('./ed25519');\nrequire('./hmac');\nrequire('./kem');\nrequire('./log');\nrequire('./md.all');\nrequire('./mgf1');\nrequire('./pbkdf2');\nrequire('./pem');\nrequire('./pkcs1');\nrequire('./pkcs12');\nrequire('./pkcs7');\nrequire('./pki');\nrequire('./prime');\nrequire('./prng');\nrequire('./pss');\nrequire('./random');\nrequire('./rc2');\nrequire('./ssh');\nrequire('./task');\nrequire('./tls');\nrequire('./util');\n","var scope = (typeof global !== \"undefined\" && global) ||\n (typeof self !== \"undefined\" && self) ||\n window;\nvar apply = Function.prototype.apply;\n\n// DOM APIs, for completeness\n\nexports.setTimeout = function() {\n return new Timeout(apply.call(setTimeout, scope, arguments), clearTimeout);\n};\nexports.setInterval = function() {\n return new Timeout(apply.call(setInterval, scope, arguments), clearInterval);\n};\nexports.clearTimeout =\nexports.clearInterval = function(timeout) {\n if (timeout) {\n timeout.close();\n }\n};\n\nfunction Timeout(id, clearFn) {\n this._id = id;\n this._clearFn = clearFn;\n}\nTimeout.prototype.unref = Timeout.prototype.ref = function() {};\nTimeout.prototype.close = function() {\n this._clearFn.call(scope, this._id);\n};\n\n// Does not start the time, just sets up the members needed.\nexports.enroll = function(item, msecs) {\n clearTimeout(item._idleTimeoutId);\n item._idleTimeout = msecs;\n};\n\nexports.unenroll = function(item) {\n clearTimeout(item._idleTimeoutId);\n item._idleTimeout = -1;\n};\n\nexports._unrefActive = exports.active = function(item) {\n clearTimeout(item._idleTimeoutId);\n\n var msecs = item._idleTimeout;\n if (msecs >= 0) {\n item._idleTimeoutId = setTimeout(function onTimeout() {\n if (item._onTimeout)\n item._onTimeout();\n }, msecs);\n }\n};\n\n// setimmediate attaches itself to the global object\nrequire(\"setimmediate\");\n// On some exotic environments, it's not clear which object `setimmediate` was\n// able to install onto. Search each possibility in the same order as the\n// `setimmediate` library.\nexports.setImmediate = (typeof self !== \"undefined\" && self.setImmediate) ||\n (typeof global !== \"undefined\" && global.setImmediate) ||\n (this && this.setImmediate);\nexports.clearImmediate = (typeof self !== \"undefined\" && self.clearImmediate) ||\n (typeof global !== \"undefined\" && global.clearImmediate) ||\n (this && this.clearImmediate);\n","(function (global, undefined) {\n \"use strict\";\n\n if (global.setImmediate) {\n return;\n }\n\n var nextHandle = 1; // Spec says greater than zero\n var tasksByHandle = {};\n var currentlyRunningATask = false;\n var doc = global.document;\n var registerImmediate;\n\n function setImmediate(callback) {\n // Callback can either be a function or a string\n if (typeof callback !== \"function\") {\n callback = new Function(\"\" + callback);\n }\n // Copy function arguments\n var args = new Array(arguments.length - 1);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 1];\n }\n // Store and register the task\n var task = { callback: callback, args: args };\n tasksByHandle[nextHandle] = task;\n registerImmediate(nextHandle);\n return nextHandle++;\n }\n\n function clearImmediate(handle) {\n delete tasksByHandle[handle];\n }\n\n function run(task) {\n var callback = task.callback;\n var args = task.args;\n switch (args.length) {\n case 0:\n callback();\n break;\n case 1:\n callback(args[0]);\n break;\n case 2:\n callback(args[0], args[1]);\n break;\n case 3:\n callback(args[0], args[1], args[2]);\n break;\n default:\n callback.apply(undefined, args);\n break;\n }\n }\n\n function runIfPresent(handle) {\n // From the spec: \"Wait until any invocations of this algorithm started before this one have completed.\"\n // So if we're currently running a task, we'll need to delay this invocation.\n if (currentlyRunningATask) {\n // Delay by doing a setTimeout. setImmediate was tried instead, but in Firefox 7 it generated a\n // \"too much recursion\" error.\n setTimeout(runIfPresent, 0, handle);\n } else {\n var task = tasksByHandle[handle];\n if (task) {\n currentlyRunningATask = true;\n try {\n run(task);\n } finally {\n clearImmediate(handle);\n currentlyRunningATask = false;\n }\n }\n }\n }\n\n function installNextTickImplementation() {\n registerImmediate = function(handle) {\n process.nextTick(function () { runIfPresent(handle); });\n };\n }\n\n function canUsePostMessage() {\n // The test against `importScripts` prevents this implementation from being installed inside a web worker,\n // where `global.postMessage` means something completely different and can't be used for this purpose.\n if (global.postMessage && !global.importScripts) {\n var postMessageIsAsynchronous = true;\n var oldOnMessage = global.onmessage;\n global.onmessage = function() {\n postMessageIsAsynchronous = false;\n };\n global.postMessage(\"\", \"*\");\n global.onmessage = oldOnMessage;\n return postMessageIsAsynchronous;\n }\n }\n\n function installPostMessageImplementation() {\n // Installs an event handler on `global` for the `message` event: see\n // * https://developer.mozilla.org/en/DOM/window.postMessage\n // * http://www.whatwg.org/specs/web-apps/current-work/multipage/comms.html#crossDocumentMessages\n\n var messagePrefix = \"setImmediate$\" + Math.random() + \"$\";\n var onGlobalMessage = function(event) {\n if (event.source === global &&\n typeof event.data === \"string\" &&\n event.data.indexOf(messagePrefix) === 0) {\n runIfPresent(+event.data.slice(messagePrefix.length));\n }\n };\n\n if (global.addEventListener) {\n global.addEventListener(\"message\", onGlobalMessage, false);\n } else {\n global.attachEvent(\"onmessage\", onGlobalMessage);\n }\n\n registerImmediate = function(handle) {\n global.postMessage(messagePrefix + handle, \"*\");\n };\n }\n\n function installMessageChannelImplementation() {\n var channel = new MessageChannel();\n channel.port1.onmessage = function(event) {\n var handle = event.data;\n runIfPresent(handle);\n };\n\n registerImmediate = function(handle) {\n channel.port2.postMessage(handle);\n };\n }\n\n function installReadyStateChangeImplementation() {\n var html = doc.documentElement;\n registerImmediate = function(handle) {\n // Create a <script> element; its readystatechange event will be fired asynchronously once it is inserted\n // into the document. Do so, thus queuing up the task. Remember to clean up once it's been called.\n var script = doc.createElement(\"script\");\n script.onreadystatechange = function () {\n runIfPresent(handle);\n script.onreadystatechange = null;\n html.removeChild(script);\n script = null;\n };\n html.appendChild(script);\n };\n }\n\n function installSetTimeoutImplementation() {\n registerImmediate = function(handle) {\n setTimeout(runIfPresent, 0, handle);\n };\n }\n\n // If supported, we should attach to the prototype of global, since that is where setTimeout et al. live.\n var attachTo = Object.getPrototypeOf && Object.getPrototypeOf(global);\n attachTo = attachTo && attachTo.setTimeout ? attachTo : global;\n\n // Don't get fooled by e.g. browserify environments.\n if ({}.toString.call(global.process) === \"[object process]\") {\n // For Node.js before 0.9\n installNextTickImplementation();\n\n } else if (canUsePostMessage()) {\n // For non-IE10 modern browsers\n installPostMessageImplementation();\n\n } else if (global.MessageChannel) {\n // For web workers, where supported\n installMessageChannelImplementation();\n\n } else if (doc && \"onreadystatechange\" in doc.createElement(\"script\")) {\n // For IE 6–8\n installReadyStateChangeImplementation();\n\n } else {\n // For older browsers\n installSetTimeoutImplementation();\n }\n\n attachTo.setImmediate = setImmediate;\n attachTo.clearImmediate = clearImmediate;\n}(typeof self === \"undefined\" ? typeof global === \"undefined\" ? this : global : self));\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(\n uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)\n ))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n return toString.call(arr) == '[object Array]';\n};\n","/**\n * Base-N/Base-X encoding/decoding functions.\n *\n * Original implementation from base-x:\n * https://github.com/cryptocoinjs/base-x\n *\n * Which is MIT licensed:\n *\n * The MIT License (MIT)\n *\n * Copyright base-x contributors (c) 2016\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING\n * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER\n * DEALINGS IN THE SOFTWARE.\n */\nvar api = {};\nmodule.exports = api;\n\n// baseN alphabet indexes\nvar _reverseAlphabets = {};\n\n/**\n * BaseN-encodes a Uint8Array using the given alphabet.\n *\n * @param input the Uint8Array to encode.\n * @param maxline the maximum number of encoded characters per line to use,\n * defaults to none.\n *\n * @return the baseN-encoded output string.\n */\napi.encode = function(input, alphabet, maxline) {\n if(typeof alphabet !== 'string') {\n throw new TypeError('\"alphabet\" must be a string.');\n }\n if(maxline !== undefined && typeof maxline !== 'number') {\n throw new TypeError('\"maxline\" must be a number.');\n }\n\n var output = '';\n\n if(!(input instanceof Uint8Array)) {\n // assume forge byte buffer\n output = _encodeWithByteBuffer(input, alphabet);\n } else {\n var i = 0;\n var base = alphabet.length;\n var first = alphabet.charAt(0);\n var digits = [0];\n for(i = 0; i < input.length; ++i) {\n for(var j = 0, carry = input[i]; j < digits.length; ++j) {\n carry += digits[j] << 8;\n digits[j] = carry % base;\n carry = (carry / base) | 0;\n }\n\n while(carry > 0) {\n digits.push(carry % base);\n carry = (carry / base) | 0;\n }\n }\n\n // deal with leading zeros\n for(i = 0; input[i] === 0 && i < input.length - 1; ++i) {\n output += first;\n }\n // convert digits to a string\n for(i = digits.length - 1; i >= 0; --i) {\n output += alphabet[digits[i]];\n }\n }\n\n if(maxline) {\n var regex = new RegExp('.{1,' + maxline + '}', 'g');\n output = output.match(regex).join('\\r\\n');\n }\n\n return output;\n};\n\n/**\n * Decodes a baseN-encoded (using the given alphabet) string to a\n * Uint8Array.\n *\n * @param input the baseN-encoded input string.\n *\n * @return the Uint8Array.\n */\napi.decode = function(input, alphabet) {\n if(typeof input !== 'string') {\n throw new TypeError('\"input\" must be a string.');\n }\n if(typeof alphabet !== 'string') {\n throw new TypeError('\"alphabet\" must be a string.');\n }\n\n var table = _reverseAlphabets[alphabet];\n if(!table) {\n // compute reverse alphabet\n table = _reverseAlphabets[alphabet] = [];\n for(var i = 0; i < alphabet.length; ++i) {\n table[alphabet.charCodeAt(i)] = i;\n }\n }\n\n // remove whitespace characters\n input = input.replace(/\\s/g, '');\n\n var base = alphabet.length;\n var first = alphabet.charAt(0);\n var bytes = [0];\n for(var i = 0; i < input.length; i++) {\n var value = table[input.charCodeAt(i)];\n if(value === undefined) {\n return;\n }\n\n for(var j = 0, carry = value; j < bytes.length; ++j) {\n carry += bytes[j] * base;\n bytes[j] = carry & 0xff;\n carry >>= 8;\n }\n\n while(carry > 0) {\n bytes.push(carry & 0xff);\n carry >>= 8;\n }\n }\n\n // deal with leading zeros\n for(var k = 0; input[k] === first && k < input.length - 1; ++k) {\n bytes.push(0);\n }\n\n if(typeof Buffer !== 'undefined') {\n return Buffer.from(bytes.reverse());\n }\n\n return new Uint8Array(bytes.reverse());\n};\n\nfunction _encodeWithByteBuffer(input, alphabet) {\n var i = 0;\n var base = alphabet.length;\n var first = alphabet.charAt(0);\n var digits = [0];\n for(i = 0; i < input.length(); ++i) {\n for(var j = 0, carry = input.at(i); j < digits.length; ++j) {\n carry += digits[j] << 8;\n digits[j] = carry % base;\n carry = (carry / base) | 0;\n }\n\n while(carry > 0) {\n digits.push(carry % base);\n carry = (carry / base) | 0;\n }\n }\n\n var output = '';\n\n // deal with leading zeros\n for(i = 0; input.at(i) === 0 && i < input.length() - 1; ++i) {\n output += first;\n }\n // convert digits to a string\n for(i = digits.length - 1; i >= 0; --i) {\n output += alphabet[digits[i]];\n }\n\n return output;\n}\n","/**\n * A Javascript implementation of AES Cipher Suites for TLS.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2009-2015 Digital Bazaar, Inc.\n *\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./tls');\n\nvar tls = module.exports = forge.tls;\n\n/**\n * Supported cipher suites.\n */\ntls.CipherSuites['TLS_RSA_WITH_AES_128_CBC_SHA'] = {\n id: [0x00, 0x2f],\n name: 'TLS_RSA_WITH_AES_128_CBC_SHA',\n initSecurityParameters: function(sp) {\n sp.bulk_cipher_algorithm = tls.BulkCipherAlgorithm.aes;\n sp.cipher_type = tls.CipherType.block;\n sp.enc_key_length = 16;\n sp.block_length = 16;\n sp.fixed_iv_length = 16;\n sp.record_iv_length = 16;\n sp.mac_algorithm = tls.MACAlgorithm.hmac_sha1;\n sp.mac_length = 20;\n sp.mac_key_length = 20;\n },\n initConnectionState: initConnectionState\n};\ntls.CipherSuites['TLS_RSA_WITH_AES_256_CBC_SHA'] = {\n id: [0x00, 0x35],\n name: 'TLS_RSA_WITH_AES_256_CBC_SHA',\n initSecurityParameters: function(sp) {\n sp.bulk_cipher_algorithm = tls.BulkCipherAlgorithm.aes;\n sp.cipher_type = tls.CipherType.block;\n sp.enc_key_length = 32;\n sp.block_length = 16;\n sp.fixed_iv_length = 16;\n sp.record_iv_length = 16;\n sp.mac_algorithm = tls.MACAlgorithm.hmac_sha1;\n sp.mac_length = 20;\n sp.mac_key_length = 20;\n },\n initConnectionState: initConnectionState\n};\n\nfunction initConnectionState(state, c, sp) {\n var client = (c.entity === forge.tls.ConnectionEnd.client);\n\n // cipher setup\n state.read.cipherState = {\n init: false,\n cipher: forge.cipher.createDecipher('AES-CBC', client ?\n sp.keys.server_write_key : sp.keys.client_write_key),\n iv: client ? sp.keys.server_write_IV : sp.keys.client_write_IV\n };\n state.write.cipherState = {\n init: false,\n cipher: forge.cipher.createCipher('AES-CBC', client ?\n sp.keys.client_write_key : sp.keys.server_write_key),\n iv: client ? sp.keys.client_write_IV : sp.keys.server_write_IV\n };\n state.read.cipherFunction = decrypt_aes_cbc_sha1;\n state.write.cipherFunction = encrypt_aes_cbc_sha1;\n\n // MAC setup\n state.read.macLength = state.write.macLength = sp.mac_length;\n state.read.macFunction = state.write.macFunction = tls.hmac_sha1;\n}\n\n/**\n * Encrypts the TLSCompressed record into a TLSCipherText record using AES\n * in CBC mode.\n *\n * @param record the TLSCompressed record to encrypt.\n * @param s the ConnectionState to use.\n *\n * @return true on success, false on failure.\n */\nfunction encrypt_aes_cbc_sha1(record, s) {\n var rval = false;\n\n // append MAC to fragment, update sequence number\n var mac = s.macFunction(s.macKey, s.sequenceNumber, record);\n record.fragment.putBytes(mac);\n s.updateSequenceNumber();\n\n // TLS 1.1+ use an explicit IV every time to protect against CBC attacks\n var iv;\n if(record.version.minor === tls.Versions.TLS_1_0.minor) {\n // use the pre-generated IV when initializing for TLS 1.0, otherwise use\n // the residue from the previous encryption\n iv = s.cipherState.init ? null : s.cipherState.iv;\n } else {\n iv = forge.random.getBytesSync(16);\n }\n\n s.cipherState.init = true;\n\n // start cipher\n var cipher = s.cipherState.cipher;\n cipher.start({iv: iv});\n\n // TLS 1.1+ write IV into output\n if(record.version.minor >= tls.Versions.TLS_1_1.minor) {\n cipher.output.putBytes(iv);\n }\n\n // do encryption (default padding is appropriate)\n cipher.update(record.fragment);\n if(cipher.finish(encrypt_aes_cbc_sha1_padding)) {\n // set record fragment to encrypted output\n record.fragment = cipher.output;\n record.length = record.fragment.length();\n rval = true;\n }\n\n return rval;\n}\n\n/**\n * Handles padding for aes_cbc_sha1 in encrypt mode.\n *\n * @param blockSize the block size.\n * @param input the input buffer.\n * @param decrypt true in decrypt mode, false in encrypt mode.\n *\n * @return true on success, false on failure.\n */\nfunction encrypt_aes_cbc_sha1_padding(blockSize, input, decrypt) {\n /* The encrypted data length (TLSCiphertext.length) is one more than the sum\n of SecurityParameters.block_length, TLSCompressed.length,\n SecurityParameters.mac_length, and padding_length.\n\n The padding may be any length up to 255 bytes long, as long as it results in\n the TLSCiphertext.length being an integral multiple of the block length.\n Lengths longer than necessary might be desirable to frustrate attacks on a\n protocol based on analysis of the lengths of exchanged messages. Each uint8\n in the padding data vector must be filled with the padding length value.\n\n The padding length should be such that the total size of the\n GenericBlockCipher structure is a multiple of the cipher's block length.\n Legal values range from zero to 255, inclusive. This length specifies the\n length of the padding field exclusive of the padding_length field itself.\n\n This is slightly different from PKCS#7 because the padding value is 1\n less than the actual number of padding bytes if you include the\n padding_length uint8 itself as a padding byte. */\n if(!decrypt) {\n // get the number of padding bytes required to reach the blockSize and\n // subtract 1 for the padding value (to make room for the padding_length\n // uint8)\n var padding = blockSize - (input.length() % blockSize);\n input.fillWithByte(padding - 1, padding);\n }\n return true;\n}\n\n/**\n * Handles padding for aes_cbc_sha1 in decrypt mode.\n *\n * @param blockSize the block size.\n * @param output the output buffer.\n * @param decrypt true in decrypt mode, false in encrypt mode.\n *\n * @return true on success, false on failure.\n */\nfunction decrypt_aes_cbc_sha1_padding(blockSize, output, decrypt) {\n var rval = true;\n if(decrypt) {\n /* The last byte in the output specifies the number of padding bytes not\n including itself. Each of the padding bytes has the same value as that\n last byte (known as the padding_length). Here we check all padding\n bytes to ensure they have the value of padding_length even if one of\n them is bad in order to ward-off timing attacks. */\n var len = output.length();\n var paddingLength = output.last();\n for(var i = len - 1 - paddingLength; i < len - 1; ++i) {\n rval = rval && (output.at(i) == paddingLength);\n }\n if(rval) {\n // trim off padding bytes and last padding length byte\n output.truncate(paddingLength + 1);\n }\n }\n return rval;\n}\n\n/**\n * Decrypts a TLSCipherText record into a TLSCompressed record using\n * AES in CBC mode.\n *\n * @param record the TLSCipherText record to decrypt.\n * @param s the ConnectionState to use.\n *\n * @return true on success, false on failure.\n */\nfunction decrypt_aes_cbc_sha1(record, s) {\n var rval = false;\n\n var iv;\n if(record.version.minor === tls.Versions.TLS_1_0.minor) {\n // use pre-generated IV when initializing for TLS 1.0, otherwise use the\n // residue from the previous decryption\n iv = s.cipherState.init ? null : s.cipherState.iv;\n } else {\n // TLS 1.1+ use an explicit IV every time to protect against CBC attacks\n // that is appended to the record fragment\n iv = record.fragment.getBytes(16);\n }\n\n s.cipherState.init = true;\n\n // start cipher\n var cipher = s.cipherState.cipher;\n cipher.start({iv: iv});\n\n // do decryption\n cipher.update(record.fragment);\n rval = cipher.finish(decrypt_aes_cbc_sha1_padding);\n\n // even if decryption fails, keep going to minimize timing attacks\n\n // decrypted data:\n // first (len - 20) bytes = application data\n // last 20 bytes = MAC\n var macLen = s.macLength;\n\n // create a random MAC to check against should the mac length check fail\n // Note: do this regardless of the failure to keep timing consistent\n var mac = forge.random.getBytesSync(macLen);\n\n // get fragment and mac\n var len = cipher.output.length();\n if(len >= macLen) {\n record.fragment = cipher.output.getBytes(len - macLen);\n mac = cipher.output.getBytes(macLen);\n } else {\n // bad data, but get bytes anyway to try to keep timing consistent\n record.fragment = cipher.output.getBytes();\n }\n record.fragment = forge.util.createBuffer(record.fragment);\n record.length = record.fragment.length();\n\n // see if data integrity checks out, update sequence number\n var mac2 = s.macFunction(s.macKey, s.sequenceNumber, record);\n s.updateSequenceNumber();\n rval = compareMacs(s.macKey, mac, mac2) && rval;\n return rval;\n}\n\n/**\n * Safely compare two MACs. This function will compare two MACs in a way\n * that protects against timing attacks.\n *\n * TODO: Expose elsewhere as a utility API.\n *\n * See: https://www.nccgroup.trust/us/about-us/newsroom-and-events/blog/2011/february/double-hmac-verification/\n *\n * @param key the MAC key to use.\n * @param mac1 as a binary-encoded string of bytes.\n * @param mac2 as a binary-encoded string of bytes.\n *\n * @return true if the MACs are the same, false if not.\n */\nfunction compareMacs(key, mac1, mac2) {\n var hmac = forge.hmac.create();\n\n hmac.start('SHA1', key);\n hmac.update(mac1);\n mac1 = hmac.digest().getBytes();\n\n hmac.start(null, null);\n hmac.update(mac2);\n mac2 = hmac.digest().getBytes();\n\n return mac1 === mac2;\n}\n","/**\n * Node.js module for Forge mask generation functions.\n *\n * @author Stefan Siegl\n *\n * Copyright 2012 Stefan Siegl <stesie@brokenpipe.de>\n */\nvar forge = require('./forge');\nrequire('./mgf1');\n\nmodule.exports = forge.mgf = forge.mgf || {};\nforge.mgf.mgf1 = forge.mgf1;\n","/**\n * JavaScript implementation of Ed25519.\n *\n * Copyright (c) 2017-2019 Digital Bazaar, Inc.\n *\n * This implementation is based on the most excellent TweetNaCl which is\n * in the public domain. Many thanks to its contributors:\n *\n * https://github.com/dchest/tweetnacl-js\n */\nvar forge = require('./forge');\nrequire('./jsbn');\nrequire('./random');\nrequire('./sha512');\nrequire('./util');\nvar asn1Validator = require('./asn1-validator');\nvar publicKeyValidator = asn1Validator.publicKeyValidator;\nvar privateKeyValidator = asn1Validator.privateKeyValidator;\n\nif(typeof BigInteger === 'undefined') {\n var BigInteger = forge.jsbn.BigInteger;\n}\n\nvar ByteBuffer = forge.util.ByteBuffer;\nvar NativeBuffer = typeof Buffer === 'undefined' ? Uint8Array : Buffer;\n\n/*\n * Ed25519 algorithms, see RFC 8032:\n * https://tools.ietf.org/html/rfc8032\n */\nforge.pki = forge.pki || {};\nmodule.exports = forge.pki.ed25519 = forge.ed25519 = forge.ed25519 || {};\nvar ed25519 = forge.ed25519;\n\ned25519.constants = {};\ned25519.constants.PUBLIC_KEY_BYTE_LENGTH = 32;\ned25519.constants.PRIVATE_KEY_BYTE_LENGTH = 64;\ned25519.constants.SEED_BYTE_LENGTH = 32;\ned25519.constants.SIGN_BYTE_LENGTH = 64;\ned25519.constants.HASH_BYTE_LENGTH = 64;\n\ned25519.generateKeyPair = function(options) {\n options = options || {};\n var seed = options.seed;\n if(seed === undefined) {\n // generate seed\n seed = forge.random.getBytesSync(ed25519.constants.SEED_BYTE_LENGTH);\n } else if(typeof seed === 'string') {\n if(seed.length !== ed25519.constants.SEED_BYTE_LENGTH) {\n throw new TypeError(\n '\"seed\" must be ' + ed25519.constants.SEED_BYTE_LENGTH +\n ' bytes in length.');\n }\n } else if(!(seed instanceof Uint8Array)) {\n throw new TypeError(\n '\"seed\" must be a node.js Buffer, Uint8Array, or a binary string.');\n }\n\n seed = messageToNativeBuffer({message: seed, encoding: 'binary'});\n\n var pk = new NativeBuffer(ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n var sk = new NativeBuffer(ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n for(var i = 0; i < 32; ++i) {\n sk[i] = seed[i];\n }\n crypto_sign_keypair(pk, sk);\n return {publicKey: pk, privateKey: sk};\n};\n\n/**\n * Converts a private key from a RFC8410 ASN.1 encoding.\n *\n * @param obj - The asn1 representation of a private key.\n *\n * @returns {Object} keyInfo - The key information.\n * @returns {Buffer|Uint8Array} keyInfo.privateKeyBytes - 32 private key bytes.\n */\ned25519.privateKeyFromAsn1 = function(obj) {\n var capture = {};\n var errors = [];\n var valid = forge.asn1.validate(obj, privateKeyValidator, capture, errors);\n if(!valid) {\n var error = new Error('Invalid Key.');\n error.errors = errors;\n throw error;\n }\n var oid = forge.asn1.derToOid(capture.privateKeyOid);\n var ed25519Oid = forge.oids.EdDSA25519;\n if(oid !== ed25519Oid) {\n throw new Error('Invalid OID \"' + oid + '\"; OID must be \"' +\n ed25519Oid + '\".');\n }\n var privateKey = capture.privateKey;\n // manually extract the private key bytes from nested octet string, see FIXME:\n // https://github.com/digitalbazaar/forge/blob/master/lib/asn1.js#L542\n var privateKeyBytes = messageToNativeBuffer({\n message: forge.asn1.fromDer(privateKey).value,\n encoding: 'binary'\n });\n // TODO: RFC8410 specifies a format for encoding the public key bytes along\n // with the private key bytes. `publicKeyBytes` can be returned in the\n // future. https://tools.ietf.org/html/rfc8410#section-10.3\n return {privateKeyBytes: privateKeyBytes};\n};\n\n/**\n * Converts a public key from a RFC8410 ASN.1 encoding.\n *\n * @param obj - The asn1 representation of a public key.\n *\n * @return {Buffer|Uint8Array} - 32 public key bytes.\n */\ned25519.publicKeyFromAsn1 = function(obj) {\n // get SubjectPublicKeyInfo\n var capture = {};\n var errors = [];\n var valid = forge.asn1.validate(obj, publicKeyValidator, capture, errors);\n if(!valid) {\n var error = new Error('Invalid Key.');\n error.errors = errors;\n throw error;\n }\n var oid = forge.asn1.derToOid(capture.publicKeyOid);\n var ed25519Oid = forge.oids.EdDSA25519;\n if(oid !== ed25519Oid) {\n throw new Error('Invalid OID \"' + oid + '\"; OID must be \"' +\n ed25519Oid + '\".');\n }\n var publicKeyBytes = capture.ed25519PublicKey;\n if(publicKeyBytes.length !== ed25519.constants.PUBLIC_KEY_BYTE_LENGTH) {\n throw new Error('Key length is invalid.');\n }\n return messageToNativeBuffer({\n message: publicKeyBytes,\n encoding: 'binary'\n });\n};\n\ned25519.publicKeyFromPrivateKey = function(options) {\n options = options || {};\n var privateKey = messageToNativeBuffer({\n message: options.privateKey, encoding: 'binary'\n });\n if(privateKey.length !== ed25519.constants.PRIVATE_KEY_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.privateKey\" must have a byte length of ' +\n ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n }\n\n var pk = new NativeBuffer(ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n for(var i = 0; i < pk.length; ++i) {\n pk[i] = privateKey[32 + i];\n }\n return pk;\n};\n\ned25519.sign = function(options) {\n options = options || {};\n var msg = messageToNativeBuffer(options);\n var privateKey = messageToNativeBuffer({\n message: options.privateKey,\n encoding: 'binary'\n });\n if(privateKey.length === ed25519.constants.SEED_BYTE_LENGTH) {\n var keyPair = ed25519.generateKeyPair({seed: privateKey});\n privateKey = keyPair.privateKey;\n } else if(privateKey.length !== ed25519.constants.PRIVATE_KEY_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.privateKey\" must have a byte length of ' +\n ed25519.constants.SEED_BYTE_LENGTH + ' or ' +\n ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n }\n\n var signedMsg = new NativeBuffer(\n ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n crypto_sign(signedMsg, msg, msg.length, privateKey);\n\n var sig = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH);\n for(var i = 0; i < sig.length; ++i) {\n sig[i] = signedMsg[i];\n }\n return sig;\n};\n\ned25519.verify = function(options) {\n options = options || {};\n var msg = messageToNativeBuffer(options);\n if(options.signature === undefined) {\n throw new TypeError(\n '\"options.signature\" must be a node.js Buffer, a Uint8Array, a forge ' +\n 'ByteBuffer, or a binary string.');\n }\n var sig = messageToNativeBuffer({\n message: options.signature,\n encoding: 'binary'\n });\n if(sig.length !== ed25519.constants.SIGN_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.signature\" must have a byte length of ' +\n ed25519.constants.SIGN_BYTE_LENGTH);\n }\n var publicKey = messageToNativeBuffer({\n message: options.publicKey,\n encoding: 'binary'\n });\n if(publicKey.length !== ed25519.constants.PUBLIC_KEY_BYTE_LENGTH) {\n throw new TypeError(\n '\"options.publicKey\" must have a byte length of ' +\n ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n }\n\n var sm = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n var m = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n var i;\n for(i = 0; i < ed25519.constants.SIGN_BYTE_LENGTH; ++i) {\n sm[i] = sig[i];\n }\n for(i = 0; i < msg.length; ++i) {\n sm[i + ed25519.constants.SIGN_BYTE_LENGTH] = msg[i];\n }\n return (crypto_sign_open(m, sm, sm.length, publicKey) >= 0);\n};\n\nfunction messageToNativeBuffer(options) {\n var message = options.message;\n if(message instanceof Uint8Array || message instanceof NativeBuffer) {\n return message;\n }\n\n var encoding = options.encoding;\n if(message === undefined) {\n if(options.md) {\n // TODO: more rigorous validation that `md` is a MessageDigest\n message = options.md.digest().getBytes();\n encoding = 'binary';\n } else {\n throw new TypeError('\"options.message\" or \"options.md\" not specified.');\n }\n }\n\n if(typeof message === 'string' && !encoding) {\n throw new TypeError('\"options.encoding\" must be \"binary\" or \"utf8\".');\n }\n\n if(typeof message === 'string') {\n if(typeof Buffer !== 'undefined') {\n return Buffer.from(message, encoding);\n }\n message = new ByteBuffer(message, encoding);\n } else if(!(message instanceof ByteBuffer)) {\n throw new TypeError(\n '\"options.message\" must be a node.js Buffer, a Uint8Array, a forge ' +\n 'ByteBuffer, or a string with \"options.encoding\" specifying its ' +\n 'encoding.');\n }\n\n // convert to native buffer\n var buffer = new NativeBuffer(message.length());\n for(var i = 0; i < buffer.length; ++i) {\n buffer[i] = message.at(i);\n }\n return buffer;\n}\n\nvar gf0 = gf();\nvar gf1 = gf([1]);\nvar D = gf([\n 0x78a3, 0x1359, 0x4dca, 0x75eb, 0xd8ab, 0x4141, 0x0a4d, 0x0070,\n 0xe898, 0x7779, 0x4079, 0x8cc7, 0xfe73, 0x2b6f, 0x6cee, 0x5203]);\nvar D2 = gf([\n 0xf159, 0x26b2, 0x9b94, 0xebd6, 0xb156, 0x8283, 0x149a, 0x00e0,\n 0xd130, 0xeef3, 0x80f2, 0x198e, 0xfce7, 0x56df, 0xd9dc, 0x2406]);\nvar X = gf([\n 0xd51a, 0x8f25, 0x2d60, 0xc956, 0xa7b2, 0x9525, 0xc760, 0x692c,\n 0xdc5c, 0xfdd6, 0xe231, 0xc0a4, 0x53fe, 0xcd6e, 0x36d3, 0x2169]);\nvar Y = gf([\n 0x6658, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666,\n 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666]);\nvar L = new Float64Array([\n 0xed, 0xd3, 0xf5, 0x5c, 0x1a, 0x63, 0x12, 0x58,\n 0xd6, 0x9c, 0xf7, 0xa2, 0xde, 0xf9, 0xde, 0x14,\n 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x10]);\nvar I = gf([\n 0xa0b0, 0x4a0e, 0x1b27, 0xc4ee, 0xe478, 0xad2f, 0x1806, 0x2f43,\n 0xd7a7, 0x3dfb, 0x0099, 0x2b4d, 0xdf0b, 0x4fc1, 0x2480, 0x2b83]);\n\n// TODO: update forge buffer implementation to use `Buffer` or `Uint8Array`,\n// whichever is available, to improve performance\nfunction sha512(msg, msgLen) {\n // Note: `out` and `msg` are NativeBuffer\n var md = forge.md.sha512.create();\n var buffer = new ByteBuffer(msg);\n md.update(buffer.getBytes(msgLen), 'binary');\n var hash = md.digest().getBytes();\n if(typeof Buffer !== 'undefined') {\n return Buffer.from(hash, 'binary');\n }\n var out = new NativeBuffer(ed25519.constants.HASH_BYTE_LENGTH);\n for(var i = 0; i < 64; ++i) {\n out[i] = hash.charCodeAt(i);\n }\n return out;\n}\n\nfunction crypto_sign_keypair(pk, sk) {\n var p = [gf(), gf(), gf(), gf()];\n var i;\n\n var d = sha512(sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n\n scalarbase(p, d);\n pack(pk, p);\n\n for(i = 0; i < 32; ++i) {\n sk[i + 32] = pk[i];\n }\n return 0;\n}\n\n// Note: difference from C - smlen returned, not passed as argument.\nfunction crypto_sign(sm, m, n, sk) {\n var i, j, x = new Float64Array(64);\n var p = [gf(), gf(), gf(), gf()];\n\n var d = sha512(sk, 32);\n d[0] &= 248;\n d[31] &= 127;\n d[31] |= 64;\n\n var smlen = n + 64;\n for(i = 0; i < n; ++i) {\n sm[64 + i] = m[i];\n }\n for(i = 0; i < 32; ++i) {\n sm[32 + i] = d[32 + i];\n }\n\n var r = sha512(sm.subarray(32), n + 32);\n reduce(r);\n scalarbase(p, r);\n pack(sm, p);\n\n for(i = 32; i < 64; ++i) {\n sm[i] = sk[i];\n }\n var h = sha512(sm, n + 64);\n reduce(h);\n\n for(i = 32; i < 64; ++i) {\n x[i] = 0;\n }\n for(i = 0; i < 32; ++i) {\n x[i] = r[i];\n }\n for(i = 0; i < 32; ++i) {\n for(j = 0; j < 32; j++) {\n x[i + j] += h[i] * d[j];\n }\n }\n\n modL(sm.subarray(32), x);\n return smlen;\n}\n\nfunction crypto_sign_open(m, sm, n, pk) {\n var i, mlen;\n var t = new NativeBuffer(32);\n var p = [gf(), gf(), gf(), gf()],\n q = [gf(), gf(), gf(), gf()];\n\n mlen = -1;\n if(n < 64) {\n return -1;\n }\n\n if(unpackneg(q, pk)) {\n return -1;\n }\n\n for(i = 0; i < n; ++i) {\n m[i] = sm[i];\n }\n for(i = 0; i < 32; ++i) {\n m[i + 32] = pk[i];\n }\n var h = sha512(m, n);\n reduce(h);\n scalarmult(p, q, h);\n\n scalarbase(q, sm.subarray(32));\n add(p, q);\n pack(t, p);\n\n n -= 64;\n if(crypto_verify_32(sm, 0, t, 0)) {\n for(i = 0; i < n; ++i) {\n m[i] = 0;\n }\n return -1;\n }\n\n for(i = 0; i < n; ++i) {\n m[i] = sm[i + 64];\n }\n mlen = n;\n return mlen;\n}\n\nfunction modL(r, x) {\n var carry, i, j, k;\n for(i = 63; i >= 32; --i) {\n carry = 0;\n for(j = i - 32, k = i - 12; j < k; ++j) {\n x[j] += carry - 16 * x[i] * L[j - (i - 32)];\n carry = (x[j] + 128) >> 8;\n x[j] -= carry * 256;\n }\n x[j] += carry;\n x[i] = 0;\n }\n carry = 0;\n for(j = 0; j < 32; ++j) {\n x[j] += carry - (x[31] >> 4) * L[j];\n carry = x[j] >> 8;\n x[j] &= 255;\n }\n for(j = 0; j < 32; ++j) {\n x[j] -= carry * L[j];\n }\n for(i = 0; i < 32; ++i) {\n x[i + 1] += x[i] >> 8;\n r[i] = x[i] & 255;\n }\n}\n\nfunction reduce(r) {\n var x = new Float64Array(64);\n for(var i = 0; i < 64; ++i) {\n x[i] = r[i];\n r[i] = 0;\n }\n modL(r, x);\n}\n\nfunction add(p, q) {\n var a = gf(), b = gf(), c = gf(),\n d = gf(), e = gf(), f = gf(),\n g = gf(), h = gf(), t = gf();\n\n Z(a, p[1], p[0]);\n Z(t, q[1], q[0]);\n M(a, a, t);\n A(b, p[0], p[1]);\n A(t, q[0], q[1]);\n M(b, b, t);\n M(c, p[3], q[3]);\n M(c, c, D2);\n M(d, p[2], q[2]);\n A(d, d, d);\n Z(e, b, a);\n Z(f, d, c);\n A(g, d, c);\n A(h, b, a);\n\n M(p[0], e, f);\n M(p[1], h, g);\n M(p[2], g, f);\n M(p[3], e, h);\n}\n\nfunction cswap(p, q, b) {\n for(var i = 0; i < 4; ++i) {\n sel25519(p[i], q[i], b);\n }\n}\n\nfunction pack(r, p) {\n var tx = gf(), ty = gf(), zi = gf();\n inv25519(zi, p[2]);\n M(tx, p[0], zi);\n M(ty, p[1], zi);\n pack25519(r, ty);\n r[31] ^= par25519(tx) << 7;\n}\n\nfunction pack25519(o, n) {\n var i, j, b;\n var m = gf(), t = gf();\n for(i = 0; i < 16; ++i) {\n t[i] = n[i];\n }\n car25519(t);\n car25519(t);\n car25519(t);\n for(j = 0; j < 2; ++j) {\n m[0] = t[0] - 0xffed;\n for(i = 1; i < 15; ++i) {\n m[i] = t[i] - 0xffff - ((m[i - 1] >> 16) & 1);\n m[i-1] &= 0xffff;\n }\n m[15] = t[15] - 0x7fff - ((m[14] >> 16) & 1);\n b = (m[15] >> 16) & 1;\n m[14] &= 0xffff;\n sel25519(t, m, 1 - b);\n }\n for (i = 0; i < 16; i++) {\n o[2 * i] = t[i] & 0xff;\n o[2 * i + 1] = t[i] >> 8;\n }\n}\n\nfunction unpackneg(r, p) {\n var t = gf(), chk = gf(), num = gf(),\n den = gf(), den2 = gf(), den4 = gf(),\n den6 = gf();\n\n set25519(r[2], gf1);\n unpack25519(r[1], p);\n S(num, r[1]);\n M(den, num, D);\n Z(num, num, r[2]);\n A(den, r[2], den);\n\n S(den2, den);\n S(den4, den2);\n M(den6, den4, den2);\n M(t, den6, num);\n M(t, t, den);\n\n pow2523(t, t);\n M(t, t, num);\n M(t, t, den);\n M(t, t, den);\n M(r[0], t, den);\n\n S(chk, r[0]);\n M(chk, chk, den);\n if(neq25519(chk, num)) {\n M(r[0], r[0], I);\n }\n\n S(chk, r[0]);\n M(chk, chk, den);\n if(neq25519(chk, num)) {\n return -1;\n }\n\n if(par25519(r[0]) === (p[31] >> 7)) {\n Z(r[0], gf0, r[0]);\n }\n\n M(r[3], r[0], r[1]);\n return 0;\n}\n\nfunction unpack25519(o, n) {\n var i;\n for(i = 0; i < 16; ++i) {\n o[i] = n[2 * i] + (n[2 * i + 1] << 8);\n }\n o[15] &= 0x7fff;\n}\n\nfunction pow2523(o, i) {\n var c = gf();\n var a;\n for(a = 0; a < 16; ++a) {\n c[a] = i[a];\n }\n for(a = 250; a >= 0; --a) {\n S(c, c);\n if(a !== 1) {\n M(c, c, i);\n }\n }\n for(a = 0; a < 16; ++a) {\n o[a] = c[a];\n }\n}\n\nfunction neq25519(a, b) {\n var c = new NativeBuffer(32);\n var d = new NativeBuffer(32);\n pack25519(c, a);\n pack25519(d, b);\n return crypto_verify_32(c, 0, d, 0);\n}\n\nfunction crypto_verify_32(x, xi, y, yi) {\n return vn(x, xi, y, yi, 32);\n}\n\nfunction vn(x, xi, y, yi, n) {\n var i, d = 0;\n for(i = 0; i < n; ++i) {\n d |= x[xi + i] ^ y[yi + i];\n }\n return (1 & ((d - 1) >>> 8)) - 1;\n}\n\nfunction par25519(a) {\n var d = new NativeBuffer(32);\n pack25519(d, a);\n return d[0] & 1;\n}\n\nfunction scalarmult(p, q, s) {\n var b, i;\n set25519(p[0], gf0);\n set25519(p[1], gf1);\n set25519(p[2], gf1);\n set25519(p[3], gf0);\n for(i = 255; i >= 0; --i) {\n b = (s[(i / 8)|0] >> (i & 7)) & 1;\n cswap(p, q, b);\n add(q, p);\n add(p, p);\n cswap(p, q, b);\n }\n}\n\nfunction scalarbase(p, s) {\n var q = [gf(), gf(), gf(), gf()];\n set25519(q[0], X);\n set25519(q[1], Y);\n set25519(q[2], gf1);\n M(q[3], X, Y);\n scalarmult(p, q, s);\n}\n\nfunction set25519(r, a) {\n var i;\n for(i = 0; i < 16; i++) {\n r[i] = a[i] | 0;\n }\n}\n\nfunction inv25519(o, i) {\n var c = gf();\n var a;\n for(a = 0; a < 16; ++a) {\n c[a] = i[a];\n }\n for(a = 253; a >= 0; --a) {\n S(c, c);\n if(a !== 2 && a !== 4) {\n M(c, c, i);\n }\n }\n for(a = 0; a < 16; ++a) {\n o[a] = c[a];\n }\n}\n\nfunction car25519(o) {\n var i, v, c = 1;\n for(i = 0; i < 16; ++i) {\n v = o[i] + c + 65535;\n c = Math.floor(v / 65536);\n o[i] = v - c * 65536;\n }\n o[0] += c - 1 + 37 * (c - 1);\n}\n\nfunction sel25519(p, q, b) {\n var t, c = ~(b - 1);\n for(var i = 0; i < 16; ++i) {\n t = c & (p[i] ^ q[i]);\n p[i] ^= t;\n q[i] ^= t;\n }\n}\n\nfunction gf(init) {\n var i, r = new Float64Array(16);\n if(init) {\n for(i = 0; i < init.length; ++i) {\n r[i] = init[i];\n }\n }\n return r;\n}\n\nfunction A(o, a, b) {\n for(var i = 0; i < 16; ++i) {\n o[i] = a[i] + b[i];\n }\n}\n\nfunction Z(o, a, b) {\n for(var i = 0; i < 16; ++i) {\n o[i] = a[i] - b[i];\n }\n}\n\nfunction S(o, a) {\n M(o, a, a);\n}\n\nfunction M(o, a, b) {\n var v, c,\n t0 = 0, t1 = 0, t2 = 0, t3 = 0, t4 = 0, t5 = 0, t6 = 0, t7 = 0,\n t8 = 0, t9 = 0, t10 = 0, t11 = 0, t12 = 0, t13 = 0, t14 = 0, t15 = 0,\n t16 = 0, t17 = 0, t18 = 0, t19 = 0, t20 = 0, t21 = 0, t22 = 0, t23 = 0,\n t24 = 0, t25 = 0, t26 = 0, t27 = 0, t28 = 0, t29 = 0, t30 = 0,\n b0 = b[0],\n b1 = b[1],\n b2 = b[2],\n b3 = b[3],\n b4 = b[4],\n b5 = b[5],\n b6 = b[6],\n b7 = b[7],\n b8 = b[8],\n b9 = b[9],\n b10 = b[10],\n b11 = b[11],\n b12 = b[12],\n b13 = b[13],\n b14 = b[14],\n b15 = b[15];\n\n v = a[0];\n t0 += v * b0;\n t1 += v * b1;\n t2 += v * b2;\n t3 += v * b3;\n t4 += v * b4;\n t5 += v * b5;\n t6 += v * b6;\n t7 += v * b7;\n t8 += v * b8;\n t9 += v * b9;\n t10 += v * b10;\n t11 += v * b11;\n t12 += v * b12;\n t13 += v * b13;\n t14 += v * b14;\n t15 += v * b15;\n v = a[1];\n t1 += v * b0;\n t2 += v * b1;\n t3 += v * b2;\n t4 += v * b3;\n t5 += v * b4;\n t6 += v * b5;\n t7 += v * b6;\n t8 += v * b7;\n t9 += v * b8;\n t10 += v * b9;\n t11 += v * b10;\n t12 += v * b11;\n t13 += v * b12;\n t14 += v * b13;\n t15 += v * b14;\n t16 += v * b15;\n v = a[2];\n t2 += v * b0;\n t3 += v * b1;\n t4 += v * b2;\n t5 += v * b3;\n t6 += v * b4;\n t7 += v * b5;\n t8 += v * b6;\n t9 += v * b7;\n t10 += v * b8;\n t11 += v * b9;\n t12 += v * b10;\n t13 += v * b11;\n t14 += v * b12;\n t15 += v * b13;\n t16 += v * b14;\n t17 += v * b15;\n v = a[3];\n t3 += v * b0;\n t4 += v * b1;\n t5 += v * b2;\n t6 += v * b3;\n t7 += v * b4;\n t8 += v * b5;\n t9 += v * b6;\n t10 += v * b7;\n t11 += v * b8;\n t12 += v * b9;\n t13 += v * b10;\n t14 += v * b11;\n t15 += v * b12;\n t16 += v * b13;\n t17 += v * b14;\n t18 += v * b15;\n v = a[4];\n t4 += v * b0;\n t5 += v * b1;\n t6 += v * b2;\n t7 += v * b3;\n t8 += v * b4;\n t9 += v * b5;\n t10 += v * b6;\n t11 += v * b7;\n t12 += v * b8;\n t13 += v * b9;\n t14 += v * b10;\n t15 += v * b11;\n t16 += v * b12;\n t17 += v * b13;\n t18 += v * b14;\n t19 += v * b15;\n v = a[5];\n t5 += v * b0;\n t6 += v * b1;\n t7 += v * b2;\n t8 += v * b3;\n t9 += v * b4;\n t10 += v * b5;\n t11 += v * b6;\n t12 += v * b7;\n t13 += v * b8;\n t14 += v * b9;\n t15 += v * b10;\n t16 += v * b11;\n t17 += v * b12;\n t18 += v * b13;\n t19 += v * b14;\n t20 += v * b15;\n v = a[6];\n t6 += v * b0;\n t7 += v * b1;\n t8 += v * b2;\n t9 += v * b3;\n t10 += v * b4;\n t11 += v * b5;\n t12 += v * b6;\n t13 += v * b7;\n t14 += v * b8;\n t15 += v * b9;\n t16 += v * b10;\n t17 += v * b11;\n t18 += v * b12;\n t19 += v * b13;\n t20 += v * b14;\n t21 += v * b15;\n v = a[7];\n t7 += v * b0;\n t8 += v * b1;\n t9 += v * b2;\n t10 += v * b3;\n t11 += v * b4;\n t12 += v * b5;\n t13 += v * b6;\n t14 += v * b7;\n t15 += v * b8;\n t16 += v * b9;\n t17 += v * b10;\n t18 += v * b11;\n t19 += v * b12;\n t20 += v * b13;\n t21 += v * b14;\n t22 += v * b15;\n v = a[8];\n t8 += v * b0;\n t9 += v * b1;\n t10 += v * b2;\n t11 += v * b3;\n t12 += v * b4;\n t13 += v * b5;\n t14 += v * b6;\n t15 += v * b7;\n t16 += v * b8;\n t17 += v * b9;\n t18 += v * b10;\n t19 += v * b11;\n t20 += v * b12;\n t21 += v * b13;\n t22 += v * b14;\n t23 += v * b15;\n v = a[9];\n t9 += v * b0;\n t10 += v * b1;\n t11 += v * b2;\n t12 += v * b3;\n t13 += v * b4;\n t14 += v * b5;\n t15 += v * b6;\n t16 += v * b7;\n t17 += v * b8;\n t18 += v * b9;\n t19 += v * b10;\n t20 += v * b11;\n t21 += v * b12;\n t22 += v * b13;\n t23 += v * b14;\n t24 += v * b15;\n v = a[10];\n t10 += v * b0;\n t11 += v * b1;\n t12 += v * b2;\n t13 += v * b3;\n t14 += v * b4;\n t15 += v * b5;\n t16 += v * b6;\n t17 += v * b7;\n t18 += v * b8;\n t19 += v * b9;\n t20 += v * b10;\n t21 += v * b11;\n t22 += v * b12;\n t23 += v * b13;\n t24 += v * b14;\n t25 += v * b15;\n v = a[11];\n t11 += v * b0;\n t12 += v * b1;\n t13 += v * b2;\n t14 += v * b3;\n t15 += v * b4;\n t16 += v * b5;\n t17 += v * b6;\n t18 += v * b7;\n t19 += v * b8;\n t20 += v * b9;\n t21 += v * b10;\n t22 += v * b11;\n t23 += v * b12;\n t24 += v * b13;\n t25 += v * b14;\n t26 += v * b15;\n v = a[12];\n t12 += v * b0;\n t13 += v * b1;\n t14 += v * b2;\n t15 += v * b3;\n t16 += v * b4;\n t17 += v * b5;\n t18 += v * b6;\n t19 += v * b7;\n t20 += v * b8;\n t21 += v * b9;\n t22 += v * b10;\n t23 += v * b11;\n t24 += v * b12;\n t25 += v * b13;\n t26 += v * b14;\n t27 += v * b15;\n v = a[13];\n t13 += v * b0;\n t14 += v * b1;\n t15 += v * b2;\n t16 += v * b3;\n t17 += v * b4;\n t18 += v * b5;\n t19 += v * b6;\n t20 += v * b7;\n t21 += v * b8;\n t22 += v * b9;\n t23 += v * b10;\n t24 += v * b11;\n t25 += v * b12;\n t26 += v * b13;\n t27 += v * b14;\n t28 += v * b15;\n v = a[14];\n t14 += v * b0;\n t15 += v * b1;\n t16 += v * b2;\n t17 += v * b3;\n t18 += v * b4;\n t19 += v * b5;\n t20 += v * b6;\n t21 += v * b7;\n t22 += v * b8;\n t23 += v * b9;\n t24 += v * b10;\n t25 += v * b11;\n t26 += v * b12;\n t27 += v * b13;\n t28 += v * b14;\n t29 += v * b15;\n v = a[15];\n t15 += v * b0;\n t16 += v * b1;\n t17 += v * b2;\n t18 += v * b3;\n t19 += v * b4;\n t20 += v * b5;\n t21 += v * b6;\n t22 += v * b7;\n t23 += v * b8;\n t24 += v * b9;\n t25 += v * b10;\n t26 += v * b11;\n t27 += v * b12;\n t28 += v * b13;\n t29 += v * b14;\n t30 += v * b15;\n\n t0 += 38 * t16;\n t1 += 38 * t17;\n t2 += 38 * t18;\n t3 += 38 * t19;\n t4 += 38 * t20;\n t5 += 38 * t21;\n t6 += 38 * t22;\n t7 += 38 * t23;\n t8 += 38 * t24;\n t9 += 38 * t25;\n t10 += 38 * t26;\n t11 += 38 * t27;\n t12 += 38 * t28;\n t13 += 38 * t29;\n t14 += 38 * t30;\n // t15 left as is\n\n // first car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c-1 + 37 * (c-1);\n\n // second car\n c = 1;\n v = t0 + c + 65535; c = Math.floor(v / 65536); t0 = v - c * 65536;\n v = t1 + c + 65535; c = Math.floor(v / 65536); t1 = v - c * 65536;\n v = t2 + c + 65535; c = Math.floor(v / 65536); t2 = v - c * 65536;\n v = t3 + c + 65535; c = Math.floor(v / 65536); t3 = v - c * 65536;\n v = t4 + c + 65535; c = Math.floor(v / 65536); t4 = v - c * 65536;\n v = t5 + c + 65535; c = Math.floor(v / 65536); t5 = v - c * 65536;\n v = t6 + c + 65535; c = Math.floor(v / 65536); t6 = v - c * 65536;\n v = t7 + c + 65535; c = Math.floor(v / 65536); t7 = v - c * 65536;\n v = t8 + c + 65535; c = Math.floor(v / 65536); t8 = v - c * 65536;\n v = t9 + c + 65535; c = Math.floor(v / 65536); t9 = v - c * 65536;\n v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n t0 += c-1 + 37 * (c-1);\n\n o[ 0] = t0;\n o[ 1] = t1;\n o[ 2] = t2;\n o[ 3] = t3;\n o[ 4] = t4;\n o[ 5] = t5;\n o[ 6] = t6;\n o[ 7] = t7;\n o[ 8] = t8;\n o[ 9] = t9;\n o[10] = t10;\n o[11] = t11;\n o[12] = t12;\n o[13] = t13;\n o[14] = t14;\n o[15] = t15;\n}\n","/**\n * Copyright (c) 2019 Digital Bazaar, Inc.\n */\n\nvar forge = require('./forge');\nrequire('./asn1');\nvar asn1 = forge.asn1;\n\nexports.privateKeyValidator = {\n // PrivateKeyInfo\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n // Version (INTEGER)\n name: 'PrivateKeyInfo.version',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.INTEGER,\n constructed: false,\n capture: 'privateKeyVersion'\n }, {\n // privateKeyAlgorithm\n name: 'PrivateKeyInfo.privateKeyAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'privateKeyOid'\n }]\n }, {\n // PrivateKey\n name: 'PrivateKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'privateKey'\n }]\n};\n\nexports.publicKeyValidator = {\n name: 'SubjectPublicKeyInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: 'subjectPublicKeyInfo',\n value: [{\n name: 'SubjectPublicKeyInfo.AlgorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'AlgorithmIdentifier.algorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'publicKeyOid'\n }]\n },\n // capture group for ed25519PublicKey\n {\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n composed: true,\n captureBitStringValue: 'ed25519PublicKey'\n }\n // FIXME: this is capture group for rsaPublicKey, use it in this API or\n // discard?\n /* {\n // subjectPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.BITSTRING,\n constructed: false,\n value: [{\n // RSAPublicKey\n name: 'SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n optional: true,\n captureAsn1: 'rsaPublicKey'\n }]\n } */\n ]\n};\n","/**\n * Javascript implementation of RSA-KEM.\n *\n * @author Lautaro Cozzani Rodriguez\n * @author Dave Longley\n *\n * Copyright (c) 2014 Lautaro Cozzani <lautaro.cozzani@scytl.com>\n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./random');\nrequire('./jsbn');\n\nmodule.exports = forge.kem = forge.kem || {};\n\nvar BigInteger = forge.jsbn.BigInteger;\n\n/**\n * The API for the RSA Key Encapsulation Mechanism (RSA-KEM) from ISO 18033-2.\n */\nforge.kem.rsa = {};\n\n/**\n * Creates an RSA KEM API object for generating a secret asymmetric key.\n *\n * The symmetric key may be generated via a call to 'encrypt', which will\n * produce a ciphertext to be transmitted to the recipient and a key to be\n * kept secret. The ciphertext is a parameter to be passed to 'decrypt' which\n * will produce the same secret key for the recipient to use to decrypt a\n * message that was encrypted with the secret key.\n *\n * @param kdf the KDF API to use (eg: new forge.kem.kdf1()).\n * @param options the options to use.\n * [prng] a custom crypto-secure pseudo-random number generator to use,\n * that must define \"getBytesSync\".\n */\nforge.kem.rsa.create = function(kdf, options) {\n options = options || {};\n var prng = options.prng || forge.random;\n\n var kem = {};\n\n /**\n * Generates a secret key and its encapsulation.\n *\n * @param publicKey the RSA public key to encrypt with.\n * @param keyLength the length, in bytes, of the secret key to generate.\n *\n * @return an object with:\n * encapsulation: the ciphertext for generating the secret key, as a\n * binary-encoded string of bytes.\n * key: the secret key to use for encrypting a message.\n */\n kem.encrypt = function(publicKey, keyLength) {\n // generate a random r where 1 < r < n\n var byteLength = Math.ceil(publicKey.n.bitLength() / 8);\n var r;\n do {\n r = new BigInteger(\n forge.util.bytesToHex(prng.getBytesSync(byteLength)),\n 16).mod(publicKey.n);\n } while(r.compareTo(BigInteger.ONE) <= 0);\n\n // prepend r with zeros\n r = forge.util.hexToBytes(r.toString(16));\n var zeros = byteLength - r.length;\n if(zeros > 0) {\n r = forge.util.fillString(String.fromCharCode(0), zeros) + r;\n }\n\n // encrypt the random\n var encapsulation = publicKey.encrypt(r, 'NONE');\n\n // generate the secret key\n var key = kdf.generate(r, keyLength);\n\n return {encapsulation: encapsulation, key: key};\n };\n\n /**\n * Decrypts an encapsulated secret key.\n *\n * @param privateKey the RSA private key to decrypt with.\n * @param encapsulation the ciphertext for generating the secret key, as\n * a binary-encoded string of bytes.\n * @param keyLength the length, in bytes, of the secret key to generate.\n *\n * @return the secret key as a binary-encoded string of bytes.\n */\n kem.decrypt = function(privateKey, encapsulation, keyLength) {\n // decrypt the encapsulation and generate the secret key\n var r = privateKey.decrypt(encapsulation, 'NONE');\n return kdf.generate(r, keyLength);\n };\n\n return kem;\n};\n\n// TODO: add forge.kem.kdf.create('KDF1', {md: ..., ...}) API?\n\n/**\n * Creates a key derivation API object that implements KDF1 per ISO 18033-2.\n *\n * @param md the hash API to use.\n * @param [digestLength] an optional digest length that must be positive and\n * less than or equal to md.digestLength.\n *\n * @return a KDF1 API object.\n */\nforge.kem.kdf1 = function(md, digestLength) {\n _createKDF(this, md, 0, digestLength || md.digestLength);\n};\n\n/**\n * Creates a key derivation API object that implements KDF2 per ISO 18033-2.\n *\n * @param md the hash API to use.\n * @param [digestLength] an optional digest length that must be positive and\n * less than or equal to md.digestLength.\n *\n * @return a KDF2 API object.\n */\nforge.kem.kdf2 = function(md, digestLength) {\n _createKDF(this, md, 1, digestLength || md.digestLength);\n};\n\n/**\n * Creates a KDF1 or KDF2 API object.\n *\n * @param md the hash API to use.\n * @param counterStart the starting index for the counter.\n * @param digestLength the digest length to use.\n *\n * @return the KDF API object.\n */\nfunction _createKDF(kdf, md, counterStart, digestLength) {\n /**\n * Generate a key of the specified length.\n *\n * @param x the binary-encoded byte string to generate a key from.\n * @param length the number of bytes to generate (the size of the key).\n *\n * @return the key as a binary-encoded string.\n */\n kdf.generate = function(x, length) {\n var key = new forge.util.ByteBuffer();\n\n // run counter from counterStart to ceil(length / Hash.len)\n var k = Math.ceil(length / digestLength) + counterStart;\n\n var c = new forge.util.ByteBuffer();\n for(var i = counterStart; i < k; ++i) {\n // I2OSP(i, 4): convert counter to an octet string of 4 octets\n c.putInt32(i);\n\n // digest 'x' and the counter and add the result to the key\n md.start();\n md.update(x + c.getBytes());\n var hash = md.digest();\n key.putBytes(hash.getBytes(digestLength));\n }\n\n // truncate to the correct key length\n key.truncate(key.length() - length);\n return key.getBytes();\n };\n}\n","/**\n * Node.js module for all known Forge message digests.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2017 Digital Bazaar, Inc.\n */\nmodule.exports = require('./md');\n\nrequire('./md5');\nrequire('./sha1');\nrequire('./sha256');\nrequire('./sha512');\n","/**\n * Javascript implementation of PKCS#7 v1.5.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n *\n * Currently this implementation only supports ContentType of EnvelopedData,\n * EncryptedData, or SignedData at the root level. The top level elements may\n * contain only a ContentInfo of ContentType Data, i.e. plain data. Further\n * nesting is not (yet) supported.\n *\n * The Forge validators for PKCS #7's ASN.1 structures are available from\n * a separate file pkcs7asn1.js, since those are referenced from other\n * PKCS standards like PKCS #12.\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./oids');\nrequire('./pem');\nrequire('./pkcs7asn1');\nrequire('./random');\nrequire('./util');\nrequire('./x509');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7 = module.exports = forge.pkcs7 = forge.pkcs7 || {};\n\n/**\n * Converts a PKCS#7 message from PEM format.\n *\n * @param pem the PEM-formatted PKCS#7 message.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromPem = function(pem) {\n var msg = forge.pem.decode(pem)[0];\n\n if(msg.type !== 'PKCS7') {\n var error = new Error('Could not convert PKCS#7 message from PEM; PEM ' +\n 'header type is not \"PKCS#7\".');\n error.headerType = msg.type;\n throw error;\n }\n if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n throw new Error('Could not convert PKCS#7 message from PEM; PEM is encrypted.');\n }\n\n // convert DER to ASN.1 object\n var obj = asn1.fromDer(msg.body);\n\n return p7.messageFromAsn1(obj);\n};\n\n/**\n * Converts a PKCS#7 message to PEM format.\n *\n * @param msg The PKCS#7 message object\n * @param maxline The maximum characters per line, defaults to 64.\n *\n * @return The PEM-formatted PKCS#7 message.\n */\np7.messageToPem = function(msg, maxline) {\n // convert to ASN.1, then DER, then PEM-encode\n var pemObj = {\n type: 'PKCS7',\n body: asn1.toDer(msg.toAsn1()).getBytes()\n };\n return forge.pem.encode(pemObj, {maxline: maxline});\n};\n\n/**\n * Converts a PKCS#7 message from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a ContentInfo.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromAsn1 = function(obj) {\n // validate root level ContentInfo and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.contentInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 message. ' +\n 'ASN.1 object is not an PKCS#7 ContentInfo.');\n error.errors = errors;\n throw error;\n }\n\n var contentType = asn1.derToOid(capture.contentType);\n var msg;\n\n switch(contentType) {\n case forge.pki.oids.envelopedData:\n msg = p7.createEnvelopedData();\n break;\n\n case forge.pki.oids.encryptedData:\n msg = p7.createEncryptedData();\n break;\n\n case forge.pki.oids.signedData:\n msg = p7.createSignedData();\n break;\n\n default:\n throw new Error('Cannot read PKCS#7 message. ContentType with OID ' +\n contentType + ' is not (yet) supported.');\n }\n\n msg.fromAsn1(capture.content.value[0]);\n return msg;\n};\n\np7.createSignedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.signedData,\n version: 1,\n certificates: [],\n crls: [],\n // TODO: add json-formatted signer stuff here?\n signers: [],\n // populated during sign()\n digestAlgorithmIdentifiers: [],\n contentInfo: null,\n signerInfos: [],\n\n fromAsn1: function(obj) {\n // validate SignedData content block and capture data.\n _fromAsn1(msg, obj, p7.asn1.signedDataValidator);\n msg.certificates = [];\n msg.crls = [];\n msg.digestAlgorithmIdentifiers = [];\n msg.contentInfo = null;\n msg.signerInfos = [];\n\n if(msg.rawCapture.certificates) {\n var certs = msg.rawCapture.certificates.value;\n for(var i = 0; i < certs.length; ++i) {\n msg.certificates.push(forge.pki.certificateFromAsn1(certs[i]));\n }\n }\n\n // TODO: parse crls\n },\n\n toAsn1: function() {\n // degenerate case with no content\n if(!msg.contentInfo) {\n msg.sign();\n }\n\n var certs = [];\n for(var i = 0; i < msg.certificates.length; ++i) {\n certs.push(forge.pki.certificateToAsn1(msg.certificates[i]));\n }\n\n var crls = [];\n // TODO: implement CRLs\n\n // [0] SignedData\n var signedData = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(msg.version).getBytes()),\n // DigestAlgorithmIdentifiers\n asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n msg.digestAlgorithmIdentifiers),\n // ContentInfo\n msg.contentInfo\n ])\n ]);\n if(certs.length > 0) {\n // [0] IMPLICIT ExtendedCertificatesAndCertificates OPTIONAL\n signedData.value[0].value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, certs));\n }\n if(crls.length > 0) {\n // [1] IMPLICIT CertificateRevocationLists OPTIONAL\n signedData.value[0].value.push(\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, crls));\n }\n // SignerInfos\n signedData.value[0].value.push(\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n msg.signerInfos));\n\n // ContentInfo\n return asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(msg.type).getBytes()),\n // [0] SignedData\n signedData\n ]);\n },\n\n /**\n * Add (another) entity to list of signers.\n *\n * Note: If authenticatedAttributes are provided, then, per RFC 2315,\n * they must include at least two attributes: content type and\n * message digest. The message digest attribute value will be\n * auto-calculated during signing and will be ignored if provided.\n *\n * Here's an example of providing these two attributes:\n *\n * forge.pkcs7.createSignedData();\n * p7.addSigner({\n * issuer: cert.issuer.attributes,\n * serialNumber: cert.serialNumber,\n * key: privateKey,\n * digestAlgorithm: forge.pki.oids.sha1,\n * authenticatedAttributes: [{\n * type: forge.pki.oids.contentType,\n * value: forge.pki.oids.data\n * }, {\n * type: forge.pki.oids.messageDigest\n * }]\n * });\n *\n * TODO: Support [subjectKeyIdentifier] as signer's ID.\n *\n * @param signer the signer information:\n * key the signer's private key.\n * [certificate] a certificate containing the public key\n * associated with the signer's private key; use this option as\n * an alternative to specifying signer.issuer and\n * signer.serialNumber.\n * [issuer] the issuer attributes (eg: cert.issuer.attributes).\n * [serialNumber] the signer's certificate's serial number in\n * hexadecimal (eg: cert.serialNumber).\n * [digestAlgorithm] the message digest OID, as a string, to use\n * (eg: forge.pki.oids.sha1).\n * [authenticatedAttributes] an optional array of attributes\n * to also sign along with the content.\n */\n addSigner: function(signer) {\n var issuer = signer.issuer;\n var serialNumber = signer.serialNumber;\n if(signer.certificate) {\n var cert = signer.certificate;\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n issuer = cert.issuer.attributes;\n serialNumber = cert.serialNumber;\n }\n var key = signer.key;\n if(!key) {\n throw new Error(\n 'Could not add PKCS#7 signer; no private key specified.');\n }\n if(typeof key === 'string') {\n key = forge.pki.privateKeyFromPem(key);\n }\n\n // ensure OID known for digest algorithm\n var digestAlgorithm = signer.digestAlgorithm || forge.pki.oids.sha1;\n switch(digestAlgorithm) {\n case forge.pki.oids.sha1:\n case forge.pki.oids.sha256:\n case forge.pki.oids.sha384:\n case forge.pki.oids.sha512:\n case forge.pki.oids.md5:\n break;\n default:\n throw new Error(\n 'Could not add PKCS#7 signer; unknown message digest algorithm: ' +\n digestAlgorithm);\n }\n\n // if authenticatedAttributes is present, then the attributes\n // must contain at least PKCS #9 content-type and message-digest\n var authenticatedAttributes = signer.authenticatedAttributes || [];\n if(authenticatedAttributes.length > 0) {\n var contentType = false;\n var messageDigest = false;\n for(var i = 0; i < authenticatedAttributes.length; ++i) {\n var attr = authenticatedAttributes[i];\n if(!contentType && attr.type === forge.pki.oids.contentType) {\n contentType = true;\n if(messageDigest) {\n break;\n }\n continue;\n }\n if(!messageDigest && attr.type === forge.pki.oids.messageDigest) {\n messageDigest = true;\n if(contentType) {\n break;\n }\n continue;\n }\n }\n\n if(!contentType || !messageDigest) {\n throw new Error('Invalid signer.authenticatedAttributes. If ' +\n 'signer.authenticatedAttributes is specified, then it must ' +\n 'contain at least two attributes, PKCS #9 content-type and ' +\n 'PKCS #9 message-digest.');\n }\n }\n\n msg.signers.push({\n key: key,\n version: 1,\n issuer: issuer,\n serialNumber: serialNumber,\n digestAlgorithm: digestAlgorithm,\n signatureAlgorithm: forge.pki.oids.rsaEncryption,\n signature: null,\n authenticatedAttributes: authenticatedAttributes,\n unauthenticatedAttributes: []\n });\n },\n\n /**\n * Signs the content.\n * @param options Options to apply when signing:\n * [detached] boolean. If signing should be done in detached mode. Defaults to false.\n */\n sign: function(options) {\n options = options || {};\n // auto-generate content info\n if(typeof msg.content !== 'object' || msg.contentInfo === null) {\n // use Data ContentInfo\n msg.contentInfo = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(forge.pki.oids.data).getBytes())\n ]);\n\n // add actual content, if present\n if('content' in msg) {\n var content;\n if(msg.content instanceof forge.util.ByteBuffer) {\n content = msg.content.bytes();\n } else if(typeof msg.content === 'string') {\n content = forge.util.encodeUtf8(msg.content);\n }\n\n if (options.detached) {\n msg.detachedContent = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, content);\n } else {\n msg.contentInfo.value.push(\n // [0] EXPLICIT content\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n content)\n ]));\n }\n }\n }\n\n // no signers, return early (degenerate case for certificate container)\n if(msg.signers.length === 0) {\n return;\n }\n\n // generate digest algorithm identifiers\n var mds = addDigestAlgorithmIds();\n\n // generate signerInfos\n addSignerInfos(mds);\n },\n\n verify: function() {\n throw new Error('PKCS#7 signature verification not yet implemented.');\n },\n\n /**\n * Add a certificate.\n *\n * @param cert the certificate to add.\n */\n addCertificate: function(cert) {\n // convert from PEM\n if(typeof cert === 'string') {\n cert = forge.pki.certificateFromPem(cert);\n }\n msg.certificates.push(cert);\n },\n\n /**\n * Add a certificate revokation list.\n *\n * @param crl the certificate revokation list to add.\n */\n addCertificateRevokationList: function(crl) {\n throw new Error('PKCS#7 CRL support not yet implemented.');\n }\n };\n return msg;\n\n function addDigestAlgorithmIds() {\n var mds = {};\n\n for(var i = 0; i < msg.signers.length; ++i) {\n var signer = msg.signers[i];\n var oid = signer.digestAlgorithm;\n if(!(oid in mds)) {\n // content digest\n mds[oid] = forge.md[forge.pki.oids[oid]].create();\n }\n if(signer.authenticatedAttributes.length === 0) {\n // no custom attributes to digest; use content message digest\n signer.md = mds[oid];\n } else {\n // custom attributes to be digested; use own message digest\n // TODO: optimize to just copy message digest state if that\n // feature is ever supported with message digests\n signer.md = forge.md[forge.pki.oids[oid]].create();\n }\n }\n\n // add unique digest algorithm identifiers\n msg.digestAlgorithmIdentifiers = [];\n for(var oid in mds) {\n msg.digestAlgorithmIdentifiers.push(\n // AlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(oid).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n }\n\n return mds;\n }\n\n function addSignerInfos(mds) {\n var content;\n\n if (msg.detachedContent) {\n // Signature has been made in detached mode.\n content = msg.detachedContent;\n } else {\n // Note: ContentInfo is a SEQUENCE with 2 values, second value is\n // the content field and is optional for a ContentInfo but required here\n // since signers are present\n // get ContentInfo content\n content = msg.contentInfo.value[1];\n // skip [0] EXPLICIT content wrapper\n content = content.value[0];\n }\n\n if(!content) {\n throw new Error(\n 'Could not sign PKCS#7 message; there is no content to sign.');\n }\n\n // get ContentInfo content type\n var contentType = asn1.derToOid(msg.contentInfo.value[0].value);\n\n // serialize content\n var bytes = asn1.toDer(content);\n\n // skip identifier and length per RFC 2315 9.3\n // skip identifier (1 byte)\n bytes.getByte();\n // read and discard length bytes\n asn1.getBerValueLength(bytes);\n bytes = bytes.getBytes();\n\n // digest content DER value bytes\n for(var oid in mds) {\n mds[oid].start().update(bytes);\n }\n\n // sign content\n var signingTime = new Date();\n for(var i = 0; i < msg.signers.length; ++i) {\n var signer = msg.signers[i];\n\n if(signer.authenticatedAttributes.length === 0) {\n // if ContentInfo content type is not \"Data\", then\n // authenticatedAttributes must be present per RFC 2315\n if(contentType !== forge.pki.oids.data) {\n throw new Error(\n 'Invalid signer; authenticatedAttributes must be present ' +\n 'when the ContentInfo content type is not PKCS#7 Data.');\n }\n } else {\n // process authenticated attributes\n // [0] IMPLICIT\n signer.authenticatedAttributesAsn1 = asn1.create(\n asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n\n // per RFC 2315, attributes are to be digested using a SET container\n // not the above [0] IMPLICIT container\n var attrsAsn1 = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.SET, true, []);\n\n for(var ai = 0; ai < signer.authenticatedAttributes.length; ++ai) {\n var attr = signer.authenticatedAttributes[ai];\n if(attr.type === forge.pki.oids.messageDigest) {\n // use content message digest as value\n attr.value = mds[signer.digestAlgorithm].digest();\n } else if(attr.type === forge.pki.oids.signingTime) {\n // auto-populate signing time if not already set\n if(!attr.value) {\n attr.value = signingTime;\n }\n }\n\n // convert to ASN.1 and push onto Attributes SET (for signing) and\n // onto authenticatedAttributesAsn1 to complete SignedData ASN.1\n // TODO: optimize away duplication\n attrsAsn1.value.push(_attributeToAsn1(attr));\n signer.authenticatedAttributesAsn1.value.push(_attributeToAsn1(attr));\n }\n\n // DER-serialize and digest SET OF attributes only\n bytes = asn1.toDer(attrsAsn1).getBytes();\n signer.md.start().update(bytes);\n }\n\n // sign digest\n signer.signature = signer.key.sign(signer.md, 'RSASSA-PKCS1-V1_5');\n }\n\n // add signer info\n msg.signerInfos = _signersToAsn1(msg.signers);\n }\n};\n\n/**\n * Creates an empty PKCS#7 message of type EncryptedData.\n *\n * @return the message.\n */\np7.createEncryptedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.encryptedData,\n version: 0,\n encryptedContent: {\n algorithm: forge.pki.oids['aes256-CBC']\n },\n\n /**\n * Reads an EncryptedData content block (in ASN.1 format)\n *\n * @param obj The ASN.1 representation of the EncryptedData content block\n */\n fromAsn1: function(obj) {\n // Validate EncryptedData content block and capture data.\n _fromAsn1(msg, obj, p7.asn1.encryptedDataValidator);\n },\n\n /**\n * Decrypt encrypted content\n *\n * @param key The (symmetric) key as a byte buffer\n */\n decrypt: function(key) {\n if(key !== undefined) {\n msg.encryptedContent.key = key;\n }\n _decryptContent(msg);\n }\n };\n return msg;\n};\n\n/**\n * Creates an empty PKCS#7 message of type EnvelopedData.\n *\n * @return the message.\n */\np7.createEnvelopedData = function() {\n var msg = null;\n msg = {\n type: forge.pki.oids.envelopedData,\n version: 0,\n recipients: [],\n encryptedContent: {\n algorithm: forge.pki.oids['aes256-CBC']\n },\n\n /**\n * Reads an EnvelopedData content block (in ASN.1 format)\n *\n * @param obj the ASN.1 representation of the EnvelopedData content block.\n */\n fromAsn1: function(obj) {\n // validate EnvelopedData content block and capture data\n var capture = _fromAsn1(msg, obj, p7.asn1.envelopedDataValidator);\n msg.recipients = _recipientsFromAsn1(capture.recipientInfos.value);\n },\n\n toAsn1: function() {\n // ContentInfo\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // ContentType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(msg.type).getBytes()),\n // [0] EnvelopedData\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(msg.version).getBytes()),\n // RecipientInfos\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n _recipientsToAsn1(msg.recipients)),\n // EncryptedContentInfo\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true,\n _encryptedContentToAsn1(msg.encryptedContent))\n ])\n ])\n ]);\n },\n\n /**\n * Find recipient by X.509 certificate's issuer.\n *\n * @param cert the certificate with the issuer to look for.\n *\n * @return the recipient object.\n */\n findRecipient: function(cert) {\n var sAttr = cert.issuer.attributes;\n\n for(var i = 0; i < msg.recipients.length; ++i) {\n var r = msg.recipients[i];\n var rAttr = r.issuer;\n\n if(r.serialNumber !== cert.serialNumber) {\n continue;\n }\n\n if(rAttr.length !== sAttr.length) {\n continue;\n }\n\n var match = true;\n for(var j = 0; j < sAttr.length; ++j) {\n if(rAttr[j].type !== sAttr[j].type ||\n rAttr[j].value !== sAttr[j].value) {\n match = false;\n break;\n }\n }\n\n if(match) {\n return r;\n }\n }\n\n return null;\n },\n\n /**\n * Decrypt enveloped content\n *\n * @param recipient The recipient object related to the private key\n * @param privKey The (RSA) private key object\n */\n decrypt: function(recipient, privKey) {\n if(msg.encryptedContent.key === undefined && recipient !== undefined &&\n privKey !== undefined) {\n switch(recipient.encryptedContent.algorithm) {\n case forge.pki.oids.rsaEncryption:\n case forge.pki.oids.desCBC:\n var key = privKey.decrypt(recipient.encryptedContent.content);\n msg.encryptedContent.key = forge.util.createBuffer(key);\n break;\n\n default:\n throw new Error('Unsupported asymmetric cipher, ' +\n 'OID ' + recipient.encryptedContent.algorithm);\n }\n }\n\n _decryptContent(msg);\n },\n\n /**\n * Add (another) entity to list of recipients.\n *\n * @param cert The certificate of the entity to add.\n */\n addRecipient: function(cert) {\n msg.recipients.push({\n version: 0,\n issuer: cert.issuer.attributes,\n serialNumber: cert.serialNumber,\n encryptedContent: {\n // We simply assume rsaEncryption here, since forge.pki only\n // supports RSA so far. If the PKI module supports other\n // ciphers one day, we need to modify this one as well.\n algorithm: forge.pki.oids.rsaEncryption,\n key: cert.publicKey\n }\n });\n },\n\n /**\n * Encrypt enveloped content.\n *\n * This function supports two optional arguments, cipher and key, which\n * can be used to influence symmetric encryption. Unless cipher is\n * provided, the cipher specified in encryptedContent.algorithm is used\n * (defaults to AES-256-CBC). If no key is provided, encryptedContent.key\n * is (re-)used. If that one's not set, a random key will be generated\n * automatically.\n *\n * @param [key] The key to be used for symmetric encryption.\n * @param [cipher] The OID of the symmetric cipher to use.\n */\n encrypt: function(key, cipher) {\n // Part 1: Symmetric encryption\n if(msg.encryptedContent.content === undefined) {\n cipher = cipher || msg.encryptedContent.algorithm;\n key = key || msg.encryptedContent.key;\n\n var keyLen, ivLen, ciphFn;\n switch(cipher) {\n case forge.pki.oids['aes128-CBC']:\n keyLen = 16;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['aes192-CBC']:\n keyLen = 24;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['aes256-CBC']:\n keyLen = 32;\n ivLen = 16;\n ciphFn = forge.aes.createEncryptionCipher;\n break;\n\n case forge.pki.oids['des-EDE3-CBC']:\n keyLen = 24;\n ivLen = 8;\n ciphFn = forge.des.createEncryptionCipher;\n break;\n\n default:\n throw new Error('Unsupported symmetric cipher, OID ' + cipher);\n }\n\n if(key === undefined) {\n key = forge.util.createBuffer(forge.random.getBytes(keyLen));\n } else if(key.length() != keyLen) {\n throw new Error('Symmetric key has wrong length; ' +\n 'got ' + key.length() + ' bytes, expected ' + keyLen + '.');\n }\n\n // Keep a copy of the key & IV in the object, so the caller can\n // use it for whatever reason.\n msg.encryptedContent.algorithm = cipher;\n msg.encryptedContent.key = key;\n msg.encryptedContent.parameter = forge.util.createBuffer(\n forge.random.getBytes(ivLen));\n\n var ciph = ciphFn(key);\n ciph.start(msg.encryptedContent.parameter.copy());\n ciph.update(msg.content);\n\n // The finish function does PKCS#7 padding by default, therefore\n // no action required by us.\n if(!ciph.finish()) {\n throw new Error('Symmetric encryption failed.');\n }\n\n msg.encryptedContent.content = ciph.output;\n }\n\n // Part 2: asymmetric encryption for each recipient\n for(var i = 0; i < msg.recipients.length; ++i) {\n var recipient = msg.recipients[i];\n\n // Nothing to do, encryption already done.\n if(recipient.encryptedContent.content !== undefined) {\n continue;\n }\n\n switch(recipient.encryptedContent.algorithm) {\n case forge.pki.oids.rsaEncryption:\n recipient.encryptedContent.content =\n recipient.encryptedContent.key.encrypt(\n msg.encryptedContent.key.data);\n break;\n\n default:\n throw new Error('Unsupported asymmetric cipher, OID ' +\n recipient.encryptedContent.algorithm);\n }\n }\n }\n };\n return msg;\n};\n\n/**\n * Converts a single recipient from an ASN.1 object.\n *\n * @param obj the ASN.1 RecipientInfo.\n *\n * @return the recipient object.\n */\nfunction _recipientFromAsn1(obj) {\n // validate EnvelopedData content block and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.recipientInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 RecipientInfo. ' +\n 'ASN.1 object is not an PKCS#7 RecipientInfo.');\n error.errors = errors;\n throw error;\n }\n\n return {\n version: capture.version.charCodeAt(0),\n issuer: forge.pki.RDNAttributesAsArray(capture.issuer),\n serialNumber: forge.util.createBuffer(capture.serial).toHex(),\n encryptedContent: {\n algorithm: asn1.derToOid(capture.encAlgorithm),\n parameter: capture.encParameter.value,\n content: capture.encKey\n }\n };\n}\n\n/**\n * Converts a single recipient object to an ASN.1 object.\n *\n * @param obj the recipient object.\n *\n * @return the ASN.1 RecipientInfo.\n */\nfunction _recipientToAsn1(obj) {\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(obj.version).getBytes()),\n // IssuerAndSerialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Name\n forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),\n // Serial\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(obj.serialNumber))\n ]),\n // KeyEncryptionAlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.encryptedContent.algorithm).getBytes()),\n // Parameter, force NULL, only RSA supported for now.\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]),\n // EncryptedKey\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n obj.encryptedContent.content)\n ]);\n}\n\n/**\n * Map a set of RecipientInfo ASN.1 objects to recipient objects.\n *\n * @param infos an array of ASN.1 representations RecipientInfo (i.e. SET OF).\n *\n * @return an array of recipient objects.\n */\nfunction _recipientsFromAsn1(infos) {\n var ret = [];\n for(var i = 0; i < infos.length; ++i) {\n ret.push(_recipientFromAsn1(infos[i]));\n }\n return ret;\n}\n\n/**\n * Map an array of recipient objects to ASN.1 RecipientInfo objects.\n *\n * @param recipients an array of recipientInfo objects.\n *\n * @return an array of ASN.1 RecipientInfos.\n */\nfunction _recipientsToAsn1(recipients) {\n var ret = [];\n for(var i = 0; i < recipients.length; ++i) {\n ret.push(_recipientToAsn1(recipients[i]));\n }\n return ret;\n}\n\n/**\n * Converts a single signer from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a SignerInfo.\n *\n * @return the signer object.\n */\nfunction _signerFromAsn1(obj) {\n // validate EnvelopedData content block and capture data\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, p7.asn1.signerInfoValidator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 SignerInfo. ' +\n 'ASN.1 object is not an PKCS#7 SignerInfo.');\n error.errors = errors;\n throw error;\n }\n\n var rval = {\n version: capture.version.charCodeAt(0),\n issuer: forge.pki.RDNAttributesAsArray(capture.issuer),\n serialNumber: forge.util.createBuffer(capture.serial).toHex(),\n digestAlgorithm: asn1.derToOid(capture.digestAlgorithm),\n signatureAlgorithm: asn1.derToOid(capture.signatureAlgorithm),\n signature: capture.signature,\n authenticatedAttributes: [],\n unauthenticatedAttributes: []\n };\n\n // TODO: convert attributes\n var authenticatedAttributes = capture.authenticatedAttributes || [];\n var unauthenticatedAttributes = capture.unauthenticatedAttributes || [];\n\n return rval;\n}\n\n/**\n * Converts a single signerInfo object to an ASN.1 object.\n *\n * @param obj the signerInfo object.\n *\n * @return the ASN.1 representation of a SignerInfo.\n */\nfunction _signerToAsn1(obj) {\n // SignerInfo\n var rval = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // version\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n asn1.integerToDer(obj.version).getBytes()),\n // issuerAndSerialNumber\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // name\n forge.pki.distinguishedNameToAsn1({attributes: obj.issuer}),\n // serial\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n forge.util.hexToBytes(obj.serialNumber))\n ]),\n // digestAlgorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.digestAlgorithm).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ])\n ]);\n\n // authenticatedAttributes (OPTIONAL)\n if(obj.authenticatedAttributesAsn1) {\n // add ASN.1 previously generated during signing\n rval.value.push(obj.authenticatedAttributesAsn1);\n }\n\n // digestEncryptionAlgorithm\n rval.value.push(asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(obj.signatureAlgorithm).getBytes()),\n // parameters (null)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n ]));\n\n // encryptedDigest\n rval.value.push(asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, obj.signature));\n\n // unauthenticatedAttributes (OPTIONAL)\n if(obj.unauthenticatedAttributes.length > 0) {\n // [1] IMPLICIT\n var attrsAsn1 = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, []);\n for(var i = 0; i < obj.unauthenticatedAttributes.length; ++i) {\n var attr = obj.unauthenticatedAttributes[i];\n attrsAsn1.values.push(_attributeToAsn1(attr));\n }\n rval.value.push(attrsAsn1);\n }\n\n return rval;\n}\n\n/**\n * Map a set of SignerInfo ASN.1 objects to an array of signer objects.\n *\n * @param signerInfoAsn1s an array of ASN.1 SignerInfos (i.e. SET OF).\n *\n * @return an array of signers objects.\n */\nfunction _signersFromAsn1(signerInfoAsn1s) {\n var ret = [];\n for(var i = 0; i < signerInfoAsn1s.length; ++i) {\n ret.push(_signerFromAsn1(signerInfoAsn1s[i]));\n }\n return ret;\n}\n\n/**\n * Map an array of signer objects to ASN.1 objects.\n *\n * @param signers an array of signer objects.\n *\n * @return an array of ASN.1 SignerInfos.\n */\nfunction _signersToAsn1(signers) {\n var ret = [];\n for(var i = 0; i < signers.length; ++i) {\n ret.push(_signerToAsn1(signers[i]));\n }\n return ret;\n}\n\n/**\n * Convert an attribute object to an ASN.1 Attribute.\n *\n * @param attr the attribute object.\n *\n * @return the ASN.1 Attribute.\n */\nfunction _attributeToAsn1(attr) {\n var value;\n\n // TODO: generalize to support more attributes\n if(attr.type === forge.pki.oids.contentType) {\n value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.value).getBytes());\n } else if(attr.type === forge.pki.oids.messageDigest) {\n value = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n attr.value.bytes());\n } else if(attr.type === forge.pki.oids.signingTime) {\n /* Note per RFC 2985: Dates between 1 January 1950 and 31 December 2049\n (inclusive) MUST be encoded as UTCTime. Any dates with year values\n before 1950 or after 2049 MUST be encoded as GeneralizedTime. [Further,]\n UTCTime values MUST be expressed in Greenwich Mean Time (Zulu) and MUST\n include seconds (i.e., times are YYMMDDHHMMSSZ), even where the\n number of seconds is zero. Midnight (GMT) must be represented as\n \"YYMMDD000000Z\". */\n // TODO: make these module-level constants\n var jan_1_1950 = new Date('1950-01-01T00:00:00Z');\n var jan_1_2050 = new Date('2050-01-01T00:00:00Z');\n var date = attr.value;\n if(typeof date === 'string') {\n // try to parse date\n var timestamp = Date.parse(date);\n if(!isNaN(timestamp)) {\n date = new Date(timestamp);\n } else if(date.length === 13) {\n // YYMMDDHHMMSSZ (13 chars for UTCTime)\n date = asn1.utcTimeToDate(date);\n } else {\n // assume generalized time\n date = asn1.generalizedTimeToDate(date);\n }\n }\n\n if(date >= jan_1_1950 && date < jan_1_2050) {\n value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.UTCTIME, false,\n asn1.dateToUtcTime(date));\n } else {\n value = asn1.create(\n asn1.Class.UNIVERSAL, asn1.Type.GENERALIZEDTIME, false,\n asn1.dateToGeneralizedTime(date));\n }\n }\n\n // TODO: expose as common API call\n // create a RelativeDistinguishedName set\n // each value in the set is an AttributeTypeAndValue first\n // containing the type (an OID) and second the value\n return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // AttributeType\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(attr.type).getBytes()),\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n // AttributeValue\n value\n ])\n ]);\n}\n\n/**\n * Map messages encrypted content to ASN.1 objects.\n *\n * @param ec The encryptedContent object of the message.\n *\n * @return ASN.1 representation of the encryptedContent object (SEQUENCE).\n */\nfunction _encryptedContentToAsn1(ec) {\n return [\n // ContentType, always Data for the moment\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(forge.pki.oids.data).getBytes()),\n // ContentEncryptionAlgorithmIdentifier\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n // Algorithm\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n asn1.oidToDer(ec.algorithm).getBytes()),\n // Parameters (IV)\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n ec.parameter.getBytes())\n ]),\n // [0] EncryptedContent\n asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n ec.content.getBytes())\n ])\n ];\n}\n\n/**\n * Reads the \"common part\" of an PKCS#7 content block (in ASN.1 format)\n *\n * This function reads the \"common part\" of the PKCS#7 content blocks\n * EncryptedData and EnvelopedData, i.e. version number and symmetrically\n * encrypted content block.\n *\n * The result of the ASN.1 validate and capture process is returned\n * to allow the caller to extract further data, e.g. the list of recipients\n * in case of a EnvelopedData object.\n *\n * @param msg the PKCS#7 object to read the data to.\n * @param obj the ASN.1 representation of the content block.\n * @param validator the ASN.1 structure validator object to use.\n *\n * @return the value map captured by validator object.\n */\nfunction _fromAsn1(msg, obj, validator) {\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, validator, capture, errors)) {\n var error = new Error('Cannot read PKCS#7 message. ' +\n 'ASN.1 object is not a supported PKCS#7 message.');\n error.errors = error;\n throw error;\n }\n\n // Check contentType, so far we only support (raw) Data.\n var contentType = asn1.derToOid(capture.contentType);\n if(contentType !== forge.pki.oids.data) {\n throw new Error('Unsupported PKCS#7 message. ' +\n 'Only wrapped ContentType Data supported.');\n }\n\n if(capture.encryptedContent) {\n var content = '';\n if(forge.util.isArray(capture.encryptedContent)) {\n for(var i = 0; i < capture.encryptedContent.length; ++i) {\n if(capture.encryptedContent[i].type !== asn1.Type.OCTETSTRING) {\n throw new Error('Malformed PKCS#7 message, expecting encrypted ' +\n 'content constructed of only OCTET STRING objects.');\n }\n content += capture.encryptedContent[i].value;\n }\n } else {\n content = capture.encryptedContent;\n }\n msg.encryptedContent = {\n algorithm: asn1.derToOid(capture.encAlgorithm),\n parameter: forge.util.createBuffer(capture.encParameter.value),\n content: forge.util.createBuffer(content)\n };\n }\n\n if(capture.content) {\n var content = '';\n if(forge.util.isArray(capture.content)) {\n for(var i = 0; i < capture.content.length; ++i) {\n if(capture.content[i].type !== asn1.Type.OCTETSTRING) {\n throw new Error('Malformed PKCS#7 message, expecting ' +\n 'content constructed of only OCTET STRING objects.');\n }\n content += capture.content[i].value;\n }\n } else {\n content = capture.content;\n }\n msg.content = forge.util.createBuffer(content);\n }\n\n msg.version = capture.version.charCodeAt(0);\n msg.rawCapture = capture;\n\n return capture;\n}\n\n/**\n * Decrypt the symmetrically encrypted content block of the PKCS#7 message.\n *\n * Decryption is skipped in case the PKCS#7 message object already has a\n * (decrypted) content attribute. The algorithm, key and cipher parameters\n * (probably the iv) are taken from the encryptedContent attribute of the\n * message object.\n *\n * @param The PKCS#7 message object.\n */\nfunction _decryptContent(msg) {\n if(msg.encryptedContent.key === undefined) {\n throw new Error('Symmetric key not available.');\n }\n\n if(msg.content === undefined) {\n var ciph;\n\n switch(msg.encryptedContent.algorithm) {\n case forge.pki.oids['aes128-CBC']:\n case forge.pki.oids['aes192-CBC']:\n case forge.pki.oids['aes256-CBC']:\n ciph = forge.aes.createDecryptionCipher(msg.encryptedContent.key);\n break;\n\n case forge.pki.oids['desCBC']:\n case forge.pki.oids['des-EDE3-CBC']:\n ciph = forge.des.createDecryptionCipher(msg.encryptedContent.key);\n break;\n\n default:\n throw new Error('Unsupported symmetric cipher, OID ' +\n msg.encryptedContent.algorithm);\n }\n ciph.start(msg.encryptedContent.parameter);\n ciph.update(msg.encryptedContent.content);\n\n if(!ciph.finish()) {\n throw new Error('Symmetric decryption failed.');\n }\n\n msg.content = ciph.output;\n }\n}\n","/**\n * Functions to output keys in SSH-friendly formats.\n *\n * This is part of the Forge project which may be used under the terms of\n * either the BSD License or the GNU General Public License (GPL) Version 2.\n *\n * See: https://github.com/digitalbazaar/forge/blob/cbebca3780658703d925b61b2caffb1d263a6c1d/LICENSE\n *\n * @author https://github.com/shellac\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./hmac');\nrequire('./md5');\nrequire('./sha1');\nrequire('./util');\n\nvar ssh = module.exports = forge.ssh = forge.ssh || {};\n\n/**\n * Encodes (and optionally encrypts) a private RSA key as a Putty PPK file.\n *\n * @param privateKey the key.\n * @param passphrase a passphrase to protect the key (falsy for no encryption).\n * @param comment a comment to include in the key file.\n *\n * @return the PPK file as a string.\n */\nssh.privateKeyToPutty = function(privateKey, passphrase, comment) {\n comment = comment || '';\n passphrase = passphrase || '';\n var algorithm = 'ssh-rsa';\n var encryptionAlgorithm = (passphrase === '') ? 'none' : 'aes256-cbc';\n\n var ppk = 'PuTTY-User-Key-File-2: ' + algorithm + '\\r\\n';\n ppk += 'Encryption: ' + encryptionAlgorithm + '\\r\\n';\n ppk += 'Comment: ' + comment + '\\r\\n';\n\n // public key into buffer for ppk\n var pubbuffer = forge.util.createBuffer();\n _addStringToBuffer(pubbuffer, algorithm);\n _addBigIntegerToBuffer(pubbuffer, privateKey.e);\n _addBigIntegerToBuffer(pubbuffer, privateKey.n);\n\n // write public key\n var pub = forge.util.encode64(pubbuffer.bytes(), 64);\n var length = Math.floor(pub.length / 66) + 1; // 66 = 64 + \\r\\n\n ppk += 'Public-Lines: ' + length + '\\r\\n';\n ppk += pub;\n\n // private key into a buffer\n var privbuffer = forge.util.createBuffer();\n _addBigIntegerToBuffer(privbuffer, privateKey.d);\n _addBigIntegerToBuffer(privbuffer, privateKey.p);\n _addBigIntegerToBuffer(privbuffer, privateKey.q);\n _addBigIntegerToBuffer(privbuffer, privateKey.qInv);\n\n // optionally encrypt the private key\n var priv;\n if(!passphrase) {\n // use the unencrypted buffer\n priv = forge.util.encode64(privbuffer.bytes(), 64);\n } else {\n // encrypt RSA key using passphrase\n var encLen = privbuffer.length() + 16 - 1;\n encLen -= encLen % 16;\n\n // pad private key with sha1-d data -- needs to be a multiple of 16\n var padding = _sha1(privbuffer.bytes());\n\n padding.truncate(padding.length() - encLen + privbuffer.length());\n privbuffer.putBuffer(padding);\n\n var aeskey = forge.util.createBuffer();\n aeskey.putBuffer(_sha1('\\x00\\x00\\x00\\x00', passphrase));\n aeskey.putBuffer(_sha1('\\x00\\x00\\x00\\x01', passphrase));\n\n // encrypt some bytes using CBC mode\n // key is 40 bytes, so truncate *by* 8 bytes\n var cipher = forge.aes.createEncryptionCipher(aeskey.truncate(8), 'CBC');\n cipher.start(forge.util.createBuffer().fillWithByte(0, 16));\n cipher.update(privbuffer.copy());\n cipher.finish();\n var encrypted = cipher.output;\n\n // Note: this appears to differ from Putty -- is forge wrong, or putty?\n // due to padding we finish as an exact multiple of 16\n encrypted.truncate(16); // all padding\n\n priv = forge.util.encode64(encrypted.bytes(), 64);\n }\n\n // output private key\n length = Math.floor(priv.length / 66) + 1; // 64 + \\r\\n\n ppk += '\\r\\nPrivate-Lines: ' + length + '\\r\\n';\n ppk += priv;\n\n // MAC\n var mackey = _sha1('putty-private-key-file-mac-key', passphrase);\n\n var macbuffer = forge.util.createBuffer();\n _addStringToBuffer(macbuffer, algorithm);\n _addStringToBuffer(macbuffer, encryptionAlgorithm);\n _addStringToBuffer(macbuffer, comment);\n macbuffer.putInt32(pubbuffer.length());\n macbuffer.putBuffer(pubbuffer);\n macbuffer.putInt32(privbuffer.length());\n macbuffer.putBuffer(privbuffer);\n\n var hmac = forge.hmac.create();\n hmac.start('sha1', mackey);\n hmac.update(macbuffer.bytes());\n\n ppk += '\\r\\nPrivate-MAC: ' + hmac.digest().toHex() + '\\r\\n';\n\n return ppk;\n};\n\n/**\n * Encodes a public RSA key as an OpenSSH file.\n *\n * @param key the key.\n * @param comment a comment.\n *\n * @return the public key in OpenSSH format.\n */\nssh.publicKeyToOpenSSH = function(key, comment) {\n var type = 'ssh-rsa';\n comment = comment || '';\n\n var buffer = forge.util.createBuffer();\n _addStringToBuffer(buffer, type);\n _addBigIntegerToBuffer(buffer, key.e);\n _addBigIntegerToBuffer(buffer, key.n);\n\n return type + ' ' + forge.util.encode64(buffer.bytes()) + ' ' + comment;\n};\n\n/**\n * Encodes a private RSA key as an OpenSSH file.\n *\n * @param key the key.\n * @param passphrase a passphrase to protect the key (falsy for no encryption).\n *\n * @return the public key in OpenSSH format.\n */\nssh.privateKeyToOpenSSH = function(privateKey, passphrase) {\n if(!passphrase) {\n return forge.pki.privateKeyToPem(privateKey);\n }\n // OpenSSH private key is just a legacy format, it seems\n return forge.pki.encryptRsaPrivateKey(privateKey, passphrase,\n {legacy: true, algorithm: 'aes128'});\n};\n\n/**\n * Gets the SSH fingerprint for the given public key.\n *\n * @param options the options to use.\n * [md] the message digest object to use (defaults to forge.md.md5).\n * [encoding] an alternative output encoding, such as 'hex'\n * (defaults to none, outputs a byte buffer).\n * [delimiter] the delimiter to use between bytes for 'hex' encoded\n * output, eg: ':' (defaults to none).\n *\n * @return the fingerprint as a byte buffer or other encoding based on options.\n */\nssh.getPublicKeyFingerprint = function(key, options) {\n options = options || {};\n var md = options.md || forge.md.md5.create();\n\n var type = 'ssh-rsa';\n var buffer = forge.util.createBuffer();\n _addStringToBuffer(buffer, type);\n _addBigIntegerToBuffer(buffer, key.e);\n _addBigIntegerToBuffer(buffer, key.n);\n\n // hash public key bytes\n md.start();\n md.update(buffer.getBytes());\n var digest = md.digest();\n if(options.encoding === 'hex') {\n var hex = digest.toHex();\n if(options.delimiter) {\n return hex.match(/.{2}/g).join(options.delimiter);\n }\n return hex;\n } else if(options.encoding === 'binary') {\n return digest.getBytes();\n } else if(options.encoding) {\n throw new Error('Unknown encoding \"' + options.encoding + '\".');\n }\n return digest;\n};\n\n/**\n * Adds len(val) then val to a buffer.\n *\n * @param buffer the buffer to add to.\n * @param val a big integer.\n */\nfunction _addBigIntegerToBuffer(buffer, val) {\n var hexVal = val.toString(16);\n // ensure 2s complement +ve\n if(hexVal[0] >= '8') {\n hexVal = '00' + hexVal;\n }\n var bytes = forge.util.hexToBytes(hexVal);\n buffer.putInt32(bytes.length);\n buffer.putBytes(bytes);\n}\n\n/**\n * Adds len(val) then val to a buffer.\n *\n * @param buffer the buffer to add to.\n * @param val a string.\n */\nfunction _addStringToBuffer(buffer, val) {\n buffer.putInt32(val.length);\n buffer.putString(val);\n}\n\n/**\n * Hashes the arguments into one value using SHA-1.\n *\n * @return the sha1 hash of the provided arguments.\n */\nfunction _sha1() {\n var sha = forge.md.sha1.create();\n var num = arguments.length;\n for (var i = 0; i < num; ++i) {\n sha.update(arguments[i]);\n }\n return sha.digest();\n}\n","/**\n * Support for concurrent task management and synchronization in web\n * applications.\n *\n * @author Dave Longley\n * @author David I. Lehn <dlehn@digitalbazaar.com>\n *\n * Copyright (c) 2009-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./debug');\nrequire('./log');\nrequire('./util');\n\n// logging category\nvar cat = 'forge.task';\n\n// verbose level\n// 0: off, 1: a little, 2: a whole lot\n// Verbose debug logging is surrounded by a level check to avoid the\n// performance issues with even calling the logging code regardless if it\n// is actually logged. For performance reasons this should not be set to 2\n// for production use.\n// ex: if(sVL >= 2) forge.log.verbose(....)\nvar sVL = 0;\n\n// track tasks for debugging\nvar sTasks = {};\nvar sNextTaskId = 0;\n// debug access\nforge.debug.set(cat, 'tasks', sTasks);\n\n// a map of task type to task queue\nvar sTaskQueues = {};\n// debug access\nforge.debug.set(cat, 'queues', sTaskQueues);\n\n// name for unnamed tasks\nvar sNoTaskName = '?';\n\n// maximum number of doNext() recursions before a context swap occurs\n// FIXME: might need to tweak this based on the browser\nvar sMaxRecursions = 30;\n\n// time slice for doing tasks before a context swap occurs\n// FIXME: might need to tweak this based on the browser\nvar sTimeSlice = 20;\n\n/**\n * Task states.\n *\n * READY: ready to start processing\n * RUNNING: task or a subtask is running\n * BLOCKED: task is waiting to acquire N permits to continue\n * SLEEPING: task is sleeping for a period of time\n * DONE: task is done\n * ERROR: task has an error\n */\nvar READY = 'ready';\nvar RUNNING = 'running';\nvar BLOCKED = 'blocked';\nvar SLEEPING = 'sleeping';\nvar DONE = 'done';\nvar ERROR = 'error';\n\n/**\n * Task actions. Used to control state transitions.\n *\n * STOP: stop processing\n * START: start processing tasks\n * BLOCK: block task from continuing until 1 or more permits are released\n * UNBLOCK: release one or more permits\n * SLEEP: sleep for a period of time\n * WAKEUP: wakeup early from SLEEPING state\n * CANCEL: cancel further tasks\n * FAIL: a failure occured\n */\nvar STOP = 'stop';\nvar START = 'start';\nvar BLOCK = 'block';\nvar UNBLOCK = 'unblock';\nvar SLEEP = 'sleep';\nvar WAKEUP = 'wakeup';\nvar CANCEL = 'cancel';\nvar FAIL = 'fail';\n\n/**\n * State transition table.\n *\n * nextState = sStateTable[currentState][action]\n */\nvar sStateTable = {};\n\nsStateTable[READY] = {};\nsStateTable[READY][STOP] = READY;\nsStateTable[READY][START] = RUNNING;\nsStateTable[READY][CANCEL] = DONE;\nsStateTable[READY][FAIL] = ERROR;\n\nsStateTable[RUNNING] = {};\nsStateTable[RUNNING][STOP] = READY;\nsStateTable[RUNNING][START] = RUNNING;\nsStateTable[RUNNING][BLOCK] = BLOCKED;\nsStateTable[RUNNING][UNBLOCK] = RUNNING;\nsStateTable[RUNNING][SLEEP] = SLEEPING;\nsStateTable[RUNNING][WAKEUP] = RUNNING;\nsStateTable[RUNNING][CANCEL] = DONE;\nsStateTable[RUNNING][FAIL] = ERROR;\n\nsStateTable[BLOCKED] = {};\nsStateTable[BLOCKED][STOP] = BLOCKED;\nsStateTable[BLOCKED][START] = BLOCKED;\nsStateTable[BLOCKED][BLOCK] = BLOCKED;\nsStateTable[BLOCKED][UNBLOCK] = BLOCKED;\nsStateTable[BLOCKED][SLEEP] = BLOCKED;\nsStateTable[BLOCKED][WAKEUP] = BLOCKED;\nsStateTable[BLOCKED][CANCEL] = DONE;\nsStateTable[BLOCKED][FAIL] = ERROR;\n\nsStateTable[SLEEPING] = {};\nsStateTable[SLEEPING][STOP] = SLEEPING;\nsStateTable[SLEEPING][START] = SLEEPING;\nsStateTable[SLEEPING][BLOCK] = SLEEPING;\nsStateTable[SLEEPING][UNBLOCK] = SLEEPING;\nsStateTable[SLEEPING][SLEEP] = SLEEPING;\nsStateTable[SLEEPING][WAKEUP] = SLEEPING;\nsStateTable[SLEEPING][CANCEL] = DONE;\nsStateTable[SLEEPING][FAIL] = ERROR;\n\nsStateTable[DONE] = {};\nsStateTable[DONE][STOP] = DONE;\nsStateTable[DONE][START] = DONE;\nsStateTable[DONE][BLOCK] = DONE;\nsStateTable[DONE][UNBLOCK] = DONE;\nsStateTable[DONE][SLEEP] = DONE;\nsStateTable[DONE][WAKEUP] = DONE;\nsStateTable[DONE][CANCEL] = DONE;\nsStateTable[DONE][FAIL] = ERROR;\n\nsStateTable[ERROR] = {};\nsStateTable[ERROR][STOP] = ERROR;\nsStateTable[ERROR][START] = ERROR;\nsStateTable[ERROR][BLOCK] = ERROR;\nsStateTable[ERROR][UNBLOCK] = ERROR;\nsStateTable[ERROR][SLEEP] = ERROR;\nsStateTable[ERROR][WAKEUP] = ERROR;\nsStateTable[ERROR][CANCEL] = ERROR;\nsStateTable[ERROR][FAIL] = ERROR;\n\n/**\n * Creates a new task.\n *\n * @param options options for this task\n * run: the run function for the task (required)\n * name: the run function for the task (optional)\n * parent: parent of this task (optional)\n *\n * @return the empty task.\n */\nvar Task = function(options) {\n // task id\n this.id = -1;\n\n // task name\n this.name = options.name || sNoTaskName;\n\n // task has no parent\n this.parent = options.parent || null;\n\n // save run function\n this.run = options.run;\n\n // create a queue of subtasks to run\n this.subtasks = [];\n\n // error flag\n this.error = false;\n\n // state of the task\n this.state = READY;\n\n // number of times the task has been blocked (also the number\n // of permits needed to be released to continue running)\n this.blocks = 0;\n\n // timeout id when sleeping\n this.timeoutId = null;\n\n // no swap time yet\n this.swapTime = null;\n\n // no user data\n this.userData = null;\n\n // initialize task\n // FIXME: deal with overflow\n this.id = sNextTaskId++;\n sTasks[this.id] = this;\n if(sVL >= 1) {\n forge.log.verbose(cat, '[%s][%s] init', this.id, this.name, this);\n }\n};\n\n/**\n * Logs debug information on this task and the system state.\n */\nTask.prototype.debug = function(msg) {\n msg = msg || '';\n forge.log.debug(cat, msg,\n '[%s][%s] task:', this.id, this.name, this,\n 'subtasks:', this.subtasks.length,\n 'queue:', sTaskQueues);\n};\n\n/**\n * Adds a subtask to run after task.doNext() or task.fail() is called.\n *\n * @param name human readable name for this task (optional).\n * @param subrun a function to run that takes the current task as\n * its first parameter.\n *\n * @return the current task (useful for chaining next() calls).\n */\nTask.prototype.next = function(name, subrun) {\n // juggle parameters if it looks like no name is given\n if(typeof(name) === 'function') {\n subrun = name;\n\n // inherit parent's name\n name = this.name;\n }\n // create subtask, set parent to this task, propagate callbacks\n var subtask = new Task({\n run: subrun,\n name: name,\n parent: this\n });\n // start subtasks running\n subtask.state = RUNNING;\n subtask.type = this.type;\n subtask.successCallback = this.successCallback || null;\n subtask.failureCallback = this.failureCallback || null;\n\n // queue a new subtask\n this.subtasks.push(subtask);\n\n return this;\n};\n\n/**\n * Adds subtasks to run in parallel after task.doNext() or task.fail()\n * is called.\n *\n * @param name human readable name for this task (optional).\n * @param subrun functions to run that take the current task as\n * their first parameter.\n *\n * @return the current task (useful for chaining next() calls).\n */\nTask.prototype.parallel = function(name, subrun) {\n // juggle parameters if it looks like no name is given\n if(forge.util.isArray(name)) {\n subrun = name;\n\n // inherit parent's name\n name = this.name;\n }\n // Wrap parallel tasks in a regular task so they are started at the\n // proper time.\n return this.next(name, function(task) {\n // block waiting for subtasks\n var ptask = task;\n ptask.block(subrun.length);\n\n // we pass the iterator from the loop below as a parameter\n // to a function because it is otherwise included in the\n // closure and changes as the loop changes -- causing i\n // to always be set to its highest value\n var startParallelTask = function(pname, pi) {\n forge.task.start({\n type: pname,\n run: function(task) {\n subrun[pi](task);\n },\n success: function(task) {\n ptask.unblock();\n },\n failure: function(task) {\n ptask.unblock();\n }\n });\n };\n\n for(var i = 0; i < subrun.length; i++) {\n // Type must be unique so task starts in parallel:\n // name + private string + task id + sub-task index\n // start tasks in parallel and unblock when the finish\n var pname = name + '__parallel-' + task.id + '-' + i;\n var pi = i;\n startParallelTask(pname, pi);\n }\n });\n};\n\n/**\n * Stops a running task.\n */\nTask.prototype.stop = function() {\n this.state = sStateTable[this.state][STOP];\n};\n\n/**\n * Starts running a task.\n */\nTask.prototype.start = function() {\n this.error = false;\n this.state = sStateTable[this.state][START];\n\n // try to restart\n if(this.state === RUNNING) {\n this.start = new Date();\n this.run(this);\n runNext(this, 0);\n }\n};\n\n/**\n * Blocks a task until it one or more permits have been released. The\n * task will not resume until the requested number of permits have\n * been released with call(s) to unblock().\n *\n * @param n number of permits to wait for(default: 1).\n */\nTask.prototype.block = function(n) {\n n = typeof(n) === 'undefined' ? 1 : n;\n this.blocks += n;\n if(this.blocks > 0) {\n this.state = sStateTable[this.state][BLOCK];\n }\n};\n\n/**\n * Releases a permit to unblock a task. If a task was blocked by\n * requesting N permits via block(), then it will only continue\n * running once enough permits have been released via unblock() calls.\n *\n * If multiple processes need to synchronize with a single task then\n * use a condition variable (see forge.task.createCondition). It is\n * an error to unblock a task more times than it has been blocked.\n *\n * @param n number of permits to release (default: 1).\n *\n * @return the current block count (task is unblocked when count is 0)\n */\nTask.prototype.unblock = function(n) {\n n = typeof(n) === 'undefined' ? 1 : n;\n this.blocks -= n;\n if(this.blocks === 0 && this.state !== DONE) {\n this.state = RUNNING;\n runNext(this, 0);\n }\n return this.blocks;\n};\n\n/**\n * Sleep for a period of time before resuming tasks.\n *\n * @param n number of milliseconds to sleep (default: 0).\n */\nTask.prototype.sleep = function(n) {\n n = typeof(n) === 'undefined' ? 0 : n;\n this.state = sStateTable[this.state][SLEEP];\n var self = this;\n this.timeoutId = setTimeout(function() {\n self.timeoutId = null;\n self.state = RUNNING;\n runNext(self, 0);\n }, n);\n};\n\n/**\n * Waits on a condition variable until notified. The next task will\n * not be scheduled until notification. A condition variable can be\n * created with forge.task.createCondition().\n *\n * Once cond.notify() is called, the task will continue.\n *\n * @param cond the condition variable to wait on.\n */\nTask.prototype.wait = function(cond) {\n cond.wait(this);\n};\n\n/**\n * If sleeping, wakeup and continue running tasks.\n */\nTask.prototype.wakeup = function() {\n if(this.state === SLEEPING) {\n cancelTimeout(this.timeoutId);\n this.timeoutId = null;\n this.state = RUNNING;\n runNext(this, 0);\n }\n};\n\n/**\n * Cancel all remaining subtasks of this task.\n */\nTask.prototype.cancel = function() {\n this.state = sStateTable[this.state][CANCEL];\n // remove permits needed\n this.permitsNeeded = 0;\n // cancel timeouts\n if(this.timeoutId !== null) {\n cancelTimeout(this.timeoutId);\n this.timeoutId = null;\n }\n // remove subtasks\n this.subtasks = [];\n};\n\n/**\n * Finishes this task with failure and sets error flag. The entire\n * task will be aborted unless the next task that should execute\n * is passed as a parameter. This allows levels of subtasks to be\n * skipped. For instance, to abort only this tasks's subtasks, then\n * call fail(task.parent). To abort this task's subtasks and its\n * parent's subtasks, call fail(task.parent.parent). To abort\n * all tasks and simply call the task callback, call fail() or\n * fail(null).\n *\n * The task callback (success or failure) will always, eventually, be\n * called.\n *\n * @param next the task to continue at, or null to abort entirely.\n */\nTask.prototype.fail = function(next) {\n // set error flag\n this.error = true;\n\n // finish task\n finish(this, true);\n\n if(next) {\n // propagate task info\n next.error = this.error;\n next.swapTime = this.swapTime;\n next.userData = this.userData;\n\n // do next task as specified\n runNext(next, 0);\n } else {\n if(this.parent !== null) {\n // finish root task (ensures it is removed from task queue)\n var parent = this.parent;\n while(parent.parent !== null) {\n // propagate task info\n parent.error = this.error;\n parent.swapTime = this.swapTime;\n parent.userData = this.userData;\n parent = parent.parent;\n }\n finish(parent, true);\n }\n\n // call failure callback if one exists\n if(this.failureCallback) {\n this.failureCallback(this);\n }\n }\n};\n\n/**\n * Asynchronously start a task.\n *\n * @param task the task to start.\n */\nvar start = function(task) {\n task.error = false;\n task.state = sStateTable[task.state][START];\n setTimeout(function() {\n if(task.state === RUNNING) {\n task.swapTime = +new Date();\n task.run(task);\n runNext(task, 0);\n }\n }, 0);\n};\n\n/**\n * Run the next subtask or finish this task.\n *\n * @param task the task to process.\n * @param recurse the recursion count.\n */\nvar runNext = function(task, recurse) {\n // get time since last context swap (ms), if enough time has passed set\n // swap to true to indicate that doNext was performed asynchronously\n // also, if recurse is too high do asynchronously\n var swap =\n (recurse > sMaxRecursions) ||\n (+new Date() - task.swapTime) > sTimeSlice;\n\n var doNext = function(recurse) {\n recurse++;\n if(task.state === RUNNING) {\n if(swap) {\n // update swap time\n task.swapTime = +new Date();\n }\n\n if(task.subtasks.length > 0) {\n // run next subtask\n var subtask = task.subtasks.shift();\n subtask.error = task.error;\n subtask.swapTime = task.swapTime;\n subtask.userData = task.userData;\n subtask.run(subtask);\n if(!subtask.error) {\n runNext(subtask, recurse);\n }\n } else {\n finish(task);\n\n if(!task.error) {\n // chain back up and run parent\n if(task.parent !== null) {\n // propagate task info\n task.parent.error = task.error;\n task.parent.swapTime = task.swapTime;\n task.parent.userData = task.userData;\n\n // no subtasks left, call run next subtask on parent\n runNext(task.parent, recurse);\n }\n }\n }\n }\n };\n\n if(swap) {\n // we're swapping, so run asynchronously\n setTimeout(doNext, 0);\n } else {\n // not swapping, so run synchronously\n doNext(recurse);\n }\n};\n\n/**\n * Finishes a task and looks for the next task in the queue to start.\n *\n * @param task the task to finish.\n * @param suppressCallbacks true to suppress callbacks.\n */\nvar finish = function(task, suppressCallbacks) {\n // subtask is now done\n task.state = DONE;\n\n delete sTasks[task.id];\n if(sVL >= 1) {\n forge.log.verbose(cat, '[%s][%s] finish',\n task.id, task.name, task);\n }\n\n // only do queue processing for root tasks\n if(task.parent === null) {\n // report error if queue is missing\n if(!(task.type in sTaskQueues)) {\n forge.log.error(cat,\n '[%s][%s] task queue missing [%s]',\n task.id, task.name, task.type);\n } else if(sTaskQueues[task.type].length === 0) {\n // report error if queue is empty\n forge.log.error(cat,\n '[%s][%s] task queue empty [%s]',\n task.id, task.name, task.type);\n } else if(sTaskQueues[task.type][0] !== task) {\n // report error if this task isn't the first in the queue\n forge.log.error(cat,\n '[%s][%s] task not first in queue [%s]',\n task.id, task.name, task.type);\n } else {\n // remove ourselves from the queue\n sTaskQueues[task.type].shift();\n // clean up queue if it is empty\n if(sTaskQueues[task.type].length === 0) {\n if(sVL >= 1) {\n forge.log.verbose(cat, '[%s][%s] delete queue [%s]',\n task.id, task.name, task.type);\n }\n /* Note: Only a task can delete a queue of its own type. This\n is used as a way to synchronize tasks. If a queue for a certain\n task type exists, then a task of that type is running.\n */\n delete sTaskQueues[task.type];\n } else {\n // dequeue the next task and start it\n if(sVL >= 1) {\n forge.log.verbose(cat,\n '[%s][%s] queue start next [%s] remain:%s',\n task.id, task.name, task.type,\n sTaskQueues[task.type].length);\n }\n sTaskQueues[task.type][0].start();\n }\n }\n\n if(!suppressCallbacks) {\n // call final callback if one exists\n if(task.error && task.failureCallback) {\n task.failureCallback(task);\n } else if(!task.error && task.successCallback) {\n task.successCallback(task);\n }\n }\n }\n};\n\n/* Tasks API */\nmodule.exports = forge.task = forge.task || {};\n\n/**\n * Starts a new task that will run the passed function asynchronously.\n *\n * In order to finish the task, either task.doNext() or task.fail()\n * *must* be called.\n *\n * The task must have a type (a string identifier) that can be used to\n * synchronize it with other tasks of the same type. That type can also\n * be used to cancel tasks that haven't started yet.\n *\n * To start a task, the following object must be provided as a parameter\n * (each function takes a task object as its first parameter):\n *\n * {\n * type: the type of task.\n * run: the function to run to execute the task.\n * success: a callback to call when the task succeeds (optional).\n * failure: a callback to call when the task fails (optional).\n * }\n *\n * @param options the object as described above.\n */\nforge.task.start = function(options) {\n // create a new task\n var task = new Task({\n run: options.run,\n name: options.name || sNoTaskName\n });\n task.type = options.type;\n task.successCallback = options.success || null;\n task.failureCallback = options.failure || null;\n\n // append the task onto the appropriate queue\n if(!(task.type in sTaskQueues)) {\n if(sVL >= 1) {\n forge.log.verbose(cat, '[%s][%s] create queue [%s]',\n task.id, task.name, task.type);\n }\n // create the queue with the new task\n sTaskQueues[task.type] = [task];\n start(task);\n } else {\n // push the task onto the queue, it will be run after a task\n // with the same type completes\n sTaskQueues[options.type].push(task);\n }\n};\n\n/**\n * Cancels all tasks of the given type that haven't started yet.\n *\n * @param type the type of task to cancel.\n */\nforge.task.cancel = function(type) {\n // find the task queue\n if(type in sTaskQueues) {\n // empty all but the current task from the queue\n sTaskQueues[type] = [sTaskQueues[type][0]];\n }\n};\n\n/**\n * Creates a condition variable to synchronize tasks. To make a task wait\n * on the condition variable, call task.wait(condition). To notify all\n * tasks that are waiting, call condition.notify().\n *\n * @return the condition variable.\n */\nforge.task.createCondition = function() {\n var cond = {\n // all tasks that are blocked\n tasks: {}\n };\n\n /**\n * Causes the given task to block until notify is called. If the task\n * is already waiting on this condition then this is a no-op.\n *\n * @param task the task to cause to wait.\n */\n cond.wait = function(task) {\n // only block once\n if(!(task.id in cond.tasks)) {\n task.block();\n cond.tasks[task.id] = task;\n }\n };\n\n /**\n * Notifies all waiting tasks to wake up.\n */\n cond.notify = function() {\n // since unblock() will run the next task from here, make sure to\n // clear the condition's blocked task list before unblocking\n var tmp = cond.tasks;\n cond.tasks = {};\n for(var id in tmp) {\n tmp[id].unblock();\n }\n };\n\n return cond;\n};\n","/**\n * @fileoverview\n * - modified davidshimjs/qrcodejs library for use in node.js\n * - Using the 'QRCode for Javascript library'\n * - Fixed dataset of 'QRCode for Javascript library' for support full-spec.\n * - this library has no dependencies.\n *\n * @version 0.9.1 (2016-02-12)\n * @author davidshimjs, papnkukn\n * @see <a href=\"http://www.d-project.com/\" target=\"_blank\">http://www.d-project.com/</a>\n * @see <a href=\"http://jeromeetienne.github.com/jquery-qrcode/\" target=\"_blank\">http://jeromeetienne.github.com/jquery-qrcode/</a>\n * @see <a href=\"https://github.com/davidshimjs/qrcodejs\" target=\"_blank\">https://github.com/davidshimjs/qrcodejs</a>\n */\n\n//---------------------------------------------------------------------\n// QRCode for JavaScript\n//\n// Copyright (c) 2009 Kazuhiko Arase\n//\n// URL: http://www.d-project.com/\n//\n// Licensed under the MIT license:\n// http://www.opensource.org/licenses/mit-license.php\n//\n// The word \"QR Code\" is registered trademark of \n// DENSO WAVE INCORPORATED\n// http://www.denso-wave.com/qrcode/faqpatent-e.html\n//\n//---------------------------------------------------------------------\nfunction QR8bitByte(data) {\n this.mode = QRMode.MODE_8BIT_BYTE;\n this.data = data;\n this.parsedData = [];\n\n // Added to support UTF-8 Characters\n for (var i = 0, l = this.data.length; i < l; i++) {\n var byteArray = [];\n var code = this.data.charCodeAt(i);\n\n if (code > 0x10000) {\n byteArray[0] = 0xF0 | ((code & 0x1C0000) >>> 18);\n byteArray[1] = 0x80 | ((code & 0x3F000) >>> 12);\n byteArray[2] = 0x80 | ((code & 0xFC0) >>> 6);\n byteArray[3] = 0x80 | (code & 0x3F);\n } else if (code > 0x800) {\n byteArray[0] = 0xE0 | ((code & 0xF000) >>> 12);\n byteArray[1] = 0x80 | ((code & 0xFC0) >>> 6);\n byteArray[2] = 0x80 | (code & 0x3F);\n } else if (code > 0x80) {\n byteArray[0] = 0xC0 | ((code & 0x7C0) >>> 6);\n byteArray[1] = 0x80 | (code & 0x3F);\n } else {\n byteArray[0] = code;\n }\n\n this.parsedData.push(byteArray);\n }\n\n this.parsedData = Array.prototype.concat.apply([], this.parsedData);\n\n if (this.parsedData.length != this.data.length) {\n this.parsedData.unshift(191);\n this.parsedData.unshift(187);\n this.parsedData.unshift(239);\n }\n}\n\nQR8bitByte.prototype = {\n getLength: function (buffer) {\n return this.parsedData.length;\n },\n write: function (buffer) {\n for (var i = 0, l = this.parsedData.length; i < l; i++) {\n buffer.put(this.parsedData[i], 8);\n }\n }\n};\n\nfunction QRCodeModel(typeNumber, errorCorrectLevel) {\n this.typeNumber = typeNumber;\n this.errorCorrectLevel = errorCorrectLevel;\n this.modules = null;\n this.moduleCount = 0;\n this.dataCache = null;\n this.dataList = [];\n}\n\nQRCodeModel.prototype={addData:function(data){var newData=new QR8bitByte(data);this.dataList.push(newData);this.dataCache=null;},isDark:function(row,col){if(row<0||this.moduleCount<=row||col<0||this.moduleCount<=col){throw new Error(row+\",\"+col);}\nreturn this.modules[row][col];},getModuleCount:function(){return this.moduleCount;},make:function(){this.makeImpl(false,this.getBestMaskPattern());},makeImpl:function(test,maskPattern){this.moduleCount=this.typeNumber*4+17;this.modules=new Array(this.moduleCount);for(var row=0;row<this.moduleCount;row++){this.modules[row]=new Array(this.moduleCount);for(var col=0;col<this.moduleCount;col++){this.modules[row][col]=null;}}\nthis.setupPositionProbePattern(0,0);this.setupPositionProbePattern(this.moduleCount-7,0);this.setupPositionProbePattern(0,this.moduleCount-7);this.setupPositionAdjustPattern();this.setupTimingPattern();this.setupTypeInfo(test,maskPattern);if(this.typeNumber>=7){this.setupTypeNumber(test);}\nif(this.dataCache==null){this.dataCache=QRCodeModel.createData(this.typeNumber,this.errorCorrectLevel,this.dataList);}\nthis.mapData(this.dataCache,maskPattern);},setupPositionProbePattern:function(row,col){for(var r=-1;r<=7;r++){if(row+r<=-1||this.moduleCount<=row+r)continue;for(var c=-1;c<=7;c++){if(col+c<=-1||this.moduleCount<=col+c)continue;if((0<=r&&r<=6&&(c==0||c==6))||(0<=c&&c<=6&&(r==0||r==6))||(2<=r&&r<=4&&2<=c&&c<=4)){this.modules[row+r][col+c]=true;}else{this.modules[row+r][col+c]=false;}}}},getBestMaskPattern:function(){var minLostPoint=0;var pattern=0;for(var i=0;i<8;i++){this.makeImpl(true,i);var lostPoint=QRUtil.getLostPoint(this);if(i==0||minLostPoint>lostPoint){minLostPoint=lostPoint;pattern=i;}}\nreturn pattern;},createMovieClip:function(target_mc,instance_name,depth){var qr_mc=target_mc.createEmptyMovieClip(instance_name,depth);var cs=1;this.make();for(var row=0;row<this.modules.length;row++){var y=row*cs;for(var col=0;col<this.modules[row].length;col++){var x=col*cs;var dark=this.modules[row][col];if(dark){qr_mc.beginFill(0,100);qr_mc.moveTo(x,y);qr_mc.lineTo(x+cs,y);qr_mc.lineTo(x+cs,y+cs);qr_mc.lineTo(x,y+cs);qr_mc.endFill();}}}\nreturn qr_mc;},setupTimingPattern:function(){for(var r=8;r<this.moduleCount-8;r++){if(this.modules[r][6]!=null){continue;}\nthis.modules[r][6]=(r%2==0);}\nfor(var c=8;c<this.moduleCount-8;c++){if(this.modules[6][c]!=null){continue;}\nthis.modules[6][c]=(c%2==0);}},setupPositionAdjustPattern:function(){var pos=QRUtil.getPatternPosition(this.typeNumber);for(var i=0;i<pos.length;i++){for(var j=0;j<pos.length;j++){var row=pos[i];var col=pos[j];if(this.modules[row][col]!=null){continue;}\nfor(var r=-2;r<=2;r++){for(var c=-2;c<=2;c++){if(r==-2||r==2||c==-2||c==2||(r==0&&c==0)){this.modules[row+r][col+c]=true;}else{this.modules[row+r][col+c]=false;}}}}}},setupTypeNumber:function(test){var bits=QRUtil.getBCHTypeNumber(this.typeNumber);for(var i=0;i<18;i++){var mod=(!test&&((bits>>i)&1)==1);this.modules[Math.floor(i/3)][i%3+this.moduleCount-8-3]=mod;}\nfor(var i=0;i<18;i++){var mod=(!test&&((bits>>i)&1)==1);this.modules[i%3+this.moduleCount-8-3][Math.floor(i/3)]=mod;}},setupTypeInfo:function(test,maskPattern){var data=(this.errorCorrectLevel<<3)|maskPattern;var bits=QRUtil.getBCHTypeInfo(data);for(var i=0;i<15;i++){var mod=(!test&&((bits>>i)&1)==1);if(i<6){this.modules[i][8]=mod;}else if(i<8){this.modules[i+1][8]=mod;}else{this.modules[this.moduleCount-15+i][8]=mod;}}\nfor(var i=0;i<15;i++){var mod=(!test&&((bits>>i)&1)==1);if(i<8){this.modules[8][this.moduleCount-i-1]=mod;}else if(i<9){this.modules[8][15-i-1+1]=mod;}else{this.modules[8][15-i-1]=mod;}}\nthis.modules[this.moduleCount-8][8]=(!test);},mapData:function(data,maskPattern){var inc=-1;var row=this.moduleCount-1;var bitIndex=7;var byteIndex=0;for(var col=this.moduleCount-1;col>0;col-=2){if(col==6)col--;while(true){for(var c=0;c<2;c++){if(this.modules[row][col-c]==null){var dark=false;if(byteIndex<data.length){dark=(((data[byteIndex]>>>bitIndex)&1)==1);}\nvar mask=QRUtil.getMask(maskPattern,row,col-c);if(mask){dark=!dark;}\nthis.modules[row][col-c]=dark;bitIndex--;if(bitIndex==-1){byteIndex++;bitIndex=7;}}}\nrow+=inc;if(row<0||this.moduleCount<=row){row-=inc;inc=-inc;break;}}}}};QRCodeModel.PAD0=0xEC;QRCodeModel.PAD1=0x11;QRCodeModel.createData=function(typeNumber,errorCorrectLevel,dataList){var rsBlocks=QRRSBlock.getRSBlocks(typeNumber,errorCorrectLevel);var buffer=new QRBitBuffer();for(var i=0;i<dataList.length;i++){var data=dataList[i];buffer.put(data.mode,4);buffer.put(data.getLength(),QRUtil.getLengthInBits(data.mode,typeNumber));data.write(buffer);}\nvar totalDataCount=0;for(var i=0;i<rsBlocks.length;i++){totalDataCount+=rsBlocks[i].dataCount;}\nif(buffer.getLengthInBits()>totalDataCount*8){throw new Error(\"code length overflow. (\"\n+buffer.getLengthInBits()\n+\">\"\n+totalDataCount*8\n+\")\");}\nif(buffer.getLengthInBits()+4<=totalDataCount*8){buffer.put(0,4);}\nwhile(buffer.getLengthInBits()%8!=0){buffer.putBit(false);}\nwhile(true){if(buffer.getLengthInBits()>=totalDataCount*8){break;}\nbuffer.put(QRCodeModel.PAD0,8);if(buffer.getLengthInBits()>=totalDataCount*8){break;}\nbuffer.put(QRCodeModel.PAD1,8);}\nreturn QRCodeModel.createBytes(buffer,rsBlocks);};QRCodeModel.createBytes=function(buffer,rsBlocks){var offset=0;var maxDcCount=0;var maxEcCount=0;var dcdata=new Array(rsBlocks.length);var ecdata=new Array(rsBlocks.length);for(var r=0;r<rsBlocks.length;r++){var dcCount=rsBlocks[r].dataCount;var ecCount=rsBlocks[r].totalCount-dcCount;maxDcCount=Math.max(maxDcCount,dcCount);maxEcCount=Math.max(maxEcCount,ecCount);dcdata[r]=new Array(dcCount);for(var i=0;i<dcdata[r].length;i++){dcdata[r][i]=0xff&buffer.buffer[i+offset];}\noffset+=dcCount;var rsPoly=QRUtil.getErrorCorrectPolynomial(ecCount);var rawPoly=new QRPolynomial(dcdata[r],rsPoly.getLength()-1);var modPoly=rawPoly.mod(rsPoly);ecdata[r]=new Array(rsPoly.getLength()-1);for(var i=0;i<ecdata[r].length;i++){var modIndex=i+modPoly.getLength()-ecdata[r].length;ecdata[r][i]=(modIndex>=0)?modPoly.get(modIndex):0;}}\nvar totalCodeCount=0;for(var i=0;i<rsBlocks.length;i++){totalCodeCount+=rsBlocks[i].totalCount;}\nvar data=new Array(totalCodeCount);var index=0;for(var i=0;i<maxDcCount;i++){for(var r=0;r<rsBlocks.length;r++){if(i<dcdata[r].length){data[index++]=dcdata[r][i];}}}\nfor(var i=0;i<maxEcCount;i++){for(var r=0;r<rsBlocks.length;r++){if(i<ecdata[r].length){data[index++]=ecdata[r][i];}}}\nreturn data;};var QRMode={MODE_NUMBER:1<<0,MODE_ALPHA_NUM:1<<1,MODE_8BIT_BYTE:1<<2,MODE_KANJI:1<<3};var QRErrorCorrectLevel={L:1,M:0,Q:3,H:2};var QRMaskPattern={PATTERN000:0,PATTERN001:1,PATTERN010:2,PATTERN011:3,PATTERN100:4,PATTERN101:5,PATTERN110:6,PATTERN111:7};var QRUtil={PATTERN_POSITION_TABLE:[[],[6,18],[6,22],[6,26],[6,30],[6,34],[6,22,38],[6,24,42],[6,26,46],[6,28,50],[6,30,54],[6,32,58],[6,34,62],[6,26,46,66],[6,26,48,70],[6,26,50,74],[6,30,54,78],[6,30,56,82],[6,30,58,86],[6,34,62,90],[6,28,50,72,94],[6,26,50,74,98],[6,30,54,78,102],[6,28,54,80,106],[6,32,58,84,110],[6,30,58,86,114],[6,34,62,90,118],[6,26,50,74,98,122],[6,30,54,78,102,126],[6,26,52,78,104,130],[6,30,56,82,108,134],[6,34,60,86,112,138],[6,30,58,86,114,142],[6,34,62,90,118,146],[6,30,54,78,102,126,150],[6,24,50,76,102,128,154],[6,28,54,80,106,132,158],[6,32,58,84,110,136,162],[6,26,54,82,110,138,166],[6,30,58,86,114,142,170]],G15:(1<<10)|(1<<8)|(1<<5)|(1<<4)|(1<<2)|(1<<1)|(1<<0),G18:(1<<12)|(1<<11)|(1<<10)|(1<<9)|(1<<8)|(1<<5)|(1<<2)|(1<<0),G15_MASK:(1<<14)|(1<<12)|(1<<10)|(1<<4)|(1<<1),getBCHTypeInfo:function(data){var d=data<<10;while(QRUtil.getBCHDigit(d)-QRUtil.getBCHDigit(QRUtil.G15)>=0){d^=(QRUtil.G15<<(QRUtil.getBCHDigit(d)-QRUtil.getBCHDigit(QRUtil.G15)));}\nreturn((data<<10)|d)^QRUtil.G15_MASK;},getBCHTypeNumber:function(data){var d=data<<12;while(QRUtil.getBCHDigit(d)-QRUtil.getBCHDigit(QRUtil.G18)>=0){d^=(QRUtil.G18<<(QRUtil.getBCHDigit(d)-QRUtil.getBCHDigit(QRUtil.G18)));}\nreturn(data<<12)|d;},getBCHDigit:function(data){var digit=0;while(data!=0){digit++;data>>>=1;}\nreturn digit;},getPatternPosition:function(typeNumber){return QRUtil.PATTERN_POSITION_TABLE[typeNumber-1];},getMask:function(maskPattern,i,j){switch(maskPattern){case QRMaskPattern.PATTERN000:return(i+j)%2==0;case QRMaskPattern.PATTERN001:return i%2==0;case QRMaskPattern.PATTERN010:return j%3==0;case QRMaskPattern.PATTERN011:return(i+j)%3==0;case QRMaskPattern.PATTERN100:return(Math.floor(i/2)+Math.floor(j/3))%2==0;case QRMaskPattern.PATTERN101:return(i*j)%2+(i*j)%3==0;case QRMaskPattern.PATTERN110:return((i*j)%2+(i*j)%3)%2==0;case QRMaskPattern.PATTERN111:return((i*j)%3+(i+j)%2)%2==0;default:throw new Error(\"bad maskPattern:\"+maskPattern);}},getErrorCorrectPolynomial:function(errorCorrectLength){var a=new QRPolynomial([1],0);for(var i=0;i<errorCorrectLength;i++){a=a.multiply(new QRPolynomial([1,QRMath.gexp(i)],0));}\nreturn a;},getLengthInBits:function(mode,type){if(1<=type&&type<10){switch(mode){case QRMode.MODE_NUMBER:return 10;case QRMode.MODE_ALPHA_NUM:return 9;case QRMode.MODE_8BIT_BYTE:return 8;case QRMode.MODE_KANJI:return 8;default:throw new Error(\"mode:\"+mode);}}else if(type<27){switch(mode){case QRMode.MODE_NUMBER:return 12;case QRMode.MODE_ALPHA_NUM:return 11;case QRMode.MODE_8BIT_BYTE:return 16;case QRMode.MODE_KANJI:return 10;default:throw new Error(\"mode:\"+mode);}}else if(type<41){switch(mode){case QRMode.MODE_NUMBER:return 14;case QRMode.MODE_ALPHA_NUM:return 13;case QRMode.MODE_8BIT_BYTE:return 16;case QRMode.MODE_KANJI:return 12;default:throw new Error(\"mode:\"+mode);}}else{throw new Error(\"type:\"+type);}},getLostPoint:function(qrCode){var moduleCount=qrCode.getModuleCount();var lostPoint=0;for(var row=0;row<moduleCount;row++){for(var col=0;col<moduleCount;col++){var sameCount=0;var dark=qrCode.isDark(row,col);for(var r=-1;r<=1;r++){if(row+r<0||moduleCount<=row+r){continue;}\nfor(var c=-1;c<=1;c++){if(col+c<0||moduleCount<=col+c){continue;}\nif(r==0&&c==0){continue;}\nif(dark==qrCode.isDark(row+r,col+c)){sameCount++;}}}\nif(sameCount>5){lostPoint+=(3+sameCount-5);}}}\nfor(var row=0;row<moduleCount-1;row++){for(var col=0;col<moduleCount-1;col++){var count=0;if(qrCode.isDark(row,col))count++;if(qrCode.isDark(row+1,col))count++;if(qrCode.isDark(row,col+1))count++;if(qrCode.isDark(row+1,col+1))count++;if(count==0||count==4){lostPoint+=3;}}}\nfor(var row=0;row<moduleCount;row++){for(var col=0;col<moduleCount-6;col++){if(qrCode.isDark(row,col)&&!qrCode.isDark(row,col+1)&&qrCode.isDark(row,col+2)&&qrCode.isDark(row,col+3)&&qrCode.isDark(row,col+4)&&!qrCode.isDark(row,col+5)&&qrCode.isDark(row,col+6)){lostPoint+=40;}}}\nfor(var col=0;col<moduleCount;col++){for(var row=0;row<moduleCount-6;row++){if(qrCode.isDark(row,col)&&!qrCode.isDark(row+1,col)&&qrCode.isDark(row+2,col)&&qrCode.isDark(row+3,col)&&qrCode.isDark(row+4,col)&&!qrCode.isDark(row+5,col)&&qrCode.isDark(row+6,col)){lostPoint+=40;}}}\nvar darkCount=0;for(var col=0;col<moduleCount;col++){for(var row=0;row<moduleCount;row++){if(qrCode.isDark(row,col)){darkCount++;}}}\nvar ratio=Math.abs(100*darkCount/moduleCount/moduleCount-50)/5;lostPoint+=ratio*10;return lostPoint;}};var QRMath={glog:function(n){if(n<1){throw new Error(\"glog(\"+n+\")\");}\nreturn QRMath.LOG_TABLE[n];},gexp:function(n){while(n<0){n+=255;}\nwhile(n>=256){n-=255;}\nreturn QRMath.EXP_TABLE[n];},EXP_TABLE:new Array(256),LOG_TABLE:new Array(256)};for(var i=0;i<8;i++){QRMath.EXP_TABLE[i]=1<<i;}\nfor(var i=8;i<256;i++){QRMath.EXP_TABLE[i]=QRMath.EXP_TABLE[i-4]^QRMath.EXP_TABLE[i-5]^QRMath.EXP_TABLE[i-6]^QRMath.EXP_TABLE[i-8];}\nfor(var i=0;i<255;i++){QRMath.LOG_TABLE[QRMath.EXP_TABLE[i]]=i;}\nfunction QRPolynomial(num,shift){if(num.length==undefined){throw new Error(num.length+\"/\"+shift);}\nvar offset=0;while(offset<num.length&&num[offset]==0){offset++;}\nthis.num=new Array(num.length-offset+shift);for(var i=0;i<num.length-offset;i++){this.num[i]=num[i+offset];}}\nQRPolynomial.prototype={get:function(index){return this.num[index];},getLength:function(){return this.num.length;},multiply:function(e){var num=new Array(this.getLength()+e.getLength()-1);for(var i=0;i<this.getLength();i++){for(var j=0;j<e.getLength();j++){num[i+j]^=QRMath.gexp(QRMath.glog(this.get(i))+QRMath.glog(e.get(j)));}}\nreturn new QRPolynomial(num,0);},mod:function(e){if(this.getLength()-e.getLength()<0){return this;}\nvar ratio=QRMath.glog(this.get(0))-QRMath.glog(e.get(0));var num=new Array(this.getLength());for(var i=0;i<this.getLength();i++){num[i]=this.get(i);}\nfor(var i=0;i<e.getLength();i++){num[i]^=QRMath.gexp(QRMath.glog(e.get(i))+ratio);}\nreturn new QRPolynomial(num,0).mod(e);}};function QRRSBlock(totalCount,dataCount){this.totalCount=totalCount;this.dataCount=dataCount;}\nQRRSBlock.RS_BLOCK_TABLE=[[1,26,19],[1,26,16],[1,26,13],[1,26,9],[1,44,34],[1,44,28],[1,44,22],[1,44,16],[1,70,55],[1,70,44],[2,35,17],[2,35,13],[1,100,80],[2,50,32],[2,50,24],[4,25,9],[1,134,108],[2,67,43],[2,33,15,2,34,16],[2,33,11,2,34,12],[2,86,68],[4,43,27],[4,43,19],[4,43,15],[2,98,78],[4,49,31],[2,32,14,4,33,15],[4,39,13,1,40,14],[2,121,97],[2,60,38,2,61,39],[4,40,18,2,41,19],[4,40,14,2,41,15],[2,146,116],[3,58,36,2,59,37],[4,36,16,4,37,17],[4,36,12,4,37,13],[2,86,68,2,87,69],[4,69,43,1,70,44],[6,43,19,2,44,20],[6,43,15,2,44,16],[4,101,81],[1,80,50,4,81,51],[4,50,22,4,51,23],[3,36,12,8,37,13],[2,116,92,2,117,93],[6,58,36,2,59,37],[4,46,20,6,47,21],[7,42,14,4,43,15],[4,133,107],[8,59,37,1,60,38],[8,44,20,4,45,21],[12,33,11,4,34,12],[3,145,115,1,146,116],[4,64,40,5,65,41],[11,36,16,5,37,17],[11,36,12,5,37,13],[5,109,87,1,110,88],[5,65,41,5,66,42],[5,54,24,7,55,25],[11,36,12],[5,122,98,1,123,99],[7,73,45,3,74,46],[15,43,19,2,44,20],[3,45,15,13,46,16],[1,135,107,5,136,108],[10,74,46,1,75,47],[1,50,22,15,51,23],[2,42,14,17,43,15],[5,150,120,1,151,121],[9,69,43,4,70,44],[17,50,22,1,51,23],[2,42,14,19,43,15],[3,141,113,4,142,114],[3,70,44,11,71,45],[17,47,21,4,48,22],[9,39,13,16,40,14],[3,135,107,5,136,108],[3,67,41,13,68,42],[15,54,24,5,55,25],[15,43,15,10,44,16],[4,144,116,4,145,117],[17,68,42],[17,50,22,6,51,23],[19,46,16,6,47,17],[2,139,111,7,140,112],[17,74,46],[7,54,24,16,55,25],[34,37,13],[4,151,121,5,152,122],[4,75,47,14,76,48],[11,54,24,14,55,25],[16,45,15,14,46,16],[6,147,117,4,148,118],[6,73,45,14,74,46],[11,54,24,16,55,25],[30,46,16,2,47,17],[8,132,106,4,133,107],[8,75,47,13,76,48],[7,54,24,22,55,25],[22,45,15,13,46,16],[10,142,114,2,143,115],[19,74,46,4,75,47],[28,50,22,6,51,23],[33,46,16,4,47,17],[8,152,122,4,153,123],[22,73,45,3,74,46],[8,53,23,26,54,24],[12,45,15,28,46,16],[3,147,117,10,148,118],[3,73,45,23,74,46],[4,54,24,31,55,25],[11,45,15,31,46,16],[7,146,116,7,147,117],[21,73,45,7,74,46],[1,53,23,37,54,24],[19,45,15,26,46,16],[5,145,115,10,146,116],[19,75,47,10,76,48],[15,54,24,25,55,25],[23,45,15,25,46,16],[13,145,115,3,146,116],[2,74,46,29,75,47],[42,54,24,1,55,25],[23,45,15,28,46,16],[17,145,115],[10,74,46,23,75,47],[10,54,24,35,55,25],[19,45,15,35,46,16],[17,145,115,1,146,116],[14,74,46,21,75,47],[29,54,24,19,55,25],[11,45,15,46,46,16],[13,145,115,6,146,116],[14,74,46,23,75,47],[44,54,24,7,55,25],[59,46,16,1,47,17],[12,151,121,7,152,122],[12,75,47,26,76,48],[39,54,24,14,55,25],[22,45,15,41,46,16],[6,151,121,14,152,122],[6,75,47,34,76,48],[46,54,24,10,55,25],[2,45,15,64,46,16],[17,152,122,4,153,123],[29,74,46,14,75,47],[49,54,24,10,55,25],[24,45,15,46,46,16],[4,152,122,18,153,123],[13,74,46,32,75,47],[48,54,24,14,55,25],[42,45,15,32,46,16],[20,147,117,4,148,118],[40,75,47,7,76,48],[43,54,24,22,55,25],[10,45,15,67,46,16],[19,148,118,6,149,119],[18,75,47,31,76,48],[34,54,24,34,55,25],[20,45,15,61,46,16]];QRRSBlock.getRSBlocks=function(typeNumber,errorCorrectLevel){var rsBlock=QRRSBlock.getRsBlockTable(typeNumber,errorCorrectLevel);if(rsBlock==undefined){throw new Error(\"bad rs block @ typeNumber:\"+typeNumber+\"/errorCorrectLevel:\"+errorCorrectLevel);}\nvar length=rsBlock.length/3;var list=[];for(var i=0;i<length;i++){var count=rsBlock[i*3+0];var totalCount=rsBlock[i*3+1];var dataCount=rsBlock[i*3+2];for(var j=0;j<count;j++){list.push(new QRRSBlock(totalCount,dataCount));}}\nreturn list;};QRRSBlock.getRsBlockTable=function(typeNumber,errorCorrectLevel){switch(errorCorrectLevel){case QRErrorCorrectLevel.L:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber-1)*4+0];case QRErrorCorrectLevel.M:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber-1)*4+1];case QRErrorCorrectLevel.Q:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber-1)*4+2];case QRErrorCorrectLevel.H:return QRRSBlock.RS_BLOCK_TABLE[(typeNumber-1)*4+3];default:return undefined;}};function QRBitBuffer(){this.buffer=[];this.length=0;}\nQRBitBuffer.prototype={get:function(index){var bufIndex=Math.floor(index/8);return((this.buffer[bufIndex]>>>(7-index%8))&1)==1;},put:function(num,length){for(var i=0;i<length;i++){this.putBit(((num>>>(length-i-1))&1)==1);}},getLengthInBits:function(){return this.length;},putBit:function(bit){var bufIndex=Math.floor(this.length/8);if(this.buffer.length<=bufIndex){this.buffer.push(0);}\nif(bit){this.buffer[bufIndex]|=(0x80>>>(this.length%8));}\nthis.length++;}};var QRCodeLimitLength=[[17,14,11,7],[32,26,20,14],[53,42,32,24],[78,62,46,34],[106,84,60,44],[134,106,74,58],[154,122,86,64],[192,152,108,84],[230,180,130,98],[271,213,151,119],[321,251,177,137],[367,287,203,155],[425,331,241,177],[458,362,258,194],[520,412,292,220],[586,450,322,250],[644,504,364,280],[718,560,394,310],[792,624,442,338],[858,666,482,382],[929,711,509,403],[1003,779,565,439],[1091,857,611,461],[1171,911,661,511],[1273,997,715,535],[1367,1059,751,593],[1465,1125,805,625],[1528,1190,868,658],[1628,1264,908,698],[1732,1370,982,742],[1840,1452,1030,790],[1952,1538,1112,842],[2068,1628,1168,898],[2188,1722,1228,958],[2303,1809,1283,983],[2431,1911,1351,1051],[2563,1989,1423,1093],[2699,2099,1499,1139],[2809,2213,1579,1219],[2953,2331,1663,1273]];\n\n\n/** Constructor */\nfunction QRCode(options) {\n var instance = this;\n \n //Default options\n this.options = {\n padding: 4,\n width: 256, \n height: 256,\n typeNumber: 4,\n color: \"#000000\",\n background: \"#ffffff\",\n ecl: \"M\"\n };\n \n //In case the options is string\n if (typeof options === 'string') {\n options = {\n content: options\n };\n }\n \n //Merge options\n if (options) {\n for (var i in options) {\n this.options[i] = options[i];\n }\n }\n \n if (typeof this.options.content !== 'string') {\n throw new Error(\"Expected 'content' as string!\");\n }\n \n if (this.options.content.length === 0 /* || this.options.content.length > 7089 */) {\n throw new Error(\"Expected 'content' to be non-empty!\");\n }\n \n if (!(this.options.padding >= 0)) {\n throw new Error(\"Expected 'padding' value to be non-negative!\");\n }\n \n if (!(this.options.width > 0) || !(this.options.height > 0)) {\n throw new Error(\"Expected 'width' or 'height' value to be higher than zero!\");\n }\n \n //Gets the error correction level\n function _getErrorCorrectLevel(ecl) {\n switch (ecl) {\n case \"L\":\n return QRErrorCorrectLevel.L;\n \n case \"M\":\n return QRErrorCorrectLevel.M;\n \n case \"Q\":\n return QRErrorCorrectLevel.Q;\n \n case \"H\":\n return QRErrorCorrectLevel.H;\n \n default:\n throw new Error(\"Unknwon error correction level: \" + ecl);\n }\n }\n \n //Get type number\n function _getTypeNumber(content, ecl) { \n var length = _getUTF8Length(content);\n \n var type = 1;\n var limit = 0;\n for (var i = 0, len = QRCodeLimitLength.length; i <= len; i++) {\n var table = QRCodeLimitLength[i];\n if (!table) {\n throw new Error(\"Content too long: expected \" + limit + \" but got \" + length);\n }\n \n switch (ecl) {\n case \"L\":\n limit = table[0];\n break;\n \n case \"M\":\n limit = table[1];\n break;\n \n case \"Q\":\n limit = table[2];\n break;\n \n case \"H\":\n limit = table[3];\n break;\n \n default:\n throw new Error(\"Unknwon error correction level: \" + ecl);\n }\n \n if (length <= limit) {\n break;\n }\n \n type++;\n }\n \n if (type > QRCodeLimitLength.length) {\n throw new Error(\"Content too long\");\n }\n \n return type;\n }\n\n //Gets text length\n function _getUTF8Length(content) {\n var result = encodeURI(content).toString().replace(/\\%[0-9a-fA-F]{2}/g, 'a');\n return result.length + (result.length != content ? 3 : 0);\n }\n \n //Generate QR Code matrix\n var content = this.options.content;\n var type = _getTypeNumber(content, this.options.ecl);\n var ecl = _getErrorCorrectLevel(this.options.ecl);\n this.qrcode = new QRCodeModel(type, ecl);\n this.qrcode.addData(content);\n this.qrcode.make();\n}\n\n/** Generates QR Code as SVG image */\nQRCode.prototype.svg = function(opt) {\n var options = this.options || { };\n var modules = this.qrcode.modules;\n \n if (typeof opt == \"undefined\") {\n opt = { container: options.container || \"svg\" };\n }\n \n //Apply new lines and indents in SVG?\n var pretty = typeof options.pretty != \"undefined\" ? !!options.pretty : true;\n \n var indent = pretty ? ' ' : '';\n var EOL = pretty ? '\\r\\n' : '';\n var width = options.width;\n var height = options.height;\n var length = modules.length;\n var xsize = width / (length + 2 * options.padding);\n var ysize = height / (length + 2 * options.padding);\n \n //Join (union, merge) rectangles into one shape?\n var join = typeof options.join != \"undefined\" ? !!options.join : false;\n \n //Swap the X and Y modules, pull request #2\n var swap = typeof options.swap != \"undefined\" ? !!options.swap : false;\n \n //Apply <?xml...?> declaration in SVG?\n var xmlDeclaration = typeof options.xmlDeclaration != \"undefined\" ? !!options.xmlDeclaration : true;\n \n //Populate with predefined shape instead of \"rect\" elements, thanks to @kkocdko\n var predefined = typeof options.predefined != \"undefined\" ? !!options.predefined : false;\n var defs = predefined ? indent + '<defs><path id=\"qrmodule\" d=\"M0 0 h' + ysize + ' v' + xsize + ' H0 z\" style=\"fill:' + options.color + ';shape-rendering:crispEdges;\" /></defs>' + EOL : '';\n \n //Background rectangle\n var bgrect = indent + '<rect x=\"0\" y=\"0\" width=\"' + width + '\" height=\"' + height + '\" style=\"fill:' + options.background + ';shape-rendering:crispEdges;\"/>' + EOL;\n \n //Rectangles representing modules\n var modrect = '';\n var pathdata = '';\n\n for (var y = 0; y < length; y++) {\n for (var x = 0; x < length; x++) {\n var module = modules[x][y];\n if (module) {\n \n var px = (x * xsize + options.padding * xsize);\n var py = (y * ysize + options.padding * ysize);\n \n //Some users have had issues with the QR Code, thanks to @danioso for the solution\n if (swap) {\n var t = px;\n px = py;\n py = t;\n }\n \n if (join) {\n //Module as a part of svg path data, thanks to @danioso\n var w = xsize + px\n var h = ysize + py\n\n px = (Number.isInteger(px))? Number(px): px.toFixed(2);\n py = (Number.isInteger(py))? Number(py): py.toFixed(2);\n w = (Number.isInteger(w))? Number(w): w.toFixed(2);\n h = (Number.isInteger(h))? Number(h): h.toFixed(2);\n\n pathdata += ('M' + px + ',' + py + ' V' + h + ' H' + w + ' V' + py + ' H' + px + ' Z ');\n }\n else if (predefined) {\n //Module as a predefined shape, thanks to @kkocdko\n modrect += indent + '<use x=\"' + px.toString() + '\" y=\"' + py.toString() + '\" href=\"#qrmodule\" />' + EOL;\n }\n else {\n //Module as rectangle element\n modrect += indent + '<rect x=\"' + px.toString() + '\" y=\"' + py.toString() + '\" width=\"' + xsize + '\" height=\"' + ysize + '\" style=\"fill:' + options.color + ';shape-rendering:crispEdges;\"/>' + EOL;\n }\n }\n }\n }\n \n if (join) {\n modrect = indent + '<path x=\"0\" y=\"0\" style=\"fill:' + options.color + ';shape-rendering:crispEdges;\" d=\"' + pathdata + '\" />';\n }\n\n var svg = \"\";\n switch (opt.container) {\n //Wrapped in SVG document\n case \"svg\":\n if (xmlDeclaration) {\n svg += '<?xml version=\"1.0\" standalone=\"yes\"?>' + EOL;\n }\n svg += '<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" width=\"' + width + '\" height=\"' + height + '\">' + EOL;\n svg += defs + bgrect + modrect;\n svg += '</svg>';\n break;\n \n //Viewbox for responsive use in a browser, thanks to @danioso\n case \"svg-viewbox\":\n if (xmlDeclaration) {\n svg += '<?xml version=\"1.0\" standalone=\"yes\"?>' + EOL;\n }\n svg += '<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" viewBox=\"0 0 ' + width + ' ' + height + '\">' + EOL;\n svg += defs + bgrect + modrect;\n svg += '</svg>';\n break;\n \n \n //Wrapped in group element \n case \"g\":\n svg += '<g width=\"' + width + '\" height=\"' + height + '\">' + EOL;\n svg += defs + bgrect + modrect;\n svg += '</g>';\n break;\n \n //Without a container\n default:\n svg += (defs + bgrect + modrect).replace(/^\\s+/, \"\"); //Clear indents on each line\n break;\n }\n \n return svg;\n};\n\n/** Writes QR Code image to a file */\nQRCode.prototype.save = function(file, callback) {\n var data = this.svg();\n if (typeof callback != \"function\") {\n callback = function(error, result) { };\n }\n try {\n //Package 'fs' is available in node.js but not in a web browser\n var fs = require('fs');\n fs.writeFile(file, data, callback);\n }\n catch (e) {\n //Sorry, 'fs' is not available\n callback(e);\n }\n};\n\nif (typeof module != \"undefined\") {\n module.exports = QRCode;\n}\n","/* eslint-env browser */\nmodule.exports = typeof self == 'object' ? self.FormData : window.FormData;\n"],"sourceRoot":""} |