{"version":3,"file":"js/decidim_votings-f17fb31f5635d40678a4.js","mappings":"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AAM,IAAM,GAAM,IAAM,IAAM,IAC1F,IAAM,IAAM,GAAM,IAAM,GAAM,IAAM,GAAM,IAAM,GAAM,GAAM,IAAM,IAAM,GAAM,IAAM,IAAM,IAC1F,GAAM,IAAM,GAAM,IAAM,IAAM,IAAM,GAAM,GAAM,GAAM,GAAM,IAAM,IAAM,EAAM,IAAM,IAAM,GAC1F,IAAM,IAAM,GAAM,IAAM,IAAM,IAAM,IAAM,GAAM,IAAM,IAAM,GAAM,GAAM,GAAM,IAAM,GAAM,IAC1F,GAAM,IAAM,IAAM,IAAM,IAAM,GAAM,IAAM,GAAM,IAAM,GAAM,IAAM,GAAM,IAAM,IAAM,IAAM,IAC1F,GAAM,IAAM,IAAM,GAAM,GAAM,IAAM,IAAM,IAAM,GAAM,GAAM,IAAM,GAAM,IAAM,GAAM,IAAM,GAC1F,IAAM,IAAM,GAAM,IAAM,GAAM,IAAM,EAAM,GAAM,GAAM,IAAM,GAAM,IAAM,IAAM,IAAM,GAAM,EAC1F,IAAM,GAAM,IAAM,IAAM,IAAM,IAAM,GAAM,IAAM,EAAM,IAAM,IAAM,GAAM,IAAM,IAAM,GAAM,IAC1F,EAAM,IAAM,IAAM,IAAM,IAAM,GAAM,IAAM,IAAM,IAAM,IAAM,IAAM,IAAM,GAAM,GAAM,IAAM,GAC1F,IAAM,GAAM,IAAM,IAAM,GAAM,GAAM,GAAM,IAAM,GAAM,IAAM,IAAM,GAAM,EAAM,GAAM,IAAM,IAC1F,IAAM,IAAM,GAAM,IAAM,GAAM,GAAM,IAAM,IAAM,GAAM,IAAM,IAAM,GAAM,IAAM,IAAM,IAAM,GAC1F,IAAM,IAAM,GAAM,IAAM,GAAM,IAAM,IAAM,IAAM,IAAM,EAAM,GAAM,GAAM,GAAM,GAAM,IAAM,GAC1F,GAAM,GAAM,IAAM,IAAM,IAAM,IAAM,IAAM,IAAM,EAAM,IAAM,GAAM,GAAM,IAAM,IAAM,IAAM,IAC1F,IAAM,EAAM,IAAM,IAAM,IAAM,IAAM,IAAM,GAAM,GAAM,GAAM,EAAM,GAAM,GAAM,IAAM,IAAM,IAC1F,GAAM,GAAM,GAAM,GAAM,IAAM,GAAM,IAAM,IAAM,IAAM,GAAM,GAAM,GAAM,IAAM,IAAM,IAAM,GAC1F,IAAM,IAAM,IAAM,GAAM,IAAM,IAAM,IAAM,I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CACT,CAEO,SAASE,GAAiB1C,EAAoB2C,GACnD,GAAI3C,EAASl9B,QAAU,IAAK,CAS1B29B,GACET,EARgB,WAChB,IACE,OAAO9wD,KAAKlY,MAAM2rE,EACpB,CAAE,MAAO51E,GACP,OAAO41E,CACT,CACF,CAGEC,GACA,iDAAAriH,OAAiDy/G,EAASl9B,QAE9D,CAEA,IACE,OAAO5zB,KAAKlY,MAAM2rE,EACpB,CAAE,MAAO51E,GACP,IAAMiyE,EAAajyE,EAKnB,MAJAiyE,EAAW14G,KAAO,mBAClB04G,EAAWgB,SAAWA,EACtBhB,EAAW0B,WAAaV,EAASl9B,OACjCk8B,EAAW2D,SAAWA,EAChB3D,CACR,CACF,CC1JO,SAAS6D,GAAaxwH,GAC3B,OAAgB,IAATA,GAA4B,KAATA,CAC5B,CCFA,IAAMywH,GAAgB,gCAEtB,SAASC,GAAgBjlH,GACvB,OAAOklH,GAAgBllH,EAAIhI,WAAW,GACxC,CAEA,IAAMktH,GAAkB,CACtB,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,MACA,MACA,MACA,UACA,MACA,MACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,UACA,GACA,GACA,MACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,OACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,UACA,U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","sources":["webpack://digigraetzl/../layers/heroku_ruby/gems/ruby/3.1.0/bundler/gems/decidim-6cc188d1399f/decidim-elections/app/packs/images/ sync ^\\.\\/.*$","webpack://digigraetzl/../layers/heroku_ruby/gems/ruby/3.1.0/bundler/gems/decidim-6cc188d1399f/decidim-elections/app/packs/src/decidim/elections/broken_promises_handler.js","webpack://digigraetzl/../layers/heroku_ruby/gems/ruby/3.1.0/bundler/gems/decidim-6cc188d1399f/decidim-elections/app/packs/src/decidim/votings/polling_officer_zone/edit-closure.js","webpack://digigraetzl/../layers/heroku_ruby/gems/ruby/3.1.0/bundler/gems/decidim-6cc188d1399f/decidim-elections/app/packs/src/decidim/votings/polling_officer_zone/in-person-vote.js","webpack://digigraetzl/../layers/heroku_ruby/gems/ruby/3.1.0/bundler/gems/decidim-6cc188d1399f/decidim-elections/app/packs/src/decidim/votings/polling_officer_zone/new-closure.js","webpack://digigraetzl/../layers/heroku_ruby/gems/ruby/3.1.0/bundler/gems/decidim-6cc188d1399f/decidim-elections/app/packs/src/decidim/votings/polling_officer_zone/sign-closure.js","webpack://digigraetzl/./node_modules/base64-js/index.js","webpack://digigraetzl/./node_modules/base64url/dist/base64url.js","webpack://digigraetzl/./node_modules/base64url/dist/pad-string.js","webpack://digigraetzl/./node_modules/base64url/index.js","webpack://digigraetzl/./node_modules/buffer/index.js","webpack://digigraetzl/config/versionTemplate.txt","webpack://digigraetzl/lib/es6-promise/utils.js","webpack://digigraetzl/lib/es6-promise/asap.js","webpack://digigraetzl/lib/es6-promise/then.js","webpack://digigraetzl/lib/es6-promise/promise/resolve.js","webpack://digigraetzl/lib/es6-promise/-internal.js","webpack://digigraetzl/lib/es6-promise/enumerator.js","webpack://digigraetzl/lib/es6-promise/promise.js","webpack://digigraetzl/lib/es6-promise.js","webpack://digigraetzl/lib/es6-promise/promise/all.js","webpack://digigraetzl/lib/es6-promise/promise/race.js","webpack://digigraetzl/lib/es6-promise/promise/reject.js","webpack://digigraetzl/lib/es6-promise/polyfill.js","webpack://digigraetzl/./node_modules/ieee754/index.js","webpack://digigraetzl/./node_modules/lodash/_DataView.js","webpack://digigraetzl/./node_modules/lodash/_Hash.js","webpack://digigraetzl/./node_modules/lodash/_LazyWrapper.js","webpack://digigraetzl/./node_modules/lodash/_ListCache.js","webpack://digigraetzl/./node_modules/lodash/_LodashWrapper.js","webpack://digigraetzl/./node_modules/lodash/_Map.js","webpack://digigraetzl/./node_modules/lodash/_MapCache.js","webpack://digigraetzl/./node_modules/lodash/_Promise.js","webpack://digigraetzl/./node_modules/lodash/_Set.js","webpack://digigraetzl/./node_modules/lodash/_SetCache.js","webpack://digigraetzl/./node_modules/lodash/_Stack.js","webpack://digigraetzl/./node_modules/lodash/_Symbol.js","webpack://digigraetzl/./node_modules/lodash/_Uint8Array.js","webpack://digigraetzl/./node_modules/lodash/_WeakMap.js","webpack://digigraetzl/./node_modules/lodash/_apply.js","webpack://digigraetzl/./node_modules/lodash/_arrayEach.js","webpack://digigraetzl/./node_modules/lodash/_arrayFilter.js","webpack://digigraetzl/./node_modules/lodash/_arrayIncludes.js","webpack://digigraetzl/./node_modules/lodash/_arrayIncludesWith.js","webpack://digigraetzl/./node_modules/lodash/_arrayLikeKeys.js","webpack://digigraetzl/./node_modules/lodash/_arrayMap.js","webpack://digigraetzl/./node_modules/lodash/_arrayPush.js","webpack://digigraetzl/./node_modules/lodash/_assignMergeValue.js","webpack://digigraetzl/./node_modules/lodash/_assignValue.js","webpack://digigraetzl/./node_modules/lodash/_assocIndexOf.js","webpack://digigraetzl/./node_modules/lodash/_baseAssign.js","webpack://digigraetzl/./node_modules/lodash/_baseAssignIn.js","webpack://digigraetzl/./node_modules/lodash/_baseAssignValue.js","webpack://digigraetzl/./node_modules/lodash/_baseClamp.js","webpack://digigraetzl/./node_modules/lodash/_baseClone.js","webpack://digigraetzl/./node_modules/lodash/_baseCreate.js","webpack://digigraetzl/./node_modules/lodash/_baseFill.js","webpack://digigraetzl/./node_modules/lodash/_baseFindIndex.js","webpack://digigraetzl/./node_modules/lodash/_baseFlatten.js","webpack://digigraetzl/./node_modules/lodash/_baseFor.js","webpack://digigraetzl/./node_modules/lodash/_baseGet.js","webpack://digigraetzl/./node_modules/lodash/_baseGetAllKeys.js","webpack://digigraetzl/./node_modules/lodash/_baseGetTag.js","webpack://digigraetzl/./node_modules/lodash/_baseHasIn.js","webpack://digigraetzl/./node_modules/lodash/_baseIndexOf.js","webpack://digigraetzl/./node_modules/lodash/_baseIntersection.js","webpack://digigraetzl/./node_modules/lodash/_baseIsArguments.js","webpack://digigraetzl/./node_modules/lodash/_baseIsMap.js","webpack://digigraetzl/./node_modules/lodash/_baseIsNaN.js","webpack://digigraetzl/./node_modules/lodash/_baseIsNative.js","webpack://digigraetzl/./node_modules/lodash/_baseIsSet.js","webpack://digigraetzl/./node_modules/lodash/_baseIsTypedArray.js","webpack://digigraetzl/./node_modules/lodash/_baseKeys.js","webpack://digigraetzl/./node_modules/lodash/_baseKeysIn.js","webpack://digigraetzl/./node_modules/lodash/_baseLodash.js","webpack://digigraetzl/./node_modules/lodash/_baseMerge.js","webpack://digigraetzl/./node_modules/lodash/_baseMergeDeep.js","webpack://digigraetzl/./node_modules/lodash/_basePick.js","webpack://digigraetzl/./node_modules/lodash/_basePickBy.js","webpack://digigraetzl/./node_modules/lodash/_baseRest.js","webpack://digigraetzl/./node_modules/lodash/_baseSet.js","webpack://digigraetzl/./node_modules/lodash/_baseSetData.js","webpack://digigraetzl/./node_modules/lodash/_baseSetToString.js","webpack://digigraetzl/./node_modules/lodash/_baseSlice.js","webpack://digigraetzl/./node_modules/lodash/_baseTimes.js","webpack://digigraetzl/./node_modules/lodash/_baseToString.js","webpack://digigraetzl/./node_modules/lodash/_baseTrim.js","webpack://digigraetzl/./node_modules/lodash/_baseUnary.js","webpack://digigraetzl/./node_modules/lodash/_baseUniq.js","webpack://digigraetzl/./node_modules/lodash/_baseUnset.js","webpack://digigraetzl/./node_modules/lodash/_cacheHas.js","webpack://digigraetzl/./node_modules/lodash/_castArrayLikeObject.js","webpack://digigraetzl/./node_modules/lodash/_castPath.js","webpack://digigraetzl/./node_modules/lodash/_cloneArrayBuffer.js","webpack://digigraetzl/./node_modules/lodash/_cloneBuffer.js","webpack://digigraetzl/./node_modules/lodash/_cloneDataView.js","webpack://digigraetzl/./node_modules/lodash/_cloneRegExp.js","webpack://digigraetzl/./node_modules/lodash/_cloneSymbol.js","webpack://digigraetzl/./node_modules/lodash/_cloneTypedArray.js","webpack://digigraetzl/./node_modules/lodash/_composeArgs.js","webpack://digigraetzl/./node_modules/lodash/_composeArgsRight.js","webpack://digigraetzl/./node_modules/lodash/_copyArray.js","webpack://digigraetzl/./node_modules/lodash/_copyObject.js","webpack://digigraetzl/./node_modules/lodash/_copySymbols.js","webpack://digigraetzl/./node_modules/lodash/_copySymbolsIn.js","webpack://digigraetzl/./node_modules/lodash/_coreJsData.js","webpack://digigraetzl/./node_modules/lodash/_countHolders.js","webpack://digigraetzl/./node_modules/lodash/_createAssigner.js","webpack://digigraetzl/./node_modules/lodash/_createBaseFor.js","webpack://digigraetzl/./node_modules/lodash/_createBind.js","webpack://digigraetzl/./node_modules/lodash/_createCtor.js","webpack://digigraetzl/./node_modules/lodash/_createCurry.js","webpack://digigraetzl/./node_modules/lodash/_createHybrid.js","webpack://digigraetzl/./node_modules/lodash/_createPartial.js","webpack://digigraetzl/./node_modules/lodash/_createRecurry.js","webpack://digigraetzl/./node_modules/lodash/_createSet.js","webpack://digigraetzl/./node_modules/lodash/_createWrap.js","webpack://digigraetzl/./node_modules/lodash/_customOmitClone.js","webpack://digigraetzl/./node_modules/lodash/_defineProperty.js","webpack://digigraetzl/./node_modules/lodash/_flatRest.js","webpack://digigraetzl/./node_modules/lodash/_freeGlobal.js","webpack://digigraetzl/./node_modules/lodash/_getAllKeys.js","webpack://digigraetzl/./node_modules/lodash/_getAllKeysIn.js","webpack://digigraetzl/./node_modules/lodash/_getData.js","webpack://digigraetzl/./node_modules/lodash/_getFuncName.js","webpack://digigraetzl/./node_modules/lodash/_getHolder.js","webpack://digigraetzl/./node_modules/lodash/_getMapData.js","webpack://digigraetzl/./node_modules/lodash/_getNative.js","webpack://digigraetzl/./node_modules/lodash/_getPrototype.js","webpack://digigraetzl/./node_modules/lodash/_getRawTag.js","webpack://digigraetzl/./node_modules/lodash/_getSymbols.js","webpack://digigraetzl/./node_modules/lodash/_getSymbolsIn.js","webpack://digigraetzl/./node_modules/lodash/_getTag.js","webpack://digigraetzl/./node_modules/lodash/_getValue.js","webpack://digigraetzl/./node_modules/lodash/_getWrapDetails.js","webpack://digigraetzl/./node_modules/lodash/_hasPath.js","webpack://digigraetzl/./node_modules/lodash/_hashClear.js","webpack://digigraetzl/./node_modules/lodash/_hashDelete.js","webpack://digigraetzl/./node_modules/lodash/_hashGet.js","webpack://digigraetzl/./node_modules/lodash/_hashHas.js","webpack://digigraetzl/./node_modules/lodash/_hashSet.js","webpack://digigraetzl/./node_modules/lodash/_initCloneArray.js","webpack://digigraetzl/./node_modules/lodash/_initCloneByTag.js","webpack://digigraetzl/./node_modules/lodash/_initCloneObject.js","webpack://digigraetzl/./node_modules/lodash/_insertWrapDetails.js","webpack://digigraetzl/./node_modules/lodash/_isFlattenable.js","webpack://digigraetzl/./node_modules/lodash/_isIndex.js","webpack://digigraetzl/./node_modules/lodash/_isIterateeCall.js","webpack://digigraetzl/./node_modules/lodash/_isKey.js","webpack://digigraetzl/./node_modules/lodash/_isKeyable.js","webpack://digigraetzl/./node_modules/lodash/_isLaziable.js","webpack://digigraetzl/./node_modules/lodash/_isMasked.js","webpack://digigraetzl/./node_modules/lodash/_isPrototype.js","webpack://digigraetzl/./node_modules/lodash/_listCacheClear.js","webpack://digigraetzl/./node_modules/lodash/_listCacheDelete.js","webpack://digigraetzl/./node_modules/lodash/_listCacheGet.js","webpack://digigraetzl/./node_modules/lodash/_listCacheHas.js","webpack://digigraetzl/./node_modules/lodash/_listCacheSet.js","webpack://digigraetzl/./node_modules/lodash/_mapCacheClear.js","webpack://digigraetzl/./node_modules/lodash/_mapCacheDelete.js","webpack://digigraetzl/./node_modules/lodash/_mapCacheGet.js","webpack://digigraetzl/./node_modules/lodash/_mapCacheHas.js","webpack://digigraetzl/./node_modules/lodash/_mapCacheSet.js","webpack://digigraetzl/./node_modules/lodash/_memoizeCapped.js","webpack://digigraetzl/./node_modules/lodash/_mergeData.js","webpack://digigraetzl/./node_modules/lodash/_metaMap.js","webpack://digigraetzl/./node_modules/lodash/_nativeCreate.js","webpack://digigraetzl/./node_modules/lodash/_nativeKeys.js","webpack://digigraetzl/./node_modules/lodash/_nativeKeysIn.js","webpack://digigraetzl/./node_modules/lodash/_nodeUtil.js","webpack://digigraetzl/./node_modules/lodash/_objectToString.js","webpack://digigraetzl/./node_modules/lodash/_overArg.js","webpack://digigraetzl/./node_modules/lodash/_overRest.js","webpack://digigraetzl/./node_modules/lodash/_parent.js","webpack://digigraetzl/./node_modules/lodash/_realNames.js","webpack://digigraetzl/./node_modules/lodash/_reorder.js","webpack://digigraetzl/./node_modules/lodash/_replaceHolders.js","webpack://digigraetzl/./node_modules/lodash/_root.js","webpack://digigraetzl/./node_modules/lodash/_safeGet.js","webpack://digigraetzl/./node_modules/lodash/_setCacheAdd.js","webpack://digigraetzl/./node_modules/lodash/_setCacheHas.js","webpack://digigraetzl/./node_modules/lodash/_setData.js","webpack://digigraetzl/./node_modules/lodash/_setToArray.js","webpack://digigraetzl/./node_modules/lodash/_setToString.js","webpack://digigraetzl/./node_modules/lodash/_setWrapToString.js","webpack://digigraetzl/./node_modules/lodash/_shortOut.js","webpack://digigraetzl/./node_modules/lodash/_stackClear.js","webpack://digigraetzl/./node_modules/lodash/_stackDelete.js","webpack://digigraetzl/./node_modules/lodash/_stackGet.js","webpack://digigraetzl/./node_modules/lodash/_stackHas.js","webpack://digigraetzl/./node_modules/lodash/_stackSet.js","webpack://digigraetzl/./node_modules/lodash/_strictIndexOf.js","webpack://digigraetzl/./node_modules/lodash/_stringToPath.js","webpack://digigraetzl/./node_modules/lodash/_toKey.js","webpack://digigraetzl/./node_modules/lodash/_toSource.js","webpack://digigraetzl/./node_modules/lodash/_trimmedEndIndex.js","webpack://digigraetzl/./node_modules/lodash/_updateWrapDetails.js","webpack://digigraetzl/./node_modules/lodash/_wrapperClone.js","webpack://digigraetzl/./node_modules/lodash/assign.js","webpack://digigraetzl/./node_modules/lodash/clone.js","webpack://digigraetzl/./node_modules/lodash/constant.js","webpack://digigraetzl/./node_modules/lodash/eq.js","webpack://digigraetzl/./node_modules/lodash/fill.js","webpack://digigraetzl/./node_modules/lodash/flatten.js","webpack://digigraetzl/./node_modules/lodash/hasIn.js","webpack://digigraetzl/./node_modules/lodash/identity.js","webpack://digigraetzl/./node_modules/lodash/intersection.js","webpack://digigraetzl/./node_modules/lodash/isArguments.js","webpack://digigraetzl/./node_modules/lodash/isArray.js","webpack://digigraetzl/./node_modules/lodash/isArrayLike.js","webpack://digigraetzl/./node_modules/lodash/isArrayLikeObject.js","webpack://digigraetzl/./node_modules/lodash/isBuffer.js","webpack://digigraetzl/./node_modules/lodash/isFunction.js","webpack://digigraetzl/./node_modules/lodash/isLength.js","webpack://digigraetzl/./node_modules/lodash/isMap.js","webpack://digigraetzl/./node_modules/lodash/isObject.js","webpack://digigraetzl/./node_modules/lodash/isObjectLike.js","webpack://digigraetzl/./node_modules/lodash/isPlainObject.js","webpack://digigraetzl/./node_modules/lodash/isSet.js","webpack://digigraetzl/./node_modules/lodash/isSymbol.js","webpack://digigraetzl/./node_modules/lodash/isTypedArray.js","webpack://digigraetzl/./node_modules/lodash/keys.js","webpack://digigraetzl/./node_modules/lodash/keysIn.js","webpack://digigraetzl/./node_modules/lodash/last.js","webpack://digigraetzl/./node_modules/lodash/memoize.js","webpack://digigraetzl/./node_modules/lodash/merge.js","webpack://digigraetzl/./node_modules/lodash/noop.js","webpack://digigraetzl/./node_modules/lodash/omit.js","webpack://digigraetzl/./node_modules/lodash/partialRight.js","webpack://digigraetzl/./node_modules/lodash/pick.js","webpack://digigraetzl/./node_modules/lodash/stubArray.js","webpack://digigraetzl/./node_modules/lodash/stubFalse.js","webpack://digigraetzl/./node_modules/lodash/toFinite.js","webpack://digigraetzl/./node_modules/lodash/toInteger.js","webpack://digigraetzl/./node_modules/lodash/toLength.js","webpack://digigraetzl/./node_modules/lodash/toNumber.js","webpack://digigraetzl/./node_modules/lodash/toPlainObject.js","webpack://digigraetzl/./node_modules/lodash/toString.js","webpack://digigraetzl/./node_modules/lodash/uniq.js","webpack://digigraetzl/./node_modules/lodash/wrapperLodash.js","webpack://digigraetzl/./node_modules/node-forge/lib/aes.js","webpack://digigraetzl/./node_modules/node-forge/lib/asn1.js","webpack://digigraetzl/./node_modules/node-forge/lib/baseN.js","webpack://digigraetzl/./node_modules/node-forge/lib/cipher.js","webpack://digigraetzl/./node_modules/node-forge/lib/cipherModes.js","webpack://digigraetzl/./node_modules/node-forge/lib/des.js","webpack://digigraetzl/./node_modules/node-forge/lib/forge.js","webpack://digigraetzl/./node_modules/node-forge/lib/hmac.js","webpack://digigraetzl/./node_modules/node-forge/lib/jsbn.js","webpack://digigraetzl/./node_modules/node-forge/lib/md.js","webpack://digigraetzl/./node_modules/node-forge/lib/mgf.js","webpack://digigraetzl/./node_modules/node-forge/lib/mgf1.js","webpack://digigraetzl/./node_modules/node-forge/lib/oids.js","webpack://digigraetzl/./node_modules/node-forge/lib/pbe.js","webpack://digigraetzl/./node_modules/node-forge/lib/pbkdf2.js","webpack://digigraetzl/./node_modules/node-forge/lib/pem.js","webpack://digigraetzl/./node_modules/node-forge/lib/pkcs1.js","webpack://digigraetzl/./node_modules/node-forge/lib/pkcs12.js","webpack://digigraetzl/./node_modules/node-forge/lib/pkcs7.js","webpack://digigraetzl/./node_modules/node-forge/lib/pkcs7asn1.js","webpack://digigraetzl/./node_modules/node-forge/lib/pki.js","webpack://digigraetzl/./node_modules/node-forge/lib/prime.js","webpack://digigraetzl/./node_modules/node-forge/lib/prng.js","webpack://digigraetzl/./node_modules/node-forge/lib/pss.js","webpack://digigraetzl/./node_modules/node-forge/lib/random.js","webpack://digigraetzl/./node_modules/node-forge/lib/rc2.js","webpack://digigraetzl/./node_modules/node-forge/lib/rsa.js","webpack://digigraetzl/./node_modules/node-forge/lib/sha1.js","webpack://digigraetzl/./node_modules/node-forge/lib/sha256.js","webpack://digigraetzl/./node_modules/node-forge/lib/sha512.js","webpack://digigraetzl/./node_modules/node-forge/lib/util.js","webpack://digigraetzl/./node_modules/node-forge/lib/x509.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/aes-cbc-hmac-sha2.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/aes-gcm.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/aes-kw.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/concat.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/constants.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/dir.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/ec-util.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/ecdh.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/ecdsa.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/helpers.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/hkdf.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/hmac.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/index.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/pbes2.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/rsa-util.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/rsaes.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/rsassa.js","webpack://digigraetzl/./node_modules/node-jose/lib/algorithms/sha.js","webpack://digigraetzl/./node_modules/node-jose/lib/deps/ciphermodes/gcm/helpers.js","webpack://digigraetzl/./node_modules/node-jose/lib/deps/ciphermodes/gcm/index.js","webpack://digigraetzl/./node_modules/node-jose/lib/deps/ciphermodes/gcm/multipliers.js","webpack://digigraetzl/./node_modules/node-jose/lib/deps/ciphermodes/helpers.js","webpack://digigraetzl/./node_modules/node-jose/lib/deps/ciphermodes/pack.js","webpack://digigraetzl/./node_modules/node-jose/lib/deps/ecc/curves.js","webpack://digigraetzl/./node_modules/node-jose/lib/deps/ecc/index.js","webpack://digigraetzl/./node_modules/node-jose/lib/deps/ecc/math.js","webpack://digigraetzl/./node_modules/node-jose/lib/deps/forge.js","webpack://digigraetzl/./node_modules/node-jose/lib/index.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwe/decrypt.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwe/defaults.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwe/encrypt.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwe/helpers.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwe/index.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwk/basekey.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwk/constants.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwk/eckey.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwk/helpers.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwk/index.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwk/keystore.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwk/octkey.js","webpack://digigraetzl/./node_modules/node-jose/lib/jwk/rsakey.js","webpack://digigraetzl/./node_modules/node-jose/lib/jws/defaults.js","webpack://digigraetzl/./node_modules/node-jose/lib/jws/helpers.js","webpack://digigraetzl/./node_modules/node-jose/lib/jws/index.js","webpack://digigraetzl/./node_modules/node-jose/lib/jws/sign.js","webpack://digigraetzl/./node_modules/node-jose/lib/jws/verify.js","webpack://digigraetzl/./node_modules/node-jose/lib/parse/compact.js","webpack://digigraetzl/./node_modules/node-jose/lib/parse/index.js","webpack://digigraetzl/./node_modules/node-jose/lib/parse/json.js","webpack://digigraetzl/./node_modules/node-jose/lib/util/algconfig.js","webpack://digigraetzl/./node_modules/node-jose/lib/util/base64url.js","webpack://digigraetzl/./node_modules/node-jose/lib/util/databuffer.js","webpack://digigraetzl/./node_modules/node-jose/lib/util/index.js","webpack://digigraetzl/./node_modules/node-jose/lib/util/merge.js","webpack://digigraetzl/./node_modules/node-jose/lib/util/utf8.js","webpack://digigraetzl/./node_modules/pako/index.js","webpack://digigraetzl/./node_modules/pako/lib/deflate.js","webpack://digigraetzl/./node_modules/pako/lib/inflate.js","webpack://digigraetzl/./node_modules/pako/lib/utils/common.js","webpack://digigraetzl/./node_modules/pako/lib/utils/strings.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/adler32.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/constants.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/crc32.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/deflate.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/gzheader.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/inffast.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/inflate.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/inftrees.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/messages.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/trees.js","webpack://digigraetzl/./node_modules/pako/lib/zlib/zstream.js","webpack://digigraetzl/./node_modules/process/browser.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/rng.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/regex.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/stringify.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/validate.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/v1.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/parse.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/v35.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/md5.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/v3.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/v4.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/sha1.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/v5.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/nil.js","webpack://digigraetzl/./node_modules/uuid/dist/esm-browser/version.js","webpack://digigraetzl/./node_modules/@decidim/decidim-bulletin_board/src/client/operations/get_election_log_entries.gql","webpack://digigraetzl/./node_modules/@decidim/decidim-bulletin_board/src/client/operations/get_log_entry.gql","webpack://digigraetzl/./node_modules/@decidim/decidim-bulletin_board/src/client/operations/get_pending_message_by_message_id.gql","webpack://digigraetzl/./node_modules/@decidim/decidim-bulletin_board/src/client/operations/process_key_ceremony_step.gql","webpack://digigraetzl/./node_modules/@decidim/decidim-bulletin_board/src/client/operations/process_tally_step.gql","webpack://digigraetzl/./node_modules/long/umd/index.js","webpack://digigraetzl/webpack/bootstrap","webpack://digigraetzl/webpack/runtime/compat get default export","webpack://digigraetzl/webpack/runtime/define property getters","webpack://digigraetzl/webpack/runtime/global","webpack://digigraetzl/webpack/runtime/hasOwnProperty shorthand","webpack://digigraetzl/webpack/runtime/make namespace object","webpack://digigraetzl/webpack/runtime/node module decorator","webpack://digigraetzl/webpack/runtime/publicPath","webpack://digigraetzl/./node_modules/tslib/tslib.es6.mjs","webpack://digigraetzl/../src/invariant.ts","webpack://digigraetzl/../src/version.ts","webpack://digigraetzl/../src/utilities/globals/maybe.ts","webpack://digigraetzl/../src/utilities/globals/global.ts","webpack://digigraetzl/../src/utilities/common/makeUniqueId.ts","webpack://digigraetzl/../src/utilities/common/stringifyForDisplay.ts","webpack://digigraetzl/../src/utilities/globals/invariantWrappers.ts","webpack://digigraetzl/../src/utilities/globals/index.ts","webpack://digigraetzl/./node_modules/zen-observable-ts/module.js","webpack://digigraetzl/../src/utilities/common/objects.ts","webpack://digigraetzl/../src/utilities/graphql/fragments.ts","webpack://digigraetzl/../src/weak.ts","webpack://digigraetzl/../src/strong.ts","webpack://digigraetzl/../src/utilities/caching/caches.ts","webpack://digigraetzl/../src/utilities/caching/sizes.ts","webpack://digigraetzl/../src/utilities/caching/getMemoryInternals.ts","webpack://digigraetzl/../src/utilities/common/canonicalStringify.ts","webpack://digigraetzl/../src/utilities/graphql/storeUtils.ts","webpack://digigraetzl/../src/utilities/graphql/getFromAST.ts","webpack://digigraetzl/../src/link/core/ApolloLink.ts","webpack://digigraetzl/../src/link/utils/createOperation.ts","webpack://digigraetzl/../src/link/utils/transformOperation.ts","webpack://digigraetzl/../src/link/utils/validateOperation.ts","webpack://digigraetzl/./node_modules/graphql/jsutils/devAssert.mjs","webpack://digigraetzl/./node_modules/graphql/jsutils/inspect.mjs","webpack://digigraetzl/./node_modules/graphql/language/ast.mjs","webpack://digigraetzl/./node_modules/graphql/language/kinds.mjs","webpack://digigraetzl/./node_modules/graphql/language/visitor.mjs","webpack://digigraetzl/../src/utilities/graphql/directives.ts","webpack://digigraetzl/../src/link/http/serializeFetchParameter.ts","webpack://digigraetzl/../src/utilities/common/canUse.ts","webpack://digigraetzl/../src/link/http/iterators/nodeStream.ts","webpack://digigraetzl/../src/link/http/iterators/reader.ts","webpack://digigraetzl/../src/link/http/responseIterator.ts","webpack://digigraetzl/../src/link/http/iterators/promise.ts","webpack://digigraetzl/../src/link/http/iterators/async.ts","webpack://digigraetzl/../src/link/utils/throwServerError.ts","webpack://digigraetzl/../src/errors/index.ts","webpack://digigraetzl/../src/utilities/common/arrays.ts","webpack://digigraetzl/../src/utilities/common/mergeDeep.ts","webpack://digigraetzl/../src/utilities/common/incrementalResult.ts","webpack://digigraetzl/../src/link/http/parseAndCheckHttpResponse.ts","webpack://digigraetzl/./node_modules/graphql/language/characterClasses.mjs","webpack://digigraetzl/./node_modules/graphql/language/printString.mjs","webpack://digigraetzl/./node_modules/graphql/language/printer.mjs","webpack://digigraetzl/../src/utilities/graphql/print.ts","webpack://digigraetzl/./node_modules/graphql/language/blockString.mjs","webpack://digigraetzl/../src/link/http/selectHttpOptionsAndBody.ts","webpack://digigraetzl/../src/link/utils/fromError.ts","webpack://digigraetzl/../src/utilities/graphql/transform.ts","webpack://digigraetzl/../src/link/http/createHttpLink.ts","webpack://digigraetzl/../src/link/http/checkFetcher.ts","webpack://digigraetzl/../src/link/http/selectURI.ts","webpack://digigraetzl/../src/link/utils/filterOperationVariables.ts","webpack://digigraetzl/../src/link/http/rewriteURIForGET.ts","webpack://digigraetzl/../src/link/http/HttpLink.ts","webpack://digigraetzl/../src/link/core/execute.ts","webpack://digigraetzl/../src/index.ts","webpack://digigraetzl/../src/slot.ts","webpack://digigraetzl/../src/context.ts","webpack://digigraetzl/../src/helpers.ts","webpack://digigraetzl/../src/entry.ts","webpack://digigraetzl/../src/dep.ts","webpack://digigraetzl/../src/utilities/graphql/DocumentTransform.ts","webpack://digigraetzl/../src/utilities/observables/asyncMap.ts","webpack://digigraetzl/../src/utilities/common/errorHandling.ts","webpack://digigraetzl/../src/utilities/observables/iteration.ts","webpack://digigraetzl/../src/utilities/observables/subclassing.ts","webpack://digigraetzl/../src/utilities/observables/Concast.ts","webpack://digigraetzl/../src/core/networkStatus.ts","webpack://digigraetzl/../src/utilities/common/compact.ts","webpack://digigraetzl/../src/utilities/common/cloneDeep.ts","webpack://digigraetzl/../src/core/equalByQuery.ts","webpack://digigraetzl/../src/core/ObservableQuery.ts","webpack://digigraetzl/./node_modules/graphql/language/predicates.mjs","webpack://digigraetzl/../src/cache/inmemory/reactiveVars.ts","webpack://digigraetzl/../src/core/LocalState.ts","webpack://digigraetzl/../src/core/QueryInfo.ts","webpack://digigraetzl/../src/core/QueryManager.ts","webpack://digigraetzl/../src/utilities/common/mergeOptions.ts","webpack://digigraetzl/../src/core/ApolloClient.ts","webpack://digigraetzl/../src/cache/core/cache.ts","webpack://digigraetzl/../src/cache/core/types/common.ts","webpack://digigraetzl/../src/utilities/common/maybeDeepFreeze.ts","webpack://digigraetzl/../src/cache/inmemory/helpers.ts","webpack://digigraetzl/../src/cache/inmemory/entityStore.ts","webpack://digigraetzl/../src/cache/inmemory/object-canon.ts","webpack://digigraetzl/../src/cache/inmemory/readFromStore.ts","webpack://digigraetzl/../src/cache/inmemory/key-extractor.ts","webpack://digigraetzl/../src/cache/inmemory/policies.ts","webpack://digigraetzl/../src/cache/inmemory/writeToStore.ts","webpack://digigraetzl/../src/cache/inmemory/inMemoryCache.ts","webpack://digigraetzl/./node_modules/@decidim/decidim-bulletin_board/src/client/graphql-client.js","webpack://digigraetzl/./node_modules/@decidim/decidim-bulletin_board/src/client/client.js","webpack://digigraetzl/./node_modules/@decidim/decidim-bulletin_board/src/trustee/trustee.js","webpack://digigraetzl/../layers/heroku_ruby/gems/ruby/3.1.0/bundler/gems/decidim-6cc188d1399f/decidim-elections/app/packs/src/decidim/votings/in-person-vote.js","webpack://digigraetzl/../layers/heroku_ruby/gems/ruby/3.1.0/bundler/gems/decidim-6cc188d1399f/decidim-elections/app/packs/entrypoints/decidim_votings.js"],"sourcesContent":["var map = {\n\t\"./decidim/elections/decidim_elections.svg\": 49681,\n\t\"./decidim/votings/decidim_votings.svg\": 48677\n};\n\n\nfunction webpackContext(req) {\n\tvar id = webpackContextResolve(req);\n\treturn __webpack_require__(id);\n}\nfunction webpackContextResolve(req) {\n\tif(!__webpack_require__.o(map, req)) {\n\t\tvar e = new Error(\"Cannot find module '\" + req + \"'\");\n\t\te.code = 'MODULE_NOT_FOUND';\n\t\tthrow e;\n\t}\n\treturn map[req];\n}\nwebpackContext.keys = function webpackContextKeys() {\n\treturn Object.keys(map);\n};\nwebpackContext.resolve = webpackContextResolve;\nmodule.exports = webpackContext;\nwebpackContext.id = 68948;","/* Fallback for non-handled failed promises */\nwindow.addEventListener(\"unhandledrejection\", (event) => {\n if (window.Decidim.currentDialogs[\"server-failure\"]) {\n document.getElementById(\"tech-info\").innerHTML = event.reason\n\n if (event.reason.toString().indexOf(\"fetch\") === -1) {\n document.getElementById(\"communication_error\").hidden = true\n document.getElementById(\"generic_error\").hidden = false\n }\n\n window.Decidim.currentDialogs[\"server-failure\"].open()\n }\n});\n","$(() => {\n const $validBallotsInput = $(\"#closure_result__ballot_results__valid_ballots_count\");\n const $blankBallotsInput = $(\"#closure_result__ballot_results__blank_ballots_count\");\n const $nullBallotsInput = $(\"#closure_result__ballot_results__null_ballots_count\");\n\n const checkTotals = () => {\n const totalBallots = $(\"#closure_result-total-ballots\").data(\"total-ballots\");\n const validBallotsCount = parseInt($validBallotsInput.val(), 10);\n const blankBallotsCount = parseInt($blankBallotsInput.val(), 10);\n const nullBallotsCount = parseInt($nullBallotsInput.val(), 10);\n\n let recount = validBallotsCount + blankBallotsCount + nullBallotsCount\n\n if (recount === totalBallots) {\n $(\"#submit-ballot-recount\").attr(\"hidden\", false);\n $(\"#btn-modal-closure-results-count-error\").attr(\"hidden\", true);\n } else {\n $(\"#submit-ballot-recount\").attr(\"hidden\", true);\n $(\"#btn-modal-closure-results-count-error\").attr(\"hidden\", false);\n }\n };\n\n $validBallotsInput.on(\"blur\", checkTotals);\n $blankBallotsInput.on(\"blur\", checkTotals);\n $nullBallotsInput.on(\"blur\", checkTotals);\n});\n","$(() => {\n $(\"#person_voted_checkbox\").on(\"change\", (event) => {\n $(\"#submit_complete_voting\").attr(\"disabled\", !$(event.target).is(\":checked\"));\n });\n});\n","$(() => {\n const $submitBtn = $(\"#submit-verify-votes\");\n const $modalBtn = $(\"#btn-modal-closure-count-error\");\n const $totalBallotsInput = $(\"#envelopes_result_total_ballots_count\");\n const $electionVotesInput = $(\"#envelopes_result_election_votes_count\");\n\n const checkValues = () => {\n const totalBallotsInputValue = parseInt($totalBallotsInput.val(), 10);\n const electionVotesInputValue = parseInt($electionVotesInput.val(), 10);\n\n if (totalBallotsInputValue === electionVotesInputValue) {\n $submitBtn.find(\"button\").attr(\"disabled\", false);\n $submitBtn.attr(\"hidden\", false);\n $modalBtn.attr(\"hidden\", true);\n } else {\n $submitBtn.attr(\"hidden\", true);\n $modalBtn.attr(\"hidden\", false);\n }\n };\n\n $totalBallotsInput.on(\"blur\", checkValues);\n\n $totalBallotsInput.on(\"keyup\", function() {\n $(\"#modal-total-ballots-value\").html(parseInt($totalBallotsInput.val(), 10));\n $(\"#envelopes_result_polling_officer_notes\").val(\"\")\n });\n\n $(\"#envelopes_result_polling_officer_notes\").on(\"keyup\", function() {\n let modalPollingOfficerNotes = $(\"#envelopes_result_polling_officer_notes\").val()\n\n $(\"#btn-submit-from-modal\").attr(\"disabled\", !modalPollingOfficerNotes.trim());\n });\n});\n","$(() => {\n const $submitBtn = $(\"#btn-submit-from-modal\");\n const $modalBtn = $(\"#btn-modal-closure-sign\");\n const $signCheckbox = $(\"#closure_sign_signed\");\n\n const changeButtonProps = (event) => {\n const notSigned = !$(event.target).is(\":checked\");\n $modalBtn.prop(\"disabled\", notSigned);\n $submitBtn.prop(\"disabled\", notSigned);\n };\n\n $signCheckbox.on(\"change\", changeButtonProps);\n});\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(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\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","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar pad_string_1 = require(\"./pad-string\");\nfunction encode(input, encoding) {\n if (encoding === void 0) { encoding = \"utf8\"; }\n if (Buffer.isBuffer(input)) {\n return fromBase64(input.toString(\"base64\"));\n }\n return fromBase64(Buffer.from(input, encoding).toString(\"base64\"));\n}\n;\nfunction decode(base64url, encoding) {\n if (encoding === void 0) { encoding = \"utf8\"; }\n return Buffer.from(toBase64(base64url), \"base64\").toString(encoding);\n}\nfunction toBase64(base64url) {\n base64url = base64url.toString();\n return pad_string_1.default(base64url)\n .replace(/\\-/g, \"+\")\n .replace(/_/g, \"/\");\n}\nfunction fromBase64(base64) {\n return base64\n .replace(/=/g, \"\")\n .replace(/\\+/g, \"-\")\n .replace(/\\//g, \"_\");\n}\nfunction toBuffer(base64url) {\n return Buffer.from(toBase64(base64url), \"base64\");\n}\nvar base64url = encode;\nbase64url.encode = encode;\nbase64url.decode = decode;\nbase64url.toBase64 = toBase64;\nbase64url.fromBase64 = fromBase64;\nbase64url.toBuffer = toBuffer;\nexports.default = base64url;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nfunction padString(input) {\n var segmentLength = 4;\n var stringLength = input.length;\n var diff = stringLength % segmentLength;\n if (!diff) {\n return input;\n }\n var position = stringLength;\n var padLength = segmentLength - diff;\n var paddedStringLength = stringLength + padLength;\n var buffer = Buffer.alloc(paddedStringLength);\n buffer.write(input);\n while (padLength--) {\n buffer.write(\"=\", position++);\n }\n return buffer.toString();\n}\nexports.default = padString;\n","module.exports = require('./dist/base64url').default;\nmodule.exports.default = module.exports;\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar customInspectSymbol =\n (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n : null\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nvar K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * 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 * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n var arr = new Uint8Array(1)\n var proto = { foo: function () { return 42 } }\n Object.setPrototypeOf(proto, Uint8Array.prototype)\n Object.setPrototypeOf(arr, proto)\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.buffer\n }\n})\n\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.byteOffset\n }\n})\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n }\n // Return an augmented `Uint8Array` instance\n var buf = new Uint8Array(length)\n Object.setPrototypeOf(buf, Buffer.prototype)\n return buf\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 // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError(\n 'The \"string\" argument must be of type string. Received type number'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value)\n }\n\n if (value == null) {\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n }\n\n if (isInstance(value, ArrayBuffer) ||\n (value && isInstance(value.buffer, ArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof SharedArrayBuffer !== 'undefined' &&\n (isInstance(value, SharedArrayBuffer) ||\n (value && isInstance(value.buffer, SharedArrayBuffer)))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'number') {\n throw new TypeError(\n 'The \"value\" argument must not be of type number. Received type number'\n )\n }\n\n var valueOf = value.valueOf && value.valueOf()\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length)\n }\n\n var b = fromObject(value)\n if (b) return b\n\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(\n value[Symbol.toPrimitive]('string'), encodingOrOffset, length\n )\n }\n\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\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(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype)\nObject.setPrototypeOf(Buffer, Uint8Array)\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number')\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(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 interpreted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(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(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\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(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(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n\n var length = byteLength(string, encoding) | 0\n var buf = createBuffer(length)\n\n var actual = buf.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 buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n var length = array.length < 0 ? 0 : checked(array.length) | 0\n var buf = createBuffer(length)\n for (var i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayView (arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n var copy = new Uint8Array(arrayView)\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n }\n return fromArrayLike(arrayView)\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds')\n }\n\n var buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype)\n\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n var len = checked(obj.length) | 0\n var buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.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 === true &&\n b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n}\n\nBuffer.compare = function compare (a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength)\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength)\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError(\n 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n )\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 (!Array.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 (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n Buffer.from(buf).copy(buffer, pos)\n } else {\n Uint8Array.prototype.set.call(\n buffer,\n buf,\n pos\n )\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n } else {\n buf.copy(buffer, pos)\n }\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 (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n throw new TypeError(\n 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n 'Received type ' + typeof string\n )\n }\n\n var len = string.length\n var mustMatch = (arguments.length > 2 && arguments[2] === true)\n if (!mustMatch && 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 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) {\n return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n }\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 coercion 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// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\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\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.toLocaleString = Buffer.prototype.toString\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 str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim()\n if (this.length > max) str += ' ... '\n return ''\n}\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength)\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError(\n 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n 'Received type ' + (typeof target)\n )\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 (numberIsNaN(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 (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 var strLen = string.length\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 (numberIsNaN(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 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 } 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 case 'latin1':\n case 'binary':\n return asciiWrite(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)\n ? 4\n : (firstByte > 0xDF)\n ? 3\n : (firstByte > 0xBF)\n ? 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 += hexSliceLookupTable[buf[i]]\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n var bytes = buf.slice(start, end)\n var res = ''\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (var i = 0; i < bytes.length - 1; 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 = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype)\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 =\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 =\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 =\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUint16LE =\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUint16BE =\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUint32LE =\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\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 =\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\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 offset = offset >>> 0\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 offset = offset >>> 0\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 offset = offset >>> 0\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 offset = offset >>> 0\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 offset = offset >>> 0\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 offset = offset >>> 0\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 offset = offset >>> 0\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 offset = offset >>> 0\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 offset = offset >>> 0\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 =\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 =\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 =\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 this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUint16LE =\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 this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUint16BE =\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 this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUint32LE =\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 this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUint32BE =\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 this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\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 (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 this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\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 this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\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 this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\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 this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\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 value = +value\n offset = offset >>> 0\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 value = +value\n offset = offset >>> 0\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 (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\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('Index out of range')\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\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end)\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, end),\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 (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 if (val.length === 1) {\n var code = val.charCodeAt(0)\n if ((encoding === 'utf8' && code < 128) ||\n encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n } else if (typeof val === 'boolean') {\n val = Number(val)\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 : Buffer.from(val, encoding)\n var len = bytes.length\n if (len === 0) {\n throw new TypeError('The value \"' + val +\n '\" is invalid for argument \"value\"')\n }\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 takes equal signs as end of the Base64 encoding\n str = str.split('=')[0]\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().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 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\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance (obj, type) {\n return obj instanceof type ||\n (obj != null && obj.constructor != null && obj.constructor.name != null &&\n obj.constructor.name === type.name)\n}\nfunction numberIsNaN (obj) {\n // For IE11 support\n return obj !== obj // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nvar hexSliceLookupTable = (function () {\n var alphabet = '0123456789abcdef'\n var table = new Array(256)\n for (var i = 0; i < 16; ++i) {\n var i16 = i * 16\n for (var j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j]\n }\n }\n return table\n})()\n","/*!\n * @overview es6-promise - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors (Conversion to ES6 API by Jake Archibald)\n * @license Licensed under MIT license\n * See https://raw.githubusercontent.com/stefanpenner/es6-promise/master/LICENSE\n * @version v4.2.8+1e68dce6\n */\n","export function objectOrFunction(x) {\n var type = typeof x;\n return x !== null && (type === 'object' || type === 'function');\n}\n\nexport function isFunction(x) {\n return typeof x === 'function';\n}\n\nexport function isMaybeThenable(x) {\n return x !== null && typeof x === 'object';\n}\n\nvar _isArray = void 0;\nif (Array.isArray) {\n _isArray = Array.isArray;\n} else {\n _isArray = function (x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n };\n}\n\nexport var isArray = _isArray;","var len = 0;\nvar vertxNext = void 0;\nvar customSchedulerFn = void 0;\n\nexport var asap = function asap(callback, arg) {\n queue[len] = callback;\n queue[len + 1] = arg;\n len += 2;\n if (len === 2) {\n // If len is 2, that means that we need to schedule an async flush.\n // If additional callbacks are queued before the queue is flushed, they\n // will be processed by this flush that we are scheduling.\n if (customSchedulerFn) {\n customSchedulerFn(flush);\n } else {\n scheduleFlush();\n }\n }\n};\n\nexport function setScheduler(scheduleFn) {\n customSchedulerFn = scheduleFn;\n}\n\nexport function setAsap(asapFn) {\n asap = asapFn;\n}\n\nvar browserWindow = typeof window !== 'undefined' ? window : undefined;\nvar browserGlobal = browserWindow || {};\nvar BrowserMutationObserver = browserGlobal.MutationObserver || browserGlobal.WebKitMutationObserver;\nvar isNode = typeof self === 'undefined' && typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n// test for web worker but not in IE10\nvar isWorker = typeof Uint8ClampedArray !== 'undefined' && typeof importScripts !== 'undefined' && typeof MessageChannel !== 'undefined';\n\n// node\nfunction useNextTick() {\n // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n // see https://github.com/cujojs/when/issues/410 for details\n return function () {\n return process.nextTick(flush);\n };\n}\n\n// vertx\nfunction useVertxTimer() {\n if (typeof vertxNext !== 'undefined') {\n return function () {\n vertxNext(flush);\n };\n }\n\n return useSetTimeout();\n}\n\nfunction useMutationObserver() {\n var iterations = 0;\n var observer = new BrowserMutationObserver(flush);\n var node = document.createTextNode('');\n observer.observe(node, { characterData: true });\n\n return function () {\n node.data = iterations = ++iterations % 2;\n };\n}\n\n// web worker\nfunction useMessageChannel() {\n var channel = new MessageChannel();\n channel.port1.onmessage = flush;\n return function () {\n return channel.port2.postMessage(0);\n };\n}\n\nfunction useSetTimeout() {\n // Store setTimeout reference so es6-promise will be unaffected by\n // other code modifying setTimeout (like sinon.useFakeTimers())\n var globalSetTimeout = setTimeout;\n return function () {\n return globalSetTimeout(flush, 1);\n };\n}\n\nvar queue = new Array(1000);\nfunction flush() {\n for (var i = 0; i < len; i += 2) {\n var callback = queue[i];\n var arg = queue[i + 1];\n\n callback(arg);\n\n queue[i] = undefined;\n queue[i + 1] = undefined;\n }\n\n len = 0;\n}\n\nfunction attemptVertx() {\n try {\n var vertx = Function('return this')().require('vertx');\n vertxNext = vertx.runOnLoop || vertx.runOnContext;\n return useVertxTimer();\n } catch (e) {\n return useSetTimeout();\n }\n}\n\nvar scheduleFlush = void 0;\n// Decide what async method to use to triggering processing of queued callbacks:\nif (isNode) {\n scheduleFlush = useNextTick();\n} else if (BrowserMutationObserver) {\n scheduleFlush = useMutationObserver();\n} else if (isWorker) {\n scheduleFlush = useMessageChannel();\n} else if (browserWindow === undefined && typeof require === 'function') {\n scheduleFlush = attemptVertx();\n} else {\n scheduleFlush = useSetTimeout();\n}","import { invokeCallback, subscribe, FULFILLED, REJECTED, noop, makePromise, PROMISE_ID } from './-internal';\n\nimport { asap } from './asap';\n\nexport default function then(onFulfillment, onRejection) {\n var parent = this;\n\n var child = new this.constructor(noop);\n\n if (child[PROMISE_ID] === undefined) {\n makePromise(child);\n }\n\n var _state = parent._state;\n\n\n if (_state) {\n var callback = arguments[_state - 1];\n asap(function () {\n return invokeCallback(_state, child, callback, parent._result);\n });\n } else {\n subscribe(parent, child, onFulfillment, onRejection);\n }\n\n return child;\n}","import { noop, resolve as _resolve } from '../-internal';\n\n/**\n `Promise.resolve` returns a promise that will become resolved with the\n passed `value`. It is shorthand for the following:\n\n ```javascript\n let promise = new Promise(function(resolve, reject){\n resolve(1);\n });\n\n promise.then(function(value){\n // value === 1\n });\n ```\n\n Instead of writing the above, your code now simply becomes the following:\n\n ```javascript\n let promise = Promise.resolve(1);\n\n promise.then(function(value){\n // value === 1\n });\n ```\n\n @method resolve\n @static\n @param {Any} value value that the returned promise will be resolved with\n Useful for tooling.\n @return {Promise} a promise that will become fulfilled with the given\n `value`\n*/\nexport default function resolve(object) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (object && typeof object === 'object' && object.constructor === Constructor) {\n return object;\n }\n\n var promise = new Constructor(noop);\n _resolve(promise, object);\n return promise;\n}","import { objectOrFunction, isFunction } from './utils';\n\nimport { asap } from './asap';\n\nimport originalThen from './then';\nimport originalResolve from './promise/resolve';\n\nexport var PROMISE_ID = Math.random().toString(36).substring(2);\n\nfunction noop() {}\n\nvar PENDING = void 0;\nvar FULFILLED = 1;\nvar REJECTED = 2;\n\nfunction selfFulfillment() {\n return new TypeError(\"You cannot resolve a promise with itself\");\n}\n\nfunction cannotReturnOwn() {\n return new TypeError('A promises callback cannot return that same promise.');\n}\n\nfunction tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n try {\n then.call(value, fulfillmentHandler, rejectionHandler);\n } catch (e) {\n return e;\n }\n}\n\nfunction handleForeignThenable(promise, thenable, then) {\n asap(function (promise) {\n var sealed = false;\n var error = tryThen(then, thenable, function (value) {\n if (sealed) {\n return;\n }\n sealed = true;\n if (thenable !== value) {\n resolve(promise, value);\n } else {\n fulfill(promise, value);\n }\n }, function (reason) {\n if (sealed) {\n return;\n }\n sealed = true;\n\n reject(promise, reason);\n }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n if (!sealed && error) {\n sealed = true;\n reject(promise, error);\n }\n }, promise);\n}\n\nfunction handleOwnThenable(promise, thenable) {\n if (thenable._state === FULFILLED) {\n fulfill(promise, thenable._result);\n } else if (thenable._state === REJECTED) {\n reject(promise, thenable._result);\n } else {\n subscribe(thenable, undefined, function (value) {\n return resolve(promise, value);\n }, function (reason) {\n return reject(promise, reason);\n });\n }\n}\n\nfunction handleMaybeThenable(promise, maybeThenable, then) {\n if (maybeThenable.constructor === promise.constructor && then === originalThen && maybeThenable.constructor.resolve === originalResolve) {\n handleOwnThenable(promise, maybeThenable);\n } else {\n if (then === undefined) {\n fulfill(promise, maybeThenable);\n } else if (isFunction(then)) {\n handleForeignThenable(promise, maybeThenable, then);\n } else {\n fulfill(promise, maybeThenable);\n }\n }\n}\n\nfunction resolve(promise, value) {\n if (promise === value) {\n reject(promise, selfFulfillment());\n } else if (objectOrFunction(value)) {\n var then = void 0;\n try {\n then = value.then;\n } catch (error) {\n reject(promise, error);\n return;\n }\n handleMaybeThenable(promise, value, then);\n } else {\n fulfill(promise, value);\n }\n}\n\nfunction publishRejection(promise) {\n if (promise._onerror) {\n promise._onerror(promise._result);\n }\n\n publish(promise);\n}\n\nfunction fulfill(promise, value) {\n if (promise._state !== PENDING) {\n return;\n }\n\n promise._result = value;\n promise._state = FULFILLED;\n\n if (promise._subscribers.length !== 0) {\n asap(publish, promise);\n }\n}\n\nfunction reject(promise, reason) {\n if (promise._state !== PENDING) {\n return;\n }\n promise._state = REJECTED;\n promise._result = reason;\n\n asap(publishRejection, promise);\n}\n\nfunction subscribe(parent, child, onFulfillment, onRejection) {\n var _subscribers = parent._subscribers;\n var length = _subscribers.length;\n\n\n parent._onerror = null;\n\n _subscribers[length] = child;\n _subscribers[length + FULFILLED] = onFulfillment;\n _subscribers[length + REJECTED] = onRejection;\n\n if (length === 0 && parent._state) {\n asap(publish, parent);\n }\n}\n\nfunction publish(promise) {\n var subscribers = promise._subscribers;\n var settled = promise._state;\n\n if (subscribers.length === 0) {\n return;\n }\n\n var child = void 0,\n callback = void 0,\n detail = promise._result;\n\n for (var i = 0; i < subscribers.length; i += 3) {\n child = subscribers[i];\n callback = subscribers[i + settled];\n\n if (child) {\n invokeCallback(settled, child, callback, detail);\n } else {\n callback(detail);\n }\n }\n\n promise._subscribers.length = 0;\n}\n\nfunction invokeCallback(settled, promise, callback, detail) {\n var hasCallback = isFunction(callback),\n value = void 0,\n error = void 0,\n succeeded = true;\n\n if (hasCallback) {\n try {\n value = callback(detail);\n } catch (e) {\n succeeded = false;\n error = e;\n }\n\n if (promise === value) {\n reject(promise, cannotReturnOwn());\n return;\n }\n } else {\n value = detail;\n }\n\n if (promise._state !== PENDING) {\n // noop\n } else if (hasCallback && succeeded) {\n resolve(promise, value);\n } else if (succeeded === false) {\n reject(promise, error);\n } else if (settled === FULFILLED) {\n fulfill(promise, value);\n } else if (settled === REJECTED) {\n reject(promise, value);\n }\n}\n\nfunction initializePromise(promise, resolver) {\n try {\n resolver(function resolvePromise(value) {\n resolve(promise, value);\n }, function rejectPromise(reason) {\n reject(promise, reason);\n });\n } catch (e) {\n reject(promise, e);\n }\n}\n\nvar id = 0;\nfunction nextId() {\n return id++;\n}\n\nfunction makePromise(promise) {\n promise[PROMISE_ID] = id++;\n promise._state = undefined;\n promise._result = undefined;\n promise._subscribers = [];\n}\n\nexport { nextId, makePromise, noop, resolve, reject, fulfill, subscribe, publish, publishRejection, initializePromise, invokeCallback, FULFILLED, REJECTED, PENDING, handleMaybeThenable };","function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nimport { isArray, isMaybeThenable } from './utils';\nimport { noop, reject, fulfill, subscribe, FULFILLED, REJECTED, PENDING, handleMaybeThenable } from './-internal';\n\nimport then from './then';\nimport Promise from './promise';\nimport originalResolve from './promise/resolve';\nimport originalThen from './then';\nimport { makePromise, PROMISE_ID } from './-internal';\n\nfunction validationError() {\n return new Error('Array Methods must be provided an Array');\n};\n\nvar Enumerator = function () {\n function Enumerator(Constructor, input) {\n this._instanceConstructor = Constructor;\n this.promise = new Constructor(noop);\n\n if (!this.promise[PROMISE_ID]) {\n makePromise(this.promise);\n }\n\n if (isArray(input)) {\n this.length = input.length;\n this._remaining = input.length;\n\n this._result = new Array(this.length);\n\n if (this.length === 0) {\n fulfill(this.promise, this._result);\n } else {\n this.length = this.length || 0;\n this._enumerate(input);\n if (this._remaining === 0) {\n fulfill(this.promise, this._result);\n }\n }\n } else {\n reject(this.promise, validationError());\n }\n }\n\n Enumerator.prototype._enumerate = function _enumerate(input) {\n for (var i = 0; this._state === PENDING && i < input.length; i++) {\n this._eachEntry(input[i], i);\n }\n };\n\n Enumerator.prototype._eachEntry = function _eachEntry(entry, i) {\n var c = this._instanceConstructor;\n var resolve = c.resolve;\n\n\n if (resolve === originalResolve) {\n var _then = void 0;\n var error = void 0;\n var didError = false;\n try {\n _then = entry.then;\n } catch (e) {\n didError = true;\n error = e;\n }\n\n if (_then === originalThen && entry._state !== PENDING) {\n this._settledAt(entry._state, i, entry._result);\n } else if (typeof _then !== 'function') {\n this._remaining--;\n this._result[i] = entry;\n } else if (c === Promise) {\n var promise = new c(noop);\n if (didError) {\n reject(promise, error);\n } else {\n handleMaybeThenable(promise, entry, _then);\n }\n this._willSettleAt(promise, i);\n } else {\n this._willSettleAt(new c(function (resolve) {\n return resolve(entry);\n }), i);\n }\n } else {\n this._willSettleAt(resolve(entry), i);\n }\n };\n\n Enumerator.prototype._settledAt = function _settledAt(state, i, value) {\n var promise = this.promise;\n\n\n if (promise._state === PENDING) {\n this._remaining--;\n\n if (state === REJECTED) {\n reject(promise, value);\n } else {\n this._result[i] = value;\n }\n }\n\n if (this._remaining === 0) {\n fulfill(promise, this._result);\n }\n };\n\n Enumerator.prototype._willSettleAt = function _willSettleAt(promise, i) {\n var enumerator = this;\n\n subscribe(promise, undefined, function (value) {\n return enumerator._settledAt(FULFILLED, i, value);\n }, function (reason) {\n return enumerator._settledAt(REJECTED, i, reason);\n });\n };\n\n return Enumerator;\n}();\n\nexport default Enumerator;\n;","function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nimport { isFunction } from './utils';\nimport { noop, nextId, PROMISE_ID, initializePromise } from './-internal';\nimport { asap, setAsap, setScheduler } from './asap';\n\nimport all from './promise/all';\nimport race from './promise/race';\nimport Resolve from './promise/resolve';\nimport Reject from './promise/reject';\nimport then from './then';\n\nfunction needsResolver() {\n throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n}\n\nfunction needsNew() {\n throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n}\n\n/**\n Promise objects represent the eventual result of an asynchronous operation. The\n primary way of interacting with a promise is through its `then` method, which\n registers callbacks to receive either a promise's eventual value or the reason\n why the promise cannot be fulfilled.\n\n Terminology\n -----------\n\n - `promise` is an object or function with a `then` method whose behavior conforms to this specification.\n - `thenable` is an object or function that defines a `then` method.\n - `value` is any legal JavaScript value (including undefined, a thenable, or a promise).\n - `exception` is a value that is thrown using the throw statement.\n - `reason` is a value that indicates why a promise was rejected.\n - `settled` the final resting state of a promise, fulfilled or rejected.\n\n A promise can be in one of three states: pending, fulfilled, or rejected.\n\n Promises that are fulfilled have a fulfillment value and are in the fulfilled\n state. Promises that are rejected have a rejection reason and are in the\n rejected state. A fulfillment value is never a thenable.\n\n Promises can also be said to *resolve* a value. If this value is also a\n promise, then the original promise's settled state will match the value's\n settled state. So a promise that *resolves* a promise that rejects will\n itself reject, and a promise that *resolves* a promise that fulfills will\n itself fulfill.\n\n\n Basic Usage:\n ------------\n\n ```js\n let promise = new Promise(function(resolve, reject) {\n // on success\n resolve(value);\n\n // on failure\n reject(reason);\n });\n\n promise.then(function(value) {\n // on fulfillment\n }, function(reason) {\n // on rejection\n });\n ```\n\n Advanced Usage:\n ---------------\n\n Promises shine when abstracting away asynchronous interactions such as\n `XMLHttpRequest`s.\n\n ```js\n function getJSON(url) {\n return new Promise(function(resolve, reject){\n let xhr = new XMLHttpRequest();\n\n xhr.open('GET', url);\n xhr.onreadystatechange = handler;\n xhr.responseType = 'json';\n xhr.setRequestHeader('Accept', 'application/json');\n xhr.send();\n\n function handler() {\n if (this.readyState === this.DONE) {\n if (this.status === 200) {\n resolve(this.response);\n } else {\n reject(new Error('getJSON: `' + url + '` failed with status: [' + this.status + ']'));\n }\n }\n };\n });\n }\n\n getJSON('/posts.json').then(function(json) {\n // on fulfillment\n }, function(reason) {\n // on rejection\n });\n ```\n\n Unlike callbacks, promises are great composable primitives.\n\n ```js\n Promise.all([\n getJSON('/posts'),\n getJSON('/comments')\n ]).then(function(values){\n values[0] // => postsJSON\n values[1] // => commentsJSON\n\n return values;\n });\n ```\n\n @class Promise\n @param {Function} resolver\n Useful for tooling.\n @constructor\n*/\n\nvar Promise = function () {\n function Promise(resolver) {\n this[PROMISE_ID] = nextId();\n this._result = this._state = undefined;\n this._subscribers = [];\n\n if (noop !== resolver) {\n typeof resolver !== 'function' && needsResolver();\n this instanceof Promise ? initializePromise(this, resolver) : needsNew();\n }\n }\n\n /**\n The primary way of interacting with a promise is through its `then` method,\n which registers callbacks to receive either a promise's eventual value or the\n reason why the promise cannot be fulfilled.\n ```js\n findUser().then(function(user){\n // user is available\n }, function(reason){\n // user is unavailable, and you are given the reason why\n });\n ```\n Chaining\n --------\n The return value of `then` is itself a promise. This second, 'downstream'\n promise is resolved with the return value of the first promise's fulfillment\n or rejection handler, or rejected if the handler throws an exception.\n ```js\n findUser().then(function (user) {\n return user.name;\n }, function (reason) {\n return 'default name';\n }).then(function (userName) {\n // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n // will be `'default name'`\n });\n findUser().then(function (user) {\n throw new Error('Found user, but still unhappy');\n }, function (reason) {\n throw new Error('`findUser` rejected and we're unhappy');\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n });\n ```\n If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n ```js\n findUser().then(function (user) {\n throw new PedagogicalException('Upstream error');\n }).then(function (value) {\n // never reached\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // The `PedgagocialException` is propagated all the way down to here\n });\n ```\n Assimilation\n ------------\n Sometimes the value you want to propagate to a downstream promise can only be\n retrieved asynchronously. This can be achieved by returning a promise in the\n fulfillment or rejection handler. The downstream promise will then be pending\n until the returned promise is settled. This is called *assimilation*.\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // The user's comments are now available\n });\n ```\n If the assimliated promise rejects, then the downstream promise will also reject.\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // If `findCommentsByAuthor` fulfills, we'll have the value here\n }, function (reason) {\n // If `findCommentsByAuthor` rejects, we'll have the reason here\n });\n ```\n Simple Example\n --------------\n Synchronous Example\n ```javascript\n let result;\n try {\n result = findResult();\n // success\n } catch(reason) {\n // failure\n }\n ```\n Errback Example\n ```js\n findResult(function(result, err){\n if (err) {\n // failure\n } else {\n // success\n }\n });\n ```\n Promise Example;\n ```javascript\n findResult().then(function(result){\n // success\n }, function(reason){\n // failure\n });\n ```\n Advanced Example\n --------------\n Synchronous Example\n ```javascript\n let author, books;\n try {\n author = findAuthor();\n books = findBooksByAuthor(author);\n // success\n } catch(reason) {\n // failure\n }\n ```\n Errback Example\n ```js\n function foundBooks(books) {\n }\n function failure(reason) {\n }\n findAuthor(function(author, err){\n if (err) {\n failure(err);\n // failure\n } else {\n try {\n findBoooksByAuthor(author, function(books, err) {\n if (err) {\n failure(err);\n } else {\n try {\n foundBooks(books);\n } catch(reason) {\n failure(reason);\n }\n }\n });\n } catch(error) {\n failure(err);\n }\n // success\n }\n });\n ```\n Promise Example;\n ```javascript\n findAuthor().\n then(findBooksByAuthor).\n then(function(books){\n // found books\n }).catch(function(reason){\n // something went wrong\n });\n ```\n @method then\n @param {Function} onFulfilled\n @param {Function} onRejected\n Useful for tooling.\n @return {Promise}\n */\n\n /**\n `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n as the catch block of a try/catch statement.\n ```js\n function findAuthor(){\n throw new Error('couldn't find that author');\n }\n // synchronous\n try {\n findAuthor();\n } catch(reason) {\n // something went wrong\n }\n // async with promises\n findAuthor().catch(function(reason){\n // something went wrong\n });\n ```\n @method catch\n @param {Function} onRejection\n Useful for tooling.\n @return {Promise}\n */\n\n\n Promise.prototype.catch = function _catch(onRejection) {\n return this.then(null, onRejection);\n };\n\n /**\n `finally` will be invoked regardless of the promise's fate just as native\n try/catch/finally behaves\n \n Synchronous example:\n \n ```js\n findAuthor() {\n if (Math.random() > 0.5) {\n throw new Error();\n }\n return new Author();\n }\n \n try {\n return findAuthor(); // succeed or fail\n } catch(error) {\n return findOtherAuther();\n } finally {\n // always runs\n // doesn't affect the return value\n }\n ```\n \n Asynchronous example:\n \n ```js\n findAuthor().catch(function(reason){\n return findOtherAuther();\n }).finally(function(){\n // author was either found, or not\n });\n ```\n \n @method finally\n @param {Function} callback\n @return {Promise}\n */\n\n\n Promise.prototype.finally = function _finally(callback) {\n var promise = this;\n var constructor = promise.constructor;\n\n if (isFunction(callback)) {\n return promise.then(function (value) {\n return constructor.resolve(callback()).then(function () {\n return value;\n });\n }, function (reason) {\n return constructor.resolve(callback()).then(function () {\n throw reason;\n });\n });\n }\n\n return promise.then(callback, callback);\n };\n\n return Promise;\n}();\n\nPromise.prototype.then = then;\nexport default Promise;\nPromise.all = all;\nPromise.race = race;\nPromise.resolve = Resolve;\nPromise.reject = Reject;\nPromise._setScheduler = setScheduler;\nPromise._setAsap = setAsap;\nPromise._asap = asap;","import Promise from './es6-promise/promise';\nimport polyfill from './es6-promise/polyfill';\n\n// Strange compat..\nPromise.polyfill = polyfill;\nPromise.Promise = Promise;\nexport default Promise;","import Enumerator from '../enumerator';\n\n/**\n `Promise.all` accepts an array of promises, and returns a new promise which\n is fulfilled with an array of fulfillment values for the passed promises, or\n rejected with the reason of the first passed promise to be rejected. It casts all\n elements of the passed iterable to promises as it runs this algorithm.\n\n Example:\n\n ```javascript\n let promise1 = resolve(1);\n let promise2 = resolve(2);\n let promise3 = resolve(3);\n let promises = [ promise1, promise2, promise3 ];\n\n Promise.all(promises).then(function(array){\n // The array here would be [ 1, 2, 3 ];\n });\n ```\n\n If any of the `promises` given to `all` are rejected, the first promise\n that is rejected will be given as an argument to the returned promises's\n rejection handler. For example:\n\n Example:\n\n ```javascript\n let promise1 = resolve(1);\n let promise2 = reject(new Error(\"2\"));\n let promise3 = reject(new Error(\"3\"));\n let promises = [ promise1, promise2, promise3 ];\n\n Promise.all(promises).then(function(array){\n // Code here never runs because there are rejected promises!\n }, function(error) {\n // error.message === \"2\"\n });\n ```\n\n @method all\n @static\n @param {Array} entries array of promises\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise} promise that is fulfilled when all `promises` have been\n fulfilled, or rejected if any of them become rejected.\n @static\n*/\nexport default function all(entries) {\n return new Enumerator(this, entries).promise;\n}","import { isArray } from \"../utils\";\n\n/**\n `Promise.race` returns a new promise which is settled in the same way as the\n first passed promise to settle.\n\n Example:\n\n ```javascript\n let promise1 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 1');\n }, 200);\n });\n\n let promise2 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 2');\n }, 100);\n });\n\n Promise.race([promise1, promise2]).then(function(result){\n // result === 'promise 2' because it was resolved before promise1\n // was resolved.\n });\n ```\n\n `Promise.race` is deterministic in that only the state of the first\n settled promise matters. For example, even if other promises given to the\n `promises` array argument are resolved, but the first settled promise has\n become rejected before the other promises became fulfilled, the returned\n promise will become rejected:\n\n ```javascript\n let promise1 = new Promise(function(resolve, reject){\n setTimeout(function(){\n resolve('promise 1');\n }, 200);\n });\n\n let promise2 = new Promise(function(resolve, reject){\n setTimeout(function(){\n reject(new Error('promise 2'));\n }, 100);\n });\n\n Promise.race([promise1, promise2]).then(function(result){\n // Code here never runs\n }, function(reason){\n // reason.message === 'promise 2' because promise 2 became rejected before\n // promise 1 became fulfilled\n });\n ```\n\n An example real-world use case is implementing timeouts:\n\n ```javascript\n Promise.race([ajax('foo.json'), timeout(5000)])\n ```\n\n @method race\n @static\n @param {Array} promises array of promises to observe\n Useful for tooling.\n @return {Promise} a promise which settles in the same way as the first passed\n promise to settle.\n*/\nexport default function race(entries) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (!isArray(entries)) {\n return new Constructor(function (_, reject) {\n return reject(new TypeError('You must pass an array to race.'));\n });\n } else {\n return new Constructor(function (resolve, reject) {\n var length = entries.length;\n for (var i = 0; i < length; i++) {\n Constructor.resolve(entries[i]).then(resolve, reject);\n }\n });\n }\n}","import { noop, reject as _reject } from '../-internal';\n\n/**\n `Promise.reject` returns a promise rejected with the passed `reason`.\n It is shorthand for the following:\n\n ```javascript\n let promise = new Promise(function(resolve, reject){\n reject(new Error('WHOOPS'));\n });\n\n promise.then(function(value){\n // Code here doesn't run because the promise is rejected!\n }, function(reason){\n // reason.message === 'WHOOPS'\n });\n ```\n\n Instead of writing the above, your code now simply becomes the following:\n\n ```javascript\n let promise = Promise.reject(new Error('WHOOPS'));\n\n promise.then(function(value){\n // Code here doesn't run because the promise is rejected!\n }, function(reason){\n // reason.message === 'WHOOPS'\n });\n ```\n\n @method reject\n @static\n @param {Any} reason value that the returned promise will be rejected with.\n Useful for tooling.\n @return {Promise} a promise rejected with the given `reason`.\n*/\nexport default function reject(reason) {\n /*jshint validthis:true */\n var Constructor = this;\n var promise = new Constructor(noop);\n _reject(promise, reason);\n return promise;\n}","/*global self*/\nimport Promise from './promise';\n\nexport default function polyfill() {\n var local = void 0;\n\n if (typeof global !== 'undefined') {\n local = global;\n } else if (typeof self !== 'undefined') {\n local = self;\n } else {\n try {\n local = Function('return this')();\n } catch (e) {\n throw new Error('polyfill failed because global object is unavailable in this environment');\n }\n }\n\n var P = local.Promise;\n\n if (P) {\n var promiseToString = null;\n try {\n promiseToString = Object.prototype.toString.call(P.resolve());\n } catch (e) {\n // silently ignored\n }\n\n if (promiseToString === '[object Promise]' && !P.cast) {\n return;\n }\n }\n\n local.Promise = Promise;\n}","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh */\nexports.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 getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nmodule.exports = DataView;\n","var hashClear = require('./_hashClear'),\n hashDelete = require('./_hashDelete'),\n hashGet = require('./_hashGet'),\n hashHas = require('./_hashHas'),\n hashSet = require('./_hashSet');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nmodule.exports = Hash;\n","var baseCreate = require('./_baseCreate'),\n baseLodash = require('./_baseLodash');\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295;\n\n/**\n * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.\n *\n * @private\n * @constructor\n * @param {*} value The value to wrap.\n */\nfunction LazyWrapper(value) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__dir__ = 1;\n this.__filtered__ = false;\n this.__iteratees__ = [];\n this.__takeCount__ = MAX_ARRAY_LENGTH;\n this.__views__ = [];\n}\n\n// Ensure `LazyWrapper` is an instance of `baseLodash`.\nLazyWrapper.prototype = baseCreate(baseLodash.prototype);\nLazyWrapper.prototype.constructor = LazyWrapper;\n\nmodule.exports = LazyWrapper;\n","var listCacheClear = require('./_listCacheClear'),\n listCacheDelete = require('./_listCacheDelete'),\n listCacheGet = require('./_listCacheGet'),\n listCacheHas = require('./_listCacheHas'),\n listCacheSet = require('./_listCacheSet');\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nmodule.exports = ListCache;\n","var baseCreate = require('./_baseCreate'),\n baseLodash = require('./_baseLodash');\n\n/**\n * The base constructor for creating `lodash` wrapper objects.\n *\n * @private\n * @param {*} value The value to wrap.\n * @param {boolean} [chainAll] Enable explicit method chain sequences.\n */\nfunction LodashWrapper(value, chainAll) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__chain__ = !!chainAll;\n this.__index__ = 0;\n this.__values__ = undefined;\n}\n\nLodashWrapper.prototype = baseCreate(baseLodash.prototype);\nLodashWrapper.prototype.constructor = LodashWrapper;\n\nmodule.exports = LodashWrapper;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nmodule.exports = Map;\n","var mapCacheClear = require('./_mapCacheClear'),\n mapCacheDelete = require('./_mapCacheDelete'),\n mapCacheGet = require('./_mapCacheGet'),\n mapCacheHas = require('./_mapCacheHas'),\n mapCacheSet = require('./_mapCacheSet');\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nmodule.exports = MapCache;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nmodule.exports = Promise;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nmodule.exports = Set;\n","var MapCache = require('./_MapCache'),\n setCacheAdd = require('./_setCacheAdd'),\n setCacheHas = require('./_setCacheHas');\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\nmodule.exports = SetCache;\n","var ListCache = require('./_ListCache'),\n stackClear = require('./_stackClear'),\n stackDelete = require('./_stackDelete'),\n stackGet = require('./_stackGet'),\n stackHas = require('./_stackHas'),\n stackSet = require('./_stackSet');\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nmodule.exports = Stack;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nmodule.exports = Symbol;\n","var root = require('./_root');\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nmodule.exports = Uint8Array;\n","var getNative = require('./_getNative'),\n root = require('./_root');\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nmodule.exports = WeakMap;\n","/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n switch (args.length) {\n case 0: return func.call(thisArg);\n case 1: return func.call(thisArg, args[0]);\n case 2: return func.call(thisArg, args[0], args[1]);\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\n }\n return func.apply(thisArg, args);\n}\n\nmodule.exports = apply;\n","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n}\n\nmodule.exports = arrayEach;\n","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nmodule.exports = arrayFilter;\n","var baseIndexOf = require('./_baseIndexOf');\n\n/**\n * A specialized version of `_.includes` for arrays without support for\n * specifying an index to search from.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludes(array, value) {\n var length = array == null ? 0 : array.length;\n return !!length && baseIndexOf(array, value, 0) > -1;\n}\n\nmodule.exports = arrayIncludes;\n","/**\n * This function is like `arrayIncludes` except that it accepts a comparator.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludesWith(array, value, comparator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (comparator(value, array[index])) {\n return true;\n }\n }\n return false;\n}\n\nmodule.exports = arrayIncludesWith;\n","var baseTimes = require('./_baseTimes'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isIndex = require('./_isIndex'),\n isTypedArray = require('./isTypedArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = arrayLikeKeys;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\nmodule.exports = arrayMap;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nmodule.exports = arrayPush;\n","var baseAssignValue = require('./_baseAssignValue'),\n eq = require('./eq');\n\n/**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignMergeValue(object, key, value) {\n if ((value !== undefined && !eq(object[key], value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nmodule.exports = assignMergeValue;\n","var baseAssignValue = require('./_baseAssignValue'),\n eq = require('./eq');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nmodule.exports = assignValue;\n","var eq = require('./eq');\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nmodule.exports = assocIndexOf;\n","var copyObject = require('./_copyObject'),\n keys = require('./keys');\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n}\n\nmodule.exports = baseAssign;\n","var copyObject = require('./_copyObject'),\n keysIn = require('./keysIn');\n\n/**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n}\n\nmodule.exports = baseAssignIn;\n","var defineProperty = require('./_defineProperty');\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nmodule.exports = baseAssignValue;\n","/**\n * The base implementation of `_.clamp` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n */\nfunction baseClamp(number, lower, upper) {\n if (number === number) {\n if (upper !== undefined) {\n number = number <= upper ? number : upper;\n }\n if (lower !== undefined) {\n number = number >= lower ? number : lower;\n }\n }\n return number;\n}\n\nmodule.exports = baseClamp;\n","var Stack = require('./_Stack'),\n arrayEach = require('./_arrayEach'),\n assignValue = require('./_assignValue'),\n baseAssign = require('./_baseAssign'),\n baseAssignIn = require('./_baseAssignIn'),\n cloneBuffer = require('./_cloneBuffer'),\n copyArray = require('./_copyArray'),\n copySymbols = require('./_copySymbols'),\n copySymbolsIn = require('./_copySymbolsIn'),\n getAllKeys = require('./_getAllKeys'),\n getAllKeysIn = require('./_getAllKeysIn'),\n getTag = require('./_getTag'),\n initCloneArray = require('./_initCloneArray'),\n initCloneByTag = require('./_initCloneByTag'),\n initCloneObject = require('./_initCloneObject'),\n isArray = require('./isArray'),\n isBuffer = require('./isBuffer'),\n isMap = require('./isMap'),\n isObject = require('./isObject'),\n isSet = require('./isSet'),\n keys = require('./keys'),\n keysIn = require('./keysIn');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n}\n\nmodule.exports = baseClone;\n","var isObject = require('./isObject');\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n}());\n\nmodule.exports = baseCreate;\n","var toInteger = require('./toInteger'),\n toLength = require('./toLength');\n\n/**\n * The base implementation of `_.fill` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n */\nfunction baseFill(array, value, start, end) {\n var length = array.length;\n\n start = toInteger(start);\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = (end === undefined || end > length) ? length : toInteger(end);\n if (end < 0) {\n end += length;\n }\n end = start > end ? 0 : toLength(end);\n while (start < end) {\n array[start++] = value;\n }\n return array;\n}\n\nmodule.exports = baseFill;\n","/**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseFindIndex(array, predicate, fromIndex, fromRight) {\n var length = array.length,\n index = fromIndex + (fromRight ? 1 : -1);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (predicate(array[index], index, array)) {\n return index;\n }\n }\n return -1;\n}\n\nmodule.exports = baseFindIndex;\n","var arrayPush = require('./_arrayPush'),\n isFlattenable = require('./_isFlattenable');\n\n/**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\nfunction baseFlatten(array, depth, predicate, isStrict, result) {\n var index = -1,\n length = array.length;\n\n predicate || (predicate = isFlattenable);\n result || (result = []);\n\n while (++index < length) {\n var value = array[index];\n if (depth > 0 && predicate(value)) {\n if (depth > 1) {\n // Recursively flatten arrays (susceptible to call stack limits).\n baseFlatten(value, depth - 1, predicate, isStrict, result);\n } else {\n arrayPush(result, value);\n }\n } else if (!isStrict) {\n result[result.length] = value;\n }\n }\n return result;\n}\n\nmodule.exports = baseFlatten;\n","var createBaseFor = require('./_createBaseFor');\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nmodule.exports = baseFor;\n","var castPath = require('./_castPath'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\nfunction baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n}\n\nmodule.exports = baseGet;\n","var arrayPush = require('./_arrayPush'),\n isArray = require('./isArray');\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nmodule.exports = baseGetAllKeys;\n","var Symbol = require('./_Symbol'),\n getRawTag = require('./_getRawTag'),\n objectToString = require('./_objectToString');\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nmodule.exports = baseGetTag;\n","/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n return object != null && key in Object(object);\n}\n\nmodule.exports = baseHasIn;\n","var baseFindIndex = require('./_baseFindIndex'),\n baseIsNaN = require('./_baseIsNaN'),\n strictIndexOf = require('./_strictIndexOf');\n\n/**\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseIndexOf(array, value, fromIndex) {\n return value === value\n ? strictIndexOf(array, value, fromIndex)\n : baseFindIndex(array, baseIsNaN, fromIndex);\n}\n\nmodule.exports = baseIndexOf;\n","var SetCache = require('./_SetCache'),\n arrayIncludes = require('./_arrayIncludes'),\n arrayIncludesWith = require('./_arrayIncludesWith'),\n arrayMap = require('./_arrayMap'),\n baseUnary = require('./_baseUnary'),\n cacheHas = require('./_cacheHas');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * The base implementation of methods like `_.intersection`, without support\n * for iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of shared values.\n */\nfunction baseIntersection(arrays, iteratee, comparator) {\n var includes = comparator ? arrayIncludesWith : arrayIncludes,\n length = arrays[0].length,\n othLength = arrays.length,\n othIndex = othLength,\n caches = Array(othLength),\n maxLength = Infinity,\n result = [];\n\n while (othIndex--) {\n var array = arrays[othIndex];\n if (othIndex && iteratee) {\n array = arrayMap(array, baseUnary(iteratee));\n }\n maxLength = nativeMin(array.length, maxLength);\n caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120))\n ? new SetCache(othIndex && array)\n : undefined;\n }\n array = arrays[0];\n\n var index = -1,\n seen = caches[0];\n\n outer:\n while (++index < length && result.length < maxLength) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (!(seen\n ? cacheHas(seen, computed)\n : includes(result, computed, comparator)\n )) {\n othIndex = othLength;\n while (--othIndex) {\n var cache = caches[othIndex];\n if (!(cache\n ? cacheHas(cache, computed)\n : includes(arrays[othIndex], computed, comparator))\n ) {\n continue outer;\n }\n }\n if (seen) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n}\n\nmodule.exports = baseIntersection;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nmodule.exports = baseIsArguments;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]';\n\n/**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\nfunction baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n}\n\nmodule.exports = baseIsMap;\n","/**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\nfunction baseIsNaN(value) {\n return value !== value;\n}\n\nmodule.exports = baseIsNaN;\n","var isFunction = require('./isFunction'),\n isMasked = require('./_isMasked'),\n isObject = require('./isObject'),\n toSource = require('./_toSource');\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nmodule.exports = baseIsNative;\n","var getTag = require('./_getTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar setTag = '[object Set]';\n\n/**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\nfunction baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n}\n\nmodule.exports = baseIsSet;\n","var baseGetTag = require('./_baseGetTag'),\n isLength = require('./isLength'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nmodule.exports = baseIsTypedArray;\n","var isPrototype = require('./_isPrototype'),\n nativeKeys = require('./_nativeKeys');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeys;\n","var isObject = require('./isObject'),\n isPrototype = require('./_isPrototype'),\n nativeKeysIn = require('./_nativeKeysIn');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n if (!isObject(object)) {\n return nativeKeysIn(object);\n }\n var isProto = isPrototype(object),\n result = [];\n\n for (var key in object) {\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = baseKeysIn;\n","/**\n * The function whose prototype chain sequence wrappers inherit from.\n *\n * @private\n */\nfunction baseLodash() {\n // No operation performed.\n}\n\nmodule.exports = baseLodash;\n","var Stack = require('./_Stack'),\n assignMergeValue = require('./_assignMergeValue'),\n baseFor = require('./_baseFor'),\n baseMergeDeep = require('./_baseMergeDeep'),\n isObject = require('./isObject'),\n keysIn = require('./keysIn'),\n safeGet = require('./_safeGet');\n\n/**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\nfunction baseMerge(object, source, srcIndex, customizer, stack) {\n if (object === source) {\n return;\n }\n baseFor(source, function(srcValue, key) {\n stack || (stack = new Stack);\n if (isObject(srcValue)) {\n baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n }\n else {\n var newValue = customizer\n ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\n : undefined;\n\n if (newValue === undefined) {\n newValue = srcValue;\n }\n assignMergeValue(object, key, newValue);\n }\n }, keysIn);\n}\n\nmodule.exports = baseMerge;\n","var assignMergeValue = require('./_assignMergeValue'),\n cloneBuffer = require('./_cloneBuffer'),\n cloneTypedArray = require('./_cloneTypedArray'),\n copyArray = require('./_copyArray'),\n initCloneObject = require('./_initCloneObject'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isArrayLikeObject = require('./isArrayLikeObject'),\n isBuffer = require('./isBuffer'),\n isFunction = require('./isFunction'),\n isObject = require('./isObject'),\n isPlainObject = require('./isPlainObject'),\n isTypedArray = require('./isTypedArray'),\n safeGet = require('./_safeGet'),\n toPlainObject = require('./toPlainObject');\n\n/**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\nfunction baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n var objValue = safeGet(object, key),\n srcValue = safeGet(source, key),\n stacked = stack.get(srcValue);\n\n if (stacked) {\n assignMergeValue(object, key, stacked);\n return;\n }\n var newValue = customizer\n ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n : undefined;\n\n var isCommon = newValue === undefined;\n\n if (isCommon) {\n var isArr = isArray(srcValue),\n isBuff = !isArr && isBuffer(srcValue),\n isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n newValue = srcValue;\n if (isArr || isBuff || isTyped) {\n if (isArray(objValue)) {\n newValue = objValue;\n }\n else if (isArrayLikeObject(objValue)) {\n newValue = copyArray(objValue);\n }\n else if (isBuff) {\n isCommon = false;\n newValue = cloneBuffer(srcValue, true);\n }\n else if (isTyped) {\n isCommon = false;\n newValue = cloneTypedArray(srcValue, true);\n }\n else {\n newValue = [];\n }\n }\n else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n newValue = objValue;\n if (isArguments(objValue)) {\n newValue = toPlainObject(objValue);\n }\n else if (!isObject(objValue) || isFunction(objValue)) {\n newValue = initCloneObject(srcValue);\n }\n }\n else {\n isCommon = false;\n }\n }\n if (isCommon) {\n // Recursively merge objects and arrays (susceptible to call stack limits).\n stack.set(srcValue, newValue);\n mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n stack['delete'](srcValue);\n }\n assignMergeValue(object, key, newValue);\n}\n\nmodule.exports = baseMergeDeep;\n","var basePickBy = require('./_basePickBy'),\n hasIn = require('./hasIn');\n\n/**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\nfunction basePick(object, paths) {\n return basePickBy(object, paths, function(value, path) {\n return hasIn(object, path);\n });\n}\n\nmodule.exports = basePick;\n","var baseGet = require('./_baseGet'),\n baseSet = require('./_baseSet'),\n castPath = require('./_castPath');\n\n/**\n * The base implementation of `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\nfunction basePickBy(object, paths, predicate) {\n var index = -1,\n length = paths.length,\n result = {};\n\n while (++index < length) {\n var path = paths[index],\n value = baseGet(object, path);\n\n if (predicate(value, path)) {\n baseSet(result, castPath(path, object), value);\n }\n }\n return result;\n}\n\nmodule.exports = basePickBy;\n","var identity = require('./identity'),\n overRest = require('./_overRest'),\n setToString = require('./_setToString');\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n return setToString(overRest(func, start, identity), func + '');\n}\n\nmodule.exports = baseRest;\n","var assignValue = require('./_assignValue'),\n castPath = require('./_castPath'),\n isIndex = require('./_isIndex'),\n isObject = require('./isObject'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n}\n\nmodule.exports = baseSet;\n","var identity = require('./identity'),\n metaMap = require('./_metaMap');\n\n/**\n * The base implementation of `setData` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\nvar baseSetData = !metaMap ? identity : function(func, data) {\n metaMap.set(func, data);\n return func;\n};\n\nmodule.exports = baseSetData;\n","var constant = require('./constant'),\n defineProperty = require('./_defineProperty'),\n identity = require('./identity');\n\n/**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar baseSetToString = !defineProperty ? identity : function(func, string) {\n return defineProperty(func, 'toString', {\n 'configurable': true,\n 'enumerable': false,\n 'value': constant(string),\n 'writable': true\n });\n};\n\nmodule.exports = baseSetToString;\n","/**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\nfunction baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n}\n\nmodule.exports = baseSlice;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nmodule.exports = baseTimes;\n","var Symbol = require('./_Symbol'),\n arrayMap = require('./_arrayMap'),\n isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = baseToString;\n","var trimmedEndIndex = require('./_trimmedEndIndex');\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n}\n\nmodule.exports = baseTrim;\n","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nmodule.exports = baseUnary;\n","var SetCache = require('./_SetCache'),\n arrayIncludes = require('./_arrayIncludes'),\n arrayIncludesWith = require('./_arrayIncludesWith'),\n cacheHas = require('./_cacheHas'),\n createSet = require('./_createSet'),\n setToArray = require('./_setToArray');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * The base implementation of `_.uniqBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\nfunction baseUniq(array, iteratee, comparator) {\n var index = -1,\n includes = arrayIncludes,\n length = array.length,\n isCommon = true,\n result = [],\n seen = result;\n\n if (comparator) {\n isCommon = false;\n includes = arrayIncludesWith;\n }\n else if (length >= LARGE_ARRAY_SIZE) {\n var set = iteratee ? null : createSet(array);\n if (set) {\n return setToArray(set);\n }\n isCommon = false;\n includes = cacheHas;\n seen = new SetCache;\n }\n else {\n seen = iteratee ? [] : result;\n }\n outer:\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (isCommon && computed === computed) {\n var seenIndex = seen.length;\n while (seenIndex--) {\n if (seen[seenIndex] === computed) {\n continue outer;\n }\n }\n if (iteratee) {\n seen.push(computed);\n }\n result.push(value);\n }\n else if (!includes(seen, computed, comparator)) {\n if (seen !== result) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n}\n\nmodule.exports = baseUniq;\n","var castPath = require('./_castPath'),\n last = require('./last'),\n parent = require('./_parent'),\n toKey = require('./_toKey');\n\n/**\n * The base implementation of `_.unset`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The property path to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n */\nfunction baseUnset(object, path) {\n path = castPath(path, object);\n object = parent(object, path);\n return object == null || delete object[toKey(last(path))];\n}\n\nmodule.exports = baseUnset;\n","/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\nmodule.exports = cacheHas;\n","var isArrayLikeObject = require('./isArrayLikeObject');\n\n/**\n * Casts `value` to an empty array if it's not an array like object.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Array|Object} Returns the cast array-like object.\n */\nfunction castArrayLikeObject(value) {\n return isArrayLikeObject(value) ? value : [];\n}\n\nmodule.exports = castArrayLikeObject;\n","var isArray = require('./isArray'),\n isKey = require('./_isKey'),\n stringToPath = require('./_stringToPath'),\n toString = require('./toString');\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nmodule.exports = castPath;\n","var Uint8Array = require('./_Uint8Array');\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n}\n\nmodule.exports = cloneArrayBuffer;\n","var root = require('./_root');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n}\n\nmodule.exports = cloneBuffer;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\nmodule.exports = cloneDataView;\n","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n}\n\nmodule.exports = cloneRegExp;\n","var Symbol = require('./_Symbol');\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nmodule.exports = cloneSymbol;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer');\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nmodule.exports = cloneTypedArray;\n","/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates an array that is the composition of partially applied arguments,\n * placeholders, and provided arguments into a single array of arguments.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to prepend to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\nfunction composeArgs(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersLength = holders.length,\n leftIndex = -1,\n leftLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(leftLength + rangeLength),\n isUncurried = !isCurried;\n\n while (++leftIndex < leftLength) {\n result[leftIndex] = partials[leftIndex];\n }\n while (++argsIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[holders[argsIndex]] = args[argsIndex];\n }\n }\n while (rangeLength--) {\n result[leftIndex++] = args[argsIndex++];\n }\n return result;\n}\n\nmodule.exports = composeArgs;\n","/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * This function is like `composeArgs` except that the arguments composition\n * is tailored for `_.partialRight`.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to append to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\nfunction composeArgsRight(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersIndex = -1,\n holdersLength = holders.length,\n rightIndex = -1,\n rightLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(rangeLength + rightLength),\n isUncurried = !isCurried;\n\n while (++argsIndex < rangeLength) {\n result[argsIndex] = args[argsIndex];\n }\n var offset = argsIndex;\n while (++rightIndex < rightLength) {\n result[offset + rightIndex] = partials[rightIndex];\n }\n while (++holdersIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[offset + holders[holdersIndex]] = args[argsIndex++];\n }\n }\n return result;\n}\n\nmodule.exports = composeArgsRight;\n","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n}\n\nmodule.exports = copyArray;\n","var assignValue = require('./_assignValue'),\n baseAssignValue = require('./_baseAssignValue');\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n var isNew = !object;\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n if (newValue === undefined) {\n newValue = source[key];\n }\n if (isNew) {\n baseAssignValue(object, key, newValue);\n } else {\n assignValue(object, key, newValue);\n }\n }\n return object;\n}\n\nmodule.exports = copyObject;\n","var copyObject = require('./_copyObject'),\n getSymbols = require('./_getSymbols');\n\n/**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n}\n\nmodule.exports = copySymbols;\n","var copyObject = require('./_copyObject'),\n getSymbolsIn = require('./_getSymbolsIn');\n\n/**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n}\n\nmodule.exports = copySymbolsIn;\n","var root = require('./_root');\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nmodule.exports = coreJsData;\n","/**\n * Gets the number of `placeholder` occurrences in `array`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} placeholder The placeholder to search for.\n * @returns {number} Returns the placeholder count.\n */\nfunction countHolders(array, placeholder) {\n var length = array.length,\n result = 0;\n\n while (length--) {\n if (array[length] === placeholder) {\n ++result;\n }\n }\n return result;\n}\n\nmodule.exports = countHolders;\n","var baseRest = require('./_baseRest'),\n isIterateeCall = require('./_isIterateeCall');\n\n/**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\nfunction createAssigner(assigner) {\n return baseRest(function(object, sources) {\n var index = -1,\n length = sources.length,\n customizer = length > 1 ? sources[length - 1] : undefined,\n guard = length > 2 ? sources[2] : undefined;\n\n customizer = (assigner.length > 3 && typeof customizer == 'function')\n ? (length--, customizer)\n : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n customizer = length < 3 ? undefined : customizer;\n length = 1;\n }\n object = Object(object);\n while (++index < length) {\n var source = sources[index];\n if (source) {\n assigner(object, source, index, customizer);\n }\n }\n return object;\n });\n}\n\nmodule.exports = createAssigner;\n","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n}\n\nmodule.exports = createBaseFor;\n","var createCtor = require('./_createCtor'),\n root = require('./_root');\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1;\n\n/**\n * Creates a function that wraps `func` to invoke it with the optional `this`\n * binding of `thisArg`.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createBind(func, bitmask, thisArg) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return fn.apply(isBind ? thisArg : this, arguments);\n }\n return wrapper;\n}\n\nmodule.exports = createBind;\n","var baseCreate = require('./_baseCreate'),\n isObject = require('./isObject');\n\n/**\n * Creates a function that produces an instance of `Ctor` regardless of\n * whether it was invoked as part of a `new` expression or by `call` or `apply`.\n *\n * @private\n * @param {Function} Ctor The constructor to wrap.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createCtor(Ctor) {\n return function() {\n // Use a `switch` statement to work with class constructors. See\n // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist\n // for more details.\n var args = arguments;\n switch (args.length) {\n case 0: return new Ctor;\n case 1: return new Ctor(args[0]);\n case 2: return new Ctor(args[0], args[1]);\n case 3: return new Ctor(args[0], args[1], args[2]);\n case 4: return new Ctor(args[0], args[1], args[2], args[3]);\n case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]);\n case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]);\n case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\n }\n var thisBinding = baseCreate(Ctor.prototype),\n result = Ctor.apply(thisBinding, args);\n\n // Mimic the constructor's `return` behavior.\n // See https://es5.github.io/#x13.2.2 for more details.\n return isObject(result) ? result : thisBinding;\n };\n}\n\nmodule.exports = createCtor;\n","var apply = require('./_apply'),\n createCtor = require('./_createCtor'),\n createHybrid = require('./_createHybrid'),\n createRecurry = require('./_createRecurry'),\n getHolder = require('./_getHolder'),\n replaceHolders = require('./_replaceHolders'),\n root = require('./_root');\n\n/**\n * Creates a function that wraps `func` to enable currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {number} arity The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createCurry(func, bitmask, arity) {\n var Ctor = createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length,\n placeholder = getHolder(wrapper);\n\n while (index--) {\n args[index] = arguments[index];\n }\n var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder)\n ? []\n : replaceHolders(args, placeholder);\n\n length -= holders.length;\n if (length < arity) {\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, undefined,\n args, holders, undefined, undefined, arity - length);\n }\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return apply(fn, this, args);\n }\n return wrapper;\n}\n\nmodule.exports = createCurry;\n","var composeArgs = require('./_composeArgs'),\n composeArgsRight = require('./_composeArgsRight'),\n countHolders = require('./_countHolders'),\n createCtor = require('./_createCtor'),\n createRecurry = require('./_createRecurry'),\n getHolder = require('./_getHolder'),\n reorder = require('./_reorder'),\n replaceHolders = require('./_replaceHolders'),\n root = require('./_root');\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n WRAP_BIND_KEY_FLAG = 2,\n WRAP_CURRY_FLAG = 8,\n WRAP_CURRY_RIGHT_FLAG = 16,\n WRAP_ARY_FLAG = 128,\n WRAP_FLIP_FLAG = 512;\n\n/**\n * Creates a function that wraps `func` to invoke it with optional `this`\n * binding of `thisArg`, partial application, and currying.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [partialsRight] The arguments to append to those provided\n * to the new function.\n * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) {\n var isAry = bitmask & WRAP_ARY_FLAG,\n isBind = bitmask & WRAP_BIND_FLAG,\n isBindKey = bitmask & WRAP_BIND_KEY_FLAG,\n isCurried = bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG),\n isFlip = bitmask & WRAP_FLIP_FLAG,\n Ctor = isBindKey ? undefined : createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length;\n\n while (index--) {\n args[index] = arguments[index];\n }\n if (isCurried) {\n var placeholder = getHolder(wrapper),\n holdersCount = countHolders(args, placeholder);\n }\n if (partials) {\n args = composeArgs(args, partials, holders, isCurried);\n }\n if (partialsRight) {\n args = composeArgsRight(args, partialsRight, holdersRight, isCurried);\n }\n length -= holdersCount;\n if (isCurried && length < arity) {\n var newHolders = replaceHolders(args, placeholder);\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, thisArg,\n args, newHolders, argPos, ary, arity - length\n );\n }\n var thisBinding = isBind ? thisArg : this,\n fn = isBindKey ? thisBinding[func] : func;\n\n length = args.length;\n if (argPos) {\n args = reorder(args, argPos);\n } else if (isFlip && length > 1) {\n args.reverse();\n }\n if (isAry && ary < length) {\n args.length = ary;\n }\n if (this && this !== root && this instanceof wrapper) {\n fn = Ctor || createCtor(fn);\n }\n return fn.apply(thisBinding, args);\n }\n return wrapper;\n}\n\nmodule.exports = createHybrid;\n","var apply = require('./_apply'),\n createCtor = require('./_createCtor'),\n root = require('./_root');\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1;\n\n/**\n * Creates a function that wraps `func` to invoke it with the `this` binding\n * of `thisArg` and `partials` prepended to the arguments it receives.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} partials The arguments to prepend to those provided to\n * the new function.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createPartial(func, bitmask, thisArg, partials) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var argsIndex = -1,\n argsLength = arguments.length,\n leftIndex = -1,\n leftLength = partials.length,\n args = Array(leftLength + argsLength),\n fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n\n while (++leftIndex < leftLength) {\n args[leftIndex] = partials[leftIndex];\n }\n while (argsLength--) {\n args[leftIndex++] = arguments[++argsIndex];\n }\n return apply(fn, isBind ? thisArg : this, args);\n }\n return wrapper;\n}\n\nmodule.exports = createPartial;\n","var isLaziable = require('./_isLaziable'),\n setData = require('./_setData'),\n setWrapToString = require('./_setWrapToString');\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n WRAP_BIND_KEY_FLAG = 2,\n WRAP_CURRY_BOUND_FLAG = 4,\n WRAP_CURRY_FLAG = 8,\n WRAP_PARTIAL_FLAG = 32,\n WRAP_PARTIAL_RIGHT_FLAG = 64;\n\n/**\n * Creates a function that wraps `func` to continue currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {Function} wrapFunc The function to create the `func` wrapper.\n * @param {*} placeholder The placeholder value.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) {\n var isCurry = bitmask & WRAP_CURRY_FLAG,\n newHolders = isCurry ? holders : undefined,\n newHoldersRight = isCurry ? undefined : holders,\n newPartials = isCurry ? partials : undefined,\n newPartialsRight = isCurry ? undefined : partials;\n\n bitmask |= (isCurry ? WRAP_PARTIAL_FLAG : WRAP_PARTIAL_RIGHT_FLAG);\n bitmask &= ~(isCurry ? WRAP_PARTIAL_RIGHT_FLAG : WRAP_PARTIAL_FLAG);\n\n if (!(bitmask & WRAP_CURRY_BOUND_FLAG)) {\n bitmask &= ~(WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG);\n }\n var newData = [\n func, bitmask, thisArg, newPartials, newHolders, newPartialsRight,\n newHoldersRight, argPos, ary, arity\n ];\n\n var result = wrapFunc.apply(undefined, newData);\n if (isLaziable(func)) {\n setData(result, newData);\n }\n result.placeholder = placeholder;\n return setWrapToString(result, func, bitmask);\n}\n\nmodule.exports = createRecurry;\n","var Set = require('./_Set'),\n noop = require('./noop'),\n setToArray = require('./_setToArray');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Creates a set object of `values`.\n *\n * @private\n * @param {Array} values The values to add to the set.\n * @returns {Object} Returns the new set.\n */\nvar createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\n return new Set(values);\n};\n\nmodule.exports = createSet;\n","var baseSetData = require('./_baseSetData'),\n createBind = require('./_createBind'),\n createCurry = require('./_createCurry'),\n createHybrid = require('./_createHybrid'),\n createPartial = require('./_createPartial'),\n getData = require('./_getData'),\n mergeData = require('./_mergeData'),\n setData = require('./_setData'),\n setWrapToString = require('./_setWrapToString'),\n toInteger = require('./toInteger');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n WRAP_BIND_KEY_FLAG = 2,\n WRAP_CURRY_FLAG = 8,\n WRAP_CURRY_RIGHT_FLAG = 16,\n WRAP_PARTIAL_FLAG = 32,\n WRAP_PARTIAL_RIGHT_FLAG = 64;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * Creates a function that either curries or invokes `func` with optional\n * `this` binding and partially applied arguments.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags.\n * 1 - `_.bind`\n * 2 - `_.bindKey`\n * 4 - `_.curry` or `_.curryRight` of a bound function\n * 8 - `_.curry`\n * 16 - `_.curryRight`\n * 32 - `_.partial`\n * 64 - `_.partialRight`\n * 128 - `_.rearg`\n * 256 - `_.ary`\n * 512 - `_.flip`\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to be partially applied.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\nfunction createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) {\n var isBindKey = bitmask & WRAP_BIND_KEY_FLAG;\n if (!isBindKey && typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var length = partials ? partials.length : 0;\n if (!length) {\n bitmask &= ~(WRAP_PARTIAL_FLAG | WRAP_PARTIAL_RIGHT_FLAG);\n partials = holders = undefined;\n }\n ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0);\n arity = arity === undefined ? arity : toInteger(arity);\n length -= holders ? holders.length : 0;\n\n if (bitmask & WRAP_PARTIAL_RIGHT_FLAG) {\n var partialsRight = partials,\n holdersRight = holders;\n\n partials = holders = undefined;\n }\n var data = isBindKey ? undefined : getData(func);\n\n var newData = [\n func, bitmask, thisArg, partials, holders, partialsRight, holdersRight,\n argPos, ary, arity\n ];\n\n if (data) {\n mergeData(newData, data);\n }\n func = newData[0];\n bitmask = newData[1];\n thisArg = newData[2];\n partials = newData[3];\n holders = newData[4];\n arity = newData[9] = newData[9] === undefined\n ? (isBindKey ? 0 : func.length)\n : nativeMax(newData[9] - length, 0);\n\n if (!arity && bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG)) {\n bitmask &= ~(WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG);\n }\n if (!bitmask || bitmask == WRAP_BIND_FLAG) {\n var result = createBind(func, bitmask, thisArg);\n } else if (bitmask == WRAP_CURRY_FLAG || bitmask == WRAP_CURRY_RIGHT_FLAG) {\n result = createCurry(func, bitmask, arity);\n } else if ((bitmask == WRAP_PARTIAL_FLAG || bitmask == (WRAP_BIND_FLAG | WRAP_PARTIAL_FLAG)) && !holders.length) {\n result = createPartial(func, bitmask, thisArg, partials);\n } else {\n result = createHybrid.apply(undefined, newData);\n }\n var setter = data ? baseSetData : setData;\n return setWrapToString(setter(result, newData), func, bitmask);\n}\n\nmodule.exports = createWrap;\n","var isPlainObject = require('./isPlainObject');\n\n/**\n * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain\n * objects.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {string} key The key of the property to inspect.\n * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`.\n */\nfunction customOmitClone(value) {\n return isPlainObject(value) ? undefined : value;\n}\n\nmodule.exports = customOmitClone;\n","var getNative = require('./_getNative');\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nmodule.exports = defineProperty;\n","var flatten = require('./flatten'),\n overRest = require('./_overRest'),\n setToString = require('./_setToString');\n\n/**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\nfunction flatRest(func) {\n return setToString(overRest(func, undefined, flatten), func + '');\n}\n\nmodule.exports = flatRest;\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nmodule.exports = freeGlobal;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbols = require('./_getSymbols'),\n keys = require('./keys');\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\nmodule.exports = getAllKeys;\n","var baseGetAllKeys = require('./_baseGetAllKeys'),\n getSymbolsIn = require('./_getSymbolsIn'),\n keysIn = require('./keysIn');\n\n/**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n}\n\nmodule.exports = getAllKeysIn;\n","var metaMap = require('./_metaMap'),\n noop = require('./noop');\n\n/**\n * Gets metadata for `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {*} Returns the metadata for `func`.\n */\nvar getData = !metaMap ? noop : function(func) {\n return metaMap.get(func);\n};\n\nmodule.exports = getData;\n","var realNames = require('./_realNames');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the name of `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {string} Returns the function name.\n */\nfunction getFuncName(func) {\n var result = (func.name + ''),\n array = realNames[result],\n length = hasOwnProperty.call(realNames, result) ? array.length : 0;\n\n while (length--) {\n var data = array[length],\n otherFunc = data.func;\n if (otherFunc == null || otherFunc == func) {\n return data.name;\n }\n }\n return result;\n}\n\nmodule.exports = getFuncName;\n","/**\n * Gets the argument placeholder value for `func`.\n *\n * @private\n * @param {Function} func The function to inspect.\n * @returns {*} Returns the placeholder value.\n */\nfunction getHolder(func) {\n var object = func;\n return object.placeholder;\n}\n\nmodule.exports = getHolder;\n","var isKeyable = require('./_isKeyable');\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nmodule.exports = getMapData;\n","var baseIsNative = require('./_baseIsNative'),\n getValue = require('./_getValue');\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nmodule.exports = getNative;\n","var overArg = require('./_overArg');\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nmodule.exports = getPrototype;\n","var Symbol = require('./_Symbol');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nmodule.exports = getRawTag;\n","var arrayFilter = require('./_arrayFilter'),\n stubArray = require('./stubArray');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nmodule.exports = getSymbols;\n","var arrayPush = require('./_arrayPush'),\n getPrototype = require('./_getPrototype'),\n getSymbols = require('./_getSymbols'),\n stubArray = require('./stubArray');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n};\n\nmodule.exports = getSymbolsIn;\n","var DataView = require('./_DataView'),\n Map = require('./_Map'),\n Promise = require('./_Promise'),\n Set = require('./_Set'),\n WeakMap = require('./_WeakMap'),\n baseGetTag = require('./_baseGetTag'),\n toSource = require('./_toSource');\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n setTag = '[object Set]',\n weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\nmodule.exports = getTag;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nmodule.exports = getValue;\n","/** Used to match wrap detail comments. */\nvar reWrapDetails = /\\{\\n\\/\\* \\[wrapped with (.+)\\] \\*/,\n reSplitDetails = /,? & /;\n\n/**\n * Extracts wrapper details from the `source` body comment.\n *\n * @private\n * @param {string} source The source to inspect.\n * @returns {Array} Returns the wrapper details.\n */\nfunction getWrapDetails(source) {\n var match = source.match(reWrapDetails);\n return match ? match[1].split(reSplitDetails) : [];\n}\n\nmodule.exports = getWrapDetails;\n","var castPath = require('./_castPath'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray'),\n isIndex = require('./_isIndex'),\n isLength = require('./isLength'),\n toKey = require('./_toKey');\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n}\n\nmodule.exports = hasPath;\n","var nativeCreate = require('./_nativeCreate');\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nmodule.exports = hashClear;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = hashDelete;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nmodule.exports = hashGet;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nmodule.exports = hashHas;\n","var nativeCreate = require('./_nativeCreate');\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nmodule.exports = hashSet;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n}\n\nmodule.exports = initCloneArray;\n","var cloneArrayBuffer = require('./_cloneArrayBuffer'),\n cloneDataView = require('./_cloneDataView'),\n cloneRegExp = require('./_cloneRegExp'),\n cloneSymbol = require('./_cloneSymbol'),\n cloneTypedArray = require('./_cloneTypedArray');\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n}\n\nmodule.exports = initCloneByTag;\n","var baseCreate = require('./_baseCreate'),\n getPrototype = require('./_getPrototype'),\n isPrototype = require('./_isPrototype');\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n}\n\nmodule.exports = initCloneObject;\n","/** Used to match wrap detail comments. */\nvar reWrapComment = /\\{(?:\\n\\/\\* \\[wrapped with .+\\] \\*\\/)?\\n?/;\n\n/**\n * Inserts wrapper `details` in a comment at the top of the `source` body.\n *\n * @private\n * @param {string} source The source to modify.\n * @returns {Array} details The details to insert.\n * @returns {string} Returns the modified source.\n */\nfunction insertWrapDetails(source, details) {\n var length = details.length;\n if (!length) {\n return source;\n }\n var lastIndex = length - 1;\n details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex];\n details = details.join(length > 2 ? ', ' : ' ');\n return source.replace(reWrapComment, '{\\n/* [wrapped with ' + details + '] */\\n');\n}\n\nmodule.exports = insertWrapDetails;\n","var Symbol = require('./_Symbol'),\n isArguments = require('./isArguments'),\n isArray = require('./isArray');\n\n/** Built-in value references. */\nvar spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined;\n\n/**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\nfunction isFlattenable(value) {\n return isArray(value) || isArguments(value) ||\n !!(spreadableSymbol && value && value[spreadableSymbol]);\n}\n\nmodule.exports = isFlattenable;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nmodule.exports = isIndex;\n","var eq = require('./eq'),\n isArrayLike = require('./isArrayLike'),\n isIndex = require('./_isIndex'),\n isObject = require('./isObject');\n\n/**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n * else `false`.\n */\nfunction isIterateeCall(value, index, object) {\n if (!isObject(object)) {\n return false;\n }\n var type = typeof index;\n if (type == 'number'\n ? (isArrayLike(object) && isIndex(index, object.length))\n : (type == 'string' && index in object)\n ) {\n return eq(object[index], value);\n }\n return false;\n}\n\nmodule.exports = isIterateeCall;\n","var isArray = require('./isArray'),\n isSymbol = require('./isSymbol');\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nmodule.exports = isKey;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nmodule.exports = isKeyable;\n","var LazyWrapper = require('./_LazyWrapper'),\n getData = require('./_getData'),\n getFuncName = require('./_getFuncName'),\n lodash = require('./wrapperLodash');\n\n/**\n * Checks if `func` has a lazy counterpart.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` has a lazy counterpart,\n * else `false`.\n */\nfunction isLaziable(func) {\n var funcName = getFuncName(func),\n other = lodash[funcName];\n\n if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) {\n return false;\n }\n if (func === other) {\n return true;\n }\n var data = getData(other);\n return !!data && func === data[0];\n}\n\nmodule.exports = isLaziable;\n","var coreJsData = require('./_coreJsData');\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nmodule.exports = isMasked;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nmodule.exports = isPrototype;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nmodule.exports = listCacheClear;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nmodule.exports = listCacheDelete;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nmodule.exports = listCacheGet;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nmodule.exports = listCacheHas;\n","var assocIndexOf = require('./_assocIndexOf');\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nmodule.exports = listCacheSet;\n","var Hash = require('./_Hash'),\n ListCache = require('./_ListCache'),\n Map = require('./_Map');\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nmodule.exports = mapCacheClear;\n","var getMapData = require('./_getMapData');\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nmodule.exports = mapCacheDelete;\n","var getMapData = require('./_getMapData');\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nmodule.exports = mapCacheGet;\n","var getMapData = require('./_getMapData');\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nmodule.exports = mapCacheHas;\n","var getMapData = require('./_getMapData');\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nmodule.exports = mapCacheSet;\n","var memoize = require('./memoize');\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nmodule.exports = memoizeCapped;\n","var composeArgs = require('./_composeArgs'),\n composeArgsRight = require('./_composeArgsRight'),\n replaceHolders = require('./_replaceHolders');\n\n/** Used as the internal argument placeholder. */\nvar PLACEHOLDER = '__lodash_placeholder__';\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n WRAP_BIND_KEY_FLAG = 2,\n WRAP_CURRY_BOUND_FLAG = 4,\n WRAP_CURRY_FLAG = 8,\n WRAP_ARY_FLAG = 128,\n WRAP_REARG_FLAG = 256;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * Merges the function metadata of `source` into `data`.\n *\n * Merging metadata reduces the number of wrappers used to invoke a function.\n * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`\n * may be applied regardless of execution order. Methods like `_.ary` and\n * `_.rearg` modify function arguments, making the order in which they are\n * executed important, preventing the merging of metadata. However, we make\n * an exception for a safe combined case where curried functions have `_.ary`\n * and or `_.rearg` applied.\n *\n * @private\n * @param {Array} data The destination metadata.\n * @param {Array} source The source metadata.\n * @returns {Array} Returns `data`.\n */\nfunction mergeData(data, source) {\n var bitmask = data[1],\n srcBitmask = source[1],\n newBitmask = bitmask | srcBitmask,\n isCommon = newBitmask < (WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG | WRAP_ARY_FLAG);\n\n var isCombo =\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_CURRY_FLAG)) ||\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_REARG_FLAG) && (data[7].length <= source[8])) ||\n ((srcBitmask == (WRAP_ARY_FLAG | WRAP_REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == WRAP_CURRY_FLAG));\n\n // Exit early if metadata can't be merged.\n if (!(isCommon || isCombo)) {\n return data;\n }\n // Use source `thisArg` if available.\n if (srcBitmask & WRAP_BIND_FLAG) {\n data[2] = source[2];\n // Set when currying a bound function.\n newBitmask |= bitmask & WRAP_BIND_FLAG ? 0 : WRAP_CURRY_BOUND_FLAG;\n }\n // Compose partial arguments.\n var value = source[3];\n if (value) {\n var partials = data[3];\n data[3] = partials ? composeArgs(partials, value, source[4]) : value;\n data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4];\n }\n // Compose partial right arguments.\n value = source[5];\n if (value) {\n partials = data[5];\n data[5] = partials ? composeArgsRight(partials, value, source[6]) : value;\n data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6];\n }\n // Use source `argPos` if available.\n value = source[7];\n if (value) {\n data[7] = value;\n }\n // Use source `ary` if it's smaller.\n if (srcBitmask & WRAP_ARY_FLAG) {\n data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]);\n }\n // Use source `arity` if one is not provided.\n if (data[9] == null) {\n data[9] = source[9];\n }\n // Use source `func` and merge bitmasks.\n data[0] = source[0];\n data[1] = newBitmask;\n\n return data;\n}\n\nmodule.exports = mergeData;\n","var WeakMap = require('./_WeakMap');\n\n/** Used to store function metadata. */\nvar metaMap = WeakMap && new WeakMap;\n\nmodule.exports = metaMap;\n","var getNative = require('./_getNative');\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nmodule.exports = nativeCreate;\n","var overArg = require('./_overArg');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nmodule.exports = nativeKeys;\n","/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n var result = [];\n if (object != null) {\n for (var key in Object(object)) {\n result.push(key);\n }\n }\n return result;\n}\n\nmodule.exports = nativeKeysIn;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nmodule.exports = nodeUtil;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nmodule.exports = objectToString;\n","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nmodule.exports = overArg;\n","var apply = require('./_apply');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max;\n\n/**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\nfunction overRest(func, start, transform) {\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n return function() {\n var args = arguments,\n index = -1,\n length = nativeMax(args.length - start, 0),\n array = Array(length);\n\n while (++index < length) {\n array[index] = args[start + index];\n }\n index = -1;\n var otherArgs = Array(start + 1);\n while (++index < start) {\n otherArgs[index] = args[index];\n }\n otherArgs[start] = transform(array);\n return apply(func, this, otherArgs);\n };\n}\n\nmodule.exports = overRest;\n","var baseGet = require('./_baseGet'),\n baseSlice = require('./_baseSlice');\n\n/**\n * Gets the parent value at `path` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} path The path to get the parent value of.\n * @returns {*} Returns the parent value.\n */\nfunction parent(object, path) {\n return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1));\n}\n\nmodule.exports = parent;\n","/** Used to lookup unminified function names. */\nvar realNames = {};\n\nmodule.exports = realNames;\n","var copyArray = require('./_copyArray'),\n isIndex = require('./_isIndex');\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMin = Math.min;\n\n/**\n * Reorder `array` according to the specified indexes where the element at\n * the first index is assigned as the first element, the element at\n * the second index is assigned as the second element, and so on.\n *\n * @private\n * @param {Array} array The array to reorder.\n * @param {Array} indexes The arranged array indexes.\n * @returns {Array} Returns `array`.\n */\nfunction reorder(array, indexes) {\n var arrLength = array.length,\n length = nativeMin(indexes.length, arrLength),\n oldArray = copyArray(array);\n\n while (length--) {\n var index = indexes[length];\n array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined;\n }\n return array;\n}\n\nmodule.exports = reorder;\n","/** Used as the internal argument placeholder. */\nvar PLACEHOLDER = '__lodash_placeholder__';\n\n/**\n * Replaces all `placeholder` elements in `array` with an internal placeholder\n * and returns an array of their indexes.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {*} placeholder The placeholder to replace.\n * @returns {Array} Returns the new array of placeholder indexes.\n */\nfunction replaceHolders(array, placeholder) {\n var index = -1,\n length = array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (value === placeholder || value === PLACEHOLDER) {\n array[index] = PLACEHOLDER;\n result[resIndex++] = index;\n }\n }\n return result;\n}\n\nmodule.exports = replaceHolders;\n","var freeGlobal = require('./_freeGlobal');\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nmodule.exports = root;\n","/**\n * Gets the value at `key`, unless `key` is \"__proto__\" or \"constructor\".\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction safeGet(object, key) {\n if (key === 'constructor' && typeof object[key] === 'function') {\n return;\n }\n\n if (key == '__proto__') {\n return;\n }\n\n return object[key];\n}\n\nmodule.exports = safeGet;\n","/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\nmodule.exports = setCacheAdd;\n","/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\nmodule.exports = setCacheHas;\n","var baseSetData = require('./_baseSetData'),\n shortOut = require('./_shortOut');\n\n/**\n * Sets metadata for `func`.\n *\n * **Note:** If this function becomes hot, i.e. is invoked a lot in a short\n * period of time, it will trip its breaker and transition to an identity\n * function to avoid garbage collection pauses in V8. See\n * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070)\n * for more details.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\nvar setData = shortOut(baseSetData);\n\nmodule.exports = setData;\n","/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\nmodule.exports = setToArray;\n","var baseSetToString = require('./_baseSetToString'),\n shortOut = require('./_shortOut');\n\n/**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\nvar setToString = shortOut(baseSetToString);\n\nmodule.exports = setToString;\n","var getWrapDetails = require('./_getWrapDetails'),\n insertWrapDetails = require('./_insertWrapDetails'),\n setToString = require('./_setToString'),\n updateWrapDetails = require('./_updateWrapDetails');\n\n/**\n * Sets the `toString` method of `wrapper` to mimic the source of `reference`\n * with wrapper details in a comment at the top of the source body.\n *\n * @private\n * @param {Function} wrapper The function to modify.\n * @param {Function} reference The reference function.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Function} Returns `wrapper`.\n */\nfunction setWrapToString(wrapper, reference, bitmask) {\n var source = (reference + '');\n return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask)));\n}\n\nmodule.exports = setWrapToString;\n","/** Used to detect hot functions by number of calls within a span of milliseconds. */\nvar HOT_COUNT = 800,\n HOT_SPAN = 16;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeNow = Date.now;\n\n/**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\nfunction shortOut(func) {\n var count = 0,\n lastCalled = 0;\n\n return function() {\n var stamp = nativeNow(),\n remaining = HOT_SPAN - (stamp - lastCalled);\n\n lastCalled = stamp;\n if (remaining > 0) {\n if (++count >= HOT_COUNT) {\n return arguments[0];\n }\n } else {\n count = 0;\n }\n return func.apply(undefined, arguments);\n };\n}\n\nmodule.exports = shortOut;\n","var ListCache = require('./_ListCache');\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nmodule.exports = stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nmodule.exports = stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nmodule.exports = stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nmodule.exports = stackHas;\n","var ListCache = require('./_ListCache'),\n Map = require('./_Map'),\n MapCache = require('./_MapCache');\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nmodule.exports = stackSet;\n","/**\n * A specialized version of `_.indexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction strictIndexOf(array, value, fromIndex) {\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (array[index] === value) {\n return index;\n }\n }\n return -1;\n}\n\nmodule.exports = strictIndexOf;\n","var memoizeCapped = require('./_memoizeCapped');\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nmodule.exports = stringToPath;\n","var isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nmodule.exports = toKey;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nmodule.exports = toSource;\n","/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n}\n\nmodule.exports = trimmedEndIndex;\n","var arrayEach = require('./_arrayEach'),\n arrayIncludes = require('./_arrayIncludes');\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_BIND_FLAG = 1,\n WRAP_BIND_KEY_FLAG = 2,\n WRAP_CURRY_FLAG = 8,\n WRAP_CURRY_RIGHT_FLAG = 16,\n WRAP_PARTIAL_FLAG = 32,\n WRAP_PARTIAL_RIGHT_FLAG = 64,\n WRAP_ARY_FLAG = 128,\n WRAP_REARG_FLAG = 256,\n WRAP_FLIP_FLAG = 512;\n\n/** Used to associate wrap methods with their bit flags. */\nvar wrapFlags = [\n ['ary', WRAP_ARY_FLAG],\n ['bind', WRAP_BIND_FLAG],\n ['bindKey', WRAP_BIND_KEY_FLAG],\n ['curry', WRAP_CURRY_FLAG],\n ['curryRight', WRAP_CURRY_RIGHT_FLAG],\n ['flip', WRAP_FLIP_FLAG],\n ['partial', WRAP_PARTIAL_FLAG],\n ['partialRight', WRAP_PARTIAL_RIGHT_FLAG],\n ['rearg', WRAP_REARG_FLAG]\n];\n\n/**\n * Updates wrapper `details` based on `bitmask` flags.\n *\n * @private\n * @returns {Array} details The details to modify.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Array} Returns `details`.\n */\nfunction updateWrapDetails(details, bitmask) {\n arrayEach(wrapFlags, function(pair) {\n var value = '_.' + pair[0];\n if ((bitmask & pair[1]) && !arrayIncludes(details, value)) {\n details.push(value);\n }\n });\n return details.sort();\n}\n\nmodule.exports = updateWrapDetails;\n","var LazyWrapper = require('./_LazyWrapper'),\n LodashWrapper = require('./_LodashWrapper'),\n copyArray = require('./_copyArray');\n\n/**\n * Creates a clone of `wrapper`.\n *\n * @private\n * @param {Object} wrapper The wrapper to clone.\n * @returns {Object} Returns the cloned wrapper.\n */\nfunction wrapperClone(wrapper) {\n if (wrapper instanceof LazyWrapper) {\n return wrapper.clone();\n }\n var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__);\n result.__actions__ = copyArray(wrapper.__actions__);\n result.__index__ = wrapper.__index__;\n result.__values__ = wrapper.__values__;\n return result;\n}\n\nmodule.exports = wrapperClone;\n","var assignValue = require('./_assignValue'),\n copyObject = require('./_copyObject'),\n createAssigner = require('./_createAssigner'),\n isArrayLike = require('./isArrayLike'),\n isPrototype = require('./_isPrototype'),\n keys = require('./keys');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns own enumerable string keyed properties of source objects to the\n * destination object. Source objects are applied from left to right.\n * Subsequent sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object` and is loosely based on\n * [`Object.assign`](https://mdn.io/Object/assign).\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assignIn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assign({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'c': 3 }\n */\nvar assign = createAssigner(function(object, source) {\n if (isPrototype(source) || isArrayLike(source)) {\n copyObject(source, keys(source), object);\n return;\n }\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n assignValue(object, key, source[key]);\n }\n }\n});\n\nmodule.exports = assign;\n","var baseClone = require('./_baseClone');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\nfunction clone(value) {\n return baseClone(value, CLONE_SYMBOLS_FLAG);\n}\n\nmodule.exports = clone;\n","/**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new constant function.\n * @example\n *\n * var objects = _.times(2, _.constant({ 'a': 1 }));\n *\n * console.log(objects);\n * // => [{ 'a': 1 }, { 'a': 1 }]\n *\n * console.log(objects[0] === objects[1]);\n * // => true\n */\nfunction constant(value) {\n return function() {\n return value;\n };\n}\n\nmodule.exports = constant;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nmodule.exports = eq;\n","var baseFill = require('./_baseFill'),\n isIterateeCall = require('./_isIterateeCall');\n\n/**\n * Fills elements of `array` with `value` from `start` up to, but not\n * including, `end`.\n *\n * **Note:** This method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Array\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.fill(array, 'a');\n * console.log(array);\n * // => ['a', 'a', 'a']\n *\n * _.fill(Array(3), 2);\n * // => [2, 2, 2]\n *\n * _.fill([4, 6, 8, 10], '*', 1, 3);\n * // => [4, '*', '*', 10]\n */\nfunction fill(array, value, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (start && typeof start != 'number' && isIterateeCall(array, value, start)) {\n start = 0;\n end = length;\n }\n return baseFill(array, value, start, end);\n}\n\nmodule.exports = fill;\n","var baseFlatten = require('./_baseFlatten');\n\n/**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\nfunction flatten(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, 1) : [];\n}\n\nmodule.exports = flatten;\n","var baseHasIn = require('./_baseHasIn'),\n hasPath = require('./_hasPath');\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n}\n\nmodule.exports = hasIn;\n","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n return value;\n}\n\nmodule.exports = identity;\n","var arrayMap = require('./_arrayMap'),\n baseIntersection = require('./_baseIntersection'),\n baseRest = require('./_baseRest'),\n castArrayLikeObject = require('./_castArrayLikeObject');\n\n/**\n * Creates an array of unique values that are included in all given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersection([2, 1], [2, 3]);\n * // => [2]\n */\nvar intersection = baseRest(function(arrays) {\n var mapped = arrayMap(arrays, castArrayLikeObject);\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped)\n : [];\n});\n\nmodule.exports = intersection;\n","var baseIsArguments = require('./_baseIsArguments'),\n isObjectLike = require('./isObjectLike');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nmodule.exports = isArguments;\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nmodule.exports = isArray;\n","var isFunction = require('./isFunction'),\n isLength = require('./isLength');\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nmodule.exports = isArrayLike;\n","var isArrayLike = require('./isArrayLike'),\n isObjectLike = require('./isObjectLike');\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n * else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\n}\n\nmodule.exports = isArrayLikeObject;\n","var root = require('./_root'),\n stubFalse = require('./stubFalse');\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nmodule.exports = isBuffer;\n","var baseGetTag = require('./_baseGetTag'),\n isObject = require('./isObject');\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nmodule.exports = isFunction;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nmodule.exports = isLength;\n","var baseIsMap = require('./_baseIsMap'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsMap = nodeUtil && nodeUtil.isMap;\n\n/**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\nvar isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\nmodule.exports = isMap;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nmodule.exports = isObject;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nmodule.exports = isObjectLike;\n","var baseGetTag = require('./_baseGetTag'),\n getPrototype = require('./_getPrototype'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar objectTag = '[object Object]';\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to infer the `Object` constructor. */\nvar objectCtorString = funcToString.call(Object);\n\n/**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\nfunction isPlainObject(value) {\n if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n return false;\n }\n var proto = getPrototype(value);\n if (proto === null) {\n return true;\n }\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n funcToString.call(Ctor) == objectCtorString;\n}\n\nmodule.exports = isPlainObject;\n","var baseIsSet = require('./_baseIsSet'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsSet = nodeUtil && nodeUtil.isSet;\n\n/**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\nvar isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\nmodule.exports = isSet;\n","var baseGetTag = require('./_baseGetTag'),\n isObjectLike = require('./isObjectLike');\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nmodule.exports = isSymbol;\n","var baseIsTypedArray = require('./_baseIsTypedArray'),\n baseUnary = require('./_baseUnary'),\n nodeUtil = require('./_nodeUtil');\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nmodule.exports = isTypedArray;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeys = require('./_baseKeys'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nmodule.exports = keys;\n","var arrayLikeKeys = require('./_arrayLikeKeys'),\n baseKeysIn = require('./_baseKeysIn'),\n isArrayLike = require('./isArrayLike');\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nmodule.exports = keysIn;\n","/**\n * Gets the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the last element of `array`.\n * @example\n *\n * _.last([1, 2, 3]);\n * // => 3\n */\nfunction last(array) {\n var length = array == null ? 0 : array.length;\n return length ? array[length - 1] : undefined;\n}\n\nmodule.exports = last;\n","var MapCache = require('./_MapCache');\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nmodule.exports = memoize;\n","var baseMerge = require('./_baseMerge'),\n createAssigner = require('./_createAssigner');\n\n/**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n * 'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n * 'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\nvar merge = createAssigner(function(object, source, srcIndex) {\n baseMerge(object, source, srcIndex);\n});\n\nmodule.exports = merge;\n","/**\n * This method returns `undefined`.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Util\n * @example\n *\n * _.times(2, _.noop);\n * // => [undefined, undefined]\n */\nfunction noop() {\n // No operation performed.\n}\n\nmodule.exports = noop;\n","var arrayMap = require('./_arrayMap'),\n baseClone = require('./_baseClone'),\n baseUnset = require('./_baseUnset'),\n castPath = require('./_castPath'),\n copyObject = require('./_copyObject'),\n customOmitClone = require('./_customOmitClone'),\n flatRest = require('./_flatRest'),\n getAllKeysIn = require('./_getAllKeysIn');\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * The opposite of `_.pick`; this method creates an object composed of the\n * own and inherited enumerable property paths of `object` that are not omitted.\n *\n * **Note:** This method is considerably slower than `_.pick`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to omit.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omit(object, ['a', 'c']);\n * // => { 'b': '2' }\n */\nvar omit = flatRest(function(object, paths) {\n var result = {};\n if (object == null) {\n return result;\n }\n var isDeep = false;\n paths = arrayMap(paths, function(path) {\n path = castPath(path, object);\n isDeep || (isDeep = path.length > 1);\n return path;\n });\n copyObject(object, getAllKeysIn(object), result);\n if (isDeep) {\n result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);\n }\n var length = paths.length;\n while (length--) {\n baseUnset(result, paths[length]);\n }\n return result;\n});\n\nmodule.exports = omit;\n","var baseRest = require('./_baseRest'),\n createWrap = require('./_createWrap'),\n getHolder = require('./_getHolder'),\n replaceHolders = require('./_replaceHolders');\n\n/** Used to compose bitmasks for function metadata. */\nvar WRAP_PARTIAL_RIGHT_FLAG = 64;\n\n/**\n * This method is like `_.partial` except that partially applied arguments\n * are appended to the arguments it receives.\n *\n * The `_.partialRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n * return greeting + ' ' + name;\n * }\n *\n * var greetFred = _.partialRight(greet, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n *\n * // Partially applied with placeholders.\n * var sayHelloTo = _.partialRight(greet, 'hello', _);\n * sayHelloTo('fred');\n * // => 'hello fred'\n */\nvar partialRight = baseRest(function(func, partials) {\n var holders = replaceHolders(partials, getHolder(partialRight));\n return createWrap(func, WRAP_PARTIAL_RIGHT_FLAG, undefined, partials, holders);\n});\n\n// Assign default placeholders.\npartialRight.placeholder = {};\n\nmodule.exports = partialRight;\n","var basePick = require('./_basePick'),\n flatRest = require('./_flatRest');\n\n/**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\nvar pick = flatRest(function(object, paths) {\n return object == null ? {} : basePick(object, paths);\n});\n\nmodule.exports = pick;\n","/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\nmodule.exports = stubArray;\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = stubFalse;\n","var toNumber = require('./toNumber');\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n}\n\nmodule.exports = toFinite;\n","var toFinite = require('./toFinite');\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\nmodule.exports = toInteger;\n","var baseClamp = require('./_baseClamp'),\n toInteger = require('./toInteger');\n\n/** Used as references for the maximum length and index of an array. */\nvar MAX_ARRAY_LENGTH = 4294967295;\n\n/**\n * Converts `value` to an integer suitable for use as the length of an\n * array-like object.\n *\n * **Note:** This method is based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toLength(3.2);\n * // => 3\n *\n * _.toLength(Number.MIN_VALUE);\n * // => 0\n *\n * _.toLength(Infinity);\n * // => 4294967295\n *\n * _.toLength('3.2');\n * // => 3\n */\nfunction toLength(value) {\n return value ? baseClamp(toInteger(value), 0, MAX_ARRAY_LENGTH) : 0;\n}\n\nmodule.exports = toLength;\n","var baseTrim = require('./_baseTrim'),\n isObject = require('./isObject'),\n isSymbol = require('./isSymbol');\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = toNumber;\n","var copyObject = require('./_copyObject'),\n keysIn = require('./keysIn');\n\n/**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\nfunction toPlainObject(value) {\n return copyObject(value, keysIn(value));\n}\n\nmodule.exports = toPlainObject;\n","var baseToString = require('./_baseToString');\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nmodule.exports = toString;\n","var baseUniq = require('./_baseUniq');\n\n/**\n * Creates a duplicate-free version of an array, using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons, in which only the first occurrence of each element\n * is kept. The order of result values is determined by the order they occur\n * in the array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniq([2, 1, 2]);\n * // => [2, 1]\n */\nfunction uniq(array) {\n return (array && array.length) ? baseUniq(array) : [];\n}\n\nmodule.exports = uniq;\n","var LazyWrapper = require('./_LazyWrapper'),\n LodashWrapper = require('./_LodashWrapper'),\n baseLodash = require('./_baseLodash'),\n isArray = require('./isArray'),\n isObjectLike = require('./isObjectLike'),\n wrapperClone = require('./_wrapperClone');\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates a `lodash` object which wraps `value` to enable implicit method\n * chain sequences. Methods that operate on and return arrays, collections,\n * and functions can be chained together. Methods that retrieve a single value\n * or may return a primitive value will automatically end the chain sequence\n * and return the unwrapped value. Otherwise, the value must be unwrapped\n * with `_#value`.\n *\n * Explicit chain sequences, which must be unwrapped with `_#value`, may be\n * enabled using `_.chain`.\n *\n * The execution of chained methods is lazy, that is, it's deferred until\n * `_#value` is implicitly or explicitly called.\n *\n * Lazy evaluation allows several methods to support shortcut fusion.\n * Shortcut fusion is an optimization to merge iteratee calls; this avoids\n * the creation of intermediate arrays and can greatly reduce the number of\n * iteratee executions. Sections of a chain sequence qualify for shortcut\n * fusion if the section is applied to an array and iteratees accept only\n * one argument. The heuristic for whether a section qualifies for shortcut\n * fusion is subject to change.\n *\n * Chaining is supported in custom builds as long as the `_#value` method is\n * directly or indirectly included in the build.\n *\n * In addition to lodash methods, wrappers have `Array` and `String` methods.\n *\n * The wrapper `Array` methods are:\n * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift`\n *\n * The wrapper `String` methods are:\n * `replace` and `split`\n *\n * The wrapper methods that support shortcut fusion are:\n * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`,\n * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`,\n * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray`\n *\n * The chainable wrapper methods are:\n * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`,\n * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`,\n * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`,\n * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`,\n * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`,\n * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`,\n * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`,\n * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`,\n * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`,\n * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`,\n * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`,\n * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`,\n * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`,\n * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`,\n * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`,\n * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`,\n * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`,\n * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`,\n * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`,\n * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`,\n * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`,\n * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`,\n * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`,\n * `zipObject`, `zipObjectDeep`, and `zipWith`\n *\n * The wrapper methods that are **not** chainable by default are:\n * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`,\n * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`,\n * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`,\n * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`,\n * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`,\n * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`,\n * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`,\n * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`,\n * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`,\n * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`,\n * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`,\n * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`,\n * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`,\n * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`,\n * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`,\n * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`,\n * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`,\n * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`,\n * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`,\n * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`,\n * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`,\n * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`,\n * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`,\n * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`,\n * `upperFirst`, `value`, and `words`\n *\n * @name _\n * @constructor\n * @category Seq\n * @param {*} value The value to wrap in a `lodash` instance.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var wrapped = _([1, 2, 3]);\n *\n * // Returns an unwrapped value.\n * wrapped.reduce(_.add);\n * // => 6\n *\n * // Returns a wrapped value.\n * var squares = wrapped.map(square);\n *\n * _.isArray(squares);\n * // => false\n *\n * _.isArray(squares.value());\n * // => true\n */\nfunction lodash(value) {\n if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) {\n if (value instanceof LodashWrapper) {\n return value;\n }\n if (hasOwnProperty.call(value, '__wrapped__')) {\n return wrapperClone(value);\n }\n }\n return new LodashWrapper(value);\n}\n\n// Ensure wrappers are instances of `baseLodash`.\nlodash.prototype = baseLodash.prototype;\nlodash.prototype.constructor = lodash;\n\nmodule.exports = lodash;\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-', 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-', 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-', 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-', 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 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-', key);\n * forge.cipher.createDecipher('AES-', 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 * 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 * [parseAllBytes] true to ensure all bytes are parsed\n * (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 * @throws Will throw an error for various malformed input conditions.\n *\n * @return the parsed asn1 object.\n */\nasn1.fromDer = function(bytes, options) {\n if(options === undefined) {\n options = {\n strict: true,\n parseAllBytes: true,\n decodeBitStrings: true\n };\n }\n if(typeof options === 'boolean') {\n options = {\n strict: options,\n parseAllBytes: true,\n decodeBitStrings: true\n };\n }\n if(!('strict' in options)) {\n options.strict = true;\n }\n if(!('parseAllBytes' in options)) {\n options.parseAllBytes = 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 var byteCount = bytes.length();\n var value = _fromDer(bytes, bytes.length(), 0, options);\n if(options.parseAllBytes && bytes.length() !== 0) {\n var error = new Error('Unparsed DER bytes remain after ASN.1 parsing.');\n error.byteCount = byteCount;\n error.remaining = bytes.length();\n throw error;\n }\n return value;\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 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 remaining -= 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 try {\n rval += forge.util.decodeUtf8(obj.value);\n } catch(e) {\n if(e.message === 'URI malformed') {\n rval +=\n '0x' + forge.util.bytesToHex(obj.value) + ' (malformed UTF8)';\n } else {\n throw e;\n }\n }\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 * 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 * 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","/**\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 * 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 \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-', 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-', 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-', 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-', 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-', key);\n * forge.cipher.createDecipher('DES-', 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 * 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 * 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","// 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<= 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))<>(this.DB-sh));\n } else\n this.data[this.t-1] |= x<= 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)< 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< 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+=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<= 0; --i) {\n r.data[i+ds+1] = (this.data[i]>>cbs)|c;\n c = (this.data[i]&bm)<= 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;\n for(var i = ds+1; i < this.t; ++i) {\n r.data[i-ds-1] |= (this.data[i]&bm)<>bs;\n }\n if(bs > 0) r.data[this.t-ds-1] |= (this.s&bm)<>= 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<1)?y.data[ys-2]>>this.F2:0);\n var d1 = this.FV/yt, d2 = (1<= 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< 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))<>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< 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+=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<>= 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< 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< 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 * 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 * Node.js module for Forge mask generation functions.\n *\n * @author Stefan Siegl\n *\n * Copyright 2012 Stefan Siegl \n */\nvar forge = require('./forge');\nrequire('./mgf1');\n\nmodule.exports = forge.mgf = forge.mgf || {};\nforge.mgf.mgf1 = forge.mgf1;\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 \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 * 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// Deprecated equivalent of sha1WithRSAEncryption\n_IN('1.3.14.3.2.29', 'sha1WithRSASignature');\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('2.16.840.1.101.3.4.2.4', 'sha224');\n_IN('2.16.840.1.101.3.4.2.5', 'sha512-224');\n_IN('2.16.840.1.101.3.4.2.6', 'sha512-256');\n_IN('1.2.840.113549.2.2', 'md2');\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.4', 'surname');\n_IN('2.5.4.5', 'serialNumber');\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.12', 'title');\n_IN('2.5.4.13', 'description');\n_IN('2.5.4.15', 'businessCategory');\n_IN('2.5.4.17', 'postalCode');\n_IN('2.5.4.42', 'givenName');\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 * Password-based encryption functions.\n *\n * @author Dave Longley\n * @author Stefan Siegl \n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl \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 * 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 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 // accept \"NEW CERTIFICATE REQUEST\" as \"CERTIFICATE REQUEST\"\n // https://datatracker.ietf.org/doc/html/rfc7468#section-7\n var type = match[1];\n if(type === 'NEW CERTIFICATE REQUEST') {\n type = 'CERTIFICATE REQUEST';\n }\n\n var msg = {\n type: type,\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","/**\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 * Javascript implementation of PKCS#12.\n *\n * @author Dave Longley\n * @author Stefan Siegl \n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl \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 PKCS#7 v1.5.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl \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 ? capture.encParameter.value : undefined,\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 !ec.parameter ?\n undefined :\n asn1.create(\n 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 * 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 \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 optional: true\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 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 * 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: ,\n * millerRabinTests: ,\n * workerScript: ,\n * workers: .\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 * 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(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 * Javascript implementation of PKCS#1 PSS signature padding.\n *\n * @author Stefan Siegl\n *\n * Copyright (c) 2012 Stefan Siegl \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","/**\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 * RC2 implementation.\n *\n * @author Stefan Siegl\n *\n * Copyright (c) 2012 Stefan Siegl \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 * 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// validator for a DigestInfo structure\nvar digestInfoValidator = {\n name: 'DigestInfo',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'DigestInfo.DigestAlgorithm',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.SEQUENCE,\n constructed: true,\n value: [{\n name: 'DigestInfo.DigestAlgorithm.algorithmIdentifier',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OID,\n constructed: false,\n capture: 'algorithmIdentifier'\n }, {\n // NULL paramters\n name: 'DigestInfo.DigestAlgorithm.parameters',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.NULL,\n // captured only to check existence for md2 and md5\n capture: 'parameters',\n optional: true,\n constructed: false\n }]\n }, {\n // digest\n name: 'DigestInfo.digest',\n tagClass: asn1.Class.UNIVERSAL,\n type: asn1.Type.OCTETSTRING,\n constructed: false,\n capture: 'digest'\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 * @param options optional verify options\n * _parseAllDigestBytes testing flag to control parsing of all\n * digest bytes. Unsupported and not for general usage.\n * (default: true)\n *\n * @return true if the signature was verified, false if not.\n */\n key.verify = function(digest, signature, scheme, options) {\n if(typeof scheme === 'string') {\n scheme = scheme.toUpperCase();\n } else if(scheme === undefined) {\n scheme = 'RSASSA-PKCS1-V1_5';\n }\n if(options === undefined) {\n options = {\n _parseAllDigestBytes: true\n };\n }\n if(!('_parseAllDigestBytes' in options)) {\n options._parseAllDigestBytes = true;\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 parseAllBytes: options._parseAllDigestBytes\n });\n\n // validate DigestInfo\n var capture = {};\n var errors = [];\n if(!asn1.validate(obj, digestInfoValidator, capture, errors)) {\n var error = new Error(\n 'ASN.1 object does not contain a valid RSASSA-PKCS1-v1_5 ' +\n 'DigestInfo value.');\n error.errors = errors;\n throw error;\n }\n // check hash algorithm identifier\n // see PKCS1-v1-5DigestAlgorithms in RFC 8017\n // FIXME: add support to vaidator for strict value choices\n var oid = asn1.derToOid(capture.algorithmIdentifier);\n if(!(oid === forge.oids.md2 ||\n oid === forge.oids.md5 ||\n oid === forge.oids.sha1 ||\n oid === forge.oids.sha224 ||\n oid === forge.oids.sha256 ||\n oid === forge.oids.sha384 ||\n oid === forge.oids.sha512 ||\n oid === forge.oids['sha512-224'] ||\n oid === forge.oids['sha512-256'])) {\n var error = new Error(\n 'Unknown RSASSA-PKCS1-v1_5 DigestAlgorithm identifier.');\n error.oid = oid;\n throw error;\n }\n\n // special check for md2 and md5 that NULL parameters exist\n if(oid === forge.oids.md2 || oid === forge.oids.md5) {\n if(!('parameters' in capture)) {\n throw new Error(\n 'ASN.1 object does not contain a valid RSASSA-PKCS1-v1_5 ' +\n 'DigestInfo value. ' +\n 'Missing algorithm identifer NULL parameters.');\n }\n }\n\n // compare the given digest to the decrypted one\n return digest === capture.digest;\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","/**\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 * 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 * 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 * 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 * 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 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 * Create signature digest for OID.\n *\n * @param options\n * signatureOid: the OID specifying the signature algorithm.\n * type: a human readable type for error messages\n * @return a created md instance. throws if unknown oid.\n */\nvar _createSignatureDigest = function(options) {\n switch(oids[options.signatureOid]) {\n case 'sha1WithRSAEncryption':\n // deprecated alias\n case 'sha1WithRSASignature':\n return forge.md.sha1.create();\n case 'md5WithRSAEncryption':\n return forge.md.md5.create();\n case 'sha256WithRSAEncryption':\n return forge.md.sha256.create();\n case 'sha384WithRSAEncryption':\n return forge.md.sha384.create();\n case 'sha512WithRSAEncryption':\n return forge.md.sha512.create();\n case 'RSASSA-PSS':\n return forge.md.sha256.create();\n default:\n var error = new Error(\n 'Could not compute ' + options.type + ' digest. ' +\n 'Unknown signature OID.');\n error.signatureOid = options.signatureOid;\n throw error;\n }\n};\n\n/**\n * Verify signature on certificate or CSR.\n *\n * @param options:\n * certificate the certificate or CSR to verify.\n * md the signature digest.\n * signature the signature\n * @return a created md instance. throws if unknown oid.\n */\nvar _verifySignature = function(options) {\n var cert = options.certificate;\n var scheme;\n\n switch(cert.signatureOid) {\n case oids.sha1WithRSAEncryption:\n // deprecated alias\n case oids.sha1WithRSASignature:\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[cert.signatureParameters.mgf.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported MGF hash function.');\n error.oid = cert.signatureParameters.mgf.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n mgf = oids[cert.signatureParameters.mgf.algorithmOid];\n if(mgf === undefined || forge.mgf[mgf] === undefined) {\n var error = new Error('Unsupported MGF function.');\n error.oid = cert.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[cert.signatureParameters.hash.algorithmOid];\n if(hash === undefined || forge.md[hash] === undefined) {\n var error = new Error('Unsupported RSASSA-PSS hash function.');\n error.oid = cert.signatureParameters.hash.algorithmOid;\n error.name = hash;\n throw error;\n }\n\n scheme = forge.pss.create(\n forge.md[hash].create(), mgf, cert.signatureParameters.saltLength\n );\n break;\n }\n\n // verify signature on cert using public key\n return cert.publicKey.verify(\n options.md.digest().getBytes(), options.signature, scheme\n );\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 = subject.attributes;\n error.actualIssuer = issuer.attributes;\n throw error;\n }\n\n var md = child.md;\n if(md === null) {\n // create digest for OID signature types\n md = _createSignatureDigest({\n signatureOid: child.signatureOid,\n type: 'certificate'\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 rval = _verifySignature({\n certificate: cert, md: md, signature: child.signature\n });\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 // create digest for OID signature type\n cert.md = _createSignatureDigest({\n signatureOid: cert.signatureOid,\n type: 'certificate'\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 var ibytes = asn1.toDer(capture.certIssuer);\n imd.update(ibytes.getBytes());\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);\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 var sbytes = asn1.toDer(capture.certSubject);\n smd.update(sbytes.getBytes());\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);\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 // create digest for OID signature type\n csr.md = _createSignatureDigest({\n signatureOid: csr.signatureOid,\n type: 'certification request'\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 -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 md = _createSignatureDigest({\n signatureOid: csr.signatureOid,\n type: 'certification request'\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 rval = _verifySignature({\n certificate: csr, md: md, signature: csr.signature\n });\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 * algorithms/aes-cbc-hmac-sha2.js - AES-CBC-HMAC-SHA2 Composited Encryption\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar helpers = require(\"./helpers.js\"),\n HMAC = require(\"./hmac.js\"),\n sha = require(\"./sha.js\"),\n forge = require(\"../deps/forge.js\"),\n DataBuffer = require(\"../util/databuffer.js\"),\n util = require(\"../util\");\n\nfunction checkIv(iv) {\n if (16 !== iv.length) {\n throw new Error(\"invalid iv\");\n }\n}\n\nfunction commonCbcEncryptFN(size) {\n // ### 'fallback' implementation -- uses forge\n var fallback = function(encKey, pdata, iv) {\n try {\n checkIv(iv);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var promise = Promise.resolve();\n\n promise = promise.then(function() {\n var cipher = forge.cipher.createCipher(\"AES-CBC\", new DataBuffer(encKey));\n cipher.start({\n iv: new DataBuffer(iv)\n });\n\n // TODO: chunk data\n cipher.update(new DataBuffer(pdata));\n if (!cipher.finish()) {\n return Promise.reject(new Error(\"encryption failed\"));\n }\n\n var cdata = Buffer.from(cipher.output.bytes(), \"binary\");\n return cdata;\n });\n\n return promise;\n };\n\n // ### WebCryptoAPI implementation\n // TODO: cache CryptoKey sooner\n var webcrypto = function(encKey, pdata, iv) {\n try {\n checkIv(iv);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var promise = Promise.resolve();\n\n promise = promise.then(function() {\n var alg = {\n name: \"AES-CBC\"\n };\n return helpers.subtleCrypto.importKey(\"raw\", encKey, alg, true, [\"encrypt\"]);\n });\n promise = promise.then(function(key) {\n var alg = {\n name: \"AES-CBC\",\n iv: iv\n };\n return helpers.subtleCrypto.encrypt(alg, key, pdata);\n });\n promise = promise.then(function(cdata) {\n cdata = Buffer.from(cdata);\n return cdata;\n });\n\n return promise;\n };\n\n // ### NodeJS implementation\n var nodejs = function(encKey, pdata, iv) {\n try {\n checkIv(iv);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var promise = Promise.resolve(pdata);\n\n promise = promise.then(function(pdata) {\n var name = \"AES-\" + size + \"-CBC\";\n var cipher = helpers.nodeCrypto.createCipheriv(name, encKey, iv);\n var cdata = Buffer.concat([\n cipher.update(pdata),\n cipher.final()\n ]);\n return cdata;\n });\n\n return promise;\n };\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction commonCbcDecryptFN(size) {\n // ### 'fallback' implementation -- uses forge\n var fallback = function(encKey, cdata, iv) {\n // validate inputs\n try {\n checkIv(iv);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var promise = Promise.resolve();\n\n promise = promise.then(function() {\n var cipher = forge.cipher.createDecipher(\"AES-CBC\", new DataBuffer(encKey));\n cipher.start({\n iv: new DataBuffer(iv)\n });\n\n // TODO: chunk data\n cipher.update(new DataBuffer(cdata));\n if (!cipher.finish()) {\n return Promise.reject(new Error(\"encryption failed\"));\n }\n\n var pdata = Buffer.from(cipher.output.bytes(), \"binary\");\n return pdata;\n });\n\n return promise;\n };\n\n // ### WebCryptoAPI implementation\n // TODO: cache CryptoKey sooner\n var webcrypto = function(encKey, cdata, iv) {\n // validate inputs\n try {\n checkIv(iv);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var promise = Promise.resolve();\n\n promise = promise.then(function() {\n var alg = {\n name: \"AES-CBC\"\n };\n return helpers.subtleCrypto.importKey(\"raw\", encKey, alg, true, [\"decrypt\"]);\n });\n promise = promise.then(function(key) {\n var alg = {\n name: \"AES-CBC\",\n iv: iv\n };\n return helpers.subtleCrypto.decrypt(alg, key, cdata);\n });\n promise = promise.then(function(pdata) {\n pdata = Buffer.from(pdata);\n return pdata;\n });\n\n return promise;\n };\n\n // ### NodeJS implementation\n var nodejs = function(encKey, cdata, iv) {\n // validate inputs\n try {\n checkIv(iv);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var promise = Promise.resolve();\n\n promise = promise.then(function() {\n var name = \"AES-\" + size + \"-CBC\";\n var cipher = helpers.nodeCrypto.createDecipheriv(name, encKey, iv);\n var pdata = Buffer.concat([\n cipher.update(cdata),\n cipher.final()\n ]);\n return pdata;\n });\n\n return promise;\n };\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction checkKey(key, size) {\n if ((size << 1) !== (key.length << 3)) {\n throw new Error(\"invalid encryption key size\");\n }\n}\n\nfunction cbcHmacEncryptFN(size) {\n var commonEncrypt = commonCbcEncryptFN(size);\n return function(key, pdata, props) {\n // validate inputs\n try {\n checkKey(key, size);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var eKey = key.slice(size / 8),\n iKey = key.slice(0, size / 8),\n iv = props.iv || Buffer.alloc(0),\n adata = props.aad || props.adata || Buffer.alloc(0);\n\n // STEP 1 -- Encrypt\n var promise = commonEncrypt(eKey, pdata, iv);\n\n // STEP 2 -- MAC\n promise = promise.then(function(cdata){\n var mdata = Buffer.concat([\n adata,\n iv,\n cdata,\n helpers.int64ToBuffer(adata.length * 8)\n ]);\n\n var promise;\n promise = HMAC[\"HS\" + (size * 2)].sign(iKey, mdata, {\n length: size\n });\n promise = promise.then(function(result) {\n // TODO: move slice to hmac.js\n var tag = result.mac.slice(0, size / 8);\n return {\n data: cdata,\n tag: tag\n };\n });\n return promise;\n });\n\n return promise;\n };\n}\n\nfunction cbcHmacDecryptFN(size) {\n var commonDecrypt = commonCbcDecryptFN(size);\n\n return function(key, cdata, props) {\n // validate inputs\n try {\n checkKey(key, size);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var eKey = key.slice(size / 8),\n iKey = key.slice(0, size / 8),\n iv = props.iv || Buffer.alloc(0),\n adata = props.aad || props.adata || Buffer.alloc(0),\n tag = props.tag || props.mac || Buffer.alloc(0);\n\n var promise = Promise.resolve();\n\n // STEP 1 -- MAC\n promise = promise.then(function() {\n var promise;\n // construct MAC input\n var mdata = Buffer.concat([\n adata,\n iv,\n cdata,\n helpers.int64ToBuffer(adata.length * 8)\n ]);\n promise = HMAC[\"HS\" + (size * 2)].verify(iKey, mdata, tag, {\n length: size\n });\n promise = promise.then(function() {\n return cdata;\n }, function() {\n // failure -- invalid tag error\n throw new Error(\"mac check failed\");\n });\n return promise;\n });\n\n // STEP 2 -- Decrypt\n promise = promise.then(function(){\n return commonDecrypt(eKey, cdata, iv);\n });\n\n return promise;\n };\n}\n\nvar EncryptionLabel = Buffer.from(\"Encryption\", \"utf8\");\nvar IntegrityLabel = Buffer.from(\"Integrity\", \"utf8\");\nvar DotLabel = Buffer.from(\".\", \"utf8\");\n\nfunction generateCek(masterKey, alg, epu, epv) {\n var masterSize = masterKey.length * 8;\n var cekSize = masterSize / 2;\n var promise = Promise.resolve();\n\n promise = promise.then(function(){\n var input = Buffer.concat([\n helpers.int32ToBuffer(1),\n masterKey,\n helpers.int32ToBuffer(cekSize),\n Buffer.from(alg, \"utf8\"),\n epu,\n epv,\n EncryptionLabel\n ]);\n\n return input;\n });\n\n promise = promise.then( function(input) {\n return sha[\"SHA-\" + masterSize].digest(input).then(function(digest) {\n return digest.slice(0, cekSize / 8);\n });\n });\n promise = Promise.resolve(promise);\n\n return promise;\n}\n\nfunction generateCik(masterKey, alg, epu, epv) {\n var masterSize = masterKey.length * 8;\n var cikSize = masterSize;\n var promise = Promise.resolve();\n\n promise = promise.then(function(){\n var input = Buffer.concat([\n helpers.int32ToBuffer(1),\n masterKey,\n helpers.int32ToBuffer(cikSize),\n Buffer.from(alg, \"utf8\"),\n epu,\n epv,\n IntegrityLabel\n ]);\n\n return input;\n });\n\n promise = promise.then( function(input) {\n return sha[\"SHA-\" + masterSize].digest(input).then(function(digest) {\n return digest.slice(0, cikSize / 8);\n });\n });\n promise = Promise.resolve(promise);\n\n return promise;\n}\n\nfunction concatKdfCbcHmacEncryptFN(size, alg) {\n var commonEncrypt = commonCbcEncryptFN(size);\n\n return function(key, pdata, props) {\n var epu = props.epu || helpers.int32ToBuffer(0),\n epv = props.epv || helpers.int32ToBuffer(0),\n iv = props.iv || Buffer.alloc(0),\n adata = props.aad || props.adata || Buffer.alloc(0),\n kdata = props.kdata || Buffer.alloc(0);\n\n // Pre Step 1 -- Generate Keys\n var promises = [\n generateCek(key, alg, epu, epv),\n generateCik(key, alg, epu, epv)\n ];\n\n var cek,\n cik;\n var promise = Promise.all(promises).then(function(keys) {\n cek = keys[0];\n cik = keys[1];\n });\n\n // STEP 1 -- Encrypt\n promise = promise.then(function(){\n return commonEncrypt(cek, pdata, iv);\n });\n\n // STEP 2 -- Mac\n promise = promise.then(function(cdata){\n var mdata = Buffer.concat([\n adata,\n DotLabel,\n Buffer.from(kdata),\n DotLabel,\n Buffer.from(util.base64url.encode(iv), \"utf8\"),\n DotLabel,\n Buffer.from(util.base64url.encode(cdata), \"utf8\")\n ]);\n return Promise.all([\n Promise.resolve(cdata),\n HMAC[\"HS\" + (size * 2)].sign(cik, mdata, { length: size })\n ]);\n });\n promise = promise.then(function(result){\n return {\n data: result[0],\n tag: result[1].mac\n };\n });\n\n return promise;\n };\n}\n\nfunction concatKdfCbcHmacDecryptFN(size, alg) {\n var commonDecrypt = commonCbcDecryptFN(size);\n\n return function(key, cdata, props) {\n var epu = props.epu || helpers.int32ToBuffer(0),\n epv = props.epv || helpers.int32ToBuffer(0),\n iv = props.iv || Buffer.alloc(0),\n adata = props.aad || props.adata || Buffer.alloc(0),\n kdata = props.kdata || Buffer.alloc(0),\n tag = props.tag || props.mac || Buffer.alloc(0);\n\n // Pre Step 1 -- Generate Keys\n var promises = [\n generateCek(key, alg, epu, epv),\n generateCik(key, alg, epu, epv)\n ];\n\n var cek,\n cik;\n var promise = Promise.all(promises).then(function(keys){\n cek = keys[0];\n cik = keys[1];\n });\n\n\n // STEP 1 -- MAC\n promise = promise.then(function() {\n // construct MAC input\n var mdata = Buffer.concat([\n adata,\n DotLabel,\n Buffer.from(kdata),\n DotLabel,\n Buffer.from(util.base64url.encode(iv), \"utf8\"),\n DotLabel,\n Buffer.from(util.base64url.encode(cdata), \"utf8\")\n ]);\n\n try {\n return HMAC[\"HS\" + (size * 2)].verify(cik, mdata, tag, {\n loose: false\n });\n } catch (e) {\n throw new Error(\"mac check failed\");\n }\n });\n\n // STEP 2 -- Decrypt\n promise = promise.then(function(){\n return commonDecrypt(cek, cdata, iv);\n });\n\n return promise;\n };\n}\n\n// ### Public API\n// * [name].encrypt\n// * [name].decrypt\nvar aesCbcHmacSha2 = {};\n[\n \"A128CBC-HS256\",\n \"A192CBC-HS384\",\n \"A256CBC-HS512\"\n].forEach(function(alg) {\n var size = parseInt(/A(\\d+)CBC-HS(\\d+)?/g.exec(alg)[1]);\n aesCbcHmacSha2[alg] = {\n encrypt: cbcHmacEncryptFN(size),\n decrypt: cbcHmacDecryptFN(size)\n };\n});\n\n[\n \"A128CBC+HS256\",\n \"A192CBC+HS384\",\n \"A256CBC+HS512\"\n].forEach(function(alg) {\n var size = parseInt(/A(\\d+)CBC\\+HS(\\d+)?/g.exec(alg)[1]);\n aesCbcHmacSha2[alg] = {\n encrypt: concatKdfCbcHmacEncryptFN(size, alg),\n decrypt: concatKdfCbcHmacDecryptFN(size, alg)\n };\n});\n\nmodule.exports = aesCbcHmacSha2;\n","/*!\n * algorithms/aes-gcm.js - AES-GCM Encryption and Key-Wrapping\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar helpers = require(\"./helpers.js\"),\n util = require(\"../util\"),\n CONSTANTS = require(\"./constants.js\"),\n GCM = require(\"../deps/ciphermodes/gcm\");\n\nfunction gcmEncryptFN(size, wrap) {\n function commonChecks(key, iv) {\n if (size !== (key.length << 3)) {\n throw new Error(\"invalid key size\");\n }\n if (!iv && !wrap) {\n throw new Error(\"invalid iv\");\n }\n if (iv && 12 !== iv.length) {\n throw new Error(\"invalid iv\");\n }\n }\n\n function prepareResults(results) {\n if (wrap) {\n var iv = util.base64url.encode(results.iv);\n var tag = util.base64url.encode(results.tag);\n\n results = {\n data: results.data,\n header: {\n iv: iv,\n tag: tag\n }\n };\n }\n\n return results;\n }\n\n // ### 'fallback' implementation -- uses forge\n var fallback = function(key, pdata, props) {\n var iv = props.iv,\n adata = props.aad || props.adata || Buffer.alloc(0),\n cipher,\n cdata;\n\n // validate inputs\n try {\n commonChecks(key, iv, adata);\n } catch (err) {\n return Promise.reject(err);\n }\n\n iv = iv || util.randomBytes(12);\n\n // setup cipher\n cipher = GCM.createCipher({\n key: key,\n iv: iv,\n additionalData: adata\n });\n // ciphertext is the same length as plaintext\n cdata = Buffer.alloc(pdata.length);\n\n var promise = new Promise(function(resolve, reject) {\n var amt = CONSTANTS.CHUNK_SIZE,\n clen = 0,\n poff = 0;\n\n (function doChunk() {\n var plen = Math.min(amt, pdata.length - poff);\n clen += cipher.update(pdata,\n poff,\n plen,\n cdata,\n clen);\n poff += plen;\n if (pdata.length > poff) {\n setTimeout(doChunk, 0);\n return;\n }\n\n // finish it\n clen += cipher.finish(cdata, clen);\n if (clen !== pdata.length) {\n reject(new Error(\"encryption failed\"));\n return;\n }\n\n // resolve with output\n var tag = cipher.tag;\n resolve(prepareResults({\n data: cdata,\n iv: iv,\n tag: tag\n }));\n })();\n });\n\n return promise;\n };\n\n // ### WebCryptoAPI implementation\n // TODO: cache CryptoKey sooner\n var webcrypto = function(key, pdata, props) {\n var iv = props.iv,\n adata = props.aad || props.adata || Buffer.alloc(0);\n\n try {\n commonChecks(key, iv, adata);\n } catch (err) {\n return Promise.reject(err);\n }\n\n iv = iv || util.randomBytes(12);\n\n var alg = {\n name: \"AES-GCM\"\n };\n var promise;\n promise = helpers.subtleCrypto.importKey(\"raw\", key, alg, true, [\"encrypt\"]);\n promise = promise.then(function(key) {\n alg.iv = iv;\n alg.tagLength = 128;\n if (adata.length) {\n alg.additionalData = adata;\n }\n\n return helpers.subtleCrypto.encrypt(alg, key, pdata);\n });\n promise = promise.then(function(result) {\n var tagStart = result.byteLength - 16;\n\n var tag = result.slice(tagStart);\n tag = Buffer.from(tag);\n\n var cdata = result.slice(0, tagStart);\n cdata = Buffer.from(cdata);\n\n return prepareResults({\n data: cdata,\n iv: iv,\n tag: tag\n });\n });\n\n return promise;\n };\n\n // ### NodeJS implementation\n var nodejs = function(key, pdata, props) {\n var iv = props.iv,\n adata = props.aad || props.adata || Buffer.alloc(0);\n\n try {\n commonChecks(key, iv, adata);\n } catch (err) {\n return Promise.reject(err);\n }\n\n iv = iv || util.randomBytes(12);\n\n var alg = \"aes-\" + (key.length * 8) + \"-gcm\";\n var cipher;\n try {\n cipher = helpers.nodeCrypto.createCipheriv(alg, key, iv);\n } catch (err) {\n throw new Error(\"unsupported algorithm: \" + alg);\n }\n if (\"function\" !== typeof cipher.setAAD) {\n throw new Error(\"unsupported algorithm: \" + alg);\n }\n if (adata.length) {\n cipher.setAAD(adata);\n }\n\n var cdata = Buffer.concat([\n cipher.update(pdata),\n cipher.final()\n ]);\n var tag = cipher.getAuthTag();\n\n return prepareResults({\n data: cdata,\n iv: iv,\n tag: tag\n });\n };\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction gcmDecryptFN(size) {\n function commonChecks(key, iv, tag) {\n if (size !== (key.length << 3)) {\n throw new Error(\"invalid key size\");\n }\n if (12 !== iv.length) {\n throw new Error(\"invalid iv\");\n }\n if (16 !== tag.length) {\n throw new Error(\"invalid tag length\");\n }\n }\n\n // ### fallback implementation -- uses forge\n var fallback = function(key, cdata, props) {\n var adata = props.aad || props.adata || Buffer.alloc(0),\n iv = props.iv || Buffer.alloc(0),\n tag = props.tag || props.mac || Buffer.alloc(0),\n cipher,\n pdata;\n\n // validate inputs\n try {\n commonChecks(key, iv, tag);\n } catch (err) {\n return Promise.reject(err);\n }\n\n // setup cipher\n cipher = GCM.createDecipher({\n key: key,\n iv: iv,\n additionalData: adata,\n tag: tag\n });\n // plaintext is the same length as ciphertext\n pdata = Buffer.alloc(cdata.length);\n\n var promise = new Promise(function(resolve, reject) {\n var amt = CONSTANTS.CHUNK_SIZE,\n plen = 0,\n coff = 0;\n\n (function doChunk() {\n var clen = Math.min(amt, cdata.length - coff);\n plen += cipher.update(cdata,\n coff,\n clen,\n pdata,\n plen);\n coff += clen;\n if (cdata.length > coff) {\n setTimeout(doChunk, 0);\n return;\n }\n\n try {\n plen += cipher.finish(pdata, plen);\n } catch (err) {\n reject(new Error(\"decryption failed\"));\n return;\n }\n\n if (plen !== cdata.length) {\n reject(new Error(\"decryption failed\"));\n return;\n }\n\n // resolve with output\n resolve(pdata);\n })();\n });\n\n return promise;\n };\n\n // ### WebCryptoAPI implementation\n // TODO: cache CryptoKey sooner\n var webcrypto = function(key, cdata, props) {\n var adata = props.aad || props.adata || Buffer.alloc(0),\n iv = props.iv || Buffer.alloc(0),\n tag = props.tag || props.mac || Buffer.alloc(0);\n\n // validate inputs\n try {\n commonChecks(key, iv, tag);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var alg = {\n name: \"AES-GCM\"\n };\n var promise;\n promise = helpers.subtleCrypto.importKey(\"raw\", key, alg, true, [\"decrypt\"]);\n promise = promise.then(function(key) {\n alg.iv = iv;\n alg.tagLength = 128;\n if (adata.length) {\n alg.additionalData = adata;\n }\n\n // concatenate cdata and tag\n cdata = Buffer.concat([cdata, tag], cdata.length + tag.length);\n\n return helpers.subtleCrypto.decrypt(alg, key, cdata);\n });\n promise = promise.then(function(pdata) {\n pdata = Buffer.from(pdata);\n return pdata;\n });\n\n return promise;\n };\n\n var nodejs = function(key, cdata, props) {\n var adata = props.aad || props.adata || Buffer.alloc(0),\n iv = props.iv || Buffer.alloc(0),\n tag = props.tag || props.mac || Buffer.alloc(0);\n\n // validate inputs\n try {\n commonChecks(key, iv, tag);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var alg = \"aes-\" + (key.length * 8) + \"-gcm\";\n var cipher;\n try {\n cipher = helpers.nodeCrypto.createDecipheriv(alg, key, iv);\n } catch(err) {\n throw new Error(\"unsupported algorithm: \" + alg);\n }\n if (\"function\" !== typeof cipher.setAAD) {\n throw new Error(\"unsupported algorithm: \" + alg);\n }\n cipher.setAuthTag(tag);\n if (adata.length) {\n cipher.setAAD(adata);\n }\n\n try {\n var pdata = Buffer.concat([\n cipher.update(cdata),\n cipher.final()\n ]);\n\n return pdata;\n } catch (err) {\n throw new Error(\"decryption failed\");\n }\n };\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\n// ### Public API\n// * [name].encrypt\n// * [name].decrypt\nvar aesGcm = {};\n[\n \"A128GCM\",\n \"A192GCM\",\n \"A256GCM\",\n \"A128GCMKW\",\n \"A192GCMKW\",\n \"A256GCMKW\"\n].forEach(function(alg) {\n var parts = /A(\\d+)GCM(KW)?/g.exec(alg);\n var size = parseInt(parts[1]);\n var wrap = (parts[2] === \"KW\");\n aesGcm[alg] = {\n encrypt: gcmEncryptFN(size, wrap),\n decrypt: gcmDecryptFN(size, wrap)\n };\n});\n\nmodule.exports = aesGcm;\n","/*!\n * algorithms/aes-kw.js - AES-KW Key-Wrapping\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar helpers = require(\"./helpers.js\"),\n forge = require(\"../deps/forge.js\"),\n DataBuffer = require(\"../util/databuffer.js\");\n\nvar A0 = Buffer.from(\"a6a6a6a6a6a6a6a6\", \"hex\");\n\n// ### helpers\nfunction xor(a, b) {\n var len = Math.max(a.length, b.length);\n var result = Buffer.alloc(len);\n for (var idx = 0; len > idx; idx++) {\n result[idx] = (a[idx] || 0) ^ (b[idx] || 0);\n }\n return result;\n}\n\nfunction split(input, size) {\n var output = [];\n for (var idx = 0; input.length > idx; idx += size) {\n output.push(input.slice(idx, idx + size));\n }\n return output;\n}\n\nfunction longToBigEndian(input) {\n var hi = Math.floor(input / 4294967296),\n lo = input % 4294967296;\n var output = Buffer.alloc(8);\n output[0] = 0xff & (hi >>> 24);\n output[1] = 0xff & (hi >>> 16);\n output[2] = 0xff & (hi >>> 8);\n output[3] = 0xff & (hi >>> 0);\n output[4] = 0xff & (lo >>> 24);\n output[5] = 0xff & (lo >>> 16);\n output[6] = 0xff & (lo >>> 8);\n output[7] = 0xff & (lo >>> 0);\n return output;\n}\n\nfunction kwEncryptFN(size) {\n function commonChecks(key, data) {\n if (size !== (key.length << 3)) {\n throw new Error(\"invalid key size\");\n }\n if (0 < data.length && 0 !== (data.length % 8)) {\n throw new Error(\"invalid data length\");\n }\n }\n\n // ### 'fallback' implementation -- uses forge\n var fallback = function(key, pdata) {\n try {\n commonChecks(key, pdata);\n } catch (err) {\n return Promise.reject(err);\n }\n\n // setup cipher\n var cipher = forge.cipher.createCipher(\"AES\", new DataBuffer(key));\n\n // split input into chunks\n var R = split(pdata, 8);\n var A,\n B,\n count;\n A = A0;\n for (var jdx = 0; 6 > jdx; jdx++) {\n for (var idx = 0; R.length > idx; idx++) {\n count = (R.length * jdx) + idx + 1;\n B = Buffer.concat([A, R[idx]]);\n cipher.start();\n cipher.update(new DataBuffer(B));\n cipher.finish();\n B = Buffer.from(cipher.output.bytes(), \"binary\");\n\n A = xor(B.slice(0, 8),\n longToBigEndian(count));\n R[idx] = B.slice(8, 16);\n }\n }\n R = [A].concat(R);\n var cdata = Buffer.concat(R);\n return Promise.resolve({\n data: cdata\n });\n };\n // ### WebCryptoAPI implementation\n var webcrypto = function(key, pdata) {\n try {\n commonChecks(key, pdata);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var alg = {\n name: \"AES-KW\"\n };\n var promise = [\n helpers.subtleCrypto.importKey(\"raw\", pdata, { name: \"HMAC\", hash: \"SHA-256\" }, true, [\"sign\"]),\n helpers.subtleCrypto.importKey(\"raw\", key, alg, true, [\"wrapKey\"])\n ];\n promise = Promise.all(promise);\n promise = promise.then(function(keys) {\n return helpers.subtleCrypto.wrapKey(\"raw\",\n keys[0], // key\n keys[1], // wrappingKey\n alg);\n });\n promise = promise.then(function(result) {\n result = Buffer.from(result);\n\n return {\n data: result\n };\n });\n return promise;\n };\n var node = function(key, pdata) {\n try {\n commonChecks(key, pdata);\n } catch (err) {\n return Promise.reject(err);\n }\n\n // split input into chunks\n var R = split(pdata, 8),\n iv = Buffer.alloc(16);\n var A,\n B,\n count;\n A = A0;\n for (var jdx = 0; 6 > jdx; jdx++) {\n for (var idx = 0; R.length > idx; idx++) {\n count = (R.length * jdx) + idx + 1;\n B = Buffer.concat([A, R[idx]]);\n var cipher = helpers.nodeCrypto.createCipheriv(\"AES\" + size, key, iv);\n B = cipher.update(B);\n\n A = xor(B.slice(0, 8),\n longToBigEndian(count));\n R[idx] = B.slice(8, 16);\n }\n }\n R = [A].concat(R);\n var cdata = Buffer.concat(R);\n return Promise.resolve({\n data: cdata\n });\n };\n\n return helpers.setupFallback(node, webcrypto, fallback);\n}\nfunction kwDecryptFN(size) {\n function commonChecks(key, data) {\n if (size !== (key.length << 3)) {\n throw new Error(\"invalid key size\");\n }\n if (0 < (data.length - 8) && 0 !== (data.length % 8)) {\n throw new Error(\"invalid data length\");\n }\n }\n\n // ### 'fallback' implementation -- uses forge\n var fallback = function(key, cdata) {\n try {\n commonChecks(key, cdata);\n } catch (err) {\n return Promise.reject(err);\n }\n\n // setup cipher\n var cipher = forge.cipher.createDecipher(\"AES\", new DataBuffer(key));\n\n // prepare inputs\n var R = split(cdata, 8),\n A,\n B,\n count;\n A = R[0];\n R = R.slice(1);\n for (var jdx = 5; 0 <= jdx; --jdx) {\n for (var idx = R.length - 1; 0 <= idx; --idx) {\n count = (R.length * jdx) + idx + 1;\n B = xor(A,\n longToBigEndian(count));\n B = Buffer.concat([B, R[idx]]);\n cipher.start();\n cipher.update(new DataBuffer(B));\n cipher.finish();\n B = Buffer.from(cipher.output.bytes(), \"binary\");\n\n A = B.slice(0, 8);\n R[idx] = B.slice(8, 16);\n }\n }\n if (A.toString() !== A0.toString()) {\n return Promise.reject(new Error(\"decryption failed\"));\n }\n var pdata = Buffer.concat(R);\n return Promise.resolve(pdata);\n };\n // ### WebCryptoAPI implementation\n var webcrypto = function(key, cdata) {\n try {\n commonChecks(key, cdata);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var alg = {\n name: \"AES-KW\"\n };\n var promise = helpers.subtleCrypto.importKey(\"raw\", key, alg, true, [\"unwrapKey\"]);\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.unwrapKey(\"raw\", cdata, key, alg, {name: \"HMAC\", hash: \"SHA-256\"}, true, [\"sign\"]);\n });\n promise = promise.then(function(result) {\n // unwrapped CryptoKey -- extract raw\n return helpers.subtleCrypto.exportKey(\"raw\", result);\n });\n promise = promise.then(function(result) {\n result = Buffer.from(result);\n return result;\n });\n return promise;\n };\n var node = function(key, cdata) {\n try {\n commonChecks(key, cdata);\n } catch (err) {\n return Promise.reject(err);\n }\n\n // prepare inputs\n var R = split(cdata, 8),\n iv = Buffer.alloc(16),\n A,\n B,\n count;\n A = R[0];\n R = R.slice(1);\n for (var jdx = 5; 0 <= jdx; --jdx) {\n for (var idx = R.length - 1; 0 <= idx; --idx) {\n count = (R.length * jdx) + idx + 1;\n B = xor(A,\n longToBigEndian(count));\n B = Buffer.concat([B, R[idx], iv]);\n var cipher = helpers.nodeCrypto.createDecipheriv(\"AES\" + size, key, iv);\n B = cipher.update(B);\n\n A = B.slice(0, 8);\n R[idx] = B.slice(8, 16);\n }\n }\n if (A.toString() !== A0.toString()) {\n return Promise.reject(new Error(\"decryption failed\"));\n }\n var pdata = Buffer.concat(R);\n return Promise.resolve(pdata);\n };\n\n return helpers.setupFallback(node, webcrypto, fallback);\n}\n\n// ### Public API\n// * [name].encrypt\n// * [name].decrypt\nvar aesKw = {};\n[\n \"A128KW\",\n \"A192KW\",\n \"A256KW\"\n].forEach(function(alg) {\n var size = parseInt(/A(\\d+)KW/g.exec(alg)[1]);\n aesKw[alg] = {\n encrypt: kwEncryptFN(size),\n decrypt: kwDecryptFN(size)\n };\n});\n\nmodule.exports = aesKw;\n","/*!\n * algorithms/concat.js - Concat Key Derivation\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar CONSTANTS = require(\"./constants.js\"),\n sha = require(\"./sha.js\");\n\nfunction concatDeriveFn(name) {\n name = name.replace(\"CONCAT-\", \"\");\n\n // NOTE: no nodejs/webcrypto/fallback model, since ConcatKDF is\n // implemented using the SHA algorithms\n\n var fn = function(key, props) {\n props = props || {};\n\n var keyLen = props.length,\n hashLen = CONSTANTS.HASHLENGTH[name];\n if (!keyLen) {\n return Promise.reject(new Error(\"invalid key length\"));\n }\n\n // setup otherInfo\n if (!props.otherInfo) {\n return Promise.reject(new Error(\"invalid otherInfo\"));\n }\n var otherInfo = props.otherInfo;\n\n var op = sha[name].digest;\n var N = Math.ceil(keyLen / hashLen),\n idx = 0,\n okm = [];\n function step() {\n if (N === idx++) {\n return Buffer.concat(okm).slice(0, keyLen);\n }\n\n var T = Buffer.alloc(4 + key.length + otherInfo.length);\n T.writeUInt32BE(idx, 0);\n key.copy(T, 4);\n otherInfo.copy(T, 4 + key.length);\n return op(T).then(function(result) {\n okm.push(result);\n return step();\n });\n }\n\n return step();\n };\n\n return fn;\n}\n\n// Public API\n// * [name].derive\nvar concat = {};\n[\n \"CONCAT-SHA-1\",\n \"CONCAT-SHA-256\",\n \"CONCAT-SHA-384\",\n \"CONCAT-SHA-512\"\n].forEach(function(name) {\n concat[name] = {\n derive: concatDeriveFn(name)\n };\n});\n\nmodule.exports = concat;\n","/*!\n * algorithms/constants.js - Constants used in Cryptographic Algorithms\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n \"use strict\";\n\nmodule.exports = {\n CHUNK_SIZE: 1024,\n HASHLENGTH: {\n \"SHA-1\": 160,\n \"SHA-256\": 256,\n \"SHA-384\": 384,\n \"SHA-512\": 512\n },\n ENCLENGTH: {\n \"AES-128-CBC\": 128,\n \"AES-192-CBC\": 192,\n \"AES-256-CBC\": 256,\n \"AES-128-KW\": 128,\n \"AES-192-KW\": 192,\n \"AES-256-KW\": 256\n },\n KEYLENGTH: {\n \"A128CBC-HS256\": 256,\n \"A192CBC-HS384\": 384,\n \"A256CBC-HS512\": 512,\n \"A128CBC+HS256\": 256,\n \"A192CBC+HS384\": 384,\n \"A256CBC+HS512\": 512,\n \"A128GCM\": 128,\n \"A192GCM\": 192,\n \"A256GCM\": 256,\n \"A128KW\": 128,\n \"A192KW\": 192,\n \"A256KW\": 256,\n \"ECDH-ES+A128KW\": 128,\n \"ECDH-ES+A192KW\": 192,\n \"ECDH-ES+A256KW\": 256\n },\n NONCELENGTH: {\n \"A128CBC-HS256\": 128,\n \"A192CBC-HS384\": 128,\n \"A256CBC-HS512\": 128,\n \"A128CBC+HS256\": 128,\n \"A192CBC+HS384\": 128,\n \"A256CBC+HS512\": 128,\n \"A128GCM\": 96,\n \"A192GCM\": 96,\n \"A256GCM\": 96\n }\n};\n","/*!\n * algorithms/dir.js - Direct key mode\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nfunction dirEncryptFN(key) {\n // NOTE: pdata unused\n // NOTE: props unused\n return Promise.resolve({\n data: key,\n once: true,\n direct: true\n });\n}\nfunction dirDecryptFN(key) {\n // NOTE: pdata unused\n // NOTE: props unused\n return Promise.resolve(key);\n}\n\n// ### Public API\n// * [name].encrypt\n// * [name].decrypt\nvar direct = {\n dir: {\n encrypt: dirEncryptFN,\n decrypt: dirDecryptFN\n }\n};\n\nmodule.exports = direct;\n","/*!\n * algorithms/ec-util.js - Elliptic Curve Utility Functions\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar clone = require(\"lodash/clone\"),\n ecc = require(\"../deps/ecc\"),\n forge = require(\"../deps/forge.js\"),\n util = require(\"../util\");\n\nvar EC_KEYSIZES = {\n \"P-256\": 256,\n \"P-384\": 384,\n \"P-521\": 521\n};\n\nfunction convertToForge(key, isPublic) {\n var parts = isPublic ?\n [\"x\", \"y\"] :\n [\"d\"];\n parts = parts.map(function(f) {\n return new forge.jsbn.BigInteger(key[f].toString(\"hex\"), 16);\n });\n // prefix with curve\n parts = [key.crv].concat(parts);\n var fn = isPublic ?\n ecc.asPublicKey :\n ecc.asPrivateKey;\n return fn.apply(ecc, parts);\n}\n\nfunction convertToJWK(key, isPublic) {\n var result = clone(key);\n var parts = isPublic ?\n [\"x\", \"y\"] :\n [\"x\", \"y\", \"d\"];\n parts.forEach(function(f) {\n result[f] = util.base64url.encode(result[f]);\n });\n\n // remove potentially troublesome properties\n delete result.key_ops;\n delete result.use;\n delete result.alg;\n\n if (isPublic) {\n delete result.d;\n }\n\n return result;\n}\n\nfunction convertToObj(key, isPublic) {\n var result = clone(key);\n var parts = isPublic ?\n [\"x\", \"y\"] :\n [\"d\"];\n parts.forEach(function(f) {\n // assume string if base64url-encoded\n result[f] = util.asBuffer(result[f], \"base64url\");\n });\n\n return result;\n}\n\nvar UNCOMPRESSED = Buffer.from([0x04]);\nfunction convertToBuffer(key, isPublic) {\n key = convertToObj(key, isPublic);\n var result = isPublic ?\n Buffer.concat([UNCOMPRESSED, key.x, key.y]) :\n key.d;\n return result;\n}\n\nfunction curveSize(crv) {\n return EC_KEYSIZES[crv || \"\"] || NaN;\n}\n\nfunction curveNameToOid(crv) {\n switch (crv) {\n case \"P-256\":\n return \"1.2.840.10045.3.1.7\";\n case \"P-384\":\n return \"1.3.132.0.34\";\n case \"P-521\":\n return \"1.3.132.0.35\";\n default:\n return null;\n }\n}\n\nvar EC_OID = \"1.2.840.10045.2.1\";\nfunction convertToPEM(key, isPrivate) {\n // curveName to OID\n var oid = key.crv;\n oid = curveNameToOid(oid);\n oid = forge.asn1.oidToDer(oid);\n // key as bytes\n var type,\n pub,\n asn1;\n if (isPrivate) {\n type = \"EC PRIVATE KEY\";\n pub = Buffer.concat([\n Buffer.from([0x00, 0x04]),\n key.x,\n key.y\n ]).toString(\"binary\");\n key = key.d.toString(\"binary\");\n asn1 = forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.SEQUENCE, true, [\n forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.INTEGER, false, \"\\u0001\"),\n forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.OCTETSTRING, false, key),\n forge.asn1.create(forge.asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.OID, false, oid.bytes())\n ]),\n forge.asn1.create(forge.asn1.Class.CONTEXT_SPECIFIC, 1, true, [\n forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.BITSTRING, false, pub)\n ])\n ]);\n } else {\n type = \"PUBLIC KEY\";\n key = Buffer.concat([\n Buffer.from([0x00, 0x04]),\n key.x,\n key.y\n ]).toString(\"binary\");\n asn1 = forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.SEQUENCE, true, [\n forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.SEQUENCE, true, [\n forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.OID, false, forge.asn1.oidToDer(EC_OID).bytes()),\n forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.OID, false, oid.bytes())\n ]),\n forge.asn1.create(forge.asn1.Class.UNIVERSAL, forge.asn1.Type.BITSTRING, false, key)\n ]);\n }\n asn1 = forge.asn1.toDer(asn1).bytes();\n var pem = forge.pem.encode({\n type: type,\n body: asn1\n });\n return pem;\n}\n\n// Inspired by teifip/node-webtokens/blob/master/lib/ecdsa.js\nvar ERR_MSG = \"Could not extract parameters from DER signature\";\nfunction derToConcat(signature, size) {\n var offset = 0;\n if (signature[offset++] !== 0x30) {\n throw new Error(ERR_MSG);\n }\n var seqLength = signature[offset++];\n if (seqLength === 0x81) {\n seqLength = signature[offset++];\n }\n if (seqLength > signature.length - offset) {\n throw new Error(ERR_MSG);\n }\n if (signature[offset++] !== 0x02) {\n throw new Error(ERR_MSG);\n }\n var rLength = signature[offset++];\n if (rLength > signature.length - offset - 2) {\n throw new Error(ERR_MSG);\n }\n if (rLength > size + 1) {\n throw new Error(ERR_MSG);\n }\n var rOffset = offset;\n offset += rLength;\n if (signature[offset++] !== 0x02) {\n throw new Error(ERR_MSG);\n }\n var sLength = signature[offset++];\n if (sLength !== signature.length - offset) {\n throw new Error(ERR_MSG);\n }\n if (sLength > size + 1) {\n throw new Error(ERR_MSG);\n }\n var sOffset = offset;\n offset += sLength;\n if (offset !== signature.length) {\n throw new Error(ERR_MSG);\n }\n var rPadding = size - rLength;\n var sPadding = size - sLength;\n var dst = Buffer.alloc(rPadding + rLength + sPadding + sLength);\n for (offset = 0; offset < rPadding; ++offset) {\n dst[offset] = 0;\n }\n var rPad = Math.max(-rPadding, 0);\n signature.copy(dst, offset, rOffset + rPad, rOffset + rLength);\n offset = size;\n for (var o = offset; offset < o + sPadding; ++offset) {\n dst[offset] = 0;\n }\n var sPad = Math.max(-sPadding, 0);\n signature.copy(dst, offset, sOffset + sPad, sOffset + sLength);\n return dst;\n}\n\nfunction countPadding(buf, start, stop) {\n var padding = 0;\n while (start + padding < stop && buf[start + padding] === 0) {\n ++padding;\n }\n var needsSign = buf[start + padding] >= 0x80;\n if (needsSign) {\n --padding;\n }\n return padding;\n}\n\nfunction concatToDer(signature, size) {\n var rPadding = countPadding(signature, 0, size);\n var sPadding = countPadding(signature, size, signature.length);\n var rLength = size - rPadding;\n var sLength = size - sPadding;\n var rsBytes = rLength + sLength + 4;\n var shortLength = rsBytes < 0x80;\n var dst = Buffer.alloc((shortLength ? 2 : 3) + rsBytes);\n var offset = 0;\n dst[offset++] = 0x30;\n if (shortLength) {\n dst[offset++] = rsBytes;\n } else {\n dst[offset++] = 0x81;\n dst[offset++] = rsBytes & 0xFF;\n }\n dst[offset++] = 0x02;\n dst[offset++] = rLength;\n if (rPadding < 0) {\n dst[offset++] = 0;\n offset += signature.copy(dst, offset, 0, size);\n } else {\n offset += signature.copy(dst, offset, rPadding, size);\n }\n dst[offset++] = 0x02;\n dst[offset++] = sLength;\n if (sPadding < 0) {\n dst[offset++] = 0;\n signature.copy(dst, offset, size);\n } else {\n signature.copy(dst, offset, size + sPadding);\n }\n return dst;\n}\n\nmodule.exports = {\n convertToForge: convertToForge,\n convertToJWK: convertToJWK,\n convertToObj: convertToObj,\n convertToBuffer: convertToBuffer,\n curveSize: curveSize,\n derToConcat: derToConcat,\n concatToDer: concatToDer,\n convertToPEM: convertToPEM,\n EC_OID: EC_OID\n};\n","/*!\n * algorithms/ecdh.js - Elliptic Curve Diffie-Hellman algorithms\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar merge = require(\"../util/merge\"),\n util = require(\"../util\"),\n ecUtil = require(\"./ec-util.js\"),\n hkdf = require(\"./hkdf.js\"),\n concat = require(\"./concat.js\"),\n aesKw = require(\"./aes-kw.js\"),\n helpers = require(\"./helpers.js\"),\n CONSTANTS = require(\"./constants.js\");\n\nvar clone = require(\"lodash/clone\");\nvar omit = require(\"lodash/omit\");\nvar pick = require(\"lodash/pick\");\n\nfunction idealHash(curve) {\n switch (curve) {\n case \"P-256\":\n return \"SHA-256\";\n case \"P-384\":\n return \"SHA-384\";\n case \"P-521\":\n return \"SHA-512\";\n default:\n throw new Error(\"unsupported curve: \" + curve);\n }\n}\n\n// ### Exported\nvar ecdh = module.exports = {};\n\n// ### Derivation algorithms\n// ### \"raw\" ECDH\nfunction ecdhDeriveFn() {\n var alg = {\n name: \"ECDH\"\n };\n\n var validatePublic = function(pk, form) {\n var pubKey = pk && ecUtil.convertToForge(pk, true);\n if (!pubKey || !pubKey.isValid()) {\n return Promise.reject(new Error(\"invalid EC public key\"));\n }\n\n switch (form) {\n case \"jwk\":\n pubKey = ecUtil.convertToJWK(pk, true);\n break;\n case \"buffer\":\n pubKey = ecUtil.convertToBuffer(pk, true);\n break;\n }\n return Promise.resolve(pubKey);\n }\n\n // ### fallback implementation -- uses ecc + forge\n var fallback = function(key, props) {\n props = props || {};\n var keyLen = props.length || 0;\n // assume {key} is privateKey\n // assume {props.public} is publicKey\n var privKey = ecUtil.convertToForge(key, false);\n\n var p = validatePublic(props.public, \"forge\");\n p = p.then(function(pubKey) {\n // {pubKey} is \"forge\"\n\n var secret = privKey.computeSecret(pubKey);\n if (keyLen) {\n // truncate to requested key length\n if (secret.length < keyLen) {\n return Promise.reject(new Error(\"key length too large: \" + keyLen));\n }\n secret = secret.slice(0, keyLen);\n }\n\n return secret;\n });\n return p;\n };\n\n // ### WebCryptoAPI implementation\n // TODO: cache CryptoKey sooner\n var webcrypto = function(key, props) {\n key = key || {};\n props = props || {};\n\n var keyLen = props.length || 0,\n algParams = merge(clone(alg), {\n namedCurve: key.crv\n });\n\n // assume {key} is privateKey\n if (!keyLen) {\n // calculate key length from private key size\n keyLen = key.d.length;\n }\n var privKey = ecUtil.convertToJWK(key, false);\n privKey = helpers.subtleCrypto.importKey(\"jwk\",\n privKey,\n algParams,\n false,\n [ \"deriveBits\" ]);\n\n // assume {props.public} is publicKey\n var pubKey = validatePublic(props.public, \"jwk\");\n pubKey = pubKey.then(function(pubKey) {\n // {pubKey} is \"jwk\"\n return helpers.subtleCrypto.importKey(\"jwk\",\n pubKey,\n algParams,\n false,\n []);\n });\n\n var p = Promise.all([privKey, pubKey]);\n p = p.then(function(keypair) {\n var privKey = keypair[0],\n pubKey = keypair[1];\n\n var algParams = merge(clone(alg), {\n public: pubKey\n });\n return helpers.subtleCrypto.deriveBits(algParams, privKey, keyLen * 8);\n });\n p = p.then(function(result) {\n result = Buffer.from(result);\n return result;\n });\n return p;\n };\n\n var nodejs = function(key, props) {\n if (\"function\" !== typeof helpers.nodeCrypto.createECDH) {\n throw new Error(\"unsupported algorithm: ECDH\");\n }\n\n props = props || {};\n var keyLen = props.length || 0;\n var curve;\n switch (key.crv) {\n case \"P-256\":\n curve = \"prime256v1\";\n break;\n case \"P-384\":\n curve = \"secp384r1\";\n break;\n case \"P-521\":\n curve = \"secp521r1\";\n break;\n default:\n return Promise.reject(new Error(\"invalid curve: \" + curve));\n }\n\n // assume {key} is privateKey\n // assume {props.public} is publicKey\n var privKey = ecUtil.convertToBuffer(key, false);\n\n var p = validatePublic(props.public, \"buffer\");\n p = p.then(function(pubKey) {\n // {pubKey} is \"buffer\"\n var ecdh = helpers.nodeCrypto.createECDH(curve);\n // dummy call so computeSecret doesn't fail\n // ecdh.generateKeys();\n ecdh.setPrivateKey(privKey);\n var secret = ecdh.computeSecret(pubKey);\n if (keyLen) {\n if (secret.length < keyLen) {\n return Promise.reject(new Error(\"key length too large: \" + keyLen));\n }\n secret = secret.slice(0, keyLen);\n }\n return secret;\n });\n return p;\n };\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction ecdhConcatDeriveFn() {\n // NOTE: no nodejs/webcrypto/fallback model, since this algorithm is\n // implemented using other primitives\n\n var fn = function(key, props) {\n props = props || {};\n\n var hash;\n try {\n hash = props.hash || idealHash(key.crv);\n if (!hash) {\n throw new Error(\"invalid hash: \" + hash);\n }\n hash.toUpperCase();\n } catch (ex) {\n return Promise.reject(ex);\n }\n\n var params = [\"public\"];\n // derive shared secret\n // NOTE: whitelist items from {props} for ECDH\n var promise = ecdh.ECDH.derive(key, pick(props, params));\n // expand\n promise = promise.then(function(shared) {\n // NOTE: blacklist items from {props} for ECDH\n return concat[\"CONCAT-\" + hash].derive(shared, omit(props, params));\n });\n return promise;\n };\n\n return fn;\n}\n\nfunction ecdhHkdfDeriveFn() {\n // NOTE: no nodejs/webcrypto/fallback model, since this algorithm is\n // implemented using other primitives\n\n var fn = function(key, props) {\n props = props || {};\n\n var hash;\n try {\n hash = props.hash || idealHash(key.crv);\n if (!hash) {\n throw new Error(\"invalid hash: \" + hash);\n }\n hash.toUpperCase();\n } catch (ex) {\n return Promise.reject(ex);\n }\n\n var params = [\"public\"];\n // derive shared secret\n // NOTE: whitelist items from {props} for ECDH\n var promise = ecdh.ECDH.derive(key, pick(props, params));\n // extract-and-expand\n promise = promise.then(function(shared) {\n // NOTE: blacklist items from {props} for ECDH\n return hkdf[\"HKDF-\" + hash].derive(shared, omit(props, params));\n });\n return promise;\n };\n\n return fn;\n}\n\n// ### Wrap/Unwrap algorithms\nfunction doEcdhesCommonDerive(privKey, pubKey, props) {\n function prependLen(input) {\n return Buffer.concat([\n helpers.int32ToBuffer(input.length),\n input\n ]);\n }\n\n var algId = props.algorithm || \"\",\n keyLen = CONSTANTS.KEYLENGTH[algId],\n apu = util.asBuffer(props.apu || \"\", \"base64url\"),\n apv = util.asBuffer(props.apv || \"\", \"base64url\");\n var otherInfo = Buffer.concat([\n prependLen(Buffer.from(algId, \"utf8\")),\n prependLen(apu),\n prependLen(apv),\n helpers.int32ToBuffer(keyLen)\n ]);\n\n var params = {\n public: pubKey,\n length: keyLen / 8,\n hash: \"SHA-256\",\n otherInfo: otherInfo\n };\n return ecdh[\"ECDH-CONCAT\"].derive(privKey, params);\n}\n\nfunction ecdhesDirEncryptFn() {\n // NOTE: no nodejs/webcrypto/fallback model, since this algorithm is\n // implemented using other primitives\n var fn = function(key, pdata, props) {\n props = props || {};\n\n // {props.epk} is private\n if (!props.epk || !props.epk.d) {\n return Promise.reject(new Error(\"missing ephemeral private key\"));\n }\n var epk = ecUtil.convertToObj(props.epk, false);\n\n // {key} is public\n if (!key || !key.x || !key.y) {\n return Promise.reject(new Error(\"missing static public key\"));\n }\n var spk = ecUtil.convertToObj(key, true);\n\n // derive ECDH shared\n var promise = doEcdhesCommonDerive(epk, spk, {\n algorithm: props.enc,\n apu: props.apu,\n apv: props.apv\n });\n promise = promise.then(function(shared) {\n return {\n data: shared,\n once: true,\n direct: true\n };\n });\n return promise;\n };\n\n return fn;\n}\nfunction ecdhesDirDecryptFn() {\n // NOTE: no nodejs/webcrypto/fallback model, since this algorithm is\n // implemented using other primitives\n var fn = function(key, cdata, props) {\n props = props || {};\n\n // {props.epk} is public\n if (!props.epk || !props.epk.x || !props.epk.y) {\n return Promise.reject(new Error(\"missing ephemeral public key\"));\n }\n var epk = ecUtil.convertToObj(props.epk, true);\n\n // {key} is private\n if (!key || !key.d) {\n return Promise.reject(new Error(\"missing static private key\"));\n }\n var spk = ecUtil.convertToObj(key, false);\n\n // derive ECDH shared\n var promise = doEcdhesCommonDerive(spk, epk, {\n algorithm: props.enc,\n apu: props.apu,\n apv: props.apv\n });\n promise = promise.then(function(shared) {\n return shared;\n });\n return promise;\n };\n\n return fn;\n}\n\nfunction ecdhesKwEncryptFn(wrap) {\n // NOTE: no nodejs/webcrypto/fallback model, since this algorithm is\n // implemented using other primitives\n var fn = function(key, pdata, props) {\n props = props || {};\n\n // {props.epk} is private\n if (!props.epk || !props.epk.d) {\n return Promise.reject(new Error(\"missing ephemeral private key\"));\n }\n var epk = ecUtil.convertToObj(props.epk, false);\n\n // {key} is public\n if (!key || !key.x || !key.y) {\n return Promise.reject(new Error(\"missing static public key\"));\n }\n var spk = ecUtil.convertToObj(key, true);\n\n // derive ECDH shared\n var promise = doEcdhesCommonDerive(epk, spk, {\n algorithm: props.alg,\n apu: props.apu,\n apv: props.apv\n });\n promise = promise.then(function(shared) {\n // wrap provided key with ECDH shared\n return wrap(shared, pdata);\n });\n return promise;\n };\n\n return fn;\n}\n\nfunction ecdhesKwDecryptFn(unwrap) {\n // NOTE: no nodejs/webcrypto/fallback model, since this algorithm is\n // implemented using other primitives\n var fn = function(key, cdata, props) {\n props = props || {};\n\n // {props.epk} is public\n if (!props.epk || !props.epk.x || !props.epk.y) {\n return Promise.reject(new Error(\"missing ephemeral public key\"));\n }\n var epk = ecUtil.convertToObj(props.epk, true);\n\n // {key} is private\n if (!key || !key.d) {\n return Promise.reject(new Error(\"missing static private key\"));\n }\n var spk = ecUtil.convertToObj(key, false);\n\n // derive ECDH shared\n var promise = doEcdhesCommonDerive(spk, epk, {\n algorithm: props.alg,\n apu: props.apu,\n apv: props.apv\n });\n promise = promise.then(function(shared) {\n // unwrap provided key with ECDH shared\n return unwrap(shared, cdata);\n });\n return promise;\n };\n\n return fn;\n}\n\n// ### Public API\n// * [name].derive\n[\n \"ECDH\",\n \"ECDH-HKDF\",\n \"ECDH-CONCAT\"\n].forEach(function(name) {\n var kdf = /^ECDH(?:-(\\w+))?$/g.exec(name || \"\")[1];\n var op = ecdh[name] = ecdh[name] || {};\n switch (kdf || \"\") {\n case \"CONCAT\":\n op.derive = ecdhConcatDeriveFn();\n break;\n case \"HKDF\":\n op.derive = ecdhHkdfDeriveFn();\n break;\n case \"\":\n op.derive = ecdhDeriveFn();\n break;\n default:\n op.derive = null;\n }\n});\n\n// * [name].encrypt\n// * [name].decrypt\n[\n \"ECDH-ES\",\n \"ECDH-ES+A128KW\",\n \"ECDH-ES+A192KW\",\n \"ECDH-ES+A256KW\"\n].forEach(function(name) {\n var kw = /^ECDH-ES(?:\\+(.+))?/g.exec(name || \"\")[1];\n var op = ecdh[name] = ecdh[name] || {};\n if (!kw) {\n op.encrypt = ecdhesDirEncryptFn();\n op.decrypt = ecdhesDirDecryptFn();\n } else {\n kw = aesKw[kw];\n if (kw) {\n op.encrypt = ecdhesKwEncryptFn(kw.encrypt);\n op.decrypt = ecdhesKwDecryptFn(kw.decrypt);\n } else {\n op.ecrypt = op.decrypt = null;\n }\n }\n});\n//*/\n","/*!\n * algorithms/ecdsa.js - Elliptic Curve Digitial Signature Algorithms\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar ecUtil = require(\"./ec-util.js\"),\n helpers = require(\"./helpers.js\"),\n sha = require(\"./sha.js\");\n\nfunction idealCurve(hash) {\n switch (hash) {\n case \"SHA-256\":\n return \"P-256\";\n case \"SHA-384\":\n return \"P-384\";\n case \"SHA-512\":\n return \"P-521\";\n default:\n throw new Error(\"unsupported hash: \" + hash);\n }\n}\n\nfunction ecdsaSignFN(hash) {\n var curve = idealCurve(hash);\n\n // ### Fallback implementation -- uses forge\n var fallback = function(key, pdata /*, props */) {\n if (curve !== key.crv) {\n return Promise.reject(new Error(\"invalid curve\"));\n }\n var pk = ecUtil.convertToForge(key, false);\n\n var promise;\n // generate hash\n promise = sha[hash].digest(pdata);\n // sign hash\n promise = promise.then(function(result) {\n result = pk.sign(result);\n result = Buffer.concat([result.r, result.s]);\n return {\n data: pdata,\n mac: result\n };\n });\n return promise;\n };\n\n // ### WebCrypto API implementation\n var webcrypto = function(key, pdata /*, props */) {\n if (curve !== key.crv) {\n return Promise.reject(new Error(\"invalid curve\"));\n }\n var pk = ecUtil.convertToJWK(key, false);\n\n var promise;\n var alg = {\n name: \"ECDSA\",\n namedCurve: pk.crv,\n hash: {\n name: hash\n }\n };\n promise = helpers.subtleCrypto.importKey(\"jwk\",\n pk,\n alg,\n true,\n [ \"sign\" ]);\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.sign(alg, key, pdata);\n });\n promise = promise.then(function(result) {\n result = Buffer.from(result);\n return {\n data: pdata,\n mac: result\n };\n });\n return promise;\n };\n\n var nodejs;\n var nodeHash = hash.toLowerCase().replace(\"-\", \"\");\n if (helpers.nodeCrypto && helpers.nodeCrypto.getHashes().indexOf(nodeHash) > -1) {\n nodejs = function(key, pdata) {\n if (curve !== key.crv) {\n return Promise.reject(new Error(\"invalid curve\"));\n }\n\n var promise;\n promise = Promise.resolve(helpers.nodeCrypto.createSign(nodeHash));\n promise = promise.then(function (sign) {\n sign.update(pdata);\n return sign;\n });\n\n var size;\n\n switch (nodeHash.slice(-3)) {\n case \"384\":\n size = 48;\n break;\n case \"512\":\n size = 66;\n break;\n default:\n size = 32;\n }\n\n promise = promise.then(function (sign) {\n return ecUtil.derToConcat(sign.sign(ecUtil.convertToPEM(key, true)), size);\n });\n\n promise = promise.then(function (result) {\n return {\n data: pdata,\n mac: result\n };\n });\n\n return promise;\n };\n }\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction ecdsaVerifyFN(hash) {\n var curve = idealCurve(hash);\n\n // ### Fallback implementation -- uses forge\n var fallback = function(key, pdata, mac /*, props */) {\n if (curve !== key.crv) {\n return Promise.reject(new Error(\"invalid curve\"));\n }\n var pk = ecUtil.convertToForge(key, true);\n\n var promise;\n // generate hash\n promise = sha[hash].digest(pdata);\n // verify hash\n promise = promise.then(function(result) {\n var len = mac.length / 2;\n var rs = {\n r: mac.slice(0, len),\n s: mac.slice(len)\n };\n if (!pk.verify(result, rs)) {\n return Promise.reject(new Error(\"verification failed\"));\n }\n return {\n data: pdata,\n mac: mac,\n valid: true\n };\n });\n return promise;\n };\n\n // ### WebCrypto API implementation\n var webcrypto = function(key, pdata, mac /* , props */) {\n if (curve !== key.crv) {\n return Promise.reject(new Error(\"invalid curve\"));\n }\n var pk = ecUtil.convertToJWK(key, true);\n\n var promise;\n var alg = {\n name: \"ECDSA\",\n namedCurve: pk.crv,\n hash: {\n name: hash\n }\n };\n promise = helpers.subtleCrypto.importKey(\"jwk\",\n pk,\n alg,\n true,\n [\"verify\"]);\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.verify(alg, key, mac, pdata);\n });\n promise = promise.then(function(result) {\n if (!result) {\n return Promise.reject(new Error(\"verification failed\"));\n }\n return {\n data: pdata,\n mac: mac,\n valid: true\n };\n });\n return promise;\n };\n\n var nodejs;\n var nodeHash = hash.toLowerCase().replace(\"-\", \"\");\n if (helpers.nodeCrypto && helpers.nodeCrypto.getHashes().indexOf(nodeHash) > -1) {\n nodejs = function(key, pdata, mac /* , props */) {\n if (curve !== key.crv) {\n return Promise.reject(new Error(\"invalid curve\"));\n }\n\n var size;\n switch (nodeHash.slice(-3)) {\n case \"384\":\n size = 48;\n break;\n case \"512\":\n size = 66;\n break;\n default:\n size = 32;\n }\n\n var promise;\n promise = Promise.resolve(helpers.nodeCrypto.createVerify(nodeHash));\n promise = promise.then(function (verify) {\n verify.update(pdata);\n verify.end();\n return verify.verify(ecUtil.convertToPEM(key, false), ecUtil.concatToDer(mac, size));\n });\n promise = promise.then(function (result) {\n if (!result) {\n throw new Error(\"verification failed\");\n }\n return {\n data: pdata,\n mac: mac,\n valid: true\n };\n });\n\n return promise;\n };\n }\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\n// ### Public API\nvar ecdsa = {};\n\n// * [name].sign\n// * [name].verify\n[\n \"ES256\",\n \"ES384\",\n \"ES512\"\n].forEach(function(name) {\n var hash = name.replace(/ES(\\d+)/g, function(m, size) {\n return \"SHA-\" + size;\n });\n ecdsa[name] = {\n sign: ecdsaSignFN(hash),\n verify: ecdsaVerifyFN(hash)\n };\n});\n\nmodule.exports = ecdsa;\n","/*!\n * algorithms/helpers.js - Internal functions and fields used in Cryptographic\n * Algorithms\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nif (typeof Promise === \"undefined\") {\n require(\"es6-promise\").polyfill();\n}\n\n// ###\nexports.int32ToBuffer = function(v, b) {\n b = b || Buffer.alloc(4);\n b[0] = (v >>> 24) & 0xff;\n b[1] = (v >>> 16) & 0xff;\n b[2] = (v >>> 8) & 0xff;\n b[3] = v & 0xff;\n return b;\n};\n\nvar MAX_INT32 = Math.pow(2, 32);\nexports.int64ToBuffer = function(v, b) {\n b = b || Buffer.alloc(8);\n var hi = Math.floor(v / MAX_INT32),\n lo = v % MAX_INT32;\n hi = exports.int32ToBuffer(hi);\n lo = exports.int32ToBuffer(lo);\n b = Buffer.concat([hi, lo]);\n return b;\n};\n\n// ### crypto and DOMException in browsers ###\n/* global crypto:false, DOMException:false */\n\nfunction getCryptoSubtle() {\n if (\"undefined\" !== typeof crypto) {\n if (\"undefined\" !== typeof crypto.subtle) {\n return crypto.subtle;\n }\n }\n\n return undefined;\n}\nfunction getCryptoNodeJS() {\n var crypto;\n try {\n crypto = require(\"crypto\");\n } catch (err) {\n return undefined;\n }\n\n if (!Object.keys(crypto).length) {\n // treat empty the same as missing\n return undefined;\n }\n\n return crypto;\n}\n\nvar supported = {};\nObject.defineProperty(exports, \"subtleCrypto\", {\n get: function() {\n var result;\n\n if (\"subtleCrypto\" in supported) {\n result = supported.subtleCrypto;\n } else {\n result = supported.subtleCrypto = getCryptoSubtle();\n }\n\n return result;\n },\n enumerable: true\n});\nObject.defineProperty(exports, \"nodeCrypto\", {\n get: function() {\n var result;\n\n if (\"nodeCrypto\" in supported) {\n result = supported.nodeCrypto;\n } else {\n result = supported.nodeCrypto = getCryptoNodeJS();\n }\n\n return result;\n },\n enumerable: true\n});\n\nexports.setupFallback = function(nodejs, webcrypto, fallback) {\n var impl;\n\n if (nodejs && exports.nodeCrypto) {\n impl = function main() {\n var args = arguments,\n promise;\n\n function check(err) {\n if (0 === err.message.indexOf(\"unsupported algorithm:\")) {\n impl = fallback;\n return impl.apply(null, args);\n }\n\n return Promise.reject(err);\n }\n\n try {\n promise = Promise.resolve(nodejs.apply(null, args));\n } catch(err) {\n promise = check(err);\n }\n\n return promise;\n };\n } else if (webcrypto && exports.subtleCrypto) {\n impl = function main() {\n var args = arguments,\n promise;\n\n function check(err) {\n if (err.code === DOMException.NOT_SUPPORTED_ERR ||\n // Firefox rejects some operations erroneously complaining about inputs\n err.message === \"Only ArrayBuffer and ArrayBufferView objects can be passed as CryptoOperationData\" ||\n // MS Edge rejects with not an Error\n !(err instanceof Error)) {\n // not actually supported -- always use fallback\n impl = fallback;\n return impl.apply(null, args);\n }\n\n return Promise.reject(err);\n }\n\n try {\n promise = webcrypto.apply(null, args);\n promise = promise.catch(check);\n } catch(err) {\n promise = check(err);\n }\n\n return promise;\n };\n } else {\n impl = fallback;\n }\n\n return impl;\n};\n","/*!\n * algorithms/hkdf.js - HMAC-based Extract-and-Expand Key Derivation\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar CONSTANTS = require(\"./constants.js\"),\n hmac = require(\"./hmac.js\");\n\nfunction hkdfDeriveFn(name) {\n var hash = name.replace(\"HKDF-\", \"\"),\n op = name.replace(\"HKDF-SHA-\", \"HS\");\n\n // NOTE: no nodejs/webcrypto/fallback model, since this HKDF is\n // implemented using the HMAC algorithms\n\n var fn = function(key, props) {\n var hashLen = CONSTANTS.HASHLENGTH[hash] / 8;\n\n if (\"string\" === typeof op) {\n op = hmac[op].sign;\n }\n\n // prepare options\n props = props || {};\n var salt = props.salt;\n if (!salt || 0 === salt.length) {\n salt = Buffer.alloc(hashLen);\n }\n var info = props.info || Buffer.alloc(0);\n var keyLen = props.length || hashLen;\n\n var promise;\n\n // Setup Expansion\n var N = Math.ceil(keyLen / hashLen),\n okm = [],\n idx = 0;\n function expand(key, T) {\n if (N === idx++) {\n return Buffer.concat(okm).slice(0, keyLen);\n }\n\n if (!T) {\n T = Buffer.alloc(0);\n }\n T = Buffer.concat([T, info, Buffer.from([idx])]);\n T = op(key, T);\n T = T.then(function(result) {\n T = result.mac;\n okm.push(T);\n\n return expand(key, T);\n });\n return T;\n }\n\n // Step 1: Extract\n promise = op(salt, key, { length: salt.length * 8 });\n promise = promise.then(function(result) {\n // Step 2: Expand\n return expand(result.mac);\n });\n\n return promise;\n };\n\n return fn;\n}\n\n// Public API\n// * [name].derive\nvar hkdf = {};\n[\n \"HKDF-SHA-1\",\n \"HKDF-SHA-256\",\n \"HKDF-SHA-384\",\n \"HKDF-SHA-512\"\n].forEach(function(name) {\n hkdf[name] = {\n derive: hkdfDeriveFn(name)\n };\n});\n\nmodule.exports = hkdf;\n","/*!\n * algorithms/hmac.js - HMAC-based \"signatures\"\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar CONSTANTS = require(\"./constants\"),\n forge = require(\"../deps/forge.js\"),\n DataBuffer = require(\"../util/databuffer.js\"),\n helpers = require(\"./helpers.js\");\n\nfunction hmacSignFN(name) {\n var md = name.replace(\"HS\", \"SHA\").toLowerCase(),\n hash = name.replace(\"HS\", \"SHA-\");\n\n function checkKeyLength(len, key) {\n len = (len || CONSTANTS.HASHLENGTH[hash]) / 8;\n if (len > key.length) {\n return Promise.reject(new Error(\"invalid key length\"));\n }\n\n return Promise.resolve(key);\n }\n\n // ### Fallback Implementation -- uses forge\n var fallback = function(key, pdata, props) {\n props = props || {};\n var promise;\n promise = checkKeyLength(props.length, key);\n promise = promise.then(function() {\n var sig = forge.hmac.create();\n sig.start(md, key.toString(\"binary\"));\n sig.update(pdata.toString(\"binary\"));\n sig = Buffer.from(sig.digest().bytes(), \"binary\");\n\n return {\n data: pdata,\n mac: sig\n }\n });\n return promise;\n };\n\n // ### WebCryptoAPI Implementation\n var webcrypto = function(key, pdata, props) {\n props = props || {};\n\n var alg = {\n name: \"HMAC\",\n hash: {\n name: hash\n }\n };\n var promise;\n promise = checkKeyLength(props.length, key);\n promise = promise.then(function() {\n return helpers.subtleCrypto.importKey(\"raw\", key, alg, true, [\"sign\"]);\n });\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.sign(alg, key, pdata);\n });\n promise = promise.then(function(result) {\n var sig = Buffer.from(result);\n return {\n data: pdata,\n mac: sig\n };\n });\n\n return promise;\n };\n\n // ### NodeJS implementation\n var nodejs = function(key, pdata, props) {\n props = props || {};\n\n var promise;\n promise = checkKeyLength(props.length, key);\n promise = promise.then(function() {\n var hmac = helpers.nodeCrypto.createHmac(md, key);\n hmac.update(pdata);\n\n var sig = hmac.digest();\n return {\n data: pdata,\n mac: sig\n };\n });\n return promise;\n };\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction hmacVerifyFN(name) {\n var md = name.replace(\"HS\", \"SHA\").toLowerCase(),\n hash = name.replace(\"HS\", \"SHA-\");\n\n function compare(len, expected, actual) {\n len = (len || CONSTANTS.HASHLENGTH[hash]) / 8;\n var valid = true;\n for (var idx = 0; len > idx; idx++) {\n valid = valid && (expected[idx] === actual[idx]);\n }\n return valid;\n }\n\n // ### Fallback Implementation -- uses forge\n var fallback = function(key, pdata, mac, props) {\n props = props || {};\n\n var vrfy = forge.hmac.create();\n vrfy.start(md, new DataBuffer(key));\n vrfy.update(pdata.toString(\"binary\"));\n vrfy = Buffer.from(vrfy.digest().bytes(), \"binary\");\n\n if (compare(props.length, mac, vrfy)) {\n return Promise.resolve({\n data: pdata,\n mac: mac,\n valid: true\n });\n } else {\n return Promise.reject(new Error(\"verification failed\"));\n }\n };\n\n var webcrypto = function(key, pdata, mac, props) {\n props = props || {};\n\n var alg = {\n name: \"HMAC\",\n hash: {\n name: hash\n }\n };\n var promise;\n if (props.length) {\n promise = helpers.subtleCrypto.importKey(\"raw\", key, alg, true, [\"sign\"]);\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.sign(alg, key, pdata);\n });\n promise = promise.then(function(result) {\n var sig = Buffer.from(result);\n return compare(props.length, mac, sig);\n });\n } else {\n promise = helpers.subtleCrypto.importKey(\"raw\", key, alg, true, [\"verify\"]);\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.verify(alg, key, mac, pdata);\n });\n }\n promise = promise.then(function(result) {\n if (!result) {\n return Promise.reject(new Error(\"verifaction failed\"));\n }\n\n return {\n data: pdata,\n mac: mac,\n valid: true\n };\n });\n\n return promise;\n };\n\n var nodejs = function(key, pdata, mac, props) {\n props = props || {};\n\n var hmac = helpers.nodeCrypto.createHmac(md, key);\n hmac.update(pdata);\n\n var sig = hmac.digest();\n if (!compare(props.length, mac, sig)) {\n throw new Error(\"verification failed\");\n }\n return {\n data: pdata,\n mac: sig,\n valid: true\n };\n };\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\n// ### Public API\n// * [name].sign\n// * [name].verify\nvar hmac = {};\n[\n \"HS1\",\n \"HS256\",\n \"HS384\",\n \"HS512\"\n].forEach(function(alg) {\n hmac[alg] = {\n sign: hmacSignFN(alg),\n verify: hmacVerifyFN(alg)\n };\n});\n\nmodule.exports = hmac;\n","/*!\n * algorithms/index.js - Cryptographic Algorithms Entry Point\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\n// setup implementations\nvar implementations = [\n require(\"./aes-cbc-hmac-sha2.js\"),\n require(\"./aes-gcm.js\"),\n require(\"./aes-kw.js\"),\n require(\"./concat.js\"),\n require(\"./dir.js\"),\n require(\"./ecdh.js\"),\n require(\"./ecdsa.js\"),\n require(\"./hkdf.js\"),\n require(\"./hmac.js\"),\n require(\"./pbes2.js\"),\n require(\"./rsaes.js\"),\n require(\"./rsassa.js\"),\n require(\"./sha.js\")\n];\n\nvar ALGS_DIGEST = {};\nvar ALGS_DERIVE = {};\nvar ALGS_SIGN = {},\n ALGS_VRFY = {};\nvar ALGS_ENC = {},\n ALGS_DEC = {};\n\nimplementations.forEach(function(mod) {\n Object.keys(mod).forEach(function(alg) {\n var op = mod[alg];\n\n if (\"function\" === typeof op.encrypt) {\n ALGS_ENC[alg] = op.encrypt;\n }\n if (\"function\" === typeof op.decrypt) {\n ALGS_DEC[alg] = op.decrypt;\n }\n if (\"function\" === typeof op.sign) {\n ALGS_SIGN[alg] = op.sign;\n }\n if (\"function\" === typeof op.verify) {\n ALGS_VRFY[alg] = op.verify;\n }\n if (\"function\" === typeof op.digest) {\n ALGS_DIGEST[alg] = op.digest;\n }\n if (\"function\" === typeof op.derive) {\n ALGS_DERIVE[alg] = op.derive;\n }\n });\n});\n\n// public API\nexports.digest = function(alg, data, props) {\n var op = ALGS_DIGEST[alg];\n if (!op) {\n return Promise.reject(new Error(\"unsupported algorithm: \" + alg));\n }\n\n return op(data, props);\n};\n\nexports.derive = function(alg, key, props) {\n var op = ALGS_DERIVE[alg];\n if (!op) {\n return Promise.reject(new Error(\"unsupported algorithm: \" + alg));\n }\n\n return op(key, props);\n};\n\nexports.sign = function(alg, key, pdata, props) {\n var op = ALGS_SIGN[alg];\n if (!op) {\n return Promise.reject(new Error(\"unsupported algorithm: \" + alg));\n }\n\n return op(key, pdata, props || {});\n};\n\nexports.verify = function(alg, key, pdata, mac, props) {\n var op = ALGS_VRFY[alg];\n if (!op) {\n return Promise.reject(new Error(\"unsupported algorithm: \" + alg));\n }\n\n return op(key, pdata, mac, props || {});\n};\n\nexports.encrypt = function(alg, key, pdata, props) {\n var op = ALGS_ENC[alg];\n if (!op) {\n return Promise.reject(new Error(\"unsupported algorithm: \" + alg));\n }\n\n return op(key, pdata, props || {});\n};\n\nexports.decrypt = function(alg, key, cdata, props) {\n var op = ALGS_DEC[alg];\n if (!op) {\n return Promise.reject(new Error(\"unsupported algorithm: \" + alg));\n }\n\n return op(key, cdata, props || {});\n};\n","/*!\n * algorithms/pbes2.js - Password-Based Encryption (v2) Algorithms\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar forge = require(\"../deps/forge.js\"),\n merge = require(\"../util/merge.js\"),\n util = require(\"../util\"),\n helpers = require(\"./helpers.js\"),\n CONSTANTS = require(\"./constants.js\"),\n KW = require(\"./aes-kw.js\");\n\nvar NULL_BUFFER = Buffer.from([0]);\nvar DEFAULT_ITERATIONS = 8192;\nvar DEFAULT_SALT_LENGTH = 16;\n\nfunction fixSalt(hmac, kw, salt) {\n var alg = \"PBES2-\" + hmac + \"+\" + kw;\n var output = [\n Buffer.from(alg, \"utf8\"),\n NULL_BUFFER,\n salt\n ];\n return Buffer.concat(output);\n}\n\nfunction pbkdf2Fn(hash) {\n function prepareProps(props) {\n props = props || {};\n var keyLen = props.length || 0;\n var salt = util.asBuffer(props.salt || Buffer.alloc(0), \"base64u4l\"),\n itrs = props.iterations || 0;\n\n if (0 >= keyLen) {\n throw new Error(\"invalid key length\");\n }\n if (0 >= itrs) {\n throw new Error(\"invalid iteration count\");\n }\n\n props.length = keyLen;\n props.salt = salt;\n props.iterations = itrs;\n\n return props;\n }\n\n var fallback = function(key, props) {\n try {\n props = prepareProps(props);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var keyLen = props.length,\n salt = props.salt,\n itrs = props.iterations;\n\n var promise = new Promise(function(resolve, reject) {\n var md = forge.md[hash.replace(\"-\", \"\").toLowerCase()].create();\n var cb = function(err, dk) {\n if (err) {\n reject(err);\n } else {\n dk = Buffer.from(dk, \"binary\");\n resolve(dk);\n }\n };\n\n forge.pkcs5.pbkdf2(key.toString(\"binary\"),\n salt.toString(\"binary\"),\n itrs,\n keyLen,\n md,\n cb);\n });\n return promise;\n };\n var webcrypto = function(key, props) {\n try {\n props = prepareProps(props);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var keyLen = props.length,\n salt = props.salt,\n itrs = props.iterations;\n\n var promise = Promise.resolve(key);\n promise = promise.then(function(keyval) {\n return helpers.subtleCrypto.importKey(\"raw\", keyval, \"PBKDF2\", false, [\"deriveBits\"]);\n });\n promise = promise.then(function(key) {\n var mainAlgo = {\n name: \"PBKDF2\",\n salt: new Uint8Array(salt),\n iterations: itrs,\n hash: hash\n };\n\n return helpers.subtleCrypto.deriveBits(mainAlgo, key, keyLen * 8);\n });\n promise = promise.then(function(result) {\n return util.asBuffer(result);\n });\n return promise;\n };\n var nodejs = function(key, props) {\n if (6 > helpers.nodeCrypto.pbkdf2.length) {\n throw new Error(\"unsupported algorithm: PBKDF2-\" + hash);\n }\n\n try {\n props = prepareProps(props);\n } catch (err) {\n return Promise.reject(err);\n }\n\n var keyLen = props.length,\n salt = props.salt,\n itrs = props.iterations;\n\n var md = hash.replace(\"-\", \"\");\n var promise = new Promise(function(resolve, reject) {\n function cb(err, dk) {\n if (err) {\n reject(err);\n } else {\n resolve(dk);\n }\n }\n helpers.nodeCrypto.pbkdf2(key, salt, itrs, keyLen, md, cb);\n });\n return promise;\n };\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction pbes2EncryptFN(hmac, kw) {\n var deriveAlg = \"PBKDF2-\" + hmac.replace(\"HS\", \"SHA-\");\n var keyLen = CONSTANTS.KEYLENGTH[kw] / 8;\n\n return function(key, pdata, props) {\n props = props || {};\n\n var salt = util.asBuffer(props.p2s || Buffer.alloc(0), \"base64url\"),\n itrs = props.p2c || DEFAULT_ITERATIONS;\n\n if (0 >= itrs) {\n throw new Error(\"invalid iteration count\");\n }\n if (0 === salt.length) {\n salt = util.randomBytes(DEFAULT_SALT_LENGTH);\n } else if (8 > salt.length) {\n throw new Error(\"salt too small\");\n }\n var header = {\n p2s: util.base64url.encode(salt),\n p2c: itrs\n };\n salt = fixSalt(hmac, kw, salt);\n props = merge(props, {\n salt: salt,\n iterations: itrs,\n length: keyLen\n });\n\n var promise = Promise.resolve(key);\n // STEP 1: derive shared key\n promise = promise.then(function (key) {\n return pbes2[deriveAlg].derive(key, props);\n });\n // STEP 2: encrypt cek\n promise = promise.then(function (dk) {\n return KW[kw].encrypt(dk, pdata);\n });\n // STEP 3: (re-)apply headers\n promise = promise.then(function (results) {\n results.header = merge(results.header || {}, header);\n return results;\n });\n\n return promise;\n };\n}\n\nfunction pbes2DecryptFN(hmac, kw) {\n var deriveAlg = \"PBKDF2-\" + hmac.replace(\"HS\", \"SHA-\");\n var keyLen = CONSTANTS.KEYLENGTH[kw] / 8;\n\n return function(key, cdata, props) {\n props = props || {};\n\n var salt = util.asBuffer(props.p2s || Buffer.alloc(0), \"base64url\"),\n itrs = props.p2c || 0;\n\n if (0 >= itrs) {\n return Promise.reject(new Error(\"invalid iteration count\"));\n }\n\n if (8 > salt.length) {\n return Promise.reject(new Error(\"salt too small\"));\n }\n salt = fixSalt(hmac, kw, salt);\n props = merge(props, {\n salt: salt,\n iterations: itrs,\n length: keyLen\n });\n\n var promise = Promise.resolve(key);\n\n // STEP 1: derived shared key\n promise = promise.then(function(key) {\n return pbes2[deriveAlg].derive(key, props);\n });\n // STEP 2: decrypt cek\n promise = promise.then(function(dk) {\n return KW[kw].decrypt(dk, cdata);\n });\n\n return promise;\n };\n}\n\n// ### Public API\nvar pbes2 = {};\n\n// * [name].derive\n[\n \"PBKDF2-SHA-256\",\n \"PBKDF2-SHA-384\",\n \"PBKDF2-SHA-512\"\n].forEach(function(alg) {\n var hash = alg.replace(\"PBKDF2-\", \"\");\n pbes2[alg] = {\n derive: pbkdf2Fn(hash)\n };\n});\n\n// [name].encrypt\n// [name].decrypt\n[\n \"PBES2-HS256+A128KW\",\n \"PBES2-HS384+A192KW\",\n \"PBES2-HS512+A256KW\"\n].forEach(function(alg) {\n var parts = /PBES2-(HS\\d+)\\+(A\\d+KW)/g.exec(alg);\n var hmac = parts[1],\n kw = parts[2];\n pbes2[alg] = {\n encrypt: pbes2EncryptFN(hmac, kw),\n decrypt: pbes2DecryptFN(hmac, kw)\n };\n});\n\nmodule.exports = pbes2;\n","/*!\n * algorithms/rsa-util.js - RSA Utility Functions\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar clone = require(\"lodash/clone\"),\n forge = require(\"../deps/forge.js\"),\n util = require(\"../util\");\n\n// ### RSA-specific Helpers\nfunction convertToForge(key, isPublic) {\n var parts = isPublic ?\n [\"n\", \"e\"] :\n [\"n\", \"e\", \"d\", \"p\", \"q\", \"dp\", \"dq\", \"qi\"];\n parts = parts.map(function(f) {\n return new forge.jsbn.BigInteger(key[f].toString(\"hex\"), 16);\n });\n\n var fn = isPublic ?\n forge.pki.rsa.setPublicKey :\n forge.pki.rsa.setPrivateKey;\n return fn.apply(forge.pki.rsa, parts);\n}\n\nfunction convertToJWK(key, isPublic) {\n var result = clone(key);\n var parts = isPublic ?\n [\"n\", \"e\"] :\n [\"n\", \"e\", \"d\", \"p\", \"q\", \"dp\", \"dq\", \"qi\"];\n parts.forEach(function(f) {\n result[f] = util.base64url.encode(result[f]);\n });\n\n // remove potentially troublesome properties\n delete result.key_ops;\n delete result.use;\n delete result.alg;\n\n if (isPublic) {\n delete result.d;\n delete result.p;\n delete result.q;\n delete result.dp;\n delete result.dq;\n delete result.qi;\n }\n\n return result;\n}\n\nfunction convertToPem(key, isPublic) {\n var cacheKey = isPublic ? \"__cachedPublicPem\" : \"__cachedPrivatePem\";\n if (key[cacheKey]) {\n return key[cacheKey];\n }\n\n var value;\n if (isPublic) {\n value = forge.pki.publicKeyToPem(convertToForge(key, isPublic));\n } else {\n value = forge.pki.privateKeyToPem(convertToForge(key, isPublic));\n }\n\n Object.defineProperty(key, cacheKey, { value: value });\n return value;\n}\n\nmodule.exports = {\n convertToForge: convertToForge,\n convertToJWK: convertToJWK,\n convertToPem: convertToPem\n};\n","/*!\n * algorithms/rsaes.js - RSA Signatures\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar forge = require(\"../deps/forge.js\"),\n helpers = require(\"./helpers.js\"),\n DataBuffer = require(\"../util/databuffer.js\"),\n rsaUtil = require(\"./rsa-util.js\");\n\nvar nodeSupport = {\n \"RSA-OAEP\": \"RSA_PKCS1_OAEP_PADDING\",\n RSA1_5: \"RSA_PKCS1_PADDING\"\n};\n\nfunction nodeSupportCheck(name) {\n return helpers.nodeCrypto && helpers.nodeCrypto.constants && Object.keys(nodeSupport).indexOf(name) !== -1;\n}\n\n// ### RSAES-PKCS1-v1_5\n\n// ### RSAES-OAEP\nfunction rsaesEncryptFn(name) {\n var alg = {\n name: name\n };\n\n if (\"RSA-OAEP-256\" === name) {\n alg.name = \"RSA-OAEP\";\n alg.hash = {\n name: \"SHA-256\"\n };\n } else if (\"RSA-OAEP\" === name) {\n alg.hash = {\n name: \"SHA-1\"\n };\n } else {\n alg.name = \"RSAES-PKCS1-v1_5\";\n }\n\n // ### Fallback Implementation -- uses forge\n var fallback = function(key, pdata) {\n // convert pdata to byte string\n pdata = new DataBuffer(pdata).bytes();\n\n // encrypt it\n var pki = rsaUtil.convertToForge(key, true),\n params = {};\n if (\"RSA-OAEP\" === alg.name) {\n params.md = alg.hash.name.toLowerCase().replace(/-/g, \"\");\n params.md = forge.md[params.md].create();\n }\n var cdata = pki.encrypt(pdata, alg.name.toUpperCase(), params);\n\n // convert cdata to Buffer\n cdata = new DataBuffer(cdata).native();\n\n return Promise.resolve({\n data: cdata\n });\n };\n\n // ### WebCryptoAPI Implementation\n var webcrypto;\n if (\"RSAES-PKCS1-v1_5\" !== alg.name) {\n webcrypto = function(key, pdata) {\n key = rsaUtil.convertToJWK(key, true);\n var promise;\n promise = helpers.subtleCrypto.importKey(\"jwk\", key, alg, true, [\"encrypt\"]);\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.encrypt(alg, key, pdata);\n });\n promise = promise.then(function(result) {\n var cdata = Buffer.from(result);\n return {\n data: cdata\n };\n });\n\n return promise;\n };\n } else {\n webcrypto = null;\n }\n\n var nodejs;\n if (nodeSupportCheck(name)) {\n nodejs = function (key, pdata) {\n key = rsaUtil.convertToPem(key, true);\n\n var cdata = helpers.nodeCrypto.publicEncrypt({\n key: key,\n padding: helpers.nodeCrypto.constants[nodeSupport[name]]\n }, pdata);\n\n return {\n data: cdata\n };\n };\n }\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction rsaesDecryptFn(name) {\n var alg = {\n name: name\n };\n\n if (\"RSA-OAEP-256\" === name) {\n alg.name = \"RSA-OAEP\";\n alg.hash = {\n name: \"SHA-256\"\n };\n } else if (\"RSA-OAEP\" === name) {\n alg.hash = {\n name: \"SHA-1\"\n };\n } else {\n alg.name = \"RSAES-PKCS1-v1_5\";\n }\n\n // ### Fallback Implementation -- uses forge\n var fallback = function(key, cdata) {\n // convert cdata to byte string\n cdata = new DataBuffer(cdata).bytes();\n\n // decrypt it\n var pki = rsaUtil.convertToForge(key, false),\n params = {};\n if (\"RSA-OAEP\" === alg.name) {\n params.md = alg.hash.name.toLowerCase().replace(/-/g, \"\");\n params.md = forge.md[params.md].create();\n }\n var pdata = pki.decrypt(cdata, alg.name.toUpperCase(), params);\n\n // convert pdata to Buffer\n pdata = new DataBuffer(pdata).native();\n\n return Promise.resolve(pdata);\n };\n\n // ### WebCryptoAPI Implementation\n var webcrypto;\n if (\"RSAES-PKCS1-v1_5\" !== alg.name) {\n webcrypto = function(key, pdata) {\n key = rsaUtil.convertToJWK(key, false);\n var promise;\n promise = helpers.subtleCrypto.importKey(\"jwk\", key, alg, true, [\"decrypt\"]);\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.decrypt(alg, key, pdata);\n });\n promise = promise.then(function(result) {\n var pdata = Buffer.from(result);\n return pdata;\n });\n\n return promise;\n };\n } else {\n webcrypto = null;\n }\n\n var nodejs;\n if (nodeSupportCheck(name)) { // node ^6.12.0 || >= 8.0.0\n nodejs = function(key, pdata) {\n key = rsaUtil.convertToPem(key, false);\n return helpers.nodeCrypto.privateDecrypt({\n key: key,\n padding: helpers.nodeCrypto.constants[nodeSupport[name]]\n }, pdata);\n };\n } else if (helpers.nodeCrypto && name === \"RSA-OAEP\") { // node (>= 6.0.0 && < 6.12.0) || ^7.0.0\n nodejs = function(key, pdata) {\n key = rsaUtil.convertToPem(key, false);\n return helpers.nodeCrypto.privateDecrypt(key, pdata);\n };\n }\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\n// ### Public API\n// * [name].encrypt\n// * [name].decrypt\nvar rsaes = {};\n[\n \"RSA-OAEP\",\n \"RSA-OAEP-256\",\n \"RSA1_5\"\n].forEach(function(name) {\n rsaes[name] = {\n encrypt: rsaesEncryptFn(name),\n decrypt: rsaesDecryptFn(name)\n };\n});\n\nmodule.exports = rsaes;\n","/*!\n * algorithms/rsassa.js - RSA Signatures\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar forge = require(\"../deps/forge.js\"),\n CONSTANTS = require(\"./constants\"),\n helpers = require(\"./helpers.js\"),\n rsaUtil = require(\"./rsa-util.js\");\n\nfunction nodePSSsupport() {\n return helpers.nodeCrypto && helpers.nodeCrypto.constants && helpers.nodeCrypto.constants.RSA_PSS_SALTLEN_DIGEST;\n}\n\n// ### RSASSA-PKCS1-v1_5\n\nfunction rsassaV15SignFn(name) {\n var md = name.replace(\"RS\", \"SHA\").toLowerCase(),\n hash = name.replace(\"RS\", \"SHA-\");\n\n var alg = {\n name: \"RSASSA-PKCS1-V1_5\",\n hash: {\n name: hash\n }\n };\n\n // ### Fallback Implementation -- uses forge\n var fallback = function(key, pdata) {\n // create the digest\n var digest = forge.md[md].create();\n digest.start();\n digest.update(pdata);\n\n // sign it\n var pki = rsaUtil.convertToForge(key, false);\n var sig = pki.sign(digest, \"RSASSA-PKCS1-V1_5\");\n sig = Buffer.from(sig, \"binary\");\n\n return Promise.resolve({\n data: pdata,\n mac: sig\n });\n };\n\n // ### WebCryptoAPI Implementation\n var webcrypto = function(key, pdata) {\n key = rsaUtil.convertToJWK(key, false);\n var promise;\n promise = helpers.subtleCrypto.importKey(\"jwk\", key, alg, true, [\"sign\"]);\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.sign(alg, key, pdata);\n });\n promise = promise.then(function(result) {\n var sig = Buffer.from(result);\n return {\n data: pdata,\n mac: sig\n };\n });\n\n return promise;\n };\n\n var nodejs;\n var nodeHash = \"RSA-\" + hash.replace(\"-\", \"\");\n if (helpers.nodeCrypto && helpers.nodeCrypto.getHashes().indexOf(nodeHash) > -1) {\n nodejs = function(key, pdata) {\n var sign = helpers.nodeCrypto.createSign(nodeHash);\n sign.update(pdata);\n\n return {\n data: pdata,\n mac: sign.sign(rsaUtil.convertToPem(key, false))\n };\n };\n }\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction rsassaV15VerifyFn(name) {\n var md = name.replace(\"RS\", \"SHA\").toLowerCase(),\n hash = name.replace(\"RS\", \"SHA-\");\n var alg = {\n name: \"RSASSA-PKCS1-V1_5\",\n hash: {\n name: hash\n }\n };\n\n // ### Fallback implementation -- uses forge\n var fallback = function(key, pdata, mac) {\n // create the digest\n var digest = forge.md[md].create();\n digest.start();\n digest.update(pdata);\n digest = digest.digest().bytes();\n\n // verify it\n var pki = rsaUtil.convertToForge(key, true);\n var sig = mac.toString(\"binary\");\n var result = pki.verify(digest, sig, \"RSASSA-PKCS1-V1_5\");\n if (!result) {\n return Promise.reject(new Error(\"verification failed\"));\n }\n return Promise.resolve({\n data: pdata,\n mac: mac,\n valid: true\n });\n };\n\n // ### WebCryptoAPI Implementation\n var webcrypto = function(key, pdata, mac) {\n key = rsaUtil.convertToJWK(key, true);\n var promise;\n promise = helpers.subtleCrypto.importKey(\"jwk\", key, alg, true, [\"verify\"]);\n promise = promise.then(function(key) {\n return helpers.subtleCrypto.verify(alg, key, mac, pdata);\n });\n promise = promise.then(function(result) {\n if (!result) {\n return Promise.reject(new Error(\"verification failed\"));\n }\n\n return {\n data: pdata,\n mac: mac,\n valid: true\n };\n });\n\n return promise;\n };\n\n var nodejs;\n if (helpers.nodeCrypto && helpers.nodeCrypto.getHashes().indexOf(md) > -1) {\n nodejs = function(key, pdata, mac) {\n var verify = helpers.nodeCrypto.createVerify(md);\n verify.update(pdata);\n verify.end();\n var result = verify.verify(rsaUtil.convertToPem(key, true), mac);\n if (!result) {\n return Promise.reject(new Error(\"verification failed\"));\n }\n\n return {\n data: pdata,\n mac: mac,\n valid: true\n };\n };\n }\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\n// ### RSA-PSS\nfunction rsassaPssSignFn(name) {\n var md = name.replace(\"PS\", \"SHA\").toLowerCase(),\n hash = name.replace(\"PS\", \"SHA-\");\n\n var alg = {\n name: \"RSA-PSS\",\n hash: {\n name: hash\n },\n saltLength: CONSTANTS.HASHLENGTH[hash] / 8\n };\n\n // ### Fallback implementation -- uses forge\n var fallback = function (key, pdata) {\n // create the digest\n var digest = forge.md[md].create();\n digest.start();\n digest.update(pdata);\n\n // setup padding\n var pss = forge.pss.create({\n md: forge.md[md].create(),\n mgf: forge.mgf.mgf1.create(forge.md[md].create()),\n saltLength: CONSTANTS.HASHLENGTH[hash] / 8\n });\n\n // sign it\n var pki = rsaUtil.convertToForge(key, false);\n var sig = pki.sign(digest, pss);\n sig = Buffer.from(sig, \"binary\");\n\n return Promise.resolve({\n data: pdata,\n mac: sig\n });\n };\n\n // ### WebCryptoAPI Implementation\n var webcrypto = function(key, pdata) {\n key = rsaUtil.convertToJWK(key, false);\n var promise;\n promise = helpers.subtleCrypto.importKey(\"jwk\", key, alg, true, [\"sign\"]);\n promise = promise.then(function (key) {\n return helpers.subtleCrypto.sign(alg, key, pdata);\n });\n promise = promise.then(function (result) {\n var sig = Buffer.from(result);\n return {\n data: pdata,\n mac: sig\n };\n });\n\n return promise;\n };\n\n var nodejs;\n var nodeHash = \"RSA-\" + hash.replace(\"-\", \"\");\n if (nodePSSsupport()) {\n nodejs = function(key, pdata) {\n var sign = helpers.nodeCrypto.createSign(nodeHash);\n sign.update(pdata);\n\n var sig = sign.sign({\n key: rsaUtil.convertToPem(key, false),\n padding: helpers.nodeCrypto.constants.RSA_PKCS1_PSS_PADDING,\n saltLength: helpers.nodeCrypto.constants.RSA_PSS_SALTLEN_DIGEST\n });\n\n return {\n data: pdata,\n mac: sig\n };\n };\n }\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\nfunction rsassaPssVerifyFn(name) {\n var md = name.replace(\"PS\", \"SHA\").toLowerCase(),\n hash = name.replace(\"PS\", \"SHA-\");\n\n var alg = {\n name: \"RSA-PSS\",\n hash: {\n name: hash\n },\n saltLength: CONSTANTS.HASHLENGTH[hash] / 8\n };\n\n // ### Fallback implementation -- uses forge\n var fallback = function (key, pdata, mac) {\n // create the digest\n var digest = forge.md[md].create();\n digest.start();\n digest.update(pdata);\n digest = digest.digest().bytes();\n\n // setup padding\n var pss = forge.pss.create({\n md: forge.md[md].create(),\n mgf: forge.mgf.mgf1.create(forge.md[md].create()),\n saltLength: CONSTANTS.HASHLENGTH[hash] / 8\n });\n\n // verify it\n var pki = rsaUtil.convertToForge(key, true);\n var sig = mac.toString(\"binary\");\n var result = pki.verify(digest, sig, pss);\n if (!result) {\n return Promise.reject(new Error(\"verification failed\"));\n }\n return Promise.resolve({\n data: pdata,\n mac: mac,\n valid: true\n });\n };\n\n // ### WebCryptoAPI Implementation\n var webcrypto = function(key, pdata, mac) {\n key = rsaUtil.convertToJWK(key, true);\n var promise;\n promise = helpers.subtleCrypto.importKey(\"jwk\", key, alg, true, [\"verify\"]);\n promise = promise.then(function (key) {\n return helpers.subtleCrypto.verify(alg, key, mac, pdata);\n });\n promise = promise.then(function (result) {\n if (!result) {\n return Promise.reject(new Error(\"verification failed\"));\n }\n\n return {\n data: pdata,\n mac: mac,\n valid: true\n };\n });\n\n return promise;\n };\n\n var nodejs;\n if (nodePSSsupport()) {\n nodejs = function(key, pdata, mac) {\n var verify = helpers.nodeCrypto.createVerify(md);\n verify.update(pdata);\n verify.end();\n var result = verify.verify({\n key: rsaUtil.convertToPem(key, true),\n padding: helpers.nodeCrypto.constants.RSA_PKCS1_PSS_PADDING,\n saltLength: helpers.nodeCrypto.constants.RSA_PSS_SALTLEN_DIGEST\n }, mac);\n if (!result) {\n return Promise.reject(new Error(\"verification failed\"));\n }\n\n return {\n data: pdata,\n mac: mac,\n valid: true\n };\n };\n }\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\n// ### Public API\n// * [name].sign\n// * [name].verify\nvar rsassa = {};\n[\n \"PS256\",\n \"PS384\",\n \"PS512\"\n].forEach(function(name) {\n rsassa[name] = {\n sign: rsassaPssSignFn(name),\n verify: rsassaPssVerifyFn(name)\n };\n});\n\n[\n \"RS256\",\n \"RS384\",\n \"RS512\"\n].forEach(function(name) {\n rsassa[name] = {\n sign: rsassaV15SignFn(name),\n verify: rsassaV15VerifyFn(name)\n };\n});\n\nmodule.exports = rsassa;\n","/*!\n * algorithms/sha.js - Cryptographic Secure Hash Algorithms, versions 1 and 2\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar forge = require(\"../deps/forge.js\"),\n helpers = require(\"./helpers.js\");\n\nfunction hashDigestFN(hash) {\n var md = hash.replace(\"SHA-\", \"SHA\").toLowerCase();\n\n var alg = {\n name: hash\n };\n\n // ### Fallback Implementation -- uses forge\n var fallback = function(pdata /* props */) {\n var digest = forge.md[md].create();\n digest.update(pdata.toString(\"binary\"));\n digest = Buffer.from(digest.digest().bytes(), \"binary\");\n\n return Promise.resolve(digest);\n };\n\n // ### WebCryptoAPI Implementation\n var webcrypto = function(pdata /* props */) {\n var promise;\n promise = helpers.subtleCrypto.digest(alg, pdata);\n promise = promise.then(function(result) {\n result = Buffer.from(result);\n return result;\n });\n return promise;\n };\n\n // ### nodejs Implementation\n var nodejs = function(pdata /* props */) {\n var digest = helpers.nodeCrypto.createHash(md);\n digest.update(pdata);\n return digest.digest();\n };\n\n return helpers.setupFallback(nodejs, webcrypto, fallback);\n}\n\n// Public API\n// * [name].digest\nvar sha = {};\n[\n \"SHA-1\",\n \"SHA-256\",\n \"SHA-384\",\n \"SHA-512\"\n].forEach(function(name) {\n sha[name] = {\n digest: hashDigestFN(name)\n };\n});\n\nmodule.exports = sha;\n","/*!\n * deps/ciphermodes/gcm/helpers.js - AES-GCM Helper Functions\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar Long = require(\"long\"),\n fill = require(\"lodash/fill\"),\n pack = require(\"../pack.js\");\n\nvar E1 = 0xe1000000,\n E1B = 0xe1,\n E1L = new Long(E1 >> 8);\n\nfunction generateLookup() {\n var lookup = [];\n\n for (var c = 0; c < 256; ++c) {\n var v = 0;\n for (var i = 7; i >= 0; --i) {\n if ((c & (1 << i)) !== 0) {\n v ^= (E1 >>> (7 - i));\n }\n }\n lookup.push(v);\n }\n\n return lookup;\n}\n\nvar helpers = module.exports = {\n // ### Constants\n E1: E1,\n E1B: E1B,\n E1L: E1L,\n LOOKUP: generateLookup(),\n\n // ### Array Helpers\n arrayCopy: function(src, srcPos, dest, destPos, length) {\n // Start by checking for negatives since arrays in JS auto-expand\n if (srcPos < 0 || destPos < 0 || length < 0) {\n throw new TypeError(\"Invalid input.\");\n }\n\n if (dest instanceof Uint8Array) {\n // Check for overflow if dest is a typed-array\n if (destPos >= dest.length || (destPos + length) > dest.length) {\n throw new TypeError(\"Invalid input.\");\n }\n\n if (srcPos !== 0 || length < src.length) {\n if (src instanceof Uint8Array) {\n src = src.subarray(srcPos, srcPos + length);\n } else {\n src = src.slice(srcPos, srcPos + length);\n }\n }\n\n dest.set(src, destPos);\n } else {\n for (var i = 0; i < length; ++i) {\n dest[destPos + i] = src[srcPos + i];\n }\n }\n },\n arrayEqual: function(a1, a2) {\n a1 = a1 || [];\n a2 = a2 || [];\n\n var len = Math.min(a1.length, a2.length),\n result = (a1.length === a2.length);\n\n for (var idx = 0; idx < len; idx++) {\n result = result &&\n (\"undefined\" !== typeof a1[idx]) &&\n (\"undefined\" !== typeof a2[idx]) &&\n (a1[idx] === a2[idx]);\n }\n\n return result;\n },\n\n // ### Conversions\n asBytes: function(x, z) {\n switch (arguments.length) {\n case 1:\n z = Buffer.alloc(16);\n pack.intToBigEndian(x, z, 0);\n return z;\n case 2:\n pack.intToBigEndian(x, z, 0);\n break;\n default:\n throw new TypeError(\"Expected 1 or 2 arguments.\");\n }\n },\n asInts: function(x, z) {\n switch (arguments.length) {\n case 1:\n z = [];\n fill(z, 0, 0, 4);\n pack.bigEndianToInt(x, 0, z);\n return z;\n case 2:\n pack.bigEndianToInt(x, 0, z);\n break;\n default:\n throw new TypeError(\"Expected 1 or 2 arguments.\");\n }\n },\n oneAsInts: function() {\n var tmp = [];\n for (var c = 0; c < 4; ++c) {\n tmp.push(1 << 31);\n }\n return tmp;\n },\n\n // ## Bit-wise\n shiftRight: function(x, z) {\n var b, c;\n switch (arguments.length) {\n case 1:\n b = x[0];\n x[0] = b >>> 1;\n c = b << 31;\n b = x[1];\n x[1] = (b >>> 1) | c;\n c = b << 31;\n b = x[2];\n x[2] = (b >>> 1) | c;\n c = b << 31;\n b = x[3];\n x[3] = (b >>> 1) | c;\n return (b << 31) & 0xffffffff;\n case 2:\n b = x[0];\n z[0] = b >>> 1;\n c = b << 31;\n b = x[1];\n z[1] = (b >>> 1) | c;\n c = b << 31;\n b = x[2];\n z[2] = (b >>> 1) | c;\n c = b << 31;\n b = x[3];\n z[3] = (b >>> 1) | c;\n return (b << 31) & 0xffffffff;\n default:\n throw new TypeError(\"Expected 1 or 2 arguments.\");\n }\n },\n shiftRightN: function(x, n, z) {\n var nInv, b, c;\n switch (arguments.length) {\n case 2:\n b = x[0];\n nInv = 32 - n;\n x[0] = b >>> n;\n c = b << nInv;\n b = x[1];\n x[1] = (b >>> n) | c;\n c = b << nInv;\n b = x[2];\n x[2] = (b >>> n) | c;\n c = b << nInv;\n b = x[3];\n x[3] = (b >>> n) | c;\n return b << nInv;\n case 3:\n b = x[0];\n nInv = 32 - n;\n z[0] = b >>> n;\n c = b << nInv;\n b = x[1];\n z[1] = (b >>> n) | c;\n c = b << nInv;\n b = x[2];\n z[2] = (b >>> n) | c;\n c = b << nInv;\n b = x[3];\n z[3] = (b >>> n) | c;\n return b << nInv;\n default:\n throw new TypeError(\"Expected 2 or 3 arguments.\");\n }\n },\n xor: function(x, y, z) {\n switch (arguments.length) {\n case 2:\n x[0] ^= y[0];\n x[1] ^= y[1];\n x[2] ^= y[2];\n x[3] ^= y[3];\n break;\n case 3:\n z[0] = x[0] ^ y[0];\n z[1] = x[1] ^ y[1];\n z[2] = x[2] ^ y[2];\n z[3] = x[3] ^ y[3];\n break;\n default:\n throw new TypeError(\"Expected 2 or 3 arguments.\");\n }\n },\n\n multiply: function(x, y) {\n var r0 = x.slice();\n var r1 = [];\n\n for (var i = 0; i < 4; ++i) {\n var bits = y[i];\n for (var j = 31; j >= 0; --j) {\n if ((bits & (1 << j)) !== 0) {\n helpers.xor(r1, r0);\n }\n\n if (helpers.shiftRight(r0) !== 0) {\n r0[0] ^= helpers.E1;\n }\n }\n }\n\n helpers.arrayCopy(r1, 0, x, 0, 4);\n },\n multiplyP: function(x, y) {\n switch (arguments.length) {\n case 1:\n if (helpers.shiftRight(x) !== 0) {\n x[0] ^= helpers.E1;\n }\n break;\n case 2:\n if (helpers.shiftRight(x, y) !== 0) {\n y[0] ^= helpers.E1;\n }\n break;\n default:\n throw new TypeError(\"Expected 1 or 2 arguments.\");\n }\n },\n multiplyP8: function(x, y) {\n var c;\n switch (arguments.length) {\n case 1:\n c = helpers.shiftRightN(x, 8);\n x[0] ^= helpers.LOOKUP[c >>> 24];\n break;\n case 2:\n c = helpers.shiftRightN(x, 8, y);\n y[0] ^= helpers.LOOKUP[c >>> 24];\n break;\n default:\n throw new TypeError(\"Expected 1 or 2 arguments.\");\n }\n }\n};\n","/*!\n * deps/ciphermodes/gcm/index.js - AES-GCM implementation Entry Point\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n \"use strict\";\n\nvar Long = require(\"long\"),\n forge = require(\"../../../deps/forge.js\"),\n multipliers = require(\"./multipliers.js\"),\n helpers = require(\"./helpers.js\"),\n pack = require(\"../pack.js\"),\n DataBuffer = require(\"../../../util/databuffer.js\"),\n cipherHelpers = require(\"../helpers.js\");\n\nvar BLOCK_SIZE = 16;\n\n// ### GCM Mode\n// ### Constructor\nfunction Gcm(options) {\n options = options || {};\n\n this.name = \"GCM\";\n this.cipher = options.cipher;\n this.blockSize = this.blockSize || 16;\n}\n\n// ### exports\nmodule.exports = {\n createCipher: function(options) {\n var alg = new forge.aes.Algorithm(\"AES-GCM\", Gcm);\n alg.initialize({\n key: new DataBuffer(options.key)\n });\n alg.mode.start(options);\n\n return alg.mode;\n },\n createDecipher: function(options) {\n var alg = new forge.aes.Algorithm(\"AES-GCM\", Gcm);\n alg.initialize({\n key: new DataBuffer(options.key)\n });\n alg.mode._decrypt = true;\n alg.mode.start(options);\n\n return alg.mode;\n }\n};\n\n// ### Public API\nGcm.prototype.start = function(options) {\n this.tag = null;\n\n options = options || {};\n\n if (!(\"iv\" in options)) {\n throw new Error(\"Gcm needs ParametersWithIV or AEADParameters\");\n }\n this.nonce = options.iv;\n if (this.nonce == null || this.nonce.length < 1) {\n throw new Error(\"IV must be at least 1 byte\");\n }\n\n // TODO: variable tagLength?\n this.tagLength = 16;\n\n // TODO: validate tag\n if (\"tag\" in options) {\n this.tag = Buffer.from(options.tag);\n }\n\n var bufLength = !this._decrypt ?\n this.blockSize :\n (this.blockSize + this.tagLength);\n this.bufBlock = Buffer.alloc(bufLength);\n\n var multiplier = options.multiplier;\n if (multiplier == null) {\n multiplier = new (multipliers[\"8k\"])();\n }\n this.multiplier = multiplier;\n\n this.H = this.zeroBlock();\n cipherHelpers.encrypt(this.cipher, this.H, 0, this.H, 0);\n\n // GcmMultiplier tables don\"t change unless the key changes\n // (and are expensive to init)\n this.multiplier.init(this.H);\n this.exp = null;\n\n this.J0 = this.zeroBlock();\n\n if (this.nonce.length === 12) {\n this.nonce.copy(this.J0, 0, 0, this.nonce.length);\n this.J0[this.blockSize - 1] = 0x01;\n } else {\n this.gHASH(this.J0, this.nonce, this.nonce.length);\n var X = this.zeroBlock();\n pack.longToBigEndian(new Long(this.nonce.length).\n multiply(8), X, 8);\n this.gHASHBlock(this.J0, X);\n }\n\n this.S = this.zeroBlock();\n this.SAt = this.zeroBlock();\n this.SAtPre = this.zeroBlock();\n this.atBlock = this.zeroBlock();\n this.atBlockPos = 0;\n this.atLength = Long.ZERO;\n this.atLengthPre = Long.ZERO;\n this.counter = Buffer.from(this.J0);\n this.bufOff = 0;\n this.totalLength = Long.ZERO;\n\n if (\"additionalData\" in options) {\n this.processAADBytes(options.additionalData, 0, options.additionalData.length);\n }\n};\n\nGcm.prototype.update = function(inV, inOff, len, out, outOff) {\n var resultLen = 0;\n\n while (len > 0) {\n var inLen = Math.min(len, this.bufBlock.length - this.bufOff);\n inV.copy(this.bufBlock, this.bufOff, inOff, inOff + inLen);\n len -= inLen;\n inOff += inLen;\n this.bufOff += inLen;\n if (this.bufOff === this.bufBlock.length) {\n this.outputBlock(out, outOff + resultLen);\n resultLen += this.blockSize;\n }\n }\n\n return resultLen;\n};\nGcm.prototype.finish = function(out, outOff) {\n var resultLen = 0;\n\n if (this._decrypt) {\n // append tag\n resultLen += this.update(this.tag, 0, this.tag.length, out, outOff);\n }\n\n if (this.totalLength.isZero()) {\n this.initCipher();\n }\n\n var extra = this.bufOff;\n if (this._decrypt) {\n if (extra < this.tagLength) {\n throw new Error(\"data too short\");\n }\n extra -= this.tagLength;\n }\n\n if (extra > 0) {\n this.gCTRPartial(this.bufBlock, 0, extra, out, outOff + resultLen);\n resultLen += extra;\n }\n\n this.atLength = this.atLength.add(this.atBlockPos);\n\n // Final gHASH\n var X = this.zeroBlock();\n pack.longToBigEndian(this.atLength.multiply(8),\n X,\n 0);\n pack.longToBigEndian(this.totalLength.multiply(8),\n X,\n 8);\n\n this.gHASHBlock(this.S, X);\n\n // TODO Fix this if tagLength becomes configurable\n // T = MSBt(GCTRk(J0,S))\n var tag = Buffer.alloc(this.blockSize);\n cipherHelpers.encrypt(this.cipher, this.J0, 0, tag, 0);\n this.xor(tag, this.S);\n\n if (this._decrypt) {\n if (!helpers.arrayEqual(this.tag, tag)) {\n throw new Error(\"mac check in Gcm failed\");\n }\n } else {\n // We place into tag our calculated value for T\n this.tag = Buffer.alloc(this.tagLength);\n tag.copy(this.tag, 0, 0, this.tagLength);\n }\n\n return resultLen;\n};\n\n// ### \"Internal\" Helper Functions\nGcm.prototype.initCipher = function() {\n if (this.atLength.greaterThan(Long.ZERO)) {\n this.SAt.copy(this.SAtPre, 0, 0, this.blockSize);\n this.atLengthPre = this.atLength.add(Long.ZERO);\n }\n\n // Finish hash for partial AAD block\n if (this.atBlockPos > 0) {\n this.gHASHPartial(this.SAtPre, this.atBlock, 0, this.atBlockPos);\n this.atLengthPre = this.atLengthPre.add(this.atBlockPos);\n }\n\n if (this.atLengthPre.greaterThan(Long.ZERO)) {\n this.SAtPre.copy(this.S, 0, 0, this.blockSize);\n }\n};\n\nGcm.prototype.outputBlock = function(output, offset) {\n if (this.totalLength.isZero()) {\n this.initCipher();\n }\n this.gCTRBlock(this.bufBlock, output, offset);\n if (!this._decrypt) {\n this.bufOff = 0;\n } else {\n this.bufBlock.copy(this.bufBlock, 0, this.blockSize, this.blockSize + this.tagLength);\n this.bufOff = this.tagLength;\n }\n};\n\nGcm.prototype.processAADBytes = function(inV, inOff, len) {\n for (var i = 0; i < len; ++i) {\n this.atBlock[this.atBlockPos] = inV[inOff + i];\n if (++this.atBlockPos === this.blockSize) {\n // Hash each block as it fills\n this.gHASHBlock(this.SAt, this.atBlock);\n this.atBlockPos = 0;\n this.atLength = this.atLength.add(this.blockSize);\n }\n }\n};\n\nGcm.prototype.getNextCounterBlock = function() {\n for (var i = 15; i >= 12; --i) {\n var b = ((this.counter[i] + 1) & 0xff);\n this.counter[i] = b;\n\n if (b !== 0) {\n break;\n }\n }\n\n // encrypt counter\n var outb = Buffer.alloc(this.blockSize);\n cipherHelpers.encrypt(this.cipher, this.counter, 0, outb, 0);\n\n return outb;\n};\n\nGcm.prototype.gCTRBlock = function(block, out, outOff) {\n var tmp = this.getNextCounterBlock();\n\n this.xor(tmp, block);\n tmp.copy(out, outOff, 0, this.blockSize);\n\n this.gHASHBlock(this.S, !this._decrypt ? tmp : block);\n\n this.totalLength = this.totalLength.add(this.blockSize);\n};\nGcm.prototype.gCTRPartial = function(buf, off, len, out, outOff) {\n var tmp = this.getNextCounterBlock();\n\n this.xor(tmp, buf, off, len);\n tmp.copy(out, outOff, 0, len);\n\n this.gHASHPartial(this.S, !this._decrypt ? tmp : buf, 0, len);\n\n this.totalLength = this.totalLength.add(len);\n};\n\nGcm.prototype.gHASHBlock = function(Y, b) {\n this.xor(Y, b);\n this.multiplier.multiplyH(Y);\n};\nGcm.prototype.gHASHPartial = function(Y, b, off, len) {\n this.xor(Y, b, off, len);\n this.multiplier.multiplyH(Y);\n};\n\nGcm.prototype.xor = function(block, val, off, len) {\n switch (arguments.length) {\n case 2:\n for (var i = 15; i >= 0; --i) {\n block[i] ^= val[i];\n }\n break;\n case 4:\n while (len-- > 0) {\n block[len] ^= val[off + len];\n }\n break;\n default:\n throw new TypeError(\"Expected 2 or 4 arguments.\");\n }\n\n return block;\n};\n\nGcm.prototype.zeroBlock = function() {\n var block = Buffer.alloc(BLOCK_SIZE);\n return block;\n};\n","/*!\n * deps/ciphermodes/gcm/multipliers.js - AES-GCM Multipliers\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n \"use strict\";\n\nvar helpers = require(\"./helpers.js\"),\n pack = require(\"../pack.js\");\n\n\n// ### 8K Table Multiplier\nfunction Gcm8KMultiplier() {\n this.H = [];\n this.M = null;\n}\n\nGcm8KMultiplier.prototype.init = function(H) {\n var i, j, k;\n if (this.M == null) {\n // sc: I realize this UGLY...\n //M = new int[32][16][4];\n this.M = [];\n for (i = 0; i < 32; ++i) {\n this.M[i] = [];\n for (j = 0; j < 16; ++j) {\n this.M[i][j] = [];\n for (k = 0; k < 4; ++k) {\n this.M[i][j][k] = 0;\n }\n }\n }\n } else if (helpers.arrayEqual(this.H, H)) {\n return;\n }\n\n this.H = H.slice();\n\n // M[0][0] is ZEROES;\n // M[1][0] is ZEROES;\n helpers.asInts(H, this.M[1][8]);\n\n for (j = 4; j >= 1; j >>= 1) {\n helpers.multiplyP(this.M[1][j + j], this.M[1][j]);\n }\n helpers.multiplyP(this.M[1][1], this.M[0][8]);\n\n for (j = 4; j >= 1; j >>= 1) {\n helpers.multiplyP(this.M[0][j + j], this.M[0][j]);\n }\n\n i = 0;\n for (;;) {\n for (j = 2; j < 16; j += j) {\n for (k = 1; k < j; ++k) {\n helpers.xor(this.M[i][j], this.M[i][k], this.M[i][j + k]);\n }\n }\n\n if (++i === 32) {\n return;\n }\n\n if (i > 1) {\n // M[i][0] is ZEROES;\n for (j = 8; j > 0; j >>= 1) {\n helpers.multiplyP8(this.M[i - 2][j], this.M[i][j]);\n }\n }\n }\n};\nGcm8KMultiplier.prototype.multiplyH = function(x) {\n var z = [];\n for (var i = 15; i >= 0; --i) {\n var m = this.M[i + i][x[i] & 0x0f];\n z[0] ^= m[0];\n z[1] ^= m[1];\n z[2] ^= m[2];\n z[3] ^= m[3];\n m = this.M[i + i + 1][(x[i] & 0xf0) >>> 4];\n z[0] ^= m[0];\n z[1] ^= m[1];\n z[2] ^= m[2];\n z[3] ^= m[3];\n }\n\n pack.intToBigEndian(z, x, 0);\n};\n\n\nmodule.exports = {\n \"8k\": Gcm8KMultiplier\n};\n","/*!\n * deps/ciphermodes/helpers.js - Cipher Helper Functions\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar pack = require(\"./pack.js\");\n\nfunction doEncrypt(cipher, inb, inOff, outb, outOff) {\n var input = new Array(4),\n output = new Array(4);\n\n pack.bigEndianToInt(inb, inOff, input);\n cipher.encrypt(input, output);\n pack.intToBigEndian(output, outb, outOff);\n}\n\nmodule.exports = {\n encrypt: doEncrypt\n};\n","/*!\n * deps/ciphermodes/pack.js - Pack/Unpack Functions\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar Long = require(\"long\");\n\nvar pack = module.exports = {\n intToBigEndian: function(n, bs, off) {\n if (typeof n === \"number\") {\n switch (arguments.length) {\n case 1:\n bs = Buffer.alloc(4);\n pack.intToBigEndian(n, bs, 0);\n break;\n case 3:\n bs[off] = 0xff & (n >>> 24);\n bs[++off] = 0xff & (n >>> 16);\n bs[++off] = 0xff & (n >>> 8);\n bs[++off] = 0xff & (n);\n break;\n default:\n throw new TypeError(\"Expected 1 or 3 arguments.\");\n }\n } else {\n switch (arguments.length) {\n case 1:\n bs = Buffer.alloc(4 * n.length);\n pack.intToBigEndian(n, bs, 0);\n break;\n case 3:\n for (var i = 0; i < n.length; ++i) {\n pack.intToBigEndian(n[i], bs, off);\n off += 4;\n }\n break;\n default:\n throw new TypeError(\"Expected 1 or 3 arguments.\");\n }\n }\n\n return bs;\n },\n longToBigEndian: function(n, bs, off) {\n if (!Array.isArray(n)) {\n // Single\n switch (arguments.length) {\n case 1:\n bs = Buffer.alloc(8);\n pack.longToBigEndian(n, bs, 0);\n break;\n case 3:\n var lo = n.low,\n hi = n.high;\n pack.intToBigEndian(hi, bs, off);\n pack.intToBigEndian(lo, bs, off + 4);\n break;\n default:\n throw new TypeError(\"Expected 1 or 3 arguments.\");\n }\n } else {\n // Array\n switch (arguments.length) {\n case 1:\n bs = Buffer.alloc(8 * n.length);\n pack.longToBigEndian(n, bs, 0);\n break;\n case 3:\n for (var i = 0; i < n.length; ++i) {\n pack.longToBigEndian(n[i], bs, off);\n off += 8;\n }\n break;\n default:\n throw new TypeError(\"Expected 1 or 3 arguments.\");\n }\n }\n\n return bs;\n },\n\n bigEndianToInt: function(bs, off, ns) {\n switch (arguments.length) {\n case 2:\n var n = bs[off] << 24;\n n |= (bs[++off] & 0xff) << 16;\n n |= (bs[++off] & 0xff) << 8;\n n |= (bs[++off] & 0xff);\n return n;\n case 3:\n for (var i = 0; i < ns.length; ++i) {\n ns[i] = pack.bigEndianToInt(bs, off);\n off += 4;\n }\n break;\n default:\n throw new TypeError(\"Expected 2 or 3 arguments.\");\n }\n },\n bigEndianToLong: function(bs, off, ns) {\n switch (arguments.length) {\n case 2:\n var hi = pack.bigEndianToInt(bs, off);\n var lo = pack.bigEndianToInt(bs, off + 4);\n var num = new Long(lo, hi);\n return num;\n case 3:\n for (var i = 0; i < ns.length; ++i) {\n ns[i] = pack.bigEndianToLong(bs, off);\n off += 8;\n }\n break;\n default:\n throw new TypeError(\"Expected 2 or 3 arguments.\");\n }\n }\n};\n","/**\n * deps/ecc/curves.js - Elliptic Curve NIST/SECG/X9.62 Parameters\n * Original Copyright (c) 2003-2005 Tom Wu.\n * Modifications Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n *\n * Ported from Tom Wu, which is ported from BouncyCastle\n * Modified to reuse existing external NPM modules, restricted to the\n * NIST//SECG/X9.62 prime curves only, and formatted to match project\n * coding styles.\n */\n\"use strict\";\n\n// Named EC curves\n\nvar BigInteger = require(\"../../deps/forge\").jsbn.BigInteger,\n ec = require(\"./math.js\");\n\n// ----------------\n// X9ECParameters\n\n// constructor\nfunction X9ECParameters(curve, g, n, h) {\n this.curve = curve;\n this.g = g;\n this.n = n;\n this.h = h;\n}\n\nfunction x9getCurve() {\n return this.curve;\n}\n\nfunction x9getG() {\n return this.g;\n}\n\nfunction x9getN() {\n return this.n;\n}\n\nfunction x9getH() {\n return this.h;\n}\n\nX9ECParameters.prototype.getCurve = x9getCurve;\nX9ECParameters.prototype.getG = x9getG;\nX9ECParameters.prototype.getN = x9getN;\nX9ECParameters.prototype.getH = x9getH;\n\n// ----------------\n// SECNamedCurves\n\nfunction fromHex(s) { return new BigInteger(s, 16); }\n\nfunction secp256r1() {\n // p = 2^224 (2^32 - 1) + 2^192 + 2^96 - 1\n var p = fromHex(\"FFFFFFFF00000001000000000000000000000000FFFFFFFFFFFFFFFFFFFFFFFF\");\n var a = fromHex(\"FFFFFFFF00000001000000000000000000000000FFFFFFFFFFFFFFFFFFFFFFFC\");\n var b = fromHex(\"5AC635D8AA3A93E7B3EBBD55769886BC651D06B0CC53B0F63BCE3C3E27D2604B\");\n var n = fromHex(\"FFFFFFFF00000000FFFFFFFFFFFFFFFFBCE6FAADA7179E84F3B9CAC2FC632551\");\n var h = BigInteger.ONE;\n var curve = new ec.ECCurveFp(p, a, b);\n var G = curve.decodePointHex(\"04\"\n + \"6B17D1F2E12C4247F8BCE6E563A440F277037D812DEB33A0F4A13945D898C296\"\n + \"4FE342E2FE1A7F9B8EE7EB4A7C0F9E162BCE33576B315ECECBB6406837BF51F5\");\n return new X9ECParameters(curve, G, n, h);\n}\n\nfunction secp384r1() {\n // p = 2^384 - 2^128 - 2^96 + 2^32 - 1\n var p = fromHex(\"FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEFFFFFFFF0000000000000000FFFFFFFF\");\n var a = fromHex(\"FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEFFFFFFFF0000000000000000FFFFFFFC\");\n var b = fromHex(\"B3312FA7E23EE7E4988E056BE3F82D19181D9C6EFE8141120314088F5013875AC656398D8A2ED19D2A85C8EDD3EC2AEF\");\n var n = fromHex(\"FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFC7634D81F4372DDF581A0DB248B0A77AECEC196ACCC52973\");\n var h = BigInteger.ONE;\n var curve = new ec.ECCurveFp(p, a, b);\n var G = curve.decodePointHex(\"04\"\n + \"AA87CA22BE8B05378EB1C71EF320AD746E1D3B628BA79B9859F741E082542A385502F25DBF55296C3A545E3872760AB7\"\n + \"3617DE4A96262C6F5D9E98BF9292DC29F8F41DBD289A147CE9DA3113B5F0B8C00A60B1CE1D7E819D7A431D7C90EA0E5F\");\n return new X9ECParameters(curve, G, n, h);\n}\n\nfunction secp521r1() {\n // p = 2^521 - 1\n var p = fromHex(\"01FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF\");\n var a = fromHex(\"01FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFC\");\n var b = fromHex(\"0051953EB9618E1C9A1F929A21A0B68540EEA2DA725B99B315F3B8B489918EF109E156193951EC7E937B1652C0BD3BB1BF073573DF883D2C34F1EF451FD46B503F00\");\n var n = fromHex(\"01FFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFA51868783BF2F966B7FCC0148F709A5D03BB5C9B8899C47AEBB6FB71E91386409\");\n var h = BigInteger.ONE;\n var curve = new ec.ECCurveFp(p, a, b);\n var G = curve.decodePointHex(\"04\"\n + \"00C6858E06B70404E9CD9E3ECB662395B4429C648139053FB521F828AF606B4D3DBAA14B5E77EFE75928FE1DC127A2FFA8DE3348B3C1856A429BF97E7E31C2E5BD66\"\n + \"011839296A789A3BC0045C8A5FB42C7D1BD998F54449579B446817AFBD17273E662C97EE72995EF42640C550B9013FAD0761353C7086A272C24088BE94769FD16650\");\n return new X9ECParameters(curve, G, n, h);\n}\n\n// ----------------\n// Public API\n\nvar CURVES = module.exports = {\n \"secp256r1\": secp256r1(),\n \"secp384r1\": secp384r1(),\n \"secp521r1\": secp521r1()\n};\n\n// also export NIST names\nCURVES[\"P-256\"] = CURVES.secp256r1;\nCURVES[\"P-384\"] = CURVES.secp384r1;\nCURVES[\"P-521\"] = CURVES.secp521r1;\n","/**\n * deps/ecc/index.js - Elliptic Curve Entry Point\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar forge = require(\"../../deps/forge\"),\n BigInteger = forge.jsbn.BigInteger,\n ec = require(\"./math.js\"),\n CURVES = require(\"./curves.js\");\n\n// ### Helpers\nfunction hex2bn(s) {\n return new BigInteger(s, 16);\n}\n\nfunction bn2bin(bn, len) {\n if (!len) {\n len = Math.ceil(bn.bitLength() / 8);\n }\n len = len * 2;\n\n var hex = bn.toString(16);\n // truncate-left if too large\n hex = hex.substring(Math.max(hex.length - len, 0));\n // pad-left if too small\n while (len > hex.length) {\n hex = \"0\" + hex;\n }\n\n return Buffer.from(hex, \"hex\");\n}\nfunction bin2bn(s) {\n if (\"string\" === typeof s) {\n s = Buffer.from(s, \"binary\");\n }\n return hex2bn(s.toString(\"hex\"));\n}\n\nfunction keySizeBytes(params) {\n return Math.ceil(params.getN().bitLength() / 8);\n}\n\nfunction namedCurve(curve) {\n var params = CURVES[curve];\n if (!params) {\n throw new TypeError(\"unsupported named curve: \" + curve);\n }\n\n return params;\n}\n\nfunction normalizeEcdsa(params, md) {\n var log2n = params.getN().bitLength(),\n mdLen = md.length * 8;\n\n var e = bin2bn(md);\n if (log2n < mdLen) {\n e = e.shiftRight(mdLen - log2n);\n }\n\n return e;\n}\n\n// ### EC Public Key\n\n/**\n *\n * @param {String} curve The named curve\n * @param {BigInteger} x The X coordinate\n * @param {BigInteger} y The Y coordinate\n */\nfunction ECPublicKey(curve, x, y) {\n var params = namedCurve(curve),\n c = params.getCurve();\n var key = new ec.ECPointFp(c,\n c.fromBigInteger(x),\n c.fromBigInteger(y));\n\n this.curve = curve;\n this.params = params;\n this.point = key;\n\n var size = keySizeBytes(params);\n this.x = bn2bin(x, size);\n this.y = bn2bin(y, size);\n}\n\n// basics\nECPublicKey.prototype.isValid = function() {\n return this.params.curve.contains(this.point);\n}\n\n// ECDSA\nECPublicKey.prototype.verify = function(md, sig) {\n var N = this.params.getN(),\n G = this.params.getG();\n\n // prepare and validate (r, s)\n var r = bin2bn(sig.r),\n s = bin2bn(sig.s);\n if (r.compareTo(BigInteger.ONE) < 0 || r.compareTo(N) >= 0) {\n return false;\n }\n if (s.compareTo(BigInteger.ONE) < 0 || r.compareTo(N) >= 0) {\n return false;\n }\n\n // normalize input\n var e = normalizeEcdsa(this.params, md);\n // verify (r, s)\n var w = s.modInverse(N),\n u1 = e.multiply(w).mod(N),\n u2 = r.multiply(w).mod(N);\n\n var v = G.multiplyTwo(u1, this.point, u2).getX().toBigInteger();\n v = v.mod(N);\n\n return v.equals(r);\n};\n\n// ### EC Private Key\n\n/**\n * @param {String} curve The named curve\n * @param {Buffer} key The private key value\n */\nfunction ECPrivateKey(curve, key) {\n var params = namedCurve(curve);\n this.curve = curve;\n this.params = params;\n\n var size = keySizeBytes(params);\n this.d = bn2bin(key, size);\n}\n\nECPrivateKey.prototype.toPublicKey = function() {\n var d = bin2bn(this.d);\n var P = this.params.getG().multiply(d);\n return new ECPublicKey(this.curve,\n P.getX().toBigInteger(),\n P.getY().toBigInteger());\n};\n\n// ECDSA\nECPrivateKey.prototype.sign = function(md) {\n var keysize = keySizeBytes(this.params),\n N = this.params.getN(),\n G = this.params.getG(),\n e = normalizeEcdsa(this.params, md),\n d = bin2bn(this.d);\n\n var r, s;\n var k, x1, z;\n do {\n do {\n // determine random nonce\n do {\n k = bin2bn(forge.random.getBytes(keysize));\n } while (k.equals(BigInteger.ZERO) || k.compareTo(N) >= 0);\n // (x1, y1) = k * G\n x1 = G.multiply(k).getX().toBigInteger();\n // r = x1 mod N\n r = x1.mod(N);\n } while (r.equals(BigInteger.ZERO));\n // s = (k^-1 * (e + r * d)) mod N\n z = d.multiply(r);\n z = e.add(z);\n s = k.modInverse(N).multiply(z).mod(N);\n } while (s.equals(BigInteger.ONE));\n\n // convert (r, s) to bytes\n var len = keySizeBytes(this.params);\n r = bn2bin(r, len);\n s = bn2bin(s, len);\n\n return {\n r: r,\n s: s\n };\n};\n\n// basics\nECPrivateKey.prototype.isValid = function() {\n var d = bin2bn(this.d),\n n1 = this.params.getN().subtract(BigInteger.ONE);\n\n return (d.compareTo(BigInteger.ONE) >= 0) &&\n (d.compareTo(n1) < 0);\n}\n\n// ECDH\nECPrivateKey.prototype.computeSecret = function(pubkey) {\n var d = bin2bn(this.d);\n var S = pubkey.point.multiply(d).getX().toBigInteger();\n S = bn2bin(S, keySizeBytes(this.params));\n return S;\n};\n\n// ### Public API\nexports.generateKeyPair = function(curve) {\n var params = namedCurve(curve),\n n = params.getN();\n\n // generate random within range [1, N-1)\n var r = forge.random.getBytes(keySizeBytes(params));\n r = bin2bn(r);\n\n var n1 = n.subtract(BigInteger.ONE);\n var d = r.mod(n1).add(BigInteger.ONE);\n\n var privkey = new ECPrivateKey(curve, d),\n pubkey = privkey.toPublicKey();\n\n return {\n \"private\": privkey,\n \"public\": pubkey\n };\n};\n\nexports.asPublicKey = function(curve, x, y) {\n if (\"string\" === typeof x) {\n x = hex2bn(x);\n } else if (Buffer.isBuffer(x)) {\n x = bin2bn(x);\n }\n\n if (\"string\" === typeof y) {\n y = hex2bn(y);\n } else if (Buffer.isBuffer(y)) {\n y = bin2bn(y);\n }\n\n var pubkey = new ECPublicKey(curve, x, y);\n return pubkey;\n};\nexports.asPrivateKey = function(curve, d) {\n // Elaborate way to get to a Buffer from a (String|Buffer|BigInteger)\n if (\"string\" === typeof d) {\n d = hex2bn(d);\n } else if (Buffer.isBuffer(d)) {\n d = bin2bn(d);\n }\n\n var privkey = new ECPrivateKey(curve, d);\n return privkey;\n};\n","/**\n * deps/ecc/math.js - Elliptic Curve Math\n * Original Copyright (c) 2003-2005 Tom Wu.\n * Modifications Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n *\n * Ported from Tom Wu, which is ported from BouncyCastle\n * Modified to reuse existing external NPM modules, restricted to the\n * NIST//SECG/X9.62 prime curves only, and formatted to match project\n * coding styles.\n */\n\"use strict\";\n\n// Basic Javascript Elliptic Curve implementation\n// Ported loosely from BouncyCastle's Java EC code\n// Only Fp curves implemented for now\n\nvar BigInteger = require(\"../../deps/forge\").jsbn.BigInteger;\n\n// ----------------\n// Helpers\n\nfunction nbi() {\n return new BigInteger(null);\n}\n\n// ----------------\n// Barrett modular reduction\n\n// constructor\nfunction Barrett(m) {\n // setup Barrett\n this.r2 = nbi();\n this.q3 = nbi();\n BigInteger.ONE.dlShiftTo(2*m.t,this.r2);\n this.mu = this.r2.divide(m);\n this.m = m;\n}\n\nfunction barrettConvert(x) {\n if(x.s < 0 || x.t > 2*this.m.t) return x.mod(this.m);\n else if(x.compareTo(this.m) < 0) return x;\n else { 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) {\n if (x.s < 0) { throw Error(\"Barrett reduction on negative input\"); }\n x.drShiftTo(this.m.t-1,this.r2);\n if(x.t > this.m.t+1) { x.t = this.m.t+1; x.clamp(); }\n this.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3);\n this.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);\n while(x.compareTo(this.r2) < 0) x.dAddOffset(1,this.m.t+1);\n x.subTo(this.r2,x);\n while(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// ----------------\n// ECFieldElementFp\n\n// constructor\nfunction ECFieldElementFp(q, x) {\n this.x = x;\n // TODO if(x.compareTo(q) >= 0) error\n this.p = q;\n}\n\nfunction feFpEquals(other) {\n if (other === this) {\n return true;\n }\n return (this.p.equals(other.p) && this.x.equals(other.x));\n}\n\nfunction feFpToBigInteger() {\n return this.x;\n}\n\nfunction feFpNegate() {\n return new ECFieldElementFp(this.p, this.x.negate().mod(this.p));\n}\n\nfunction feFpAdd(b) {\n return new ECFieldElementFp(this.p, this.x.add(b.toBigInteger()).mod(this.p));\n}\n\nfunction feFpSubtract(b) {\n return new ECFieldElementFp(this.p, this.x.subtract(b.toBigInteger()).mod(this.p));\n}\n\nfunction feFpMultiply(b) {\n return new ECFieldElementFp(this.p, this.x.multiply(b.toBigInteger()).mod(this.p));\n}\n\nfunction feFpSquare() {\n return new ECFieldElementFp(this.p, this.x.pow(2).mod(this.p));\n}\n\nfunction feFpDivide(b) {\n return new ECFieldElementFp(this.p, this.x.multiply(b.toBigInteger().modInverse(this.p)).mod(this.p));\n}\n\nECFieldElementFp.prototype.equals = feFpEquals;\nECFieldElementFp.prototype.toBigInteger = feFpToBigInteger;\nECFieldElementFp.prototype.negate = feFpNegate;\nECFieldElementFp.prototype.add = feFpAdd;\nECFieldElementFp.prototype.subtract = feFpSubtract;\nECFieldElementFp.prototype.multiply = feFpMultiply;\nECFieldElementFp.prototype.square = feFpSquare;\nECFieldElementFp.prototype.divide = feFpDivide;\n\n// ----------------\n// ECPointFp\n\n// constructor\nfunction ECPointFp(curve, x, y, z) {\n this.curve = curve;\n this.x = x;\n this.y = y;\n // Projective coordinates: either zinv == null or z * zinv == 1\n // z and zinv are just BigIntegers, not fieldElements\n if (!z) {\n this.z = BigInteger.ONE;\n } else {\n this.z = z;\n }\n this.zinv = null;\n //TODO: compression flag\n}\n\nfunction pointFpGetX() {\n if(!this.zinv) {\n this.zinv = this.z.modInverse(this.curve.p);\n }\n var r = this.x.toBigInteger().multiply(this.zinv);\n this.curve.reduce(r);\n return this.curve.fromBigInteger(r);\n}\n\nfunction pointFpGetY() {\n if(!this.zinv) {\n this.zinv = this.z.modInverse(this.curve.p);\n }\n var r = this.y.toBigInteger().multiply(this.zinv);\n this.curve.reduce(r);\n return this.curve.fromBigInteger(r);\n}\n\nfunction pointFpEquals(other) {\n if (other === this) {\n return true;\n }\n if (this.isInfinity()) {\n return other.isInfinity();\n }\n if (other.isInfinity()) {\n return this.isInfinity();\n }\n var u, v;\n // u = Y2 * Z1 - Y1 * Z2\n u = other.y.toBigInteger().multiply(this.z).subtract(this.y.toBigInteger().multiply(other.z)).mod(this.curve.p);\n if (!u.equals(BigInteger.ZERO)) {\n return false;\n }\n // v = X2 * Z1 - X1 * Z2\n v = other.x.toBigInteger().multiply(this.z).subtract(this.x.toBigInteger().multiply(other.z)).mod(this.curve.p);\n return v.equals(BigInteger.ZERO);\n}\n\nfunction pointFpIsInfinity() {\n if ((this.x == null) && (this.y == null)) {\n return true;\n }\n return (this.z.equals(BigInteger.ZERO) && !this.y.toBigInteger().equals(BigInteger.ZERO));\n}\n\nfunction pointFpNegate() {\n return new ECPointFp(this.curve, this.x, this.y.negate(), this.z);\n}\n\nfunction pointFpAdd(b) {\n if (this.isInfinity()) {\n return b;\n }\n if (b.isInfinity()) {\n return this;\n }\n\n // u = Y2 * Z1 - Y1 * Z2\n var u = b.y.toBigInteger().multiply(this.z).subtract(this.y.toBigInteger().multiply(b.z)).mod(this.curve.p);\n // v = X2 * Z1 - X1 * Z2\n var v = b.x.toBigInteger().multiply(this.z).subtract(this.x.toBigInteger().multiply(b.z)).mod(this.curve.p);\n\n if (BigInteger.ZERO.equals(v)) {\n if (BigInteger.ZERO.equals(u)) {\n return this.twice(); // this == b, so double\n }\n return this.curve.getInfinity(); // this = -b, so infinity\n }\n\n var THREE = new BigInteger(\"3\");\n var x1 = this.x.toBigInteger();\n var y1 = this.y.toBigInteger();\n\n var v2 = v.pow(2);\n var v3 = v2.multiply(v);\n var x1v2 = x1.multiply(v2);\n var zu2 = u.pow(2).multiply(this.z);\n\n // x3 = v * (z2 * (z1 * u^2 - 2 * x1 * v^2) - v^3)\n var x3 = zu2.subtract(x1v2.shiftLeft(1)).multiply(b.z).subtract(v3).multiply(v).mod(this.curve.p);\n // y3 = z2 * (3 * x1 * u * v^2 - y1 * v^3 - z1 * u^3) + u * v^3\n var y3 = x1v2.multiply(THREE).multiply(u).subtract(y1.multiply(v3)).subtract(zu2.multiply(u)).multiply(b.z).add(u.multiply(v3)).mod(this.curve.p);\n // z3 = v^3 * z1 * z2\n var z3 = v3.multiply(this.z).multiply(b.z).mod(this.curve.p);\n\n return new ECPointFp(this.curve, this.curve.fromBigInteger(x3), this.curve.fromBigInteger(y3), z3);\n}\n\nfunction pointFpTwice() {\n if(this.isInfinity()) {\n return this;\n }\n if (this.y.toBigInteger().signum() === 0) {\n return this.curve.getInfinity();\n }\n\n // TODO: optimized handling of constants\n var THREE = new BigInteger(\"3\");\n var x1 = this.x.toBigInteger();\n var y1 = this.y.toBigInteger();\n\n var y1z1 = y1.multiply(this.z);\n var y1sqz1 = y1z1.multiply(y1).mod(this.curve.p);\n var a = this.curve.a.toBigInteger();\n\n // w = 3 * x1^2 + a * z1^2\n var w = x1.pow(2).multiply(THREE);\n if (!BigInteger.ZERO.equals(a)) {\n w = w.add(this.z.pow(2).multiply(a));\n }\n w = w.mod(this.curve.p);\n //this.curve.reduce(w);\n // x3 = 2 * y1 * z1 * (w^2 - 8 * x1 * y1^2 * z1)\n var x3 = w.pow(2).subtract(x1.shiftLeft(3).multiply(y1sqz1)).shiftLeft(1).multiply(y1z1).mod(this.curve.p);\n // y3 = 4 * y1^2 * z1 * (3 * w * x1 - 2 * y1^2 * z1) - w^3\n var y3 = w.multiply(THREE).multiply(x1).subtract(y1sqz1.shiftLeft(1)).shiftLeft(2).multiply(y1sqz1).subtract(w.pow(2).multiply(w)).mod(this.curve.p);\n // z3 = 8 * (y1 * z1)^3\n var z3 = y1z1.pow(2).multiply(y1z1).shiftLeft(3).mod(this.curve.p);\n\n return new ECPointFp(this.curve, this.curve.fromBigInteger(x3), this.curve.fromBigInteger(y3), z3);\n}\n\n// Simple NAF (Non-Adjacent Form) multiplication algorithm\n// TODO: modularize the multiplication algorithm\nfunction pointFpMultiply(k) {\n if (this.isInfinity()) {\n return this;\n }\n if (k.signum() === 0) {\n return this.curve.getInfinity();\n }\n\n var e = k;\n var h = e.multiply(new BigInteger(\"3\"));\n\n var neg = this.negate();\n var R = this;\n\n var i;\n for(i = h.bitLength() - 2; i > 0; --i) {\n R = R.twice();\n\n var hBit = h.testBit(i);\n var eBit = e.testBit(i);\n\n if (hBit !== eBit) {\n R = R.add(hBit ? this : neg);\n }\n }\n\n return R;\n}\n\n// Compute this*j + x*k (simultaneous multiplication)\nfunction pointFpMultiplyTwo(j, x, k) {\n var i;\n if (j.bitLength() > k.bitLength()) {\n i = j.bitLength() - 1;\n } else {\n i = k.bitLength() - 1;\n }\n\n var R = this.curve.getInfinity();\n var both = this.add(x);\n while (i >= 0) {\n R = R.twice();\n if (j.testBit(i)) {\n if (k.testBit(i)) {\n R = R.add(both);\n }\n else {\n R = R.add(this);\n }\n }\n else {\n if (k.testBit(i)) {\n R = R.add(x);\n }\n }\n --i;\n }\n\n return R;\n}\n\nECPointFp.prototype.getX = pointFpGetX;\nECPointFp.prototype.getY = pointFpGetY;\nECPointFp.prototype.equals = pointFpEquals;\nECPointFp.prototype.isInfinity = pointFpIsInfinity;\nECPointFp.prototype.negate = pointFpNegate;\nECPointFp.prototype.add = pointFpAdd;\nECPointFp.prototype.twice = pointFpTwice;\nECPointFp.prototype.multiply = pointFpMultiply;\nECPointFp.prototype.multiplyTwo = pointFpMultiplyTwo;\n\n// ----------------\n// ECCurveFp\n\n// constructor\nfunction ECCurveFp(p, a, b) {\n this.p = p;\n this.a = this.fromBigInteger(a);\n this.b = this.fromBigInteger(b);\n this.infinity = new ECPointFp(this, null, null);\n this.reducer = new Barrett(this.p);\n}\n\nfunction curveFpgetP() {\n return this.p;\n}\n\nfunction curveFpGetA() {\n return this.a;\n}\n\nfunction curveFpGetB() {\n return this.b;\n}\n\nfunction curveFpEquals(other) {\n if (other === this) {\n return true;\n }\n return (this.p.equals(other.p) && this.a.equals(other.a) && this.b.equals(other.b));\n}\n\nfunction curveFpContains(pt) {\n // y^2 = x^3 + a*x + b mod p\n var x = pt.getX().toBigInteger(),\n y = pt.getY().toBigInteger(),\n a = this.a.toBigInteger(),\n b = this.b.toBigInteger(),\n p = this.p;\n\n var left = y.pow(2).mod(p),\n right = x.pow(3).add(a.multiply(x)).add(b).mod(p)\n\n return left.equals(right);\n}\n\nfunction curveFpGetInfinity() {\n return this.infinity;\n}\n\nfunction curveFpFromBigInteger(x) {\n return new ECFieldElementFp(this.p, x);\n}\n\nfunction curveReduce(x) {\n this.reducer.reduce(x);\n}\n\n// for now, work with hex strings because they're easier in JS\nfunction curveFpDecodePointHex(s) {\n switch (parseInt(s.substring(0, 2), 16)) {\n // first byte\n case 0:\n return this.infinity;\n case 2:\n case 3:\n // point compression not supported yet\n return null;\n case 4:\n case 6:\n case 7:\n var len = (s.length - 2) / 2;\n var xHex = s.substr(2, len);\n var yHex = s.substr(len + 2, len);\n\n return new ECPointFp(this,\n this.fromBigInteger(new BigInteger(xHex, 16)),\n this.fromBigInteger(new BigInteger(yHex, 16)));\n\n default: // unsupported\n return null;\n }\n}\n\nfunction curveFpEncodePointHex(p) {\n if (p.isInfinity()) {\n return \"00\";\n }\n var xHex = p.getX().toBigInteger().toString(16);\n var yHex = p.getY().toBigInteger().toString(16);\n var oLen = this.getP().toString(16).length;\n if ((oLen % 2) !== 0) {\n oLen++;\n }\n while (xHex.length < oLen) {\n xHex = \"0\" + xHex;\n }\n while (yHex.length < oLen) {\n yHex = \"0\" + yHex;\n }\n return \"04\" + xHex + yHex;\n}\n\nECCurveFp.prototype.getP = curveFpgetP;\nECCurveFp.prototype.getA = curveFpGetA;\nECCurveFp.prototype.getB = curveFpGetB;\nECCurveFp.prototype.equals = curveFpEquals;\nECCurveFp.prototype.contains = curveFpContains;\nECCurveFp.prototype.getInfinity = curveFpGetInfinity;\nECCurveFp.prototype.fromBigInteger = curveFpFromBigInteger;\nECCurveFp.prototype.reduce = curveReduce;\nECCurveFp.prototype.decodePointHex = curveFpDecodePointHex;\nECCurveFp.prototype.encodePointHex = curveFpEncodePointHex;\n\n// Exports\nmodule.exports = {\n ECFieldElementFp: ECFieldElementFp,\n ECPointFp: ECPointFp,\n ECCurveFp: ECCurveFp\n};\n","/*!\n * deps/forge.js - Forge Package Customization\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar forge = require(\"node-forge/lib/forge\");\nrequire(\"node-forge/lib/aes\");\nrequire(\"node-forge/lib/asn1\");\nrequire(\"node-forge/lib/cipher\");\nrequire(\"node-forge/lib/hmac\");\nrequire(\"node-forge/lib/mgf1\");\nrequire(\"node-forge/lib/pbkdf2\");\nrequire(\"node-forge/lib/pem\");\nrequire(\"node-forge/lib/pkcs1\");\nrequire(\"node-forge/lib/pkcs7\");\nrequire(\"node-forge/lib/pki\");\nrequire(\"node-forge/lib/prime\");\nrequire(\"node-forge/lib/prng\");\nrequire(\"node-forge/lib/pss\");\nrequire(\"node-forge/lib/random\");\nrequire(\"node-forge/lib/sha1\");\nrequire(\"node-forge/lib/sha256\");\nrequire(\"node-forge/lib/sha512\");\nrequire(\"node-forge/lib/util\");\n\n// Define AES \"raw\" cipher mode\nfunction modeRaw(options) {\n options = options || {};\n this.name = \"\";\n this.cipher = options.cipher;\n this.blockSize = options.blockSize || 16;\n this._blocks = this.blockSize / 4;\n this._inBlock = new Array(this._blocks);\n this._outBlock = new Array(this._blocks);\n}\n\nmodeRaw.prototype.start = function() {};\n\nmodeRaw.prototype.encrypt = function(input, output, finish) {\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n var i;\n\n // get next block\n for(i = 0; i < this._blocks; ++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(i = 0; i < this._blocks; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n};\n\nmodeRaw.prototype.decrypt = function(input, output, finish) {\n if(input.length() < this.blockSize && !(finish && input.length() > 0)) {\n return true;\n }\n\n var i;\n\n // get next block\n for(i = 0; i < this._blocks; ++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(i = 0; i < this._blocks; ++i) {\n output.putInt32(this._outBlock[i]);\n }\n};\n\n(function() {\n var name = \"AES\",\n mode = modeRaw,\n factory;\n factory = function() { return new forge.aes.Algorithm(name, mode); };\n forge.cipher.registerAlgorithm(name, factory);\n})();\n\n// Ensure that the jsbn modInverse function always returns a positive result\nconst originalModInverse = forge.jsbn.BigInteger.prototype.modInverse;\nconst positiveModInverse = function(m) {\n const inv = originalModInverse.apply(this, [m]);\n return inv.mod(m);\n}\n\nforge.jsbn.BigInteger.prototype.modInverse = positiveModInverse;\n\nmodule.exports = forge;\n","/*!\n * index.js - Main Entry Point\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nif (typeof Promise === \"undefined\") {\n require(\"es6-promise\").polyfill();\n}\n\nif (typeof Buffer === \"undefined\") {\n (global || window).Buffer = require(\"buffer\").Buffer;\n}\n\nif (typeof process === \"undefined\") {\n (global || window).process = require(\"process\");\n}\n\nif (!process.version) {\n process.version = \"\";\n}\n\nvar JWS = require(\"./jws\");\n\nmodule.exports = {\n JWA: require(\"./algorithms\"),\n JWE: require(\"./jwe\"),\n JWK: require(\"./jwk\"),\n JWS: JWS,\n util: require(\"./util\"),\n parse: require(\"./parse\"),\n canYouSee: JWS.createVerify\n};\n","/*!\n * jwe/decrypt.js - Decrypt from a JWE\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar base64url = require(\"../util/base64url\"),\n AlgConfig = require(\"../util/algconfig\"),\n JWK = require(\"../jwk\"),\n merge = require(\"../util/merge\"),\n pako = require(\"pako\");\n\nvar DEFAULT_OPTIONS = {\n algorithms: \"*\"\n};\n\n/**\n * @class JWE.Decrypter\n * @classdesc Processor of encrypted data.\n *\n * @description\n * **NOTE:** This class cannot be instantiated directly. Instead\n * call {@link JWE.createDecrypt}.\n */\nfunction JWEDecrypter(ks, globalOpts) {\n var assumedKey,\n keystore;\n\n if (JWK.isKey(ks)) {\n assumedKey = ks;\n keystore = assumedKey.keystore;\n } else if (JWK.isKeyStore(ks)) {\n keystore = ks;\n } else {\n throw new TypeError(\"Keystore must be provided\");\n }\n\n globalOpts = merge({}, DEFAULT_OPTIONS, globalOpts);\n\n /**\n * Decrypts the given input.\n *\n * {opts}, if provided, is used to customize this specific decrypt operation.\n * This argument has the same semantics as {JWE.createDecrypt}, and takes\n * precedence over those options.\n *\n * The returned PRomise, when fulfilled, returns an object with the\n * following members:\n *\n * - `header` - The JOSE Header, combined from the relevant \"header\" and\n * \"protected\" fields from the original JWE object.\n * - `protected` - An array containing the names of the protected fields\n * - `key` - The used to decrypt the content\n * - `payload` - The decrypted content (as a Buffer)\n * - `plaintext` - An alias for `payload`\n *\n * @param {Object|String} input The encrypted content\n * @param {Object} [opts] The options for this decryption operation.\n * @returns {Promise} A promise for the decyprted plaintext\n */\n Object.defineProperty(this, \"decrypt\", {\n value: function(input, opts) {\n opts = merge({}, globalOpts, opts || {});\n var extraHandlers = opts.handlers || {};\n var handlerKeys = Object.keys(extraHandlers);\n var algSpec = new AlgConfig(opts.algorithms);\n\n /* eslint camelcase: [0] */\n if (typeof input === \"string\") {\n input = input.split(\".\");\n input = {\n protected: input[0],\n recipients: [\n {\n encrypted_key: input[1]\n }\n ],\n iv: input[2],\n ciphertext: input[3],\n tag: input[4]\n };\n } else if (!input || typeof input !== \"object\") {\n throw new Error(\"invalid input\");\n }\n if (\"encrypted_key\" in input) {\n input.recipients = [\n {\n encrypted_key: input.encrypted_key\n }\n ];\n }\n\n var promise;\n\n // ensure recipients exists\n var rcptList = input.recipients || [{}];\n promise = Promise.resolve(rcptList);\n\n //combine fields\n var fields,\n protect;\n promise = promise.then(function(rcptList) {\n if (input.protected) {\n protect = base64url.decode(input.protected).toString(\"utf8\");\n protect = JSON.parse(protect);\n\n // verify \"crit\" field first\n var crit = protect.crit;\n if (crit) {\n if (!Array.isArray(crit)) {\n return Promise.reject(new Error(\"Invalid 'crit' header\"));\n }\n for (var idx = 0; crit.length > idx; idx++) {\n if (-1 === handlerKeys.indexOf(crit[idx])) {\n return Promise.reject(new Error(\n \"Critical extension is not supported: \" + crit[idx]\n ));\n }\n }\n }\n\n fields = protect;\n protect = Object.keys(protect);\n } else {\n fields = {};\n protect = [];\n }\n fields = merge(input.unprotected || {}, fields);\n\n rcptList = rcptList.map(function(r) {\n var promise = Promise.resolve();\n var header = r.header || {};\n header = merge(header, fields);\n r.header = header;\n r.protected = protect;\n\n // check on allowed algorithms\n if (!algSpec.match(header.alg)) {\n promise = promise.then(function() {\n return Promise.reject(new Error(\"Algorithm not allowed: \" + header.alg));\n });\n }\n if (!algSpec.match(header.enc)) {\n promise = promise.then(function () {\n return Promise.reject(new Error(\"Algorithm not allowed: \" + header.enc));\n });\n }\n\n if (header.epk) {\n promise = promise.then(function() {\n return JWK.asKey(header.epk);\n });\n promise = promise.then(function(epk) {\n header.epk = epk.toObject(false);\n });\n }\n return promise.then(function() {\n return r;\n });\n });\n\n return Promise.all(rcptList);\n });\n\n // decrypt with first key found\n var algKey,\n encKey,\n kdata;\n promise = promise.then(function(rcptList) {\n var jwe = {};\n return new Promise(function(resolve, reject) {\n var processKey = function() {\n var rcpt = rcptList.shift();\n if (!rcpt) {\n reject(new Error(\"no key found\"));\n return;\n }\n\n var algPromise = Promise.resolve(rcpt);\n algPromise = algPromise.then(function(rcpt) {\n // try to unwrap encrypted key\n var prekey = kdata = rcpt.encrypted_key || \"\";\n prekey = base64url.decode(prekey);\n algKey = assumedKey || keystore.get({\n use: \"enc\",\n alg: rcpt.header.alg,\n kid: rcpt.header.kid\n });\n if (algKey) {\n return algKey.unwrap(rcpt.header.alg, prekey, rcpt.header);\n } else {\n return Promise.reject();\n }\n });\n algPromise = algPromise.then(function(key) {\n encKey = {\n \"kty\": \"oct\",\n \"k\": base64url.encode(key)\n };\n encKey = JWK.asKey(encKey);\n jwe.key = algKey;\n jwe.header = rcpt.header;\n jwe.protected = rcpt.protected;\n resolve(jwe);\n });\n algPromise.catch(processKey);\n };\n processKey();\n });\n });\n\n // assign decipher inputs\n promise = promise.then(function(jwe) {\n jwe.iv = input.iv;\n jwe.tag = input.tag;\n jwe.ciphertext = input.ciphertext;\n\n return jwe;\n });\n\n // process any prepare-decrypt handlers\n promise = promise.then(function(jwe) {\n var processing = [];\n handlerKeys.forEach(function(h) {\n h = extraHandlers[h];\n var p;\n if (\"function\" === typeof h) {\n p = h(jwe);\n } else if (\"object\" === typeof h && \"function\" === typeof h.prepare) {\n p = h.prepare(jwe);\n }\n if (p) {\n processing.push(Promise.resolve(p));\n }\n });\n return Promise.all(processing).then(function() {\n // don't actually care about individual handler results\n // assume {jwe} is updated\n return jwe;\n });\n });\n\n // prepare decrypt inputs\n promise = promise.then(function(jwe) {\n if (!Buffer.isBuffer(jwe.ciphertext)) {\n jwe.ciphertext = base64url.decode(jwe.ciphertext);\n }\n\n return jwe;\n });\n\n // decrypt it!\n promise = promise.then(function(jwe) {\n var adata = input.protected;\n if (\"aad\" in input && null != input.aad) {\n adata += \".\" + input.aad;\n }\n\n var params = {\n iv: jwe.iv,\n adata: adata,\n tag: jwe.tag,\n kdata: kdata,\n epu: jwe.epu,\n epv: jwe.epv\n };\n var cdata = jwe.ciphertext;\n\n delete jwe.iv;\n delete jwe.tag;\n delete jwe.ciphertext;\n\n return encKey.\n then(function(enkKey) {\n return enkKey.decrypt(jwe.header.enc, cdata, params).\n then(function(pdata) {\n jwe.payload = jwe.plaintext = pdata;\n return jwe;\n });\n });\n });\n\n // (OPTIONAL) decompress plaintext\n promise = promise.then(function(jwe) {\n if (\"DEF\" === jwe.header.zip) {\n return new Promise(function(resolve, reject) {\n try {\n var data = pako.inflateRaw(Buffer.from(jwe.plaintext))\n\n jwe.payload = jwe.plaintext = Buffer.from(data);\n resolve(jwe);\n } catch (err) {\n reject(err);\n }\n });\n }\n\n return jwe;\n });\n\n // process any post-decrypt handlers\n promise = promise.then(function(jwe) {\n var processing = [];\n handlerKeys.forEach(function(h) {\n h = extraHandlers[h];\n var p;\n if (\"object\" === typeof h && \"function\" === typeof h.complete) {\n p = h.complete(jwe);\n }\n if (p) {\n processing.push(Promise.resolve(p));\n }\n });\n return Promise.all(processing).then(function() {\n // don't actually care about individual handler results\n // assume {jwe} is updated\n return jwe;\n });\n });\n\n return promise;\n }\n });\n}\n\n/**\n * @description\n * Creates a new Decrypter for the given Key or KeyStore.\n *\n * {opts}, when provided, is used to customize decryption processes. The\n * following options are currently supported:\n *\n * - `handlers` - An object where each name is a JOSE header member name and\n * the value can be a boolean, function, or an object.\n *\n * Handlers are intended to support 'crit' extensions. When a boolean value,\n * the member is expected to be processed once decryption is fully complete.\n * When a function, it is called just before the ciphertext is decrypted\n * (processed as if it were a `prepare` handler, as decribed below). When an\n * object, it can contain any of the following members:\n *\n * - `recipient` - A function called after a valid key is determined; it takes\n * an object describing the recipient, and returns a Promise that is\n * fulfilled once the handler's processing is complete.\n * - `prepare` - A function called just prior to decrypting the ciphertext;\n * it takes an object describing the decryption result (but containing\n * `ciphertext` and `tag' instead of `payload` and `plaintext`), and\n * returns a Promise that is fulfilled once the handler's processing is\n * complete.\n * - `complete` - A function called once decryption is complete, just prior\n * to fulfilling the Promise returned by `decrypt()`; it takes the object\n * that will be returned by `decrypt()`'s fulfilled Promise, and returns\n * a Promise that is fulfilled once the handler's processing is complete.\n *\n * Note that normal processing of `decrypt()` does not continue until all\n * relevant handlers have completed. Any changes handlers make to the\n * provided objects affects `decrypt()`'s processing.\n *\n * @param {JWK.Key|JWK.KeyStore} ks The Key or KeyStore to use for decryption.\n * @param {Object} [opts] The options for this Decrypter.\n * @returns {JWE.Decrypter} The new Decrypter.\n */\nfunction createDecrypt(ks, opts) {\n var dec = new JWEDecrypter(ks, opts);\n return dec;\n}\n\nmodule.exports = {\n decrypter: JWEDecrypter,\n createDecrypt: createDecrypt\n};\n","/*!\n * jwe/defaults.js - Defaults for JWEs\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\n/**\n * @description\n * The default options for {@link JWE.createEncrypt}.\n *\n * @property {Boolean|String} zip Determines the compression algorithm to\n * apply to the plaintext (if any) before it is encrypted. This can\n * also be `true` (which is equivalent to `\"DEF\"`) or **`false`**\n * (the default, which is equivalent to no compression).\n * @property {String} format Determines the serialization format of the\n * output. Expected to be `\"general\"` for general JSON\n * Serialization, `\"flattened\"` for flattened JSON Serialization,\n * or `\"compact\"` for Compact Serialization (default is\n * **`\"general\"`**).\n * @property {Boolean} compact Determines if the output is the Compact\n * serialization (`true`) or the JSON serialization (**`false`**,\n * the default).\n * @property {String} contentAlg The algorithm used to encrypt the plaintext\n * (default is **`\"A128CBC-HS256\"`**).\n * @property {String|String[]} protect The names of the headers to integrity\n * protect. The value `\"\"` means that none of the header parameters\n * are integrity protected, while `\"*\"` (the default) means that all\n * header parameters are integrity protected.\n */\nvar JWEDefaults = {\n zip: false,\n format: \"general\",\n contentAlg: \"A128CBC-HS256\",\n protect: \"*\"\n};\n\nmodule.exports = JWEDefaults;\n","/*!\n * jwe/encrypt.js - Encrypt to a JWE\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar util = require(\"../util\"),\n generateCEK = require(\"./helpers\").generateCEK,\n JWK = require(\"../jwk\"),\n slice = require(\"./helpers\").slice,\n pako = require(\"pako\"),\n CONSTANTS = require(\"../algorithms/constants\");\n\nvar assign = require(\"lodash/assign\");\nvar clone = require(\"lodash/clone\");\nvar DEFAULTS = require(\"./defaults\");\n\n/**\n * @class JWE.Encrypter\n * @classdesc\n * Generator of encrypted data.\n *\n * @description\n * **NOTE:** This class cannot be instantiated directly. Instead call {@link\n * JWE.createEncrypt}.\n */\nfunction JWEEncrypter(cfg, fields, recipients) {\n var finalized = false,\n format = cfg.format || \"general\",\n protectAll = !!cfg.protectAll,\n content = Buffer.alloc(0);\n\n /**\n * @member {String} JWE.Encrypter#zip\n * @readonly\n * @description\n * Indicates the compression algorithm applied to the plaintext\n * before it is encrypted. The possible values are:\n *\n * + **`\"DEF\"`**: Compress the plaintext using the DEFLATE algorithm.\n * + **`\"\"`**: Do not compress the plaintext.\n */\n Object.defineProperty(this, \"zip\", {\n get: function() {\n return fields.zip || \"\";\n },\n enumerable: true\n });\n /**\n * @member {Boolean} JWE.Encrypter#compact\n * @readonly\n * @description\n * Indicates whether the output of this encryption generator is\n * using the Compact serialization (`true`) or the JSON\n * serialization (`false`).\n */\n Object.defineProperty(this, \"compact\", {\n get: function() { return \"compact\" === format; },\n enumerable: true\n });\n /**\n * @member {String} JWE.Encrypter#format\n * @readonly\n * @description\n * Indicates the format the output of this encryption generator takes.\n */\n Object.defineProperty(this, \"format\", {\n get: function() { return format; },\n enumerable: true\n });\n /**\n * @member {String[]} JWE.Encrypter#protected\n * @readonly\n * @description\n * The header parameter names that are protected. Protected header fields\n * are first serialized to UTF-8 then encoded as util.base64url, then used as\n * the additional authenticated data in the encryption operation.\n */\n Object.defineProperty(this, \"protected\", {\n get: function() {\n return clone(cfg.protect);\n },\n enumerable: true\n });\n /**\n * @member {Object} JWE.Encrypter#header\n * @readonly\n * @description\n * The global header parameters, both protected and unprotected. Call\n * {@link JWE.Encrypter#protected} to determine which parameters will\n * be protected.\n */\n Object.defineProperty(this, \"header\", {\n get: function() {\n return clone(fields);\n },\n enumerable: true\n });\n\n /**\n * @method JWE.Encrypter#update\n * @description\n * Updates the plaintext data for the encryption generator. The plaintext\n * is appended to the end of any other plaintext already applied.\n *\n * If {data} is a Buffer, {encoding} is ignored. Otherwise, {data} is\n * converted to a Buffer internally to {encoding}.\n *\n * @param {Buffer|String} [data] The plaintext to apply.\n * @param {String} [encoding] The encoding of the plaintext.\n * @returns {JWE.Encrypter} This encryption generator.\n * @throws {Error} If ciphertext has already been generated.\n */\n Object.defineProperty(this, \"update\", {\n value: function(data, encoding) {\n if (finalized) {\n throw new Error(\"already final\");\n }\n if (data != null) {\n data = util.asBuffer(data, encoding);\n if (content.length) {\n content = Buffer.concat([content, data],\n content.length + data.length);\n } else {\n content = data;\n }\n }\n\n return this;\n }\n });\n /**\n * @method JWE.Encrypter#final\n * @description\n * Finishes the encryption operation.\n *\n * The returned Promise, when fulfilled, is the JSON Web Encryption (JWE)\n * object, either in the Compact (if {@link JWE.Encrypter#compact} is\n * `true`) or the JSON serialization.\n *\n * @param {Buffer|String} [data] The final plaintext data to apply.\n * @param {String} [encoding] The encoding of the final plaintext data\n * (if any).\n * @returns {Promise} A promise for the encryption operation.\n * @throws {Error} If ciphertext has already been generated.\n */\n Object.defineProperty(this, \"final\", {\n value: function(data, encoding) {\n if (finalized) {\n return Promise.reject(new Error(\"already final\"));\n }\n\n // last-minute data\n this.update(data, encoding);\n\n // mark as done...ish\n finalized = true;\n var promise = Promise.resolve({});\n\n // determine CEK and IV\n var encAlg = fields.enc;\n var encKey;\n promise = promise.then(function(jwe) {\n if (cfg.cek) {\n encKey = JWK.asKey(cfg.cek);\n }\n return jwe;\n });\n\n // process recipients\n promise = promise.then(function(jwe) {\n var procR = function(r, one) {\n var props = {};\n props = assign(props, fields);\n props = assign(props, r.header);\n\n var algKey = r.key,\n algAlg = props.alg;\n\n // generate Ephemeral EC Key\n var tks,\n rpromise;\n if ((props.alg || \"\").indexOf(\"ECDH-ES\") === 0) {\n tks = algKey.keystore.temp();\n if (r.epk) {\n rpromise = Promise.resolve(r.epk).\n then(function(epk) {\n r.header.epk = epk.toJSON(false, [\"kid\"]);\n props.epk = epk.toObject(true, [\"kid\"]);\n });\n } else {\n rpromise = tks.generate(\"EC\", algKey.get(\"crv\")).\n then(function(epk) {\n r.header.epk = epk.toJSON(false, [\"kid\"]);\n props.epk = epk.toObject(true, [\"kid\"]);\n });\n }\n } else {\n rpromise = Promise.resolve();\n }\n\n // encrypt the CEK\n rpromise = rpromise.then(function() {\n var cek,\n p;\n // special case 'alg=dir'\n if (\"dir\" === algAlg && one) {\n encKey = Promise.resolve(algKey);\n p = encKey.then(function(jwk) {\n // fixup encAlg\n if (!encAlg) {\n props.enc = fields.enc = encAlg = jwk.algorithms(JWK.MODE_ENCRYPT)[0];\n }\n return {\n once: true,\n direct: true\n };\n });\n } else {\n if (!encKey) {\n if (!encAlg) {\n props.enc = fields.enc = encAlg = cfg.contentAlg;\n }\n encKey = generateCEK(encAlg);\n }\n p = encKey.then(function(jwk) {\n cek = jwk.get(\"k\", true);\n // algKey may or may not be a promise\n return algKey;\n });\n p = p.then(function(algKey) {\n return algKey.wrap(algAlg, cek, props);\n });\n }\n return p;\n });\n rpromise = rpromise.then(function(wrapped) {\n if (wrapped.once && !one) {\n return Promise.reject(new Error(\"cannot use 'alg':'\" + algAlg + \"' with multiple recipients\"));\n }\n\n var rjwe = {},\n cek;\n if (wrapped.data) {\n cek = wrapped.data;\n cek = util.base64url.encode(cek);\n }\n\n if (wrapped.direct && cek) {\n // replace content key\n encKey = JWK.asKey({\n kty: \"oct\",\n k: cek\n });\n } else if (cek) {\n /* eslint camelcase: [0] */\n rjwe.encrypted_key = cek;\n }\n\n if (r.header && Object.keys(r.header).length) {\n rjwe.header = clone(r.header || {});\n }\n if (wrapped.header) {\n rjwe.header = assign(rjwe.header || {},\n wrapped.header);\n }\n\n return rjwe;\n });\n return rpromise;\n };\n\n var p = Promise.all(recipients);\n p = p.then(function(rcpts) {\n var single = (1 === rcpts.length);\n rcpts = rcpts.map(function(r) {\n return procR(r, single);\n });\n return Promise.all(rcpts);\n });\n p = p.then(function(rcpts) {\n jwe.recipients = rcpts.filter(function(r) { return !!r; });\n return jwe;\n });\n return p;\n });\n\n // normalize headers\n var props = {};\n promise = promise.then(function(jwe) {\n var protect,\n lenProtect,\n unprotect,\n lenUnprotect;\n\n unprotect = clone(fields);\n if ((protectAll && jwe.recipients.length === 1) || \"compact\" === format) {\n // merge single recipient into fields\n protect = {};\n protect = assign({},\n unprotect,\n jwe.recipients[0].header);\n lenProtect = Object.keys(protect).length;\n\n unprotect = undefined;\n lenUnprotect = 0;\n\n delete jwe.recipients[0].header;\n if (Object.keys(jwe.recipients[0]).length === 0) {\n jwe.recipients.splice(0, 1);\n }\n } else {\n protect = {};\n lenProtect = 0;\n lenUnprotect = Object.keys(unprotect).length;\n cfg.protect.forEach(function(f) {\n // remove protected header values from body unprotected header\n if (!(f in unprotect)) {\n return;\n }\n protect[f] = unprotect[f];\n lenProtect++;\n\n delete unprotect[f];\n lenUnprotect--;\n });\n\n jwe.recipients = (jwe.recipients || []).map(function(rcpt) {\n rcpt = rcpt || {};\n var header = rcpt.header;\n if (header) {\n Object.keys(header).forEach(function (f) {\n if (f in protect) { delete header[f]; }\n });\n if (!Object.keys(header).length) {\n delete rcpt.header;\n }\n }\n return rcpt;\n });\n }\n\n if (!jwe.recipients || jwe.recipients.length === 0) {\n delete jwe.recipients;\n }\n\n // \"serialize\" (and setup merged props)\n if (unprotect && lenUnprotect > 0) {\n props = assign(props, unprotect);\n jwe.unprotected = unprotect;\n }\n if (protect && lenProtect > 0) {\n props = assign(props, protect);\n protect = JSON.stringify(protect);\n jwe.protected = util.base64url.encode(protect, \"utf8\");\n }\n\n return jwe;\n });\n\n // (OPTIONAL) compress plaintext\n promise = promise.then(function(jwe) {\n var pdata = content;\n if (!props.zip) {\n jwe.plaintext = pdata;\n return jwe;\n } else if (props.zip === \"DEF\") {\n return new Promise(function(resolve, reject) {\n try {\n var data = pako.deflateRaw(Buffer.from(pdata, \"binary\"));\n\n jwe.plaintext = Buffer.from(data);\n resolve(jwe);\n } catch (error) {\n reject(error);\n }\n });\n }\n return Promise.reject(new Error(\"unsupported 'zip' mode\"));\n });\n\n // encrypt plaintext\n promise = promise.then(function(jwe) {\n props.adata = jwe.protected;\n if (\"aad\" in cfg && cfg.aad != null) {\n props.adata += \".\" + cfg.aad;\n props.adata = Buffer.from(props.adata, \"utf8\");\n }\n // calculate IV\n var iv = cfg.iv ||\n util.randomBytes(CONSTANTS.NONCELENGTH[encAlg] / 8);\n if (\"string\" === typeof iv) {\n iv = util.base64url.decode(iv);\n }\n props.iv = iv;\n\n if (\"recipients\" in jwe && jwe.recipients.length === 1) {\n props.kdata = jwe.recipients[0].encrypted_key;\n }\n\n if (\"epu\" in cfg && cfg.epu != null) {\n props.epu = cfg.epu;\n }\n\n if (\"epv\" in cfg && cfg.epv != null) {\n props.epv = cfg.epv;\n }\n\n var pdata = jwe.plaintext;\n delete jwe.plaintext;\n return encKey.then(function(encKey) {\n var p = encKey.encrypt(encAlg, pdata, props);\n p = p.then(function(result) {\n jwe.iv = util.base64url.encode(iv, \"binary\");\n if (\"aad\" in cfg && cfg.aad != null) {\n jwe.aad = cfg.aad;\n }\n jwe.ciphertext = util.base64url.encode(result.data, \"binary\");\n jwe.tag = util.base64url.encode(result.tag, \"binary\");\n return jwe;\n });\n return p;\n });\n });\n\n // (OPTIONAL) compact/flattened results\n switch (format) {\n case \"compact\":\n promise = promise.then(function(jwe) {\n var compact = new Array(5);\n\n compact[0] = jwe.protected;\n if (jwe.recipients && jwe.recipients[0]) {\n compact[1] = jwe.recipients[0].encrypted_key;\n }\n\n compact[2] = jwe.iv;\n compact[3] = jwe.ciphertext;\n compact[4] = jwe.tag;\n compact = compact.join(\".\");\n\n return compact;\n });\n break;\n case \"flattened\":\n promise = promise.then(function(jwe) {\n var flattened = {},\n rcpt = jwe.recipients && jwe.recipients[0];\n\n if (jwe.protected) {\n flattened.protected = jwe.protected;\n }\n if (jwe.unprotected) {\n flattened.unprotected = jwe.unprotected;\n }\n [\"header\", \"encrypted_key\"].forEach(function(f) {\n if (!rcpt) { return; }\n if (!(f in rcpt)) { return; }\n if (!rcpt[f]) { return; }\n if (\"object\" === typeof rcpt[f] && !Object.keys(rcpt[f]).length) { return; }\n flattened[f] = rcpt[f];\n });\n if (jwe.aad) {\n flattened.aad = jwe.aad;\n }\n flattened.iv = jwe.iv;\n flattened.ciphertext = jwe.ciphertext;\n flattened.tag = jwe.tag;\n\n return flattened;\n });\n break;\n case \"general\":\n promise = promise.then(function(jwe) {\n var recipients = jwe.recipients || [];\n recipients = recipients.map(function (rcpt) {\n if (!Object.keys(rcpt).length) { return undefined; }\n return rcpt;\n });\n recipients = recipients.filter(function (rcpt) { return !!rcpt; });\n if (recipients.length) {\n jwe.recipients = recipients;\n } else {\n delete jwe.recipients;\n }\n\n return jwe;\n });\n }\n\n return promise;\n }\n });\n}\n\nfunction createEncrypt(opts, rcpts) {\n // fixup recipients\n var options = opts,\n rcptStart = 1,\n rcptList = rcpts;\n\n if (arguments.length === 0) {\n throw new Error(\"at least one recipient must be provided\");\n }\n if (arguments.length === 1) {\n // assume opts is the recipient list\n rcptList = opts;\n rcptStart = 0;\n options = {};\n } else if (JWK.isKey(opts) ||\n (opts && \"kty\" in opts) ||\n (opts && \"key\" in opts &&\n (JWK.isKey(opts.key) || \"kty\" in opts.key))) {\n rcptList = opts;\n rcptStart = 0;\n options = {};\n } else {\n options = clone(opts);\n }\n if (!Array.isArray(rcptList)) {\n rcptList = slice(arguments, rcptStart);\n }\n\n // fixup options\n options = assign(clone(DEFAULTS), options);\n\n // setup header fields\n var fields = clone(options.fields || {});\n if (options.zip) {\n fields.zip = (typeof options.zip === \"boolean\") ?\n (options.zip ? \"DEF\" : false) :\n options.zip;\n }\n options.format = (options.compact ? \"compact\" : options.format) || \"general\";\n switch (options.format) {\n case \"compact\":\n if (\"aad\" in opts) {\n throw new Error(\"additional authenticated data cannot be used for compact serialization\");\n }\n /* eslint no-fallthrough: [0] */\n case \"flattened\":\n if (rcptList.length > 1) {\n throw new Error(\"too many recipients for compact serialization\");\n }\n break;\n }\n\n // note protected fields (globally)\n // protected fields are global only\n var protectAll = false;\n if (\"compact\" === options.format || \"*\" === options.protect) {\n protectAll = true;\n options.protect = Object.keys(fields).concat(\"enc\");\n } else if (typeof options.protect === \"string\") {\n options.protect = [options.protect];\n } else if (Array.isArray(options.protect)) {\n options.protect = options.protect.concat();\n } else if (!options.protect) {\n options.protect = [];\n } else {\n throw new Error(\"protect must be a list of fields\");\n }\n\n if (protectAll && 1 < rcptList.length) {\n throw new Error(\"too many recipients to protect all header parameters\");\n }\n\n rcptList = rcptList.map(function(r, idx) {\n var p;\n\n // resolve a key\n if (r && \"kty\" in r) {\n p = JWK.asKey(r);\n p = p.then(function(k) {\n return {\n key: k\n };\n });\n } else if (r) {\n p = JWK.asKey(r.key);\n p = p.then(function(k) {\n return {\n header: r.header,\n reference: r.reference,\n key: k\n };\n });\n } else {\n p = Promise.reject(new Error(\"missing key for recipient \" + idx));\n }\n\n // convert ephemeral key (if present)\n if (r.epk) {\n p = p.then(function(recipient) {\n return JWK.asKey(r.epk).\n then(function(epk) {\n recipient.epk = epk;\n return recipient;\n });\n });\n }\n\n // resolve the complete recipient\n p = p.then(function(recipient) {\n var key = recipient.key;\n\n // prepare the recipient header\n var header = recipient.header || {};\n recipient.header = header;\n var props = {};\n props = assign(props, fields);\n props = assign(props, recipient.header);\n\n // ensure key protection algorithm is set\n if (!props.alg) {\n props.alg = key.algorithms(JWK.MODE_WRAP)[0];\n header.alg = props.alg;\n }\n if (!props.alg) {\n return Promise.reject(new Error(\"key not valid for encrypting to recipient \" + idx));\n }\n header.alg = props.alg;\n\n // determine the key reference\n var ref = recipient.reference;\n delete recipient.reference;\n if (undefined === ref) {\n // header already contains the key reference\n ref = [\"kid\", \"jku\", \"x5c\", \"x5t\", \"x5u\"].some(function(k) {\n return (k in header);\n });\n ref = !ref ? \"kid\" : null;\n } else if (\"boolean\" === typeof ref) {\n // explicit (positive | negative) request for key reference\n ref = ref ? \"kid\" : null;\n }\n var jwk;\n if (ref) {\n jwk = key.toJSON();\n if (\"jwk\" === ref) {\n if (\"oct\" === key.kty) {\n return Promise.reject(new Error(\"cannot embed key\"));\n }\n header.jwk = jwk;\n } else if (ref in jwk) {\n header[ref] = jwk[ref];\n }\n }\n\n // freeze recipient\n recipient = Object.freeze(recipient);\n return recipient;\n });\n\n return p;\n });\n\n // create and configure encryption\n var cfg = {\n aad: (\"aad\" in options) ? util.base64url.encode(options.aad || \"\") : null,\n contentAlg: options.contentAlg,\n format: options.format,\n protect: options.protect,\n cek: options.cek,\n iv: options.iv,\n protectAll: protectAll\n };\n var enc = new JWEEncrypter(cfg, fields, rcptList);\n\n return enc;\n}\n\nmodule.exports = {\n encrypter: JWEEncrypter,\n createEncrypt: createEncrypt\n};\n","/*!\n * jwe/helpers.js - JWE Internal Helper Functions\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar CONSTANTS = require(\"../algorithms/constants\"),\n JWK = require(\"../jwk\");\n\nmodule.exports = {\n slice: function(input, start) {\n return Array.prototype.slice.call(input, start || 0);\n },\n generateCEK: function(enc) {\n var ks = JWK.createKeyStore();\n var len = CONSTANTS.KEYLENGTH[enc];\n\n if (len) {\n return ks.generate(\"oct\", len);\n }\n\n throw new Error(\"unsupported encryption algorithm\");\n }\n};\n","/*!\n * jwe/index.js - JSON Web Encryption (JWE) Entry Point\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar JWE = {\n createEncrypt: require(\"./encrypt\").createEncrypt,\n createDecrypt: require(\"./decrypt\").createDecrypt\n};\n\nmodule.exports = JWE;\n","/*!\n * jwk/basekey.js - JWK Key Base Class Implementation\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar merge = require(\"../util/merge\");\nconst { v4: uuidv4 } = require(\"uuid\");\n\nvar assign = require(\"lodash/assign\");\nvar clone = require(\"lodash/clone\");\nvar flatten = require(\"lodash/flatten\");\nvar intersection = require(\"lodash/intersection\");\nvar omit = require(\"lodash/omit\");\nvar pick = require(\"lodash/pick\");\nvar uniq = require(\"lodash/uniq\");\n\nvar ALGORITHMS = require(\"../algorithms\"),\n CONSTANTS = require(\"./constants.js\"),\n HELPERS = require(\"./helpers.js\"),\n UTIL = require(\"../util\");\n\n/**\n * @class JWK.Key\n * @classdesc\n * Represents a JSON Web Key instance.\n *\n * @description\n * **NOTE:** This class cannot be instantiated directly. Instead call\n * {@link JWK.asKey}, {@link JWK.KeyStore#add}, or\n * {@link JWK.KeyStore#generate}.\n */\nvar JWKBaseKeyObject = function(kty, ks, props, cfg) {\n // ### validate/coerce arguments ###\n if (!kty) {\n throw new Error(\"kty cannot be null\");\n }\n\n if (!ks) {\n throw new Error(\"keystore cannot be null\");\n }\n\n if (!props) {\n throw new Error(\"props cannot be null\");\n } else if (\"string\" === typeof props) {\n props = JSON.parse(props);\n }\n\n if (!cfg) {\n throw new Error(\"cfg cannot be null\");\n }\n\n var excluded = [];\n var keys = {},\n json = {},\n prints,\n kid;\n\n props = clone(props);\n // strip thumbprints if present\n prints = assign({}, props[HELPERS.INTERNALS.THUMBPRINT_KEY] || {});\n delete props[HELPERS.INTERNALS.THUMBPRINT_KEY];\n Object.keys(prints).forEach(function(a) {\n var h = prints[a];\n if (!kid) {\n kid = h;\n if (Buffer.isBuffer(kid)) {\n kid = UTIL.base64url.encode(kid);\n }\n }\n if (!Buffer.isBuffer(h)) {\n h = UTIL.base64url.decode(h);\n prints[a] = h;\n }\n });\n\n // force certain values\n props.kty = kty;\n props.kid = props.kid || kid || uuidv4();\n\n // setup base info\n var included = Object.keys(HELPERS.COMMON_PROPS).map(function(p) {\n return HELPERS.COMMON_PROPS[p].name;\n });\n json.base = pick(props, included);\n excluded = excluded.concat(Object.keys(json.base));\n\n // setup public information\n json.public = clone(props);\n keys.public = cfg.publicKey(json.public);\n if (keys.public) {\n // exclude public values from extra\n excluded = excluded.concat(Object.keys(json.public));\n }\n\n // setup private information\n json.private = clone(props);\n keys.private = cfg.privateKey(json.private);\n if (keys.private) {\n // exclude private values from extra\n excluded = excluded.concat(Object.keys(json.private));\n }\n\n // setup extra information\n json.extra = omit(props, excluded);\n\n // TODO: validate 'alg' against supported algorithms\n\n // setup calculated values\n var keyLen;\n if (keys.public && (\"length\" in keys.public)) {\n keyLen = keys.public.length;\n } else if (keys.private && (\"length\" in keys.private)) {\n keyLen = keys.private.length;\n } else {\n keyLen = NaN;\n }\n\n // ### Public Properties ###\n /**\n * @member {JWK.KeyStore} JWK.Key#keystore\n * @description\n * The owning keystore.\n */\n Object.defineProperty(this, \"keystore\", {\n value: ks,\n enumerable: true\n });\n /**\n * @member {Number} JWK.Key#length\n * @description\n * The size of this Key, in bits.\n */\n Object.defineProperty(this, \"length\", {\n value: keyLen,\n enumerable: true\n });\n /**\n * @member {String} JWK.Key#kty\n * @description\n * The type of Key.\n */\n Object.defineProperty(this, \"kty\", {\n value: kty,\n enumerable: true\n });\n\n /**\n * @member {String} JWK.Key#kid\n * @description\n * The identifier for this Key.\n */\n Object.defineProperty(this, \"kid\", {\n value: json.base.kid,\n enumerable: true\n });\n /**\n * @member {String} JWK.Key#use\n * @description\n * The usage for this Key.\n */\n Object.defineProperty(this, \"use\", {\n value: json.base.use || \"\",\n enumerable: true\n });\n /**\n * @member {String} JWK.Key#alg\n * @description\n * The sole algorithm this key can be used for.\n */\n Object.defineProperty(this, \"alg\", {\n value: json.base.alg || \"\",\n enumerable: true\n });\n\n // ### Public Methods ###\n /**\n * Generates the thumbprint of this Key.\n *\n * @param {String} [] The hash algorithm to use\n * @returns {Promise} The promise for the thumbprint generation.\n */\n Object.defineProperty(this, \"thumbprint\", {\n value: function(hash) {\n hash = (hash || HELPERS.INTERNALS.THUMBPRINT_HASH).toUpperCase();\n if (prints[hash]) {\n // return cached value\n return Promise.resolve(prints[hash]);\n }\n var p = HELPERS.thumbprint(cfg, json, hash);\n p = p.then(function(result) {\n if (result) {\n prints[hash] = result;\n }\n return result;\n });\n return p;\n }\n });\n /**\n * @method JWK.Key#algorithms\n * @description\n * The possible algorithms this Key can be used for. The returned\n * list is not any particular order, but is filtered based on the\n * Key's intended usage.\n *\n * @param {String} mode The operation mode\n * @returns {String[]} The list of supported algorithms\n * @see JWK.Key#supports\n */\n Object.defineProperty(this, \"algorithms\", {\n value: function(mode) {\n var modes = [];\n if (!this.use || this.use === \"sig\") {\n if (!mode || CONSTANTS.MODE_SIGN === mode) {\n modes.push(CONSTANTS.MODE_SIGN);\n }\n if (!mode || CONSTANTS.MODE_VERIFY === mode) {\n modes.push(CONSTANTS.MODE_VERIFY);\n }\n }\n if (!this.use || this.use === \"enc\") {\n if (!mode || CONSTANTS.MODE_ENCRYPT === mode) {\n modes.push(CONSTANTS.MODE_ENCRYPT);\n }\n if (!mode || CONSTANTS.MODE_DECRYPT === mode) {\n modes.push(CONSTANTS.MODE_DECRYPT);\n }\n if (!mode || CONSTANTS.MODE_WRAP === mode) {\n modes.push(CONSTANTS.MODE_WRAP);\n }\n if (!mode || CONSTANTS.MODE_UNWRAP === mode) {\n modes.push(CONSTANTS.MODE_UNWRAP);\n }\n }\n\n var self = this;\n var algs = modes.map(function(m) {\n return cfg.algorithms.call(self, keys, m);\n });\n algs = flatten(algs);\n algs = uniq(algs);\n if (this.alg) {\n // TODO: fix this correctly\n var valid;\n if (\"oct\" === kty) {\n valid = [this.alg, \"dir\"];\n } else {\n valid = [this.alg];\n }\n algs = intersection(algs, valid);\n }\n\n return algs;\n }\n });\n /**\n * @method JWK.Key#supports\n * @description\n * Determines if the given algorithm is supported.\n *\n * @param {String} alg The algorithm in question\n * @param {String} [mode] The operation mode\n * @returns {Boolean} `true` if {alg} is supported, and `false` otherwise.\n * @see JWK.Key#algorithms\n */\n Object.defineProperty(this, \"supports\", {\n value: function(alg, mode) {\n return (this.algorithms(mode).indexOf(alg) !== -1);\n }\n });\n /**\n * @method JWK.Key#has\n * @description\n * Determines if this Key contains the given parameter.\n *\n * @param {String} name The name of the parameter\n * @param {Boolean} [isPrivate=false] `true` if private parameters should be\n * checked.\n * @returns {Boolean} `true` if the given parameter is present; `false`\n * otherwise.\n */\n Object.defineProperty(this, \"has\", {\n value: function(name, isPrivate) {\n var contains = false;\n contains = contains || !!(json.base &&\n (name in json.base));\n contains = contains || !!(keys.public &&\n (name in keys.public));\n contains = contains || !!(json.extra &&\n (name in json.extra));\n contains = contains || !!(isPrivate &&\n keys.private &&\n (name in keys.private));\n // TODO: check for export restrictions\n\n return contains;\n }\n });\n /**\n * @method JWK.Key#get\n * @description\n * Retrieves the value of the given parameter. The value returned by this\n * method is in its natural format, which might not exactly match its\n * JSON encoding (e.g., a binary string rather than a base64url-encoded\n * string).\n *\n * **NOTE:** This method can return `false`. Call\n * {@link JWK.Key#has} to determine if the parameter is present.\n *\n * @param {String} name The name of the parameter\n * @param {Boolean} [isPrivate=false] `true` if private parameters should\n * be checked.\n * @returns {any} The value of the named parameter, or undefined if\n * it is not present.\n */\n Object.defineProperty(this, \"get\", {\n value: function(name, isPrivate) {\n var src;\n if (json.base && (name in json.base)) {\n src = json.base;\n } else if (keys.public && (name in keys.public)) {\n src = keys.public;\n } else if (json.extra && (name in json.extra)) {\n src = json.extra;\n } else if (isPrivate && keys.private && (name in keys.private)) {\n // TODO: check for export restrictions\n src = keys.private;\n }\n\n return src && src[name] || null;\n }\n });\n /**\n * @method JWK.Key#toJSON\n * @description\n * Returns the JSON representation of this Key. All properties of the\n * returned JSON object are properly encoded (e.g., base64url encoding for\n * any binary strings).\n *\n * @param {Boolean} [isPrivate=false] `true` if private parameters should be\n * included.\n * @param {String[]} [excluded] The list of parameters to exclude from\n * the returned JSON.\n * @returns {Object} The plain JSON object\n */\n Object.defineProperty(this, \"toJSON\", {\n value: function(isPrivate, excluded) {\n // coerce arguments\n if (Array.isArray(isPrivate)) {\n excluded = isPrivate;\n isPrivate = false;\n }\n var result = {};\n\n // TODO: check for export restrictions\n result = merge(result,\n json.base,\n json.public,\n (\"boolean\" === typeof isPrivate && isPrivate) ? json.private : {},\n json.extra);\n result = omit(result, excluded || []);\n\n return result;\n }\n });\n\n /**\n * @method JWK.Key#toPEM\n * @description\n * Returns the PEM representation of this Key as a string.\n *\n * @param {Boolean} [isPrivate=false] `true` if private parameters should be\n * included.\n * @returns {string} The PEM-encoded string\n */\n Object.defineProperty(this, \"toPEM\", {\n value: function(isPrivate) {\n if (isPrivate === null) {\n isPrivate = false;\n }\n\n if (!cfg.convertToPEM) {\n throw new Error(\"Unsupported key type for PEM encoding\");\n }\n var k = (isPrivate) ? keys.private : keys.public;\n if (!k) {\n throw new Error(\"Invalid key\");\n }\n return cfg.convertToPEM.call(this, k, isPrivate);\n }\n });\n\n /**\n * @method JWK.Key#toObject\n * @description\n * Returns the plain object representing this Key. All properties of the\n * returned object are in their natural encoding (e.g., binary strings\n * instead of base64url encoded).\n *\n * @param {Boolean} [isPrivate=false] `true` if private parameters should be\n * included.\n * @param {String[]} [excluded] The list of parameters to exclude from\n * the returned object.\n * @returns {Object} The plain Object.\n */\n Object.defineProperty(this, \"toObject\", {\n value: function(isPrivate, excluded) {\n // coerce arguments\n if (Array.isArray(isPrivate)) {\n excluded = isPrivate;\n isPrivate = false;\n }\n var result = {};\n\n // TODO: check for export restrictions\n result = merge(result,\n json.base,\n keys.public,\n (\"boolean\" === typeof isPrivate && isPrivate) ? keys.private : {},\n json.extra);\n result = omit(result, (excluded || []).concat(\"length\"));\n\n return result;\n }\n });\n\n /**\n * @method JWK.Key#sign\n * @description\n * Sign the given data using the specified algorithm.\n *\n * **NOTE:** This is the primitive signing operation; the output is\n * _**NOT**_ a JSON Web Signature (JWS) object.\n *\n * The Promise, when fulfilled, returns an Object with the following\n * properties:\n *\n * + **data**: The data that was signed (and should be equal to {data}).\n * + **mac**: The signature or message authentication code (MAC).\n *\n * @param {String} alg The signing algorithm\n * @param {String|Buffer} data The data to sign\n * @param {Object} [props] Additional properties for the signing\n * algorithm.\n * @returns {Promise} The promise for the signing operation.\n * @throws {Error} If {alg} is not appropriate for this Key; or if\n * this Key does not contain the appropriate parameters.\n */\n Object.defineProperty(this, \"sign\", {\n value: function(alg, data, props) {\n // validate appropriateness\n if (this.algorithms(\"sign\").indexOf(alg) === -1) {\n return Promise.reject(new Error(\"unsupported algorithm\"));\n }\n var k = cfg.signKey.call(this, alg, keys);\n if (!k) {\n return Promise.reject(new Error(\"improper key\"));\n }\n\n // prepare properties (if any)\n props = (props) ?\n clone(props) :\n {};\n if (cfg.signProps) {\n props = merge(props, cfg.signProps.call(this, alg, props));\n }\n return ALGORITHMS.sign(alg, k, data, props);\n }\n });\n /**\n * @method JWK.Key#verify\n * @description\n * Verify the given data and signature using the specified algorithm.\n *\n * **NOTE:** This is the primitive verification operation; the input is\n * _**NOT**_ a JSON Web Signature.

\n *\n * The Promise, when fulfilled, returns an Object with the following\n * properties:\n *\n * + **data**: The data that was verified (and should be equal to\n * {data}).\n * + **mac**: The signature or MAC that was verified (and should be equal\n * to {mac}).\n * + **valid**: `true` if {mac} is valid for {data}.\n *\n * @param {String} alg The verification algorithm\n * @param {String|Buffer} data The data to verify\n * @param {String|Buffer} mac The signature or MAC to verify\n * @param {Object} [props] Additional properties for the verification\n * algorithm.\n * @returns {Promise} The promise for the verification operation.\n * @throws {Error} If {alg} is not appropriate for this Key; or if\n * the Key does not contain the appropriate properties.\n */\n Object.defineProperty(this, \"verify\", {\n value: function(alg, data, mac, props) {\n // validate appropriateness\n if (this.algorithms(\"verify\").indexOf(alg) === -1) {\n return Promise.reject(new Error(\"unsupported algorithm\"));\n }\n var k = cfg.verifyKey.call(this, alg, keys);\n if (!k) {\n return Promise.reject(new Error(\"improper key\"));\n }\n\n // prepare properties (if any)\n props = (props) ?\n clone(props) :\n {};\n if (cfg.verifyProps) {\n props = merge(props, cfg.verifyProps.call(this, alg, props));\n }\n return ALGORITHMS.verify(alg, k, data, mac, props);\n }\n });\n\n /**\n * @method JWK.Key#encrypt\n * @description\n * Encrypts the given data using the specified algorithm.\n *\n * **NOTE:** This is the primitive encryption operation; the output is\n * _**NOT**_ a JSON Web Encryption (JWE) object.\n *\n * **NOTE:** This operation is treated as distinct from {@link\n * JWK.Key#wrap}, as different algorithms and properties are often\n * used for wrapping a key versues encrypting arbitrary data.\n *\n * The Promise, when fulfilled, returns an object with the following\n * properties:\n *\n * + **data**: The ciphertext data\n * + **mac**: The associated message authentication code (MAC).\n *\n * @param {String} alg The encryption algorithm\n * @param {Buffer|String} data The data to encrypt\n * @param {Object} [props] Additional properties for the encryption\n * algorithm.\n * @returns {Promise} The promise for the encryption operation.\n * @throws {Error} If {alg} is not appropriate for this Key; or if\n * this Key does not contain the appropriate parameters.\n */\n Object.defineProperty(this, \"encrypt\", {\n value: function(alg, data, props) {\n // validate appropriateness\n if (this.algorithms(\"encrypt\").indexOf(alg) === -1) {\n return Promise.reject(new Error(\"unsupported algorithm\"));\n }\n var k = cfg.encryptKey.call(this, alg, keys);\n if (!k) {\n return Promise.reject(new Error(\"improper key\"));\n }\n\n // prepare properties (if any)\n props = (props) ?\n clone(props) :\n {};\n if (cfg.encryptProps) {\n props = merge(props, cfg.encryptProps.call(this, alg, props));\n }\n return ALGORITHMS.encrypt(alg, k, data, props);\n }\n });\n /**\n * @method JWK.Key#decrypt\n * @description\n * Decrypts the given data using the specified algorithm.\n *\n * **NOTE:** This is the primitive decryption operation; the input is\n * _**NOT**_ a JSON Web Encryption (JWE) object.\n *\n * **NOTE:** This operation is treated as distinct from {@link\n * JWK.Key#unwrap}, as different algorithms and properties are often used\n * for unwrapping a key versues decrypting arbitrary data.\n *\n * The Promise, when fulfilled, returns the plaintext data.\n *\n * @param {String} alg The decryption algorithm.\n * @param {Buffer|String} data The data to decypt.\n * @param {Object} [props] Additional data for the decryption operation.\n * @returns {Promise} The promise for the decryption operation.\n * @throws {Error} If {alg} is not appropriate for this Key; or if\n * the Key does not contain the appropriate properties.\n */\n Object.defineProperty(this, \"decrypt\", {\n value: function(alg, data, props) {\n // validate appropriateness\n if (this.algorithms(\"decrypt\").indexOf(alg) === -1) {\n return Promise.reject(new Error(\"unsupported algorithm\"));\n }\n var k = cfg.decryptKey.call(this, alg, keys);\n if (!k) {\n return Promise.reject(new Error(\"improper key\"));\n }\n\n // prepare properties (if any)\n props = (props) ?\n clone(props) :\n {};\n if (cfg.decryptProps) {\n props = merge(props, cfg.decryptProps.call(this, alg, props));\n }\n return ALGORITHMS.decrypt(alg, k, data, props);\n }\n });\n\n /**\n * @method JWK.Key#wrap\n * @description\n * Wraps the given key using the specified algorithm.\n *\n * **NOTE:** This is the primitive encryption operation; the output is\n * _**NOT**_ a JSON Web Encryption (JWE) object.\n *\n * **NOTE:** This operation is treated as distinct from {@link\n * JWK.Key#encrypt}, as different algorithms and properties are\n * often used for wrapping a key versues encrypting arbitrary data.\n *\n * The Promise, when fulfilled, returns an object with the following\n * properties:\n *\n * + **data**: The ciphertext data\n * + **headers**: The additional header parameters to apply to a JWE.\n *\n * @param {String} alg The encryption algorithm\n * @param {Buffer|String} data The data to encrypt\n * @param {Object} [props] Additional properties for the encryption\n * algorithm.\n * @returns {Promise} The promise for the encryption operation.\n * @throws {Error} If {alg} is not appropriate for this Key; or if\n * this Key does not contain the appropriate parameters.\n */\n Object.defineProperty(this, \"wrap\", {\n value: function(alg, data, props) {\n // validate appropriateness\n if (this.algorithms(\"wrap\").indexOf(alg) === -1) {\n return Promise.reject(new Error(\"unsupported algorithm\"));\n }\n var k = cfg.wrapKey.call(this, alg, keys);\n if (!k) {\n return Promise.reject(new Error(\"improper key\"));\n }\n\n // prepare properties (if any)\n props = (props) ?\n clone(props) :\n {};\n if (cfg.wrapProps) {\n props = merge(props, cfg.wrapProps.call(this, alg, props));\n }\n return ALGORITHMS.encrypt(alg, k, data, props);\n }\n });\n /**\n * @method JWK.Key#unwrap\n * @description\n * Unwraps the given key using the specified algorithm.\n *\n * **NOTE:** This is the primitive unwrap operation; the input is\n * _**NOT**_ a JSON Web Encryption (JWE) object.\n *\n * **NOTE:** This operation is treated as distinct from {@link\n * JWK.Key#decrypt}, as different algorithms and properties are often used\n * for unwrapping a key versues decrypting arbitrary data.\n *\n * The Promise, when fulfilled, returns the unwrapped key.\n *\n * @param {String} alg The unwrap algorithm.\n * @param {Buffer|String} data The data to unwrap.\n * @param {Object} [props] Additional data for the unwrap operation.\n * @returns {Promise} The promise for the unwrap operation.\n * @throws {Error} If {alg} is not appropriate for this Key; or if\n * the Key does not contain the appropriate properties.\n */\n Object.defineProperty(this, \"unwrap\", {\n value: function(alg, data, props) {\n // validate appropriateness\n if (this.algorithms(\"unwrap\").indexOf(alg) === -1) {\n return Promise.reject(new Error(\"unsupported algorithm\"));\n }\n var k = cfg.unwrapKey.call(this, alg, keys);\n if (!k) {\n return Promise.reject(new Error(\"improper key\"));\n }\n\n // prepare properties (if any)\n props = (props) ?\n clone(props) :\n {};\n if (cfg.unwrapProps) {\n props = merge(props, cfg.unwrapProps.call(this, alg, props));\n }\n return ALGORITHMS.decrypt(alg, k, data, props);\n }\n });\n};\n\nmodule.exports = JWKBaseKeyObject;\n","/*!\n * jwk/constants.js - Constants for JWKs\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nmodule.exports = {\n MODE_SIGN: \"sign\",\n MODE_VERIFY: \"verify\",\n MODE_ENCRYPT: \"encrypt\",\n MODE_DECRYPT: \"decrypt\",\n MODE_WRAP: \"wrap\",\n MODE_UNWRAP: \"unwrap\"\n};\n","/*!\n * jwk/rsa.js - RSA Key Representation\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar ecutil = require(\"../algorithms/ec-util.js\"),\n forge = require(\"../deps/forge\"),\n depsecc = require(\"../deps/ecc\");\n\nvar JWK = {\n BaseKey: require(\"./basekey.js\"),\n helpers: require(\"./helpers.js\")\n};\n\nvar SIG_ALGS = [\n \"ES256\",\n \"ES384\",\n \"ES512\"\n];\nvar WRAP_ALGS = [\n \"ECDH-ES\",\n \"ECDH-ES+A128KW\",\n \"ECDH-ES+A192KW\",\n \"ECDH-ES+A256KW\"\n];\n\nvar EC_OID = ecutil.EC_OID;\nfunction oidToCurveName(oid) {\n switch (oid) {\n case \"1.2.840.10045.3.1.7\":\n return \"P-256\";\n case \"1.3.132.0.34\":\n return \"P-384\";\n case \"1.3.132.0.35\":\n return \"P-521\";\n default:\n return null;\n }\n}\n\nvar JWKEcCfg = {\n publicKey: function(props) {\n var fields = JWK.helpers.COMMON_PROPS.concat([\n {name: \"crv\", type: \"string\"},\n {name: \"x\", type: \"binary\"},\n {name: \"y\", type: \"binary\"}\n ]);\n var pk = JWK.helpers.unpackProps(props, fields);\n if (pk && pk.crv && pk.x && pk.y) {\n pk.length = ecutil.curveSize(pk.crv);\n } else {\n delete pk.crv;\n delete pk.x;\n delete pk.y;\n }\n\n return pk;\n },\n privateKey: function(props) {\n var fields = JWK.helpers.COMMON_PROPS.concat([\n {name: \"crv\", type: \"string\"},\n {name: \"x\", type: \"binary\"},\n {name: \"y\", type: \"binary\"},\n {name: \"d\", type: \"binary\"}\n ]);\n var pk = JWK.helpers.unpackProps(props, fields);\n if (pk && pk.crv && pk.x && pk.y && pk.d) {\n pk.length = ecutil.curveSize(pk.crv);\n } else {\n pk = undefined;\n }\n\n return pk;\n },\n thumbprint: function(json) {\n if (json.public) {\n json = json.public;\n }\n var fields = {\n crv: json.crv,\n kty: \"EC\",\n x: json.x,\n y: json.y\n };\n return fields;\n },\n algorithms: function(keys, mode) {\n var len = (keys.public && keys.public.length) ||\n (keys.private && keys.private.length) ||\n 0;\n // NOTE: 521 is the actual, but 512 is the expected\n if (len === 521) {\n len = 512;\n }\n\n switch (mode) {\n case \"encrypt\":\n case \"decrypt\":\n return [];\n case \"wrap\":\n return (keys.public && WRAP_ALGS) || [];\n case \"unwrap\":\n return (keys.private && WRAP_ALGS) || [];\n case \"sign\":\n if (!keys.private) {\n return [];\n }\n return SIG_ALGS.filter(function(a) {\n return (a === (\"ES\" + len));\n });\n case \"verify\":\n if (!keys.public) {\n return [];\n }\n return SIG_ALGS.filter(function(a) {\n return (a === (\"ES\" + len));\n });\n }\n },\n\n encryptKey: function(alg, keys) {\n return keys.public;\n },\n decryptKey: function(alg, keys) {\n return keys.private;\n },\n\n wrapKey: function(alg, keys) {\n return keys.public;\n },\n unwrapKey: function(alg, keys) {\n return keys.private;\n },\n\n signKey: function(alg, keys) {\n return keys.private;\n },\n verifyKey: function(alg, keys) {\n return keys.public;\n }\n};\nJWKEcCfg.convertToPEM = ecutil.convertToPEM;\n\n// Inspired by digitalbaazar/node-forge/js/rsa.js\nvar validators = {\n oid: EC_OID,\n privateKey: {\n // ECPrivateKey\n name: \"ECPrivateKey\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n // EC version\n name: \"ECPrivateKey.version\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false\n },\n {\n // private value (d)\n name: \"ECPrivateKey.private\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.OCTETSTRING,\n constructed: false,\n capture: \"d\"\n },\n {\n // EC parameters\n tagClass: forge.asn1.Class.CONTEXT_SPECIFIC,\n name: \"ECPrivateKey.parameters\",\n constructed: true,\n value: [\n {\n // namedCurve (crv)\n name: \"ECPrivateKey.namedCurve\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.OID,\n constructed: false,\n capture: \"crv\"\n }\n ]\n },\n {\n // publicKey\n name: \"ECPrivateKey.publicKey\",\n tagClass: forge.asn1.Class.CONTEXT_SPECIFIC,\n constructed: true,\n value: [\n {\n name: \"ECPrivateKey.point\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.BITSTRING,\n constructed: false,\n capture: \"point\"\n }\n ]\n }\n ]\n },\n embeddedPrivateKey: {\n // ECPrivateKey\n name: \"ECPrivateKey\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n // EC version\n name: \"ECPrivateKey.version\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false\n },\n {\n // private value (d)\n name: \"ECPrivateKey.private\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.OCTETSTRING,\n constructed: false,\n capture: \"d\"\n },\n {\n // publicKey\n name: \"ECPrivateKey.publicKey\",\n tagClass: forge.asn1.Class.CONTEXT_SPECIFIC,\n constructed: true,\n value: [\n {\n name: \"ECPrivateKey.point\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.BITSTRING,\n constructed: false,\n capture: \"point\"\n }\n ]\n }\n ]\n }\n};\n\nvar JWKEcFactory = {\n kty: \"EC\",\n validators: validators,\n prepare: function(props) {\n // TODO: validate key properties\n var cfg = JWKEcCfg;\n var p = Promise.resolve(props);\n p = p.then(function(json) {\n return JWK.helpers.thumbprint(cfg, json);\n });\n p = p.then(function(hash) {\n var prints = {};\n prints[JWK.helpers.INTERNALS.THUMBPRINT_HASH] = hash;\n props[JWK.helpers.INTERNALS.THUMBPRINT_KEY] = prints;\n return cfg;\n });\n return p;\n },\n generate: function(size) {\n var keypair = depsecc.generateKeyPair(size);\n var result = {\n \"crv\": size,\n \"x\": keypair.public.x,\n \"y\": keypair.public.y,\n \"d\": keypair.private.d\n };\n return Promise.resolve(result);\n },\n import: function(input) {\n if (validators.oid !== input.keyOid) {\n return null;\n }\n\n // coerce key params to OID\n var crv;\n if (input.keyParams && forge.asn1.Type.OID === input.keyParams.type) {\n crv = forge.asn1.derToOid(input.keyParams.value);\n crv = oidToCurveName(crv);\n } else if (input.crv) {\n crv = forge.asn1.derToOid(input.crv);\n crv = oidToCurveName(crv);\n }\n if (!crv) {\n return null;\n }\n\n if (!input.parsed) {\n var capture = {},\n errors = [];\n if (\"private\" === input.type) {\n // coerce capture.value to DER *iff* private\n if (\"string\" === typeof input.keyValue) {\n input.keyValue = forge.asn1.fromDer(input.keyValue);\n } else if (Array.isArray(input.keyValue)) {\n input.keyValue = input.keyValue[0];\n }\n\n if (!forge.asn1.validate(input.keyValue,\n validators.embeddedPrivateKey,\n capture,\n errors)) {\n return null;\n }\n } else {\n capture.point = input.keyValue;\n }\n input = capture;\n }\n\n // convert factors to Buffers\n var output = {\n kty: \"EC\",\n crv: crv\n };\n if (input.d) {\n output.d = Buffer.from(input.d, \"binary\");\n }\n if (input.point) {\n var pt = Buffer.from(input.point, \"binary\");\n // only support uncompressed\n if (4 !== pt.readUInt16BE(0)) {\n return null;\n }\n pt = pt.slice(2);\n var len = pt.length / 2;\n output.x = pt.slice(0, len);\n output.y = pt.slice(len);\n }\n return output;\n }\n};\n// public API\nmodule.exports = Object.freeze({\n config: JWKEcCfg,\n factory: JWKEcFactory\n});\n\n// registration\n(function(REGISTRY) {\n REGISTRY.register(JWKEcFactory);\n})(require(\"./keystore\").registry);\n","/*!\n * jwk/helpers.js - JWK Internal Helper Functions and Constants\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar clone = require(\"lodash/clone\"),\n util = require(\"../util\"),\n forge = require(\"../deps/forge\");\n\nvar ALGORITHMS = require(\"../algorithms\");\n\n// ### ASN.1 Validators\n// Adapted from digitalbazaar/node-forge/js/asn1.js\n// PrivateKeyInfo\nvar privateKeyValidator = {\n name: \"PrivateKeyInfo\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n // Version (INTEGER)\n name: \"PrivateKeyInfo.version\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"keyVersion\"\n },\n {\n name: \"PrivateKeyInfo.privateKeyAlgorithm\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n name: \"AlgorithmIdentifier.algorithm\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.OID,\n constructed: false,\n capture: \"keyOid\"\n },\n {\n name: \"AlgorithmIdentifier.parameters\",\n captureAsn1: \"keyParams\"\n }\n ]\n },\n {\n name: \"PrivateKeyInfo\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.OCTETSTRING,\n constructed: false,\n capture: \"keyValue\"\n }\n ]\n};\n// Adapted from digitalbazaar/node-forge/x509.js\nvar publicKeyValidator = {\n name: \"SubjectPublicKeyInfo\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n name: \"SubjectPublicKeyInfo.AlgorithmIdentifier\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n name: \"AlgorithmIdentifier.algorithm\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.OID,\n constructed: false,\n capture: \"keyOid\"\n },\n {\n name: \"AlgorithmIdentifier.parameters\",\n captureAsn1: \"keyParams\"\n }\n ]\n },\n {\n name: \"SubjectPublicKeyInfo.subjectPublicKey\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.BITSTRING,\n constructed: false,\n capture: \"keyValue\"\n }\n ]\n};\n// Adapted from digitalbazaar/node-forge/x509.js\nvar X509CertificateValidator = {\n name: \"Certificate\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n name: \"Certificate.TBSCertificate\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: \"certificate\",\n value: [\n {\n name: \"Certificate.TBSCertificate.version\",\n tagClass: forge.asn1.Class.CONTEXT_SPECIFIC,\n type: 0,\n constructed: true,\n optional: true,\n value: [\n {\n name: \"Certificate.TBSCertificate.version.integer\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"certVersion\"\n }\n ]\n },\n {\n name: \"Certificate.TBSCertificate.serialNumber\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"certSerialNumber\"\n },\n {\n name: \"Certificate.TBSCertificate.signature\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n name: \"Certificate.TBSCertificate.signature.algorithm\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.OID,\n constructed: false,\n capture: \"certSignatureOid\"\n }, {\n name: \"Certificate.TBSCertificate.signature.parameters\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: \"certSignatureParams\"\n }\n ]\n },\n {\n name: \"Certificate.TBSCertificate.issuer\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n captureAsn1: \"certIssuer\"\n },\n {\n name: \"Certificate.TBSCertificate.validity\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.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 {\n // notBefore (Time) (UTC time case)\n name: \"Certificate.TBSCertificate.validity.notBefore (utc)\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.UTCTIME,\n constructed: false,\n optional: true,\n capture: \"certValidity1UTCTime\"\n },\n {\n // notBefore (Time) (generalized time case)\n name: \"Certificate.TBSCertificate.validity.notBefore (generalized)\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.GENERALIZEDTIME,\n constructed: false,\n optional: true,\n capture: \"certValidity2GeneralizedTime\"\n },\n {\n // notAfter (Time) (only UTC time is supported)\n name: \"Certificate.TBSCertificate.validity.notAfter (utc)\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.UTCTIME,\n constructed: false,\n optional: true,\n capture: \"certValidity3UTCTime\"\n },\n {\n // notAfter (Time) (only UTC time is supported)\n name: \"Certificate.TBSCertificate.validity.notAfter (generalized)\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.GENERALIZEDTIME,\n constructed: false,\n optional: true,\n capture: \"certValidity4GeneralizedTime\"\n }\n ]\n }, {\n // Name (subject) (RDNSequence)\n name: \"Certificate.TBSCertificate.subject\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.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: forge.asn1.Class.CONTEXT_SPECIFIC,\n type: 1,\n constructed: true,\n optional: true,\n value: [\n {\n name: \"Certificate.TBSCertificate.issuerUniqueID.id\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.BITSTRING,\n constructed: false,\n capture: \"certIssuerUniqueId\"\n }\n ]\n },\n {\n // subjectUniqueID (optional)\n name: \"Certificate.TBSCertificate.subjectUniqueID\",\n tagClass: forge.asn1.Class.CONTEXT_SPECIFIC,\n type: 2,\n constructed: true,\n optional: true,\n value: [\n {\n name: \"Certificate.TBSCertificate.subjectUniqueID.id\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.BITSTRING,\n constructed: false,\n capture: \"certSubjectUniqueId\"\n }\n ]\n },\n {\n // Extensions (optional)\n name: \"Certificate.TBSCertificate.extensions\",\n tagClass: forge.asn1.Class.CONTEXT_SPECIFIC,\n type: 3,\n constructed: true,\n captureAsn1: \"certExtensions\",\n optional: true\n }\n ]\n },\n {\n // AlgorithmIdentifier (signature algorithm)\n name: \"Certificate.signatureAlgorithm\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n // algorithm\n name: \"Certificate.signatureAlgorithm.algorithm\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.OID,\n constructed: false,\n capture: \"certSignatureOid\"\n },\n {\n name: \"Certificate.TBSCertificate.signature.parameters\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n optional: true,\n captureAsn1: \"certSignatureParams\"\n }\n ]\n },\n {\n // SignatureValue\n name: \"Certificate.signatureValue\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.BITSTRING,\n constructed: false,\n capture: \"certSignature\"\n }\n ]\n};\n\nvar INTERNALS = {\n THUMBPRINT_KEY: \"internal\\u0000thumbprint\",\n THUMBPRINT_HASH: \"SHA-256\"\n};\n\nmodule.exports = {\n validators: {\n privateKey: privateKeyValidator,\n publicKey: publicKeyValidator,\n certificate: X509CertificateValidator\n },\n\n thumbprint: function(cfg, json, hash) {\n if (\"function\" !== typeof cfg.thumbprint) {\n return Promise.reject(new Error(\"thumbprint not supported\"));\n }\n\n hash = (hash || INTERNALS.THUMBPRINT_HASH).toUpperCase();\n var fields = cfg.thumbprint(json);\n var input = Object.keys(fields).\n sort().\n map(function(k) {\n var v = fields[k];\n if (Buffer.isBuffer(v)) {\n v = util.base64url.encode(v);\n }\n return JSON.stringify(k) + \":\" + JSON.stringify(v);\n });\n input = \"{\" + input.join(\",\") + \"}\";\n try {\n return ALGORITHMS.digest(hash, Buffer.from(input, \"utf8\"));\n } catch (err) {\n return Promise.reject(err);\n }\n },\n unpackProps: function(props, allowed) {\n var output;\n\n // apply all of the existing values\n allowed.forEach(function(cfg) {\n if (!(cfg.name in props)) {\n return;\n }\n output = output || {};\n var value = props[cfg.name];\n switch (cfg.type) {\n case \"binary\":\n if (Buffer.isBuffer(value)) {\n props[cfg.name] = util.base64url.encode(value);\n } else {\n value = util.base64url.decode(value);\n }\n break;\n case \"string\":\n case \"number\":\n case \"boolean\":\n break;\n case \"array\":\n value = [].concat(value);\n break;\n case \"object\":\n value = clone(value);\n break;\n default:\n // TODO: deep clone?\n break;\n }\n output[cfg.name] = value;\n });\n\n // remove any from json that didn't apply\n var check = output || {};\n Object.keys(props).\n forEach(function(n) {\n if (n in check) { return; }\n delete props[n];\n });\n\n return output;\n },\n COMMON_PROPS: [\n {name: \"kty\", type: \"string\"},\n {name: \"kid\", type: \"string\"},\n {name: \"use\", type: \"string\"},\n {name: \"alg\", type: \"string\"},\n {name: \"x5c\", type: \"array\"},\n {name: \"x5t\", type: \"binary\"},\n {name: \"x5u\", type: \"string\"},\n {name: \"key_ops\", type: \"array\"}\n ],\n INTERNALS: INTERNALS\n};\n","/*!\n * jwk/index.js - JSON Web Key (JWK) Entry Point\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar JWKStore = require(\"./keystore.js\");\n\n// Public API -- Key and KeyStore methods\nObject.keys(JWKStore.KeyStore).forEach(function(name) {\n exports[name] = JWKStore.KeyStore[name];\n});\n\n// Public API -- constants\nvar CONSTANTS = require(\"./constants.js\");\nObject.keys(CONSTANTS).forEach(function(name) {\n exports[name] = CONSTANTS[name];\n});\n\n// Registered Key Types\nrequire(\"./octkey.js\");\nrequire(\"./rsakey.js\");\nrequire(\"./eckey.js\");\n","/*!\n * jwk/keystore.js - JWK KeyStore Implementation\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar clone = require(\"lodash/clone\"),\n merge = require(\"../util/merge\"),\n forge = require(\"../deps/forge\"),\n util = require(\"../util\");\n\nvar JWK = {\n BaseKey: require(\"./basekey.js\"),\n helpers: require(\"./helpers.js\")\n};\n\n/**\n * @class JWK.KeyStoreRegistry\n * @classdesc\n * A registry of JWK.Key types that can be used.\n *\n * @description\n * **NOTE:** This constructor cannot be called directly. Instead use the\n * global {JWK.registry}\n */\nvar JWKRegistry = function() {\n var types = {};\n\n Object.defineProperty(this, \"register\", {\n value: function(factory) {\n if (!factory || \"string\" !== typeof factory.kty || !factory.kty) {\n throw new Error(\"invalid Key factory\");\n }\n\n var kty = factory.kty;\n types[kty] = factory;\n return this;\n }\n });\n Object.defineProperty(this, \"unregister\", {\n value: function(factory) {\n if (!factory || \"string\" !== typeof factory.kty || !factory.kty) {\n throw new Error(\"invalid Key factory\");\n }\n\n var kty = factory.kty;\n if (factory === types[kty]) {\n delete types[kty];\n }\n return this;\n }\n });\n\n Object.defineProperty(this, \"get\", {\n value: function(kty) {\n return types[kty || \"\"] || undefined;\n }\n });\n Object.defineProperty(this, \"all\", {\n value: function() {\n return Object.keys(types).map(function(t) { return types[t]; });\n }\n });\n};\n\n// Globals\nvar GLOBAL_REGISTRY = new JWKRegistry();\n\n// importer\nfunction processCert(input) {\n // convert certIssuer to readable attributes\n [\"certIssuer\", \"certSubject\"].forEach(function(field) {\n /* eslint new-cap: [0] */\n var attrs = forge.pki.RDNAttributesAsArray(input[field]);\n var result = input[field] = {};\n attrs.forEach(function(a) {\n result[a.name || a.type] = a.value;\n });\n });\n\n return input;\n}\n\nfunction fromPEM(input) {\n var result = {};\n var pems = forge.pem.decode(input);\n var found = pems.some(function(p) {\n switch (p.type) {\n case \"CERTIFICATE\":\n result.form = \"pkix\";\n break;\n case \"PUBLIC KEY\":\n result.form = \"spki\";\n break;\n case \"PRIVATE KEY\":\n result.form = \"pkcs8\";\n break;\n case \"EC PRIVATE KEY\":\n /* eslint no-fallthrough: [0] */\n case \"RSA PRIVATE KEY\":\n result.form = \"private\";\n break;\n default:\n return false;\n }\n\n result.body = p.body;\n return true;\n });\n if (!found) {\n throw new Error(\"supported PEM type not found\");\n }\n return result;\n}\nfunction importFrom(registry, input) {\n // form can be one of:\n // 'private' | 'pkcs8' | 'public' | 'spki' | 'pkix' | 'x509'\n var capture = {},\n errors = [],\n result;\n\n // conver from DER to ASN1\n var form = input.form,\n der = input.body,\n thumbprint = null;\n input = forge.asn1.fromDer(der);\n switch(form) {\n case \"private\":\n registry.all().some(function(factory) {\n if (result) {\n return false;\n }\n if (!factory.validators) {\n return false;\n }\n\n var oid = factory.validators.oid,\n validator = factory.validators.privateKey;\n if (!validator) {\n return false;\n }\n capture = {};\n errors = [];\n result = forge.asn1.validate(input, validator, capture, errors);\n if (result) {\n capture.keyOid = forge.asn1.oidToDer(oid);\n capture.parsed = true;\n }\n return result;\n });\n capture.type = \"private\";\n break;\n case \"pkcs8\":\n result = forge.asn1.validate(input, JWK.helpers.validators.privateKey, capture, errors);\n capture.type = \"private\";\n break;\n case \"public\":\n // eslint no-fallthrough: [0] */\n case \"spki\":\n result = forge.asn1.validate(input, JWK.helpers.validators.publicKey, capture, errors);\n capture.type = \"public\";\n break;\n case \"pkix\":\n /* eslint no-fallthrough: [0] */\n case \"x509\":\n result = forge.asn1.validate(input, JWK.helpers.validators.certificate, capture, errors);\n if (result) {\n capture = processCert(capture);\n var md = forge.md.sha1.create();\n md.update(der);\n thumbprint = util.base64url.encode(Buffer.from(md.digest().toHex(), \"hex\"));\n }\n capture.type = \"public\";\n break;\n }\n if (!result) {\n return null;\n }\n\n // convert oids\n if (capture.keyOid) {\n capture.keyOid = forge.asn1.derToOid(capture.keyOid);\n }\n\n // find and invoke the importer\n result = null;\n GLOBAL_REGISTRY.all().forEach(function(factory) {\n if (result) {\n return;\n }\n if (!factory) {\n return;\n }\n if (\"function\" !== typeof factory.import) {\n return;\n }\n result = factory.import(capture);\n });\n if (result && capture.certSubject && capture.certSubject.commonName) {\n result.kid = capture.certSubject.commonName;\n }\n if (result && thumbprint) {\n result.x5t = thumbprint;\n }\n return result;\n}\n\n/**\n * @class JWK.KeyStore\n * @classdesc\n * Represents a collection of Keys.\n *\n * @description\n * **NOTE:** This constructor cannot be called directly. Instead call {@link\n * JWK.createKeyStore}.\n */\nvar JWKStore = function(registry, parent) {\n var keysets = {};\n\n /**\n * @method JWK.KeyStore#generate\n * @description\n * Generates a new random Key into this KeyStore.\n *\n * The type of {size} depends on the value of {kty}:\n *\n * + **`EC`**: String naming the curve to use, which can be one of:\n * `\"P-256\"`, `\"P-384\"`, or `\"P-521\"` (default is **`\"P-256\"`**).\n * + **`RSA`**: Number describing the size of the key, in bits (default is\n * **`2048`**).\n * + **`oct`**: Number describing the size of the key, in bits (default is\n * **`256`**).\n *\n * Any properties in {props} are applied before the key is generated,\n * and are expected to be data types acceptable in JSON. This allows the\n * generated key to have a specific key identifier, or to specify its\n * acceptable usage.\n *\n * The returned Promise, when fulfilled, returns the generated Key.\n *\n * @param {String} kty The type of generated key\n * @param {String|Number} [size] The size of the generated key\n * @param {Object} [props] Additional properties to apply to the generated\n * key.\n * @returns {Promise} The promise for the generated Key\n * @throws {Error} If {kty} is not supported\n */\n Object.defineProperty(this, \"generate\", {\n value: function(kty, size, props) {\n var keytype = registry.get(kty);\n if (!keytype) {\n return Promise.reject(new Error(\"unsupported key type\"));\n }\n\n props = clone(props || {});\n props.kty = kty;\n\n var self = this,\n promise = keytype.generate(size);\n return promise.then(function(jwk) {\n jwk = merge(props, jwk, {\n kty: kty\n });\n return self.add(jwk);\n });\n }\n });\n /**\n * @method JWK.KeyStore#add\n * @description\n * Adds a Key to this KeyStore. If {jwk} is a string, it is first\n * parsed into a plain JSON object. If {jwk} is already an instance\n * of JWK.Key, its (public) JSON representation is first obtained\n * then applied to a new JWK.Key object within this KeyStore.\n *\n * @param {String|Object} jwk The JSON Web Key (JWK)\n * @param {String} [form] The format of a String key to expect\n * @param {Object} [extras] extra jwk fields inserted when importing from a non json string (eg \"pem\")\n * @returns {Promise} The promise for the added key\n */\n Object.defineProperty(this, \"add\", {\n value: function(jwk, form, extras) {\n extras = extras || {};\n\n var factors;\n if (Buffer.isBuffer(jwk) || typeof jwk === \"string\") {\n // form can be 'json', 'pkcs8', 'spki', 'pkix', 'x509', 'pem'\n form = (form || \"json\").toLowerCase();\n if (\"json\" === form) {\n jwk = JSON.parse(jwk.toString(\"utf8\"));\n } else {\n try {\n if (\"pem\" === form) {\n // convert *first* PEM -> DER\n factors = fromPEM(jwk);\n } else {\n factors = {\n body: jwk.toString(\"binary\"),\n form: form\n };\n }\n jwk = importFrom(registry, factors);\n if (!jwk) {\n throw new Error(\"no importer for key\");\n }\n Object.keys(extras).forEach(function(field){\n jwk[field] = extras[field];\n });\n } catch (err) {\n return Promise.reject(err);\n }\n }\n } else if (JWKStore.isKey(jwk)) {\n // assume a complete duplicate is desired\n jwk = jwk.toJSON(true);\n } else {\n jwk = clone(jwk);\n }\n\n var keytype = registry.get(jwk.kty);\n if (!keytype) {\n return Promise.reject(new Error(\"unsupported key type\"));\n }\n\n var self = this,\n promise = keytype.prepare(jwk);\n return promise.then(function(cfg) {\n return new JWK.BaseKey(jwk.kty, self, jwk, cfg);\n }).then(function(jwk) {\n var kid = jwk.kid || \"\";\n var keys = keysets[kid] = keysets[kid] || [];\n keys.push(jwk);\n\n return jwk;\n });\n }\n });\n /**\n * @method JWK.KeyStore#remove\n * @description\n * Removes a Key from this KeyStore.\n *\n * **NOTE:** The removed Key's {keystore} property is not changed.\n *\n * @param {JWK.Key} jwk The key to remove.\n */\n Object.defineProperty(this, \"remove\", {\n value: function(jwk) {\n if (!jwk) {\n return;\n }\n\n var keys = keysets[jwk.kid];\n if (!keys) {\n return;\n }\n\n var pos = keys.indexOf(jwk);\n if (pos === -1) {\n return;\n }\n\n keys.splice(pos, 1);\n if (!keys.length) {\n delete keysets[jwk.kid];\n }\n }\n });\n\n /**\n * @method JWK.KeyStore#all\n * @description\n * Retrieves all of the contained Keys that optinally match all of the\n * given properties.\n *\n * If {props} are specified, this method only returns Keys which exactly\n * match the given properties. The properties can be any of the\n * following:\n *\n * + **alg**: The algorithm for the Key.\n * + **use**: The usage for the Key.\n * + **kid**: The identifier for the Key.\n *\n * If no properties are given, this method returns all of the Keys for this\n * KeyStore.\n *\n * @param {Object} [props] The properties to match against\n * @param {Boolean} [local = false] `true` if only the Keys\n * directly contained by this KeyStore should be returned, or\n * `false` if it should return all Keys of this KeyStore and\n * its ancestors.\n * @returns {JWK.Key[]} The list of matching Keys, or an empty array if no\n * matches are found.\n */\n Object.defineProperty(this, \"all\", {\n value: function(props, local) {\n props = props || {};\n\n // workaround for issues/109\n if (props.kid !== undefined && props.kid !== null && typeof props.kid !== \"string\") {\n props.kid = String(props.kid);\n }\n\n var candidates = [];\n var matches = function(key) {\n // match on 'kty'\n if (props.kty &&\n key.kty &&\n props.kty !== key.kty) {\n return false;\n }\n // match on 'use'\n if (props.use &&\n key.use &&\n props.use !== key.use) {\n return false;\n }\n // match on 'alg'\n if (props.alg) {\n if (props.alg !== \"dir\" &&\n key.alg &&\n props.alg !== key.alg) {\n return false;\n }\n return key.supports(props.alg);\n }\n //TODO: match on 'key_ops'\n\n return true;\n };\n Object.keys(keysets).forEach(function(id) {\n if (props.kid && props.kid !== id) {\n return;\n }\n\n var keys = keysets[id].filter(matches);\n if (keys.length) {\n candidates = candidates.concat(keys);\n }\n });\n\n if (!local && parent) {\n candidates = candidates.concat(parent.all(props));\n }\n\n return candidates;\n }\n });\n /**\n * @method JWK.KeyStore#get\n * @description\n * Retrieves the contained Key matching the given {kid}, and optionally\n * all of the given properties. This method equivalent to calling\n * {@link JWK.Store#all}, then returning the first Key whose\n * \"kid\" is {kid}. If {kid} is undefined, then the first Key that\n * is returned from `all()` is returned.\n *\n * @param {String} [kid] The key identifier to match against.\n * @param {Object} [props] The properties to match against.\n * @param {Boolean} [local = false] `true` if only the Keys\n * directly contained by this KeyStore should be returned, or\n * `false` if it should return all Keys of this KeyStore and\n * its ancestors.\n * @returns {JWK.Key} The Key matching {kid} and {props}, or `null`\n * if no match is found.\n */\n Object.defineProperty(this, \"get\", {\n value: function(kid, props, local) {\n // reconcile arguments\n if (typeof kid === \"boolean\") {\n local = kid;\n props = kid = null;\n } else if (typeof kid === \"object\") {\n local = props;\n props = kid;\n kid = null;\n }\n\n // fixup props\n props = props || {};\n if (kid) {\n props.kid = kid;\n }\n\n // workaround for issues/109\n if (props.kid !== undefined && props.kid !== null && typeof props.kid !== \"string\") {\n props.kid = String(props.kid);\n }\n\n var candidates = this.all(props, true);\n if (!candidates.length && parent && !local) {\n candidates = parent.get(props, local);\n }\n return candidates[0] || null;\n }\n });\n\n /**\n * @method JWK.KeyStore#temp\n * @description\n * Creates a temporary KeyStore based on this KeyStore.\n *\n * @returns {JWK.KeyStore} The temporary KeyStore.\n */\n Object.defineProperty(this, \"temp\", {\n value: function() {\n return new JWKStore(registry, this);\n }\n });\n\n /**\n * @method JWK.KeyStore#toJSON\n * @description\n * Generates a JSON representation of this KeyStore, which conforms\n * to a JWK Set from {I-D.ietf-jose-json-web-key}.\n *\n * @param {Boolean} [isPrivate = false] `true` if the private fields\n * of stored keys are to be included.\n * @returns {Object} The JSON representation of this KeyStore.\n */\n Object.defineProperty(this, \"toJSON\", {\n value: function(isPrivate) {\n var keys = [];\n\n Object.keys(keysets).forEach(function(kid) {\n var items = keysets[kid].map(function(k) {\n return k.toJSON(isPrivate);\n });\n keys = keys.concat(items);\n });\n\n return {\n keys: keys\n };\n }\n });\n};\n\n/**\n * Determines if the given object is an instance of JWK.KeyStore.\n *\n * @param {Object} obj The object to test\n * @returns {Boolean} `true` if {obj} is an instance of JWK.KeyStore,\n * and `false` otherwise.\n */\nJWKStore.isKeyStore = function(obj) {\n if (!obj) {\n return false;\n }\n\n if (\"object\" !== typeof obj) {\n return false;\n }\n\n if (\"function\" !== typeof obj.get ||\n \"function\" !== typeof obj.all ||\n \"function\" !== typeof obj.generate ||\n \"function\" !== typeof obj.add ||\n \"function\" !== typeof obj.remove) {\n return false;\n }\n\n return true;\n};\n\n/**\n * Creates a new empty KeyStore.\n *\n * @returns {JWK.KeyStore} The empty KeyStore.\n */\nJWKStore.createKeyStore = function() {\n return new JWKStore(GLOBAL_REGISTRY);\n};\n\n/**\n * Coerces the given object into a KeyStore. This method uses the following\n * algorithm to coerce {ks}:\n *\n * 1. if {ks} is an instance of JWK.KeyStore, it is returned directly\n * 2. if {ks} is a string, it is parsed into a JSON value\n * 3. if {ks} is an array, it creates a new JWK.KeyStore and calls {@link\n * JWK.KeyStore#add} for each element in the {ks} array.\n * 4. if {ks} is a JSON object, it creates a new JWK.KeyStore and calls {@link\n * JWK.KeyStore#add} for each element in the \"keys\" property.\n *\n * @param {Object|String} ks The value to coerce into a\n * KeyStore\n * @returns {Promise(JWK.KeyStore)} A promise for the coerced KeyStore.\n */\nJWKStore.asKeyStore = function(ks) {\n if (JWKStore.isKeyStore(ks)) {\n return Promise.resolve(ks);\n }\n\n var store = JWKStore.createKeyStore(),\n keys;\n\n if (typeof ks === \"string\") {\n ks = JSON.parse(ks);\n }\n\n if (Array.isArray(ks)) {\n keys = ks;\n } else if (\"keys\" in ks) {\n keys = ks.keys;\n } else {\n return Promise.reject(new Error(\"invalid keystore\"));\n }\n\n keys = keys.map(function(k) {\n return store.add(k);\n });\n\n var promise = Promise.all(keys);\n promise = promise.then(function() {\n return store;\n });\n\n return promise;\n};\n\n\n/**\n * Determines if the given object is a JWK.Key instance.\n *\n * @param {Object} obj The object to test\n * @returns `true` if {obj} is a JWK.Key\n */\nJWKStore.isKey = function(obj) {\n if (!obj) {\n return false;\n }\n\n if (\"object\" !== typeof obj) {\n return false;\n }\n\n if (!JWKStore.isKeyStore(obj.keystore)) {\n return false;\n }\n\n if (\"string\" !== typeof obj.kty ||\n \"number\" !== typeof obj.length ||\n \"function\" !== typeof obj.algorithms ||\n \"function\" !== typeof obj.supports ||\n \"function\" !== typeof obj.encrypt ||\n \"function\" !== typeof obj.decrypt ||\n \"function\" !== typeof obj.wrap ||\n \"function\" !== typeof obj.unwrap ||\n \"function\" !== typeof obj.sign ||\n \"function\" !== typeof obj.verify) {\n return false;\n }\n\n return true;\n};\n\n/**\n * Creates a new key with the given properties. This method is a convenience\n * to calling `JWK.createKeyStore()` then `generate()` on the returned keystore.\n *\n * @param {String} kty The type of generated key\n * @param {String|Number} [size] The size of the generated key\n * @param {Object} [props] Additional properties to apply to the generated\n * key.\n * @returns {Promise} The promise for the generated Key\n * @throws {Error} If {kty} is not supported\n * @see JWKStore#generate\n */\nJWKStore.createKey = function(kty, size, props) {\n var ks = JWKStore.createKeyStore();\n return ks.generate(kty, size, props);\n}\n\n/**\n * Coerces the given object into a Key. If {key} is an instance of JWK.Key,\n * it is returned directly. Otherwise, this method first creates a new\n * JWK.KeyStore and calls {@link JWK.KeyStore#add} on this new KeyStore.\n *\n * @param {Object|String} key The value to coerce into a Key\n * @param {String} [form] The format of a String Key to expect\n * @param {Object} [extras] extra jwk fields inserted when importing from a non json string (eg \"pem\")\n * @returns {Promise(JWK.Key)} A promise for the coerced Key.\n */\nJWKStore.asKey = function(key, form, extras) {\n if (JWKStore.isKey(key)) {\n return Promise.resolve(key);\n }\n\n var ks = JWKStore.createKeyStore();\n key = ks.add(key, form, extras);\n\n return key;\n};\n\nmodule.exports = {\n KeyRegistry: JWKRegistry,\n KeyStore: JWKStore,\n registry: GLOBAL_REGISTRY\n};\n","/*!\n * jwk/octkey.js - Symmetric Octet Key Representation\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar util = require(\"../util\");\n\nvar JWK = {\n BaseKey: require(\"./basekey.js\"),\n helpers: require(\"./helpers.js\")\n};\n\nvar SIG_ALGS = [\n \"HS256\",\n \"HS384\",\n \"HS512\"\n];\nvar ENC_ALGS = [\n \"A128GCM\",\n \"A192GCM\",\n \"A256GCM\",\n \"A128CBC-HS256\",\n \"A192CBC-HS384\",\n \"A256CBC-HS512\",\n \"A128CBC+HS256\",\n \"A192CBC+HS384\",\n \"A256CBC+HS512\"\n];\nvar WRAP_ALGS = [\n \"A128KW\",\n \"A192KW\",\n \"A256KW\",\n \"A128GCMKW\",\n \"A192GCMKW\",\n \"A256GCMKW\",\n \"PBES2-HS256+A128KW\",\n \"PBES2-HS384+A192KW\",\n \"PBES2-HS512+A256KW\",\n \"dir\"\n];\n\nfunction adjustDecryptProps(alg, props) {\n if (\"iv\" in props) {\n props.iv = Buffer.isBuffer(props.iv) ?\n props.iv :\n util.base64url.decode(props.iv || \"\");\n }\n if (\"adata\" in props) {\n props.adata = Buffer.isBuffer(props.adata) ?\n props.adata :\n Buffer.from(props.adata || \"\", \"utf8\");\n }\n if (\"mac\" in props) {\n props.mac = Buffer.isBuffer(props.mac) ?\n props.mac :\n util.base64url.decode(props.mac || \"\");\n }\n if (\"tag\" in props) {\n props.tag = Buffer.isBuffer(props.tag) ?\n props.tag :\n util.base64url.decode(props.tag || \"\");\n }\n\n return props;\n}\nfunction adjustEncryptProps(alg, props) {\n if (\"iv\" in props) {\n props.iv = Buffer.isBuffer(props.iv) ?\n props.iv :\n util.base64url.decode(props.iv || \"\");\n }\n if (\"adata\" in props) {\n props.adata = Buffer.isBuffer(props.adata) ?\n props.adata :\n Buffer.from(props.adata || \"\", \"utf8\");\n }\n\n return props;\n}\n\nvar JWKOctetCfg = {\n publicKey: function(props) {\n var fields = JWK.helpers.COMMON_PROPS.concat([\n ]);\n\n var pk;\n pk = JWK.helpers.unpackProps(props, fields);\n\n return pk;\n },\n privateKey: function(props) {\n var fields = JWK.helpers.COMMON_PROPS.concat([\n {name: \"k\", type: \"binary\"}\n ]);\n\n var pk;\n pk = JWK.helpers.unpackProps(props, fields);\n if (pk && pk.k) {\n pk.length = pk.k.length * 8;\n } else {\n pk = undefined;\n }\n\n return pk;\n },\n\n thumbprint: function(json) {\n if (json.private) {\n json = json.private;\n }\n var fields;\n fields = {\n k: json.k || \"\",\n kty: \"oct\"\n };\n return fields;\n },\n algorithms: function(keys, mode) {\n var len = keys.private && (keys.private.k.length * 8);\n var mins = [256, 384, 512];\n\n if (!len) {\n return [];\n }\n switch (mode) {\n case \"encrypt\":\n case \"decrypt\":\n return ENC_ALGS.filter(function(a) {\n return (a === (\"A\" + (len / 2) + \"CBC-HS\" + len)) ||\n (a === (\"A\" + (len / 2) + \"CBC+HS\" + len)) ||\n (a === (\"A\" + len + \"GCM\"));\n });\n case \"sign\":\n case \"verify\":\n // TODO: allow for HS{less-than-keysize}\n return SIG_ALGS.filter(function(a) {\n var result = false;\n mins.forEach(function(m) {\n if (m > len) { return; }\n result = result | (a === (\"HS\" + m));\n });\n return result;\n });\n case \"wrap\":\n case \"unwrap\":\n return WRAP_ALGS.filter(function(a) {\n return (a === (\"A\" + len + \"KW\")) ||\n (a === (\"A\" + len + \"GCMKW\")) ||\n (a.indexOf(\"PBES2-\") === 0) ||\n (a === \"dir\");\n });\n }\n\n return [];\n },\n encryptKey: function(alg, keys) {\n return keys.private && keys.private.k;\n },\n encryptProps: adjustEncryptProps,\n\n decryptKey: function(alg, keys) {\n return keys.private && keys.private.k;\n },\n decryptProps: adjustDecryptProps,\n\n wrapKey: function(alg, keys) {\n return keys.private && keys.private.k;\n },\n wrapProps: adjustEncryptProps,\n\n unwrapKey: function(alg, keys) {\n return keys.private && keys.private.k;\n },\n unwrapProps: adjustDecryptProps,\n\n signKey: function(alg, keys) {\n return keys.private && keys.private.k;\n },\n verifyKey: function(alg, keys) {\n return keys.private && keys.private.k;\n }\n};\n\n// Factory\nvar JWKOctetFactory = {\n kty: \"oct\",\n prepare: function(props) {\n // TODO: validate key properties\n var cfg = JWKOctetCfg;\n var p = Promise.resolve(props);\n p = p.then(function(json) {\n return JWK.helpers.thumbprint(cfg, json);\n });\n p = p.then(function(hash) {\n var prints = {};\n prints[JWK.helpers.INTERNALS.THUMBPRINT_HASH] = hash;\n props[JWK.helpers.INTERNALS.THUMBPRINT_KEY] = prints;\n return cfg;\n });\n return p;\n },\n generate: function(size) {\n // TODO: validate key sizes\n var key = util.randomBytes(size / 8);\n\n return Promise.resolve({\n k: key\n });\n }\n};\n\n// public API\nmodule.exports = Object.freeze({\n config: JWKOctetCfg,\n factory: JWKOctetFactory\n});\n\n// registration\n(function(REGISTRY) {\n REGISTRY.register(JWKOctetFactory);\n})(require(\"./keystore\").registry);\n","/*!\n * jwk/rsa.js - RSA Key Representation\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar forge = require(\"../deps/forge.js\"),\n rsau = require(\"../algorithms/rsa-util\"),\n nodeCrypto = require(\"../algorithms/helpers\").nodeCrypto;\n\nvar JWK = {\n BaseKey: require(\"./basekey.js\"),\n helpers: require(\"./helpers.js\")\n};\n\nvar SIG_ALGS = [\n \"RS256\",\n \"RS384\",\n \"RS512\",\n \"PS256\",\n \"PS384\",\n \"PS512\"\n];\nvar WRAP_ALGS = [\n \"RSA-OAEP\",\n \"RSA-OAEP-256\",\n \"RSA1_5\"\n];\n\nvar JWKRsaCfg = {\n publicKey: function(props) {\n var fields = JWK.helpers.COMMON_PROPS.concat([\n {name: \"n\", type: \"binary\"},\n {name: \"e\", type: \"binary\"}\n ]);\n var pk;\n pk = JWK.helpers.unpackProps(props, fields);\n if (pk && pk.n && pk.e) {\n pk.length = pk.n.length * 8;\n } else {\n delete pk.e;\n delete pk.n;\n }\n\n return pk;\n },\n privateKey: function(props) {\n var fields = JWK.helpers.COMMON_PROPS.concat([\n {name: \"n\", type: \"binary\"},\n {name: \"e\", type: \"binary\"},\n {name: \"d\", type: \"binary\"},\n {name: \"p\", type: \"binary\"},\n {name: \"q\", type: \"binary\"},\n {name: \"dp\", type: \"binary\"},\n {name: \"dq\", type: \"binary\"},\n {name: \"qi\", type: \"binary\"}\n ]);\n\n var pk;\n pk = JWK.helpers.unpackProps(props, fields);\n if (pk && pk.d && pk.n && pk.e && pk.p && pk.q && pk.dp && pk.dq && pk.qi) {\n pk.length = pk.d.length * 8;\n } else {\n pk = undefined;\n }\n\n return pk;\n },\n thumbprint: function(json) {\n if (json.public) {\n json = json.public;\n }\n var fields = {\n e: json.e,\n kty: \"RSA\",\n n: json.n\n };\n return fields;\n },\n algorithms: function(keys, mode) {\n switch (mode) {\n case \"encrypt\":\n case \"decrypt\":\n return [];\n case \"wrap\":\n return (keys.public && WRAP_ALGS.slice()) || [];\n case \"unwrap\":\n return (keys.private && WRAP_ALGS.slice()) || [];\n case \"sign\":\n return (keys.private && SIG_ALGS.slice()) || [];\n case \"verify\":\n return (keys.public && SIG_ALGS.slice()) || [];\n }\n\n return [];\n },\n\n wrapKey: function(alg, keys) {\n return keys.public;\n },\n unwrapKey: function(alg, keys) {\n return keys.private;\n },\n\n signKey: function(alg, keys) {\n return keys.private;\n },\n verifyKey: function(alg, keys) {\n return keys.public;\n },\n\n convertToPEM: function(key, isPrivate) {\n var k = rsau.convertToForge(key, !isPrivate);\n if (!isPrivate) {\n return forge.pki.publicKeyToPem(k);\n }\n return forge.pki.privateKeyToPem(k);\n }\n};\n\nfunction convertBNtoBuffer(bn) {\n bn = bn.toString(16);\n if (bn.length % 2) {\n bn = \"0\" + bn;\n }\n return Buffer.from(bn, \"hex\");\n}\n\n// Adapted from digitalbaazar/node-forge/js/rsa.js\nvar validators = {\n oid: \"1.2.840.113549.1.1.1\",\n privateKey: {\n name: \"RSAPrivateKey\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n // Version (INTEGER)\n name: \"RSAPrivateKey.version\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"version\"\n },\n {\n // modulus (n)\n name: \"RSAPrivateKey.modulus\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"n\"\n },\n {\n // publicExponent (e)\n name: \"RSAPrivateKey.publicExponent\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"e\"\n },\n {\n // privateExponent (d)\n name: \"RSAPrivateKey.privateExponent\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"d\"\n },\n {\n // prime1 (p)\n name: \"RSAPrivateKey.prime1\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"p\"\n },\n {\n // prime2 (q)\n name: \"RSAPrivateKey.prime2\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"q\"\n },\n {\n // exponent1 (d mod (p-1))\n name: \"RSAPrivateKey.exponent1\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"dp\"\n },\n {\n // exponent2 (d mod (q-1))\n name: \"RSAPrivateKey.exponent2\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"dq\"\n },\n {\n // coefficient ((inverse of q) mod p)\n name: \"RSAPrivateKey.coefficient\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"qi\"\n }\n ]\n },\n publicKey: {\n // RSAPublicKey\n name: \"RSAPublicKey\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.SEQUENCE,\n constructed: true,\n value: [\n {\n // modulus (n)\n name: \"RSAPublicKey.modulus\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"n\"\n },\n {\n // publicExponent (e)\n name: \"RSAPublicKey.exponent\",\n tagClass: forge.asn1.Class.UNIVERSAL,\n type: forge.asn1.Type.INTEGER,\n constructed: false,\n capture: \"e\"\n }\n ]\n }\n};\n\n// Factory\nvar JWKRsaFactory = {\n kty: \"RSA\",\n validators: validators,\n prepare: function(props) {\n // TODO: validate key properties\n var cfg = JWKRsaCfg;\n var p = Promise.resolve(props);\n p = p.then(function(json) {\n return JWK.helpers.thumbprint(cfg, json);\n });\n p = p.then(function(hash) {\n var prints = {};\n prints[JWK.helpers.INTERNALS.THUMBPRINT_HASH] = hash;\n props[JWK.helpers.INTERNALS.THUMBPRINT_KEY] = prints;\n return cfg;\n });\n return p;\n },\n generate: function(size) {\n // TODO: validate key sizes\n var promise;\n\n if (nodeCrypto) {\n promise = new Promise(function (resolve, reject) {\n forge.pki.rsa.generateKeyPair({\n bits: size,\n e: 0x010001\n }, function (err, key) {\n if (err) return reject(err);\n resolve(key.privateKey);\n });\n });\n } else {\n var key = forge.pki.rsa.generateKeyPair({\n bits: size,\n e: 0x010001\n });\n promise = Promise.resolve(key.privateKey);\n }\n\n return promise.then(function (key) {\n\n // convert to JSON-ish\n var result = {};\n [\n \"e\",\n \"n\",\n \"d\",\n \"p\",\n \"q\",\n {incoming: \"dP\", outgoing: \"dp\"},\n {incoming: \"dQ\", outgoing: \"dq\"},\n {incoming: \"qInv\", outgoing: \"qi\"}\n ].forEach(function(f) {\n var incoming,\n outgoing;\n\n if (\"string\" === typeof f) {\n incoming = outgoing = f;\n } else {\n incoming = f.incoming;\n outgoing = f.outgoing;\n }\n\n if (incoming in key) {\n result[outgoing] = convertBNtoBuffer(key[incoming]);\n }\n });\n\n return result;\n });\n },\n import: function(input) {\n if (validators.oid !== input.keyOid) {\n return null;\n }\n\n if (!input.parsed) {\n // coerce capture.keyValue to DER\n if (\"string\" === typeof input.keyValue) {\n input.keyValue = forge.asn1.fromDer(input.keyValue);\n } else if (Array.isArray(input.keyValue)) {\n input.keyValue = input.keyValue[0];\n }\n // capture key factors\n var validator = (\"private\" === input.type) ?\n validators.privateKey :\n validators.publicKey;\n var capture = {},\n errors = [];\n if (!forge.asn1.validate(input.keyValue, validator, capture, errors)) {\n return null;\n }\n input = capture;\n }\n\n // convert factors to Buffers\n var output = {\n kty: \"RSA\"\n };\n [\"n\", \"e\", \"d\", \"p\", \"q\", \"dp\", \"dq\", \"qi\"].forEach(function(f) {\n if (!(f in input)) {\n return;\n }\n var b = Buffer.from(input[f], \"binary\");\n // remove leading zero padding if any\n if (0 === b[0]) {\n b = b.slice(1);\n }\n output[f] = b;\n });\n return output;\n }\n};\n\n// public API\nmodule.exports = Object.freeze({\n config: JWKRsaCfg,\n factory: JWKRsaFactory\n});\n\n// registration\n(function(REGISTRY) {\n REGISTRY.register(JWKRsaFactory);\n})(require(\"./keystore\").registry);\n","/*!\n * jws/defaults.js - Defaults for JWSs\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\n/**\n * @description\n * The default options for {@link JWS.createSign}.\n *\n * @property {Boolean} compact Determines if the output is the Compact\n * serialization (`true`) or the JSON serialization (**`false`**,\n * the default).\n * @property {String|String[]} protect The names of the headers to integrity\n * protect. The value `\"\"` means that none of header parameters\n * are integrity protected, while `\"*\"` (the default) means that all\n * headers parameter sare integrity protected.\n */\nvar JWSDefaults = {\n compact: false,\n protect: \"*\"\n};\n\nmodule.exports = JWSDefaults;\n","/*!\n * jws/helpers.js - JWS Internal Helper Functions\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nmodule.exports = {\n slice: function(input, start) {\n return Array.prototype.slice.call(input, start || 0);\n }\n};\n","/*!\n * jws/index.js - JSON Web Signature (JWS) Entry Point\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar JWS = {\n createSign: require(\"./sign\").createSign,\n createVerify: require(\"./verify\").createVerify\n};\n\nmodule.exports = JWS;\n","/*!\n * jws/sign.js - Sign to JWS\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar merge = require(\"../util/merge\"),\n util = require(\"../util\"),\n JWK = require(\"../jwk\"),\n slice = require(\"./helpers\").slice;\n\nvar clone = require(\"lodash/clone\");\nvar uniq = require(\"lodash/uniq\");\n\nvar DEFAULTS = require(\"./defaults\");\n\n/**\n * @class JWS.Signer\n * @classdesc Generator of signed content.\n *\n * @description\n * **NOTE:** this class cannot be instantiated directly. Instead call {@link\n * JWS.createSign}.\n */\nvar JWSSigner = function(cfg, signatories) {\n var finalized = false,\n format = cfg.format || \"general\",\n content = Buffer.alloc(0);\n\n /**\n * @member {Boolean} JWS.Signer#compact\n * @description\n * Indicates whether the outuput of this signature generator is using\n * the Compact serialization (`true`) or the JSON serialization\n * (`false`).\n */\n Object.defineProperty(this, \"compact\", {\n get: function() {\n return \"compact\" === format;\n },\n enumerable: true\n });\n Object.defineProperty(this, \"format\", {\n get: function() {\n return format;\n },\n enumerable: true\n });\n\n /**\n * @method JWS.Signer#update\n * @description\n * Updates the signing content for this signature content. The content\n * is appended to the end of any other content already applied.\n *\n * If {data} is a Buffer, {encoding} is ignored. Otherwise, {data} is\n * converted to a Buffer internally to {encoding}.\n *\n * @param {Buffer|String} data The data to sign.\n * @param {String} [encoding=\"binary\"] The encoding of {data}.\n * @returns {JWS.Signer} This signature generator.\n * @throws {Error} If a signature has already been generated.\n */\n Object.defineProperty(this, \"update\", {\n value: function(data, encoding) {\n if (finalized) {\n throw new Error(\"already final\");\n }\n if (data != null) {\n data = util.asBuffer(data, encoding);\n if (content.length) {\n content = Buffer.concat([content, data],\n content.length + data.length);\n } else {\n content = data;\n }\n }\n\n return this;\n }\n });\n /**\n * @method JWS.Signer#final\n * @description\n * Finishes the signature operation.\n *\n * The returned Promise, when fulfilled, is the JSON Web Signature (JWS)\n * object, either in the Compact (if {@link JWS.Signer#format} is\n * `\"compact\"`), the flattened JSON (if {@link JWS.Signer#format} is\n * \"flattened\"), or the general JSON serialization.\n *\n * @param {Buffer|String} [data] The final content to apply.\n * @param {String} [encoding=\"binary\"] The encoding of the final content\n * (if any).\n * @returns {Promise} The promise for the signatures\n * @throws {Error} If a signature has already been generated.\n */\n Object.defineProperty(this, \"final\", {\n value: function(data, encoding) {\n if (finalized) {\n return Promise.reject(new Error(\"already final\"));\n }\n\n // last-minute data\n this.update(data, encoding);\n\n // mark as done...ish\n finalized = true;\n var promise;\n\n // map signatory promises to just signatories\n promise = Promise.all(signatories);\n promise = promise.then(function(sigs) {\n // prepare content\n content = util.base64url.encode(content);\n\n sigs = sigs.map(function(s) {\n // prepare protected\n var protect = {},\n lenProtect = 0,\n unprotect = clone(s.header),\n lenUnprotect = Object.keys(unprotect).length;\n s.protected.forEach(function(h) {\n if (!(h in unprotect)) {\n return;\n }\n protect[h] = unprotect[h];\n lenProtect++;\n delete unprotect[h];\n lenUnprotect--;\n });\n if (lenProtect > 0) {\n protect = JSON.stringify(protect);\n protect = util.base64url.encode(protect);\n } else {\n protect = \"\";\n }\n\n // signit!\n var data = Buffer.from(protect + \".\" + content, \"ascii\");\n s = s.key.sign(s.header.alg, data, s.header);\n s = s.then(function(result) {\n var sig = {};\n if (0 < lenProtect) {\n sig.protected = protect;\n }\n if (0 < lenUnprotect) {\n sig.header = unprotect;\n }\n sig.signature = util.base64url.encode(result.mac);\n return sig;\n });\n return s;\n });\n sigs = [Promise.resolve(content)].concat(sigs);\n return Promise.all(sigs);\n });\n promise = promise.then(function(results) {\n var content = results[0];\n return {\n payload: content,\n signatures: results.slice(1)\n };\n });\n switch (format) {\n case \"compact\":\n promise = promise.then(function(jws) {\n var compact = [\n jws.signatures[0].protected,\n jws.payload,\n jws.signatures[0].signature\n ];\n compact = compact.join(\".\");\n return compact;\n });\n break;\n case \"flattened\":\n promise = promise.then(function(jws) {\n var flattened = {};\n flattened.payload = jws.payload;\n\n var sig = jws.signatures[0];\n if (sig.protected) {\n flattened.protected = sig.protected;\n }\n if (sig.header) {\n flattened.header = sig.header;\n }\n flattened.signature = sig.signature;\n\n return flattened;\n });\n break;\n }\n\n return promise;\n }\n });\n};\n\n\n/**\n * @description\n * Creates a new JWS.Signer with the given options and signatories.\n *\n * @param {Object} [opts] The signing options\n * @param {Boolean} [opts.compact] Use compact serialization?\n * @param {String} [opts.format] The serialization format to use (\"compact\",\n * \"flattened\", \"general\")\n * @param {Object} [opts.fields] Additional header fields\n * @param {JWK.Key[]|Object[]} [signs] Signatories, either as an array of\n * JWK.Key instances; or an array of objects, each with the following\n * properties\n * @param {JWK.Key} signs.key Key used to sign content\n * @param {Object} [signs.header] Per-signatory header fields\n * @param {String} [signs.reference] Reference field to identify the key\n * @param {String[]|String} [signs.protect] List of fields to integrity\n * protect (\"*\" to protect all fields)\n * @returns {JWS.Signer} The signature generator.\n * @throws {Error} If Compact serialization is requested but there are\n * multiple signatories\n */\nfunction createSign(opts, signs) {\n // fixup signatories\n var options = opts,\n signStart = 1,\n signList = signs;\n\n if (arguments.length === 0) {\n throw new Error(\"at least one signatory must be provided\");\n }\n if (arguments.length === 1) {\n signList = opts;\n signStart = 0;\n options = {};\n } else if (JWK.isKey(opts) ||\n (opts && \"kty\" in opts) ||\n (opts && \"key\" in opts &&\n (JWK.isKey(opts.key) || \"kty\" in opts.key))) {\n signList = opts;\n signStart = 0;\n options = {};\n } else {\n options = clone(opts);\n }\n if (!Array.isArray(signList)) {\n signList = slice(arguments, signStart);\n }\n\n // fixup options\n options = merge(clone(DEFAULTS), options);\n\n // setup header fields\n var allFields = options.fields || {};\n // setup serialization format\n var format = options.format;\n if (!format) {\n format = options.compact ? \"compact\" : \"general\";\n }\n if ((\"compact\" === format || \"flattened\" === format) && 1 < signList.length) {\n throw new Error(\"too many signatories for compact or flattened JSON serialization\");\n }\n\n // note protected fields (globally)\n // protected fields are per signature\n var protectAll = (\"*\" === options.protect);\n if (options.compact) {\n protectAll = true;\n }\n\n signList = signList.map(function(s, idx) {\n var p;\n\n // resolve a key\n if (s && \"kty\" in s) {\n p = JWK.asKey(s);\n p = p.then(function(k) {\n return {\n key: k\n };\n });\n } else if (s) {\n p = JWK.asKey(s.key);\n p = p.then(function(k) {\n return {\n header: s.header,\n reference: s.reference,\n protect: s.protect,\n key: k\n };\n });\n } else {\n p = Promise.reject(new Error(\"missing key for signatory \" + idx));\n }\n\n // resolve the complete signatory\n p = p.then(function(signatory) {\n var key = signatory.key;\n\n // make sure there is a header\n var header = signatory.header || {};\n header = merge(merge({}, allFields), header);\n signatory.header = header;\n\n // ensure an algorithm\n if (!header.alg) {\n header.alg = key.algorithms(JWK.MODE_SIGN)[0] || \"\";\n }\n\n // determine the key reference\n var ref = signatory.reference;\n delete signatory.reference;\n if (undefined === ref) {\n // header already contains the key reference\n ref = [\"kid\", \"jku\", \"x5c\", \"x5t\", \"x5u\"].some(function(k) {\n return (k in header);\n });\n ref = !ref ? \"kid\" : null;\n } else if (\"boolean\" === typeof ref) {\n // explicit (positive | negative) request for key reference\n ref = ref ? \"kid\" : null;\n }\n var jwk;\n if (ref) {\n jwk = key.toJSON();\n if (\"jwk\" === ref) {\n if (\"oct\" === key.kty) {\n return Promise.reject(new Error(\"cannot embed key\"));\n }\n header.jwk = jwk;\n } else if (ref in jwk) {\n header[ref] = jwk[ref];\n }\n }\n\n // determine protected fields\n var protect = signatory.protect;\n if (protectAll || \"*\" === protect) {\n protect = Object.keys(header);\n } else if (\"string\" === protect) {\n protect = [protect];\n } else if (Array.isArray(protect)) {\n protect = protect.concat();\n } else if (!protect) {\n protect = [];\n } else {\n return Promise.reject(new Error(\"protect must be a list of fields\"));\n }\n protect = uniq(protect);\n signatory.protected = protect;\n\n // freeze signatory\n signatory = Object.freeze(signatory);\n return signatory;\n });\n\n return p;\n });\n\n var cfg = {\n format: format\n };\n return new JWSSigner(cfg,\n signList);\n}\n\nmodule.exports = {\n signer: JWSSigner,\n createSign: createSign\n};\n","/*!\n * jws/verify.js - Verifies from a JWS\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar clone = require(\"lodash/clone\"),\n merge = require(\"../util/merge\"),\n base64url = require(\"../util/base64url\"),\n AlgConfig = require(\"../util/algconfig\"),\n JWK = require(\"../jwk\");\n\nvar DEFAULT_OPTIONS = {\n algorithms: \"*\",\n allowEmbeddedKey: false\n};\n\n/**\n * @class JWS.Verifier\n * @classdesc Parser of signed content.\n *\n * @description\n * **NOTE:** this class cannot be instantiated directly. Instead call {@link\n * JWS.createVerify}.\n */\nvar JWSVerifier = function(ks, globalOpts) {\n var assumedKey,\n keystore;\n\n if (JWK.isKey(ks)) {\n assumedKey = ks;\n keystore = assumedKey.keystore;\n } else if (JWK.isKeyStore(ks)) {\n keystore = ks;\n } else {\n keystore = JWK.createKeyStore();\n }\n\n globalOpts = merge(DEFAULT_OPTIONS, globalOpts);\n\n Object.defineProperty(this, \"defaultKey\", {\n value: assumedKey || undefined,\n enumerable: true\n });\n Object.defineProperty(this, \"keystore\", {\n value: keystore,\n enumerable: true\n });\n\n Object.defineProperty(this, \"verify\", {\n value: function(input, opts) {\n opts = merge({}, globalOpts, opts || {});\n var extraHandlers = opts.handlers || {};\n var handlerKeys = Object.keys(extraHandlers);\n var algSpec = new AlgConfig(opts.algorithms);\n\n if (\"string\" === typeof input) {\n input = input.split(\".\");\n input = {\n payload: input[1],\n signatures: [\n {\n protected: input[0],\n signature: input[2]\n }\n ]\n };\n } else if (!input || \"object\" !== typeof input) {\n throw new Error(\"invalid input\");\n }\n\n // fixup \"flattened JSON\" to look like \"general JSON\"\n if (input.signature) {\n input.signatures = [\n {\n protected: input.protected || undefined,\n header: input.header || undefined,\n signature: input.signature\n }\n ];\n }\n\n // ensure signatories exists\n var sigList = input.signatures || [{}];\n\n // combine fields and decode signature per signatory\n sigList = sigList.map(function(s) {\n var header = clone(s.header || {});\n var protect = s.protected ?\n JSON.parse(base64url.decode(s.protected, \"utf8\")) :\n {};\n header = merge(header, protect);\n var signature = base64url.decode(s.signature);\n\n // process allowed algorithims\n if (!algSpec.match(header.alg)) {\n return Promise.reject(new Error(\"Algorithm not allowed: \" + header.alg));\n }\n\n // process \"crit\" first\n var crit = protect.crit;\n if (crit) {\n if (!Array.isArray(crit)) {\n return Promise.reject(new Error(\"Invalid 'crit' header\"));\n }\n for (var idx = 0; crit.length > idx; idx++) {\n if (-1 === handlerKeys.indexOf(crit[idx])) {\n return Promise.reject(new Error(\n \"Critical extension is not supported: \" + crit[idx]\n ));\n }\n }\n }\n protect = Object.keys(protect);\n\n return Promise.resolve({\n protected: protect,\n aad: s.protected || \"\",\n header: header,\n signature: signature\n });\n });\n\n var promise = Promise.all(sigList);\n promise = promise.then(function(sigList) {\n return new Promise(function(resolve, reject) {\n var processSig = function() {\n var sig = sigList.shift();\n if (!sig) {\n reject(new Error(\"no key found\"));\n return;\n }\n\n sig = merge({}, sig, {\n payload: input.payload\n });\n var p = Promise.resolve(sig);\n // find the key\n p = p.then(function(sig) {\n var algKey;\n // TODO: resolve jku, x5c, x5u\n if (opts.allowEmbeddedKey && sig.header.jwk) {\n algKey = JWK.asKey(sig.header.jwk);\n } else if (opts.allowEmbeddedKey && sig.header.x5c) {\n algKey = sig.header.x5c[0];\n algKey = Buffer.from(algKey, \"base64\");\n // TODO: callback to validate chain\n algKey = JWK.asKey(algKey, \"pkix\");\n } else {\n algKey = Promise.resolve(assumedKey || keystore.get({\n use: \"sig\",\n alg: sig.header.alg,\n kid: sig.header.kid\n }));\n }\n return algKey.then(function(k) {\n if (!k) {\n return Promise.reject(new Error(\"key does not match\"));\n }\n sig.key = k;\n return sig;\n });\n });\n\n // process any prepare-verify handlers\n p = p.then(function(sig) {\n var processing = [];\n handlerKeys.forEach(function(h) {\n h = extraHandlers[h];\n var p;\n if (\"function\" === typeof h) {\n p = h(sig);\n } else if (\"object\" === typeof h && \"function\" === typeof h.prepare) {\n p = h.prepare(sig);\n }\n if (p) {\n processing.push(Promise.resolve(p));\n }\n });\n return Promise.all(processing).then(function() {\n // don't actually care about individual handler results\n // assume {sig} is updated\n return sig;\n });\n });\n\n // prepare verify inputs\n p = p.then(function(sig) {\n var aad = sig.aad || \"\",\n payload = sig.payload || \"\";\n var content = Buffer.alloc(1 + aad.length + payload.length),\n pos = 0;\n content.write(aad, pos, \"ascii\");\n pos += aad.length;\n content.write(\".\", pos, \"ascii\");\n pos++;\n\n if (Buffer.isBuffer(payload)) {\n payload.copy(content, pos);\n } else {\n content.write(payload, pos, \"binary\");\n }\n sig.content = content;\n return sig;\n });\n\n p = p.then(function(sig) {\n return sig.key.verify(sig.header.alg,\n sig.content,\n sig.signature);\n });\n\n p = p.then(function(result) {\n var payload = sig.payload;\n payload = base64url.decode(payload);\n return {\n protected: sig.protected,\n header: sig.header,\n payload: payload,\n signature: result.mac,\n key: sig.key\n };\n });\n\n // process any post-verify handlers\n p = p.then(function(jws) {\n var processing = [];\n handlerKeys.forEach(function(h) {\n h = extraHandlers[h];\n var p;\n if (\"object\" === typeof h && \"function\" === typeof h.complete) {\n p = h.complete(jws);\n }\n if (p) {\n processing.push(Promise.resolve(p));\n }\n });\n return Promise.all(processing).then(function() {\n // don't actually care about individual handler results\n // assume {jws} is updated\n return jws;\n });\n });\n p.then(resolve, processSig);\n };\n processSig();\n });\n });\n return promise;\n }\n });\n};\n\n/**\n * @description\n * Creates a new JWS.Verifier with the given Key or KeyStore.\n *\n * @param {JWK.Key|JWK.KeyStore} ks The Key or KeyStore to use for verification.\n * @returns {JWS.Verifier} The new Verifier.\n */\nfunction createVerify(ks, opts) {\n var vfy = new JWSVerifier(ks, opts);\n\n return vfy;\n}\n\nmodule.exports = {\n verifier: JWSVerifier,\n createVerify: createVerify\n};\n","/*!\n * parse/compact.js - JOSE Compact Serialization Parser\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar jose = {\n JWE: require(\"../jwe\"),\n JWS: require(\"../jws\"),\n util: require(\"../util\")\n};\n\nfunction parseCompact(input) {\n var parts = input.split(\".\");\n\n var type,\n op;\n if (3 === parts.length) {\n // JWS\n type = \"JWS\";\n op = function(ks, opts) {\n return jose.JWS.createVerify(ks).\n verify(input, opts);\n };\n } else if (5 === parts.length) {\n // JWE\n type = \"JWE\";\n op = function(ks, opts) {\n return jose.JWE.createDecrypt(ks).\n decrypt(input, opts);\n };\n } else {\n throw new TypeError(\"invalid jose serialization\");\n }\n\n // parse header\n var header;\n header = jose.util.base64url.decode(parts[0], \"utf8\");\n header = JSON.parse(header);\n return {\n type: type,\n format: \"compact\",\n input: input,\n header: header,\n perform: op\n };\n}\n\nmodule.exports = parseCompact;\n","/*!\n * parse/index.js - JOSE Parser Entry Point\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar compact = require(\"./compact\"),\n json = require(\"./json\");\n\nvar parse = module.exports = function(input) {\n if (Buffer.isBuffer(input)) {\n // assume buffer holds a Compact Serialization string\n return compact(input.toString(\"ascii\"));\n } else if (\"string\" === typeof input) {\n return compact(input);\n } else if (input) {\n return json(input);\n } else {\n throw new TypeError(\"invalid input\");\n }\n};\n\nparse.compact = compact;\nparse.json = json;\n","/*!\n * parse/compact.js - JOSE JSON Serialization Parser\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar merge = require(\"../util/merge\");\n\nvar jose = {\n JWE: require(\"../jwe\"),\n JWS: require(\"../jws\"),\n util: require(\"../util\")\n};\n\nfunction parseJSON(input) {\n var type,\n op,\n headers;\n\n if (\"signatures\" in input || \"signature\" in input) {\n // JWS\n type = \"JWS\";\n op = function(ks, opts) {\n return jose.JWS.createVerify(ks).\n verify(input, opts);\n };\n // headers can be (signatures[].protected, signatures[].header, signature.protected, signature.header)\n headers = input.signatures ||\n [ {\n protected: input.protected,\n header: input.header,\n signature: input.signature\n }];\n headers = headers.map(function(sig) {\n var all = {};\n if (sig.header) {\n all = merge(all, sig.header);\n }\n\n var prot;\n if (sig.protected) {\n prot = sig.protected;\n prot = jose.util.base64url.decode(prot, \"utf8\");\n prot = JSON.parse(prot);\n all = merge(all, prot);\n }\n\n return all;\n });\n } else if (\"ciphertext\" in input) {\n // JWE\n type = \"JWE\";\n op = function(ks, opts) {\n return jose.JWE.createDecrypt(ks).\n decrypt(input, opts);\n };\n // headers can be (protected, unprotected, recipients[].header)\n var root = {};\n if (input.protected) {\n root.protected = input.protected;\n root.protected = jose.util.base64url.decode(root.protected, \"utf8\");\n root.protected = JSON.parse(root.protected);\n }\n if (input.unprotected) {\n root.unprotected = input.unprotected;\n }\n\n headers = input.recipients || [{}];\n headers = headers.map(function(rcpt) {\n var all = {};\n if (rcpt.header) {\n all = merge(all, rcpt.header);\n }\n if (root.unprotected) {\n all = merge(all, root.unprotected);\n }\n if (root.protected) {\n all = merge(all, root.protected);\n }\n\n return all;\n });\n }\n\n return {\n type: type,\n format: \"json\",\n input: input,\n all: headers,\n perform: op\n };\n}\n\nmodule.exports = parseJSON;\n","/*!\n * util/algconfig.js - Functions for managing algorithm set options\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nfunction quoteRE(str) {\n return str.replace(/[.?*+^$[\\]\\\\(){}|-]/g, \"\\\\$&\");\n}\n\nfunction makeRE(prefix, wildcard, suffix) {\n var parts = [];\n\n parts.push(\"^\");\n if (prefix) {\n prefix = quoteRE(prefix);\n parts.push(prefix);\n }\n if (wildcard) {\n parts.push((prefix || suffix) ? \".*\" : \".+\");\n }\n if (suffix) {\n suffix = quoteRE(suffix);\n parts.push(suffix);\n }\n parts.push(\"$\");\n\n return parts.join(\"\");\n}\n\nvar AlgConfig = function(algspec) {\n if (!algspec) {\n algspec = [];\n } else if (\"string\" === typeof algspec) {\n algspec = algspec.split(\" \");\n }\n\n var specAllowed = [], specDisallowed = [];\n var ptnAllowed = [], ptnDisallowed = [];\n var ptn = /^(!)?([^*]*)(\\*?)([^*]*)$/, fmt;\n algspec.forEach(function (a) {\n if (!a) { return; }\n\n ptn.lastIndex = 0;\n var parts = ptn.exec(a);\n if (!parts) { return; }\n\n fmt = \"(\" + makeRE(parts[2], parts[3], parts[4]) + \")\";\n if (!parts[1]) {\n // allowed pattern\n ptnAllowed.push(fmt);\n specAllowed.push(parts[0]);\n } else {\n // disallowed pattern\n ptnDisallowed.push(fmt);\n specDisallowed.push(parts[0]);\n }\n });\n\n ptnAllowed = (ptnAllowed.length) ?\n new RegExp(ptnAllowed.join(\"|\")) :\n null;\n ptnDisallowed = (ptnDisallowed.length) ?\n new RegExp(ptnDisallowed.join(\"|\")) :\n null;\n if (!specAllowed.length) {\n specAllowed = [\"*\"];\n }\n\n Object.defineProperty(this, \"spec\", {\n value: specAllowed.join(\" \") + \" \" + specDisallowed.join(\" \"),\n enumerable: true\n });\n Object.defineProperty(this, \"match\", {\n value: function(alg) {\n var result = Boolean(alg);\n\n if (result && ptnAllowed) {\n ptnAllowed.lastIndex = 0;\n result = ptnAllowed.test(alg);\n }\n if (result && ptnDisallowed) {\n ptnDisallowed.lastIndex = 0;\n result = !ptnDisallowed.test(alg);\n }\n\n return result;\n }\n });\n}\n\nmodule.exports = AlgConfig;\n","/*!\n * util/base64url.js - Implementation of web-safe Base64 Encoder/Decoder\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar impl = require(\"base64url\");\n\n/**\n * @namespace base64url\n * @description\n * Provides methods to encode and decode data according to the\n * base64url alphabet.\n */\nvar base64url = {\n /**\n * @function\n * Encodes the input to base64url.\n *\n * If {input} is a Buffer, then {encoding} is ignored. Otherwise,\n * {encoding} can be one of \"binary\", \"base64\", \"hex\", \"utf8\".\n *\n * @param {Buffer|String} input The data to encode.\n * @param {String} [encoding = binary] The input encoding format.\n * @returns {String} the base64url encoding of {input}.\n */\n encode: function encode(buffer, encoding) {\n if (buffer instanceof ArrayBuffer) {\n buffer = new Uint8Array(buffer);\n }\n\n if (!Buffer.isBuffer(buffer)) {\n buffer = Buffer.from(buffer, encoding);\n }\n\n return impl.encode(buffer);\n },\n /**\n * @function\n * Decodes the input from base64url.\n *\n * @param {String} input The data to decode.\n * @returns {Buffer|String} the base64url decoding of {input}.\n */\n decode: impl.toBuffer\n};\n\nmodule.exports = base64url;\n","/*!\n * util/databuffer.js - Forge-compatible Buffer based on Node.js Buffers\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar forge = require(\"../deps/forge.js\"),\n base64url = require(\"./base64url.js\");\n\n/**\n *\n */\nfunction DataBuffer(b, options) {\n options = options || {};\n\n // treat (views of) (Array)Buffers special\n // NOTE: default implementation creates copies, but efficiently\n // wherever possible\n if (Buffer.isBuffer(b)) {\n this.data = b;\n } else if (forge.util.isArrayBuffer(b)) {\n b = new Uint8Array(b);\n this.data = Buffer.from(b);\n } else if (forge.util.isArrayBufferView(b)) {\n b = new Uint8Array(b.buffer, b.byteOffset, b.byteLength);\n this.data = Buffer.from(b);\n }\n\n if (this.data) {\n this.write = this.data.length;\n b = undefined;\n }\n\n // setup growth rate\n this.growSize = options.growSize || DataBuffer.DEFAULT_GROW_SIZE;\n\n // initialize pointers and data\n this.write = this.write || 0;\n this.read = this.read || 0;\n if (b) {\n this.putBytes(b);\n } else if (!this.data) {\n this.accommodate(0);\n }\n\n // massage read/write pointers\n options.readOffset = (\"readOffset\" in options) ?\n options.readOffset :\n this.read;\n this.write = (\"writeOffset\" in options) ?\n options.writeOffset :\n this.write;\n this.read = Math.min(options.readOffset, this.write);\n}\nDataBuffer.DEFAULT_GROW_SIZE = 16;\n\nDataBuffer.prototype.length = function() {\n return this.write - this.read;\n};\nDataBuffer.prototype.available = function() {\n return this.data.length - this.write;\n};\nDataBuffer.prototype.isEmpty = function() {\n return this.length() <= 0;\n};\n\nDataBuffer.prototype.accommodate = function(length) {\n if (!this.data) {\n // initializes a new buffer\n length = Math.max(this.write + length, this.growSize);\n\n this.data = Buffer.alloc(length);\n } else if (this.available() < length) {\n length = Math.max(length, this.growSize);\n\n // create a new empty buffer, and copy current one into it\n var src = this.data;\n var dst = Buffer.alloc(src.length + length);\n src.copy(dst, 0);\n\n // set data as the new buffer\n this.data = dst;\n }\n // ensure the rest is 0\n this.data.fill(0, this.write);\n\n return this;\n};\nDataBuffer.prototype.clear = function() {\n this.read = this.write = 0;\n this.data = Buffer.alloc(0);\n return this;\n};\nDataBuffer.prototype.truncate = function(count) {\n // chop off bytes from the end\n this.write = this.read + Math.max(0, this.length() - count);\n // ensure the remainder is 0\n this.data.fill(0, this.write);\n return this;\n};\nDataBuffer.prototype.compact = function() {\n if (this.read > 0) {\n if (this.write === this.read) {\n this.read = this.write = 0;\n } else {\n this.data.copy(this.data, 0, this.read, this.write);\n this.write = this.write - this.read;\n this.read = 0;\n }\n // ensure remainder is 0\n this.data.fill(0, this.write);\n }\n return this;\n};\nDataBuffer.prototype.copy = function() {\n return new DataBuffer(this, {\n readOffset: this.read,\n writeOffset: this.write,\n growSize: this.growSize\n });\n};\n\nDataBuffer.prototype.equals = function(test) {\n if (!DataBuffer.isBuffer(test)) {\n return false;\n }\n\n if (test.length() !== this.length()) {\n return false;\n }\n\n var rval = true,\n delta = this.read - test.read;\n // constant time\n for (var idx = test.read; test.write > idx; idx++) {\n rval = rval && (this.data[idx + delta] === test.data[idx]);\n }\n return rval;\n};\nDataBuffer.prototype.at = function(idx) {\n return this.data[this.read + idx];\n};\nDataBuffer.prototype.setAt = function(idx, b) {\n this.data[this.read + idx] = b;\n return this;\n};\nDataBuffer.prototype.last = function() {\n return this.data[this.write - 1];\n};\nDataBuffer.prototype.bytes = function(count) {\n var rval;\n if (undefined === count) {\n count = this.length();\n } else if (count) {\n count = Math.min(count, this.length());\n }\n\n if (0 === count) {\n rval = \"\";\n } else {\n var begin = this.read,\n end = begin + count,\n data = this.data.slice(begin, end);\n rval = String.fromCharCode.apply(null, data);\n }\n\n return rval;\n};\nDataBuffer.prototype.buffer = function(count) {\n var rval;\n if (undefined === count) {\n count = this.length();\n } else if (count) {\n count = Math.min(count, this.length());\n }\n\n if (0 === count) {\n rval = new ArrayBuffer(0);\n } else {\n var begin = this.read,\n end = begin + count,\n data = this.data.slice(begin, end);\n rval = new Uint8Array(end - begin);\n rval.set(data);\n }\n\n return rval;\n};\nDataBuffer.prototype.native = function(count) {\n var rval;\n if (\"undefined\" === typeof count) {\n count = this.length();\n } else if (count) {\n count = Math.min(count, this.length());\n }\n\n if (0 === count) {\n rval = Buffer.alloc(0);\n } else {\n var begin = this.read,\n end = begin + count;\n rval = this.data.slice(begin, end);\n }\n\n return rval;\n};\n\nDataBuffer.prototype.toHex = function() {\n return this.toString(\"hex\");\n};\nDataBuffer.prototype.toString = function(encoding) {\n // short circuit empty string\n if (0 === this.length()) {\n return \"\";\n }\n\n var view = this.data.slice(this.read, this.write);\n encoding = encoding || \"utf8\";\n // special cases, then built-in support\n switch (encoding) {\n case \"raw\":\n return view.toString(\"binary\");\n case \"base64url\":\n return base64url.encode(view);\n case \"utf16\":\n return view.toString(\"ucs2\");\n default:\n return view.toString(encoding);\n }\n};\n\nDataBuffer.prototype.fillWithByte = function(b, n) {\n if (!n) {\n n = this.available();\n }\n this.accommodate(n);\n this.data.fill(b, this.write, this.write + n);\n this.write += n;\n\n return this;\n};\n\nDataBuffer.prototype.getBuffer = function(count) {\n var rval = this.buffer(count);\n this.read += rval.byteLength;\n\n return rval;\n};\nDataBuffer.prototype.putBuffer = function(bytes) {\n return this.putBytes(bytes);\n};\n\nDataBuffer.prototype.getBytes = function(count) {\n var rval = this.bytes(count);\n this.read += rval.length;\n return rval;\n};\nDataBuffer.prototype.putBytes = function(bytes, encoding) {\n if (\"string\" === typeof bytes) {\n // fixup encoding\n encoding = encoding || \"binary\";\n switch (encoding) {\n case \"utf16\":\n // treat as UCS-2/UTF-16BE\n encoding = \"ucs-2\";\n break;\n case \"raw\":\n encoding = \"binary\";\n break;\n case \"base64url\":\n // NOTE: this returns a Buffer\n bytes = base64url.decode(bytes);\n break;\n }\n\n // replace bytes with decoded Buffer (if not already)\n if (!Buffer.isBuffer(bytes)) {\n bytes = Buffer.from(bytes, encoding);\n }\n }\n\n var src, dst;\n if (bytes instanceof DataBuffer) {\n // be slightly more efficient\n var orig = bytes;\n bytes = orig.data.slice(orig.read, orig.write);\n orig.read = orig.write;\n } else if (bytes instanceof forge.util.ByteStringBuffer) {\n bytes = bytes.getBytes();\n }\n\n // process array\n if (Buffer.isBuffer(bytes)) {\n src = bytes;\n } else if (Array.isArray(bytes)) {\n src = Buffer.from(bytes);\n } else if (forge.util.isArrayBuffer(bytes)) {\n src = new Uint8Array(bytes);\n src = Buffer.from(src);\n } else if (forge.util.isArrayBufferView(bytes)) {\n src = (bytes instanceof Uint8Array) ?\n bytes :\n new Uint8Array(bytes.buffer,\n bytes.byteOffset,\n bytes.byteLength);\n src = Buffer.from(src);\n } else {\n throw new TypeError(\"invalid source type\");\n }\n\n this.accommodate(src.length);\n dst = this.data;\n src.copy(dst, this.write);\n this.write += src.length;\n\n return this;\n};\n\nDataBuffer.prototype.getNative = function(count) {\n var rval = this.native(count);\n this.read += rval.length;\n return rval;\n};\nDataBuffer.prototype.putNative = DataBuffer.prototype.putBuffer;\n\nDataBuffer.prototype.getByte = function() {\n var b = this.data[this.read];\n this.read = Math.min(this.read + 1, this.write);\n return b;\n};\nDataBuffer.prototype.putByte = function(b) {\n this.accommodate(1);\n this.data[this.write] = b & 0xff;\n this.write++;\n\n return this;\n};\n\nDataBuffer.prototype.getInt16 = function() {\n var n = (this.data[this.read] << 8) ^\n (this.data[this.read + 1]);\n this.read = Math.min(this.read + 2, this.write);\n return n;\n};\nDataBuffer.prototype.putInt16 = function(n) {\n this.accommodate(2);\n this.data[this.write] = (n >>> 8) & 0xff;\n this.data[this.write + 1] = n & 0xff;\n this.write += 2;\n return this;\n};\n\nDataBuffer.prototype.getInt24 = function() {\n var n = (this.data[this.read] << 16) ^\n (this.data[this.read + 1] << 8) ^\n this.data[this.read + 2];\n this.read = Math.min(this.read + 3, this.write);\n return n;\n};\nDataBuffer.prototype.putInt24 = function(n) {\n this.accommodate(3);\n this.data[this.write] = (n >>> 16) & 0xff;\n this.data[this.write + 1] = (n >>> 8) & 0xff;\n this.data[this.write + 2] = n & 0xff;\n this.write += 3;\n return this;\n};\n\nDataBuffer.prototype.getInt32 = function() {\n var n = (this.data[this.read] << 24) ^\n (this.data[this.read + 1] << 16) ^\n (this.data[this.read + 2] << 8) ^\n this.data[this.read + 3];\n this.read = Math.min(this.read + 4, this.write);\n return n;\n};\nDataBuffer.prototype.putInt32 = function(n) {\n this.accommodate(4);\n this.data[this.write] = (n >>> 24) & 0xff;\n this.data[this.write + 1] = (n >>> 16) & 0xff;\n this.data[this.write + 2] = (n >>> 8) & 0xff;\n this.data[this.write + 3] = n & 0xff;\n this.write += 4;\n return this;\n};\n\nDataBuffer.prototype.getInt16Le = function() {\n var n = (this.data[this.read + 1] << 8) ^\n this.data[this.read];\n this.read = Math.min(this.read + 2, this.write);\n return n;\n};\nDataBuffer.prototype.putInt16Le = function(n) {\n this.accommodate(2);\n this.data[this.write + 1] = (n >>> 8) & 0xff;\n this.data[this.write] = n & 0xff;\n this.write += 2;\n return this;\n};\n\nDataBuffer.prototype.getInt24Le = function() {\n var n = (this.data[this.read + 2] << 16) ^\n (this.data[this.read + 1] << 8) ^\n this.data[this.read];\n this.read = Math.min(this.read + 3, this.write);\n return n;\n};\nDataBuffer.prototype.putInt24Le = function(n) {\n this.accommodate(3);\n this.data[this.write + 2] = (n >>> 16) & 0xff;\n this.data[this.write + 1] = (n >>> 8) & 0xff;\n this.data[this.write] = n & 0xff;\n this.write += 3;\n return this;\n};\nDataBuffer.prototype.getInt32Le = function() {\n var n = (this.data[this.read + 3] << 24) ^\n (this.data[this.read + 2] << 16) ^\n (this.data[this.read + 1] << 8) ^\n this.data[this.read];\n this.read = Math.min(this.read + 4, this.write);\n return n;\n};\nDataBuffer.prototype.putInt32Le = function(n) {\n this.accommodate(4);\n this.data[this.write + 3] = (n >>> 24) & 0xff;\n this.data[this.write + 2] = (n >>> 16) & 0xff;\n this.data[this.write + 1] = (n >>> 8) & 0xff;\n this.data[this.write] = n & 0xff;\n this.write += 4;\n return this;\n};\n\nDataBuffer.prototype.getInt = function(bits) {\n var rval = 0;\n do {\n rval = (rval << 8) | this.getByte();\n bits -= 8;\n } while (bits > 0);\n return rval;\n};\nDataBuffer.prototype.putInt = function(n, bits) {\n this.accommodate(Math.ceil(bits / 8));\n do {\n bits -= 8;\n this.putByte((n >> bits) & 0xff);\n } while (bits > 0);\n return this;\n};\n\nDataBuffer.prototype.putSignedInt = function(n, bits) {\n if (n < 0) {\n n += 2 << (bits - 1);\n }\n return this.putInt(n, bits);\n};\n\nDataBuffer.prototype.putString = function(str) {\n return this.putBytes(str, \"utf16\");\n};\n\nDataBuffer.isBuffer = function(test) {\n return (test instanceof DataBuffer);\n};\nDataBuffer.asBuffer = function(orig) {\n return DataBuffer.isBuffer(orig) ?\n orig :\n orig ?\n new DataBuffer(orig) :\n new DataBuffer();\n};\n\nmodule.exports = DataBuffer;\n","/*!\n * util/index.js - Utilities Entry Point\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar forge = require(\"../deps/forge.js\");\n\nvar util;\n\nfunction asBuffer(input, encoding) {\n if (Buffer.isBuffer(input)) {\n return input;\n }\n\n if (\"string\" === typeof input) {\n encoding = encoding || \"binary\";\n if (\"base64url\" === encoding) {\n return util.base64url.decode(input);\n }\n return Buffer.from(input, encoding);\n }\n\n // assume input is an Array, ArrayBuffer, or ArrayBufferView\n if (forge.util.isArrayBufferView(input)) {\n input = (input instanceof Uint8Array) ?\n input :\n new Uint8Array(input.buffer, input.byteOffset, input.byteOffset + input.byteLength);\n } else if (forge.util.isArrayBuffer(input)) {\n input = new Uint8Array(input);\n }\n\n var output;\n output = Buffer.from(input);\n\n return output;\n}\n\nfunction randomBytes(len) {\n return Buffer.from(forge.random.getBytes(len), \"binary\");\n}\n\nutil = {\n base64url: require(\"./base64url.js\"),\n utf8: require(\"./utf8.js\"),\n asBuffer: asBuffer,\n randomBytes: randomBytes\n};\nmodule.exports = util;\n","/*!\n * util/utf8.js - Implementation of UTF-8 Encoder/Decoder\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar partialRight = require(\"lodash/partialRight\");\nvar merge = require(\"lodash/merge\");\n\nvar typedArrayCtors = (function() {\n var ctors = [];\n if (\"undefined\" !== typeof Uint8ClampedArray) {\n ctors.push(Uint8ClampedArray);\n }\n if (\"undefined\" !== typeof Uint8Array) {\n ctors.push(Uint8Array);\n }\n if (\"undefined\" !== typeof Uint16Array) {\n ctors.push(Uint16Array);\n }\n if (\"undefined\" !== typeof Uint32Array) {\n ctors.push(Uint32Array);\n }\n if (\"undefined\" !== typeof Float32Array) {\n ctors.push(Float32Array);\n }\n if (\"undefined\" !== typeof Float64Array) {\n ctors.push(Float64Array);\n }\n return ctors;\n})();\n\nfunction findTypedArrayFor(ta) {\n var ctor;\n for (var idx = 0; !ctor && typedArrayCtors.length > idx; idx++) {\n if (ta instanceof typedArrayCtors[idx]) {\n ctor = typedArrayCtors[idx];\n }\n }\n return ctor;\n}\n\nfunction mergeBuffer(a, b) {\n // TODO: should this be a copy, or the reference itself?\n if (Buffer.isBuffer(b)) {\n b = Buffer.from(b);\n } else {\n var Ctor = findTypedArrayFor(b);\n b = Ctor ?\n new Ctor(b, b.byteOffset, b.byteLength) :\n undefined;\n }\n\n // TODO: QUESTION: create a merged ??\n // for now, a is b\n a = b;\n\n return b;\n}\n\nmodule.exports = partialRight(merge, mergeBuffer);\n","/*!\n * util/utf8.js - Implementation of UTF-8 Encoder/Decoder\n *\n * Copyright (c) 2015 Cisco Systems, Inc. See LICENSE file.\n */\n\"use strict\";\n\nvar utf8 = exports;\n\nutf8.encode = function(input) {\n var output = encodeURIComponent(input || \"\");\n output = output.replace(/%([0-9a-fA-F]{2})/g, function(m, code) {\n code = parseInt(code, 16);\n return String.fromCharCode(code);\n });\n\n return output;\n};\nutf8.decode = function(input) {\n var output = (input || \"\").replace(/[\\u0080-\\u00ff]/g, function(m) {\n var code = (0x100 | m.charCodeAt(0)).toString(16).substring(1);\n return \"%\" + code;\n });\n output = decodeURIComponent(output);\n\n return output;\n};\n","// Top level file is just a mixin of submodules & constants\n'use strict';\n\nconst { Deflate, deflate, deflateRaw, gzip } = require('./lib/deflate');\n\nconst { Inflate, inflate, inflateRaw, ungzip } = require('./lib/inflate');\n\nconst constants = require('./lib/zlib/constants');\n\nmodule.exports.Deflate = Deflate;\nmodule.exports.deflate = deflate;\nmodule.exports.deflateRaw = deflateRaw;\nmodule.exports.gzip = gzip;\nmodule.exports.Inflate = Inflate;\nmodule.exports.inflate = inflate;\nmodule.exports.inflateRaw = inflateRaw;\nmodule.exports.ungzip = ungzip;\nmodule.exports.constants = constants;\n","'use strict';\n\n\nconst zlib_deflate = require('./zlib/deflate');\nconst utils = require('./utils/common');\nconst strings = require('./utils/strings');\nconst msg = require('./zlib/messages');\nconst ZStream = require('./zlib/zstream');\n\nconst toString = Object.prototype.toString;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_NO_FLUSH, Z_SYNC_FLUSH, Z_FULL_FLUSH, Z_FINISH,\n Z_OK, Z_STREAM_END,\n Z_DEFAULT_COMPRESSION,\n Z_DEFAULT_STRATEGY,\n Z_DEFLATED\n} = require('./zlib/constants');\n\n/* ===========================================================================*/\n\n\n/**\n * class Deflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[deflate]],\n * [[deflateRaw]] and [[gzip]].\n **/\n\n/* internal\n * Deflate.chunks -> Array\n *\n * Chunks of output data, if [[Deflate#onData]] not overridden.\n **/\n\n/**\n * Deflate.result -> Uint8Array\n *\n * Compressed result, generated by default [[Deflate#onData]]\n * and [[Deflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Deflate#push]] with `Z_FINISH` / `true` param).\n **/\n\n/**\n * Deflate.err -> Number\n *\n * Error code after deflate finished. 0 (Z_OK) on success.\n * You will not need it in real life, because deflate errors\n * are possible only on wrong options or bad `onData` / `onEnd`\n * custom handlers.\n **/\n\n/**\n * Deflate.msg -> String\n *\n * Error message, if [[Deflate.err]] != 0\n **/\n\n\n/**\n * new Deflate(options)\n * - options (Object): zlib deflate options.\n *\n * Creates new deflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `level`\n * - `windowBits`\n * - `memLevel`\n * - `strategy`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw deflate\n * - `gzip` (Boolean) - create gzip wrapper\n * - `header` (Object) - custom header for gzip\n * - `text` (Boolean) - true if compressed data believed to be text\n * - `time` (Number) - modification time, unix timestamp\n * - `os` (Number) - operation system code\n * - `extra` (Array) - array of bytes with extra data (max 65536)\n * - `name` (String) - file name (binary string)\n * - `comment` (String) - comment (binary string)\n * - `hcrc` (Boolean) - true if header crc should be added\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako')\n * , chunk1 = new Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = new Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * const deflate = new pako.Deflate({ level: 3});\n *\n * deflate.push(chunk1, false);\n * deflate.push(chunk2, true); // true -> last chunk\n *\n * if (deflate.err) { throw new Error(deflate.err); }\n *\n * console.log(deflate.result);\n * ```\n **/\nfunction Deflate(options) {\n this.options = utils.assign({\n level: Z_DEFAULT_COMPRESSION,\n method: Z_DEFLATED,\n chunkSize: 16384,\n windowBits: 15,\n memLevel: 8,\n strategy: Z_DEFAULT_STRATEGY\n }, options || {});\n\n let opt = this.options;\n\n if (opt.raw && (opt.windowBits > 0)) {\n opt.windowBits = -opt.windowBits;\n }\n\n else if (opt.gzip && (opt.windowBits > 0) && (opt.windowBits < 16)) {\n opt.windowBits += 16;\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new ZStream();\n this.strm.avail_out = 0;\n\n let status = zlib_deflate.deflateInit2(\n this.strm,\n opt.level,\n opt.method,\n opt.windowBits,\n opt.memLevel,\n opt.strategy\n );\n\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n\n if (opt.header) {\n zlib_deflate.deflateSetHeader(this.strm, opt.header);\n }\n\n if (opt.dictionary) {\n let dict;\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n // If we need to compress text, change encoding to utf8.\n dict = strings.string2buf(opt.dictionary);\n } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n dict = new Uint8Array(opt.dictionary);\n } else {\n dict = opt.dictionary;\n }\n\n status = zlib_deflate.deflateSetDictionary(this.strm, dict);\n\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n\n this._dict_set = true;\n }\n}\n\n/**\n * Deflate#push(data[, flush_mode]) -> Boolean\n * - data (Uint8Array|ArrayBuffer|String): input data. Strings will be\n * converted to utf8 byte sequence.\n * - flush_mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` means Z_FINISH.\n *\n * Sends input data to deflate pipe, generating [[Deflate#onData]] calls with\n * new compressed chunks. Returns `true` on success. The last data block must\n * have `flush_mode` Z_FINISH (or `true`). That will flush internal pending\n * buffers and call [[Deflate#onEnd]].\n *\n * On fail call [[Deflate#onEnd]] with error code and return false.\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nDeflate.prototype.push = function (data, flush_mode) {\n const strm = this.strm;\n const chunkSize = this.options.chunkSize;\n let status, _flush_mode;\n\n if (this.ended) { return false; }\n\n if (flush_mode === ~~flush_mode) _flush_mode = flush_mode;\n else _flush_mode = flush_mode === true ? Z_FINISH : Z_NO_FLUSH;\n\n // Convert data if needed\n if (typeof data === 'string') {\n // If we need to compress text, change encoding to utf8.\n strm.input = strings.string2buf(data);\n } else if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n for (;;) {\n if (strm.avail_out === 0) {\n strm.output = new Uint8Array(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n // Make sure avail_out > 6 to avoid repeating markers\n if ((_flush_mode === Z_SYNC_FLUSH || _flush_mode === Z_FULL_FLUSH) && strm.avail_out <= 6) {\n this.onData(strm.output.subarray(0, strm.next_out));\n strm.avail_out = 0;\n continue;\n }\n\n status = zlib_deflate.deflate(strm, _flush_mode);\n\n // Ended => flush and finish\n if (status === Z_STREAM_END) {\n if (strm.next_out > 0) {\n this.onData(strm.output.subarray(0, strm.next_out));\n }\n status = zlib_deflate.deflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === Z_OK;\n }\n\n // Flush if out buffer full\n if (strm.avail_out === 0) {\n this.onData(strm.output);\n continue;\n }\n\n // Flush if requested and has data\n if (_flush_mode > 0 && strm.next_out > 0) {\n this.onData(strm.output.subarray(0, strm.next_out));\n strm.avail_out = 0;\n continue;\n }\n\n if (strm.avail_in === 0) break;\n }\n\n return true;\n};\n\n\n/**\n * Deflate#onData(chunk) -> Void\n * - chunk (Uint8Array): output data.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nDeflate.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Deflate#onEnd(status) -> Void\n * - status (Number): deflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called once after you tell deflate that the input stream is\n * complete (Z_FINISH). By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nDeflate.prototype.onEnd = function (status) {\n // On success - join\n if (status === Z_OK) {\n this.result = utils.flattenChunks(this.chunks);\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * deflate(data[, options]) -> Uint8Array\n * - data (Uint8Array|ArrayBuffer|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * Compress `data` with deflate algorithm and `options`.\n *\n * Supported options are:\n *\n * - level\n * - windowBits\n * - memLevel\n * - strategy\n * - dictionary\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako')\n * const data = new Uint8Array([1,2,3,4,5,6,7,8,9]);\n *\n * console.log(pako.deflate(data));\n * ```\n **/\nfunction deflate(input, options) {\n const deflator = new Deflate(options);\n\n deflator.push(input, true);\n\n // That will never happens, if you don't cheat with options :)\n if (deflator.err) { throw deflator.msg || msg[deflator.err]; }\n\n return deflator.result;\n}\n\n\n/**\n * deflateRaw(data[, options]) -> Uint8Array\n * - data (Uint8Array|ArrayBuffer|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction deflateRaw(input, options) {\n options = options || {};\n options.raw = true;\n return deflate(input, options);\n}\n\n\n/**\n * gzip(data[, options]) -> Uint8Array\n * - data (Uint8Array|ArrayBuffer|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but create gzip wrapper instead of\n * deflate one.\n **/\nfunction gzip(input, options) {\n options = options || {};\n options.gzip = true;\n return deflate(input, options);\n}\n\n\nmodule.exports.Deflate = Deflate;\nmodule.exports.deflate = deflate;\nmodule.exports.deflateRaw = deflateRaw;\nmodule.exports.gzip = gzip;\nmodule.exports.constants = require('./zlib/constants');\n","'use strict';\n\n\nconst zlib_inflate = require('./zlib/inflate');\nconst utils = require('./utils/common');\nconst strings = require('./utils/strings');\nconst msg = require('./zlib/messages');\nconst ZStream = require('./zlib/zstream');\nconst GZheader = require('./zlib/gzheader');\n\nconst toString = Object.prototype.toString;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_NO_FLUSH, Z_FINISH,\n Z_OK, Z_STREAM_END, Z_NEED_DICT, Z_STREAM_ERROR, Z_DATA_ERROR, Z_MEM_ERROR\n} = require('./zlib/constants');\n\n/* ===========================================================================*/\n\n\n/**\n * class Inflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[inflate]]\n * and [[inflateRaw]].\n **/\n\n/* internal\n * inflate.chunks -> Array\n *\n * Chunks of output data, if [[Inflate#onData]] not overridden.\n **/\n\n/**\n * Inflate.result -> Uint8Array|String\n *\n * Uncompressed result, generated by default [[Inflate#onData]]\n * and [[Inflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Inflate#push]] with `Z_FINISH` / `true` param).\n **/\n\n/**\n * Inflate.err -> Number\n *\n * Error code after inflate finished. 0 (Z_OK) on success.\n * Should be checked if broken data possible.\n **/\n\n/**\n * Inflate.msg -> String\n *\n * Error message, if [[Inflate.err]] != 0\n **/\n\n\n/**\n * new Inflate(options)\n * - options (Object): zlib inflate options.\n *\n * Creates new inflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `windowBits`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw inflate\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n * By default, when no options set, autodetect deflate/gzip data format via\n * wrapper header.\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako')\n * const chunk1 = new Uint8Array([1,2,3,4,5,6,7,8,9])\n * const chunk2 = new Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * const inflate = new pako.Inflate({ level: 3});\n *\n * inflate.push(chunk1, false);\n * inflate.push(chunk2, true); // true -> last chunk\n *\n * if (inflate.err) { throw new Error(inflate.err); }\n *\n * console.log(inflate.result);\n * ```\n **/\nfunction Inflate(options) {\n this.options = utils.assign({\n chunkSize: 1024 * 64,\n windowBits: 15,\n to: ''\n }, options || {});\n\n const opt = this.options;\n\n // Force window size for `raw` data, if not set directly,\n // because we have no header for autodetect.\n if (opt.raw && (opt.windowBits >= 0) && (opt.windowBits < 16)) {\n opt.windowBits = -opt.windowBits;\n if (opt.windowBits === 0) { opt.windowBits = -15; }\n }\n\n // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate\n if ((opt.windowBits >= 0) && (opt.windowBits < 16) &&\n !(options && options.windowBits)) {\n opt.windowBits += 32;\n }\n\n // Gzip header has no info about windows size, we can do autodetect only\n // for deflate. So, if window size not set, force it to max when gzip possible\n if ((opt.windowBits > 15) && (opt.windowBits < 48)) {\n // bit 3 (16) -> gzipped data\n // bit 4 (32) -> autodetect gzip/deflate\n if ((opt.windowBits & 15) === 0) {\n opt.windowBits |= 15;\n }\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new ZStream();\n this.strm.avail_out = 0;\n\n let status = zlib_inflate.inflateInit2(\n this.strm,\n opt.windowBits\n );\n\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n\n this.header = new GZheader();\n\n zlib_inflate.inflateGetHeader(this.strm, this.header);\n\n // Setup dictionary\n if (opt.dictionary) {\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n opt.dictionary = strings.string2buf(opt.dictionary);\n } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n opt.dictionary = new Uint8Array(opt.dictionary);\n }\n if (opt.raw) { //In raw mode we need to set the dictionary early\n status = zlib_inflate.inflateSetDictionary(this.strm, opt.dictionary);\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n }\n }\n}\n\n/**\n * Inflate#push(data[, flush_mode]) -> Boolean\n * - data (Uint8Array|ArrayBuffer): input data\n * - flush_mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE\n * flush modes. See constants. Skipped or `false` means Z_NO_FLUSH,\n * `true` means Z_FINISH.\n *\n * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with\n * new output chunks. Returns `true` on success. If end of stream detected,\n * [[Inflate#onEnd]] will be called.\n *\n * `flush_mode` is not needed for normal operation, because end of stream\n * detected automatically. You may try to use it for advanced things, but\n * this functionality was not tested.\n *\n * On fail call [[Inflate#onEnd]] with error code and return false.\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nInflate.prototype.push = function (data, flush_mode) {\n const strm = this.strm;\n const chunkSize = this.options.chunkSize;\n const dictionary = this.options.dictionary;\n let status, _flush_mode, last_avail_out;\n\n if (this.ended) return false;\n\n if (flush_mode === ~~flush_mode) _flush_mode = flush_mode;\n else _flush_mode = flush_mode === true ? Z_FINISH : Z_NO_FLUSH;\n\n // Convert data if needed\n if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n for (;;) {\n if (strm.avail_out === 0) {\n strm.output = new Uint8Array(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n status = zlib_inflate.inflate(strm, _flush_mode);\n\n if (status === Z_NEED_DICT && dictionary) {\n status = zlib_inflate.inflateSetDictionary(strm, dictionary);\n\n if (status === Z_OK) {\n status = zlib_inflate.inflate(strm, _flush_mode);\n } else if (status === Z_DATA_ERROR) {\n // Replace code with more verbose\n status = Z_NEED_DICT;\n }\n }\n\n // Skip snyc markers if more data follows and not raw mode\n while (strm.avail_in > 0 &&\n status === Z_STREAM_END &&\n strm.state.wrap > 0 &&\n data[strm.next_in] !== 0)\n {\n zlib_inflate.inflateReset(strm);\n status = zlib_inflate.inflate(strm, _flush_mode);\n }\n\n switch (status) {\n case Z_STREAM_ERROR:\n case Z_DATA_ERROR:\n case Z_NEED_DICT:\n case Z_MEM_ERROR:\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n\n // Remember real `avail_out` value, because we may patch out buffer content\n // to align utf8 strings boundaries.\n last_avail_out = strm.avail_out;\n\n if (strm.next_out) {\n if (strm.avail_out === 0 || status === Z_STREAM_END) {\n\n if (this.options.to === 'string') {\n\n let next_out_utf8 = strings.utf8border(strm.output, strm.next_out);\n\n let tail = strm.next_out - next_out_utf8;\n let utf8str = strings.buf2string(strm.output, next_out_utf8);\n\n // move tail & realign counters\n strm.next_out = tail;\n strm.avail_out = chunkSize - tail;\n if (tail) strm.output.set(strm.output.subarray(next_out_utf8, next_out_utf8 + tail), 0);\n\n this.onData(utf8str);\n\n } else {\n this.onData(strm.output.length === strm.next_out ? strm.output : strm.output.subarray(0, strm.next_out));\n }\n }\n }\n\n // Must repeat iteration if out buffer is full\n if (status === Z_OK && last_avail_out === 0) continue;\n\n // Finalize if end of stream reached.\n if (status === Z_STREAM_END) {\n status = zlib_inflate.inflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return true;\n }\n\n if (strm.avail_in === 0) break;\n }\n\n return true;\n};\n\n\n/**\n * Inflate#onData(chunk) -> Void\n * - chunk (Uint8Array|String): output data. When string output requested,\n * each chunk will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nInflate.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Inflate#onEnd(status) -> Void\n * - status (Number): inflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called either after you tell inflate that the input stream is\n * complete (Z_FINISH). By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nInflate.prototype.onEnd = function (status) {\n // On success - join\n if (status === Z_OK) {\n if (this.options.to === 'string') {\n this.result = this.chunks.join('');\n } else {\n this.result = utils.flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * inflate(data[, options]) -> Uint8Array|String\n * - data (Uint8Array|ArrayBuffer): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Decompress `data` with inflate/ungzip and `options`. Autodetect\n * format via wrapper header by default. That's why we don't provide\n * separate `ungzip` method.\n *\n * Supported options are:\n *\n * - windowBits\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako');\n * const input = pako.deflate(new Uint8Array([1,2,3,4,5,6,7,8,9]));\n * let output;\n *\n * try {\n * output = pako.inflate(input);\n * } catch (err) {\n * console.log(err);\n * }\n * ```\n **/\nfunction inflate(input, options) {\n const inflator = new Inflate(options);\n\n inflator.push(input);\n\n // That will never happens, if you don't cheat with options :)\n if (inflator.err) throw inflator.msg || msg[inflator.err];\n\n return inflator.result;\n}\n\n\n/**\n * inflateRaw(data[, options]) -> Uint8Array|String\n * - data (Uint8Array|ArrayBuffer): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * The same as [[inflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction inflateRaw(input, options) {\n options = options || {};\n options.raw = true;\n return inflate(input, options);\n}\n\n\n/**\n * ungzip(data[, options]) -> Uint8Array|String\n * - data (Uint8Array|ArrayBuffer): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Just shortcut to [[inflate]], because it autodetects format\n * by header.content. Done for convenience.\n **/\n\n\nmodule.exports.Inflate = Inflate;\nmodule.exports.inflate = inflate;\nmodule.exports.inflateRaw = inflateRaw;\nmodule.exports.ungzip = inflate;\nmodule.exports.constants = require('./zlib/constants');\n","'use strict';\n\n\nconst _has = (obj, key) => {\n return Object.prototype.hasOwnProperty.call(obj, key);\n};\n\nmodule.exports.assign = function (obj /*from1, from2, from3, ...*/) {\n const sources = Array.prototype.slice.call(arguments, 1);\n while (sources.length) {\n const source = sources.shift();\n if (!source) { continue; }\n\n if (typeof source !== 'object') {\n throw new TypeError(source + 'must be non-object');\n }\n\n for (const p in source) {\n if (_has(source, p)) {\n obj[p] = source[p];\n }\n }\n }\n\n return obj;\n};\n\n\n// Join array of chunks to single array.\nmodule.exports.flattenChunks = (chunks) => {\n // calculate data length\n let len = 0;\n\n for (let i = 0, l = chunks.length; i < l; i++) {\n len += chunks[i].length;\n }\n\n // join chunks\n const result = new Uint8Array(len);\n\n for (let i = 0, pos = 0, l = chunks.length; i < l; i++) {\n let chunk = chunks[i];\n result.set(chunk, pos);\n pos += chunk.length;\n }\n\n return result;\n};\n","// String encode/decode helpers\n'use strict';\n\n\n// Quick check if we can use fast array to bin string conversion\n//\n// - apply(Array) can fail on Android 2.2\n// - apply(Uint8Array) can fail on iOS 5.1 Safari\n//\nlet STR_APPLY_UIA_OK = true;\n\ntry { String.fromCharCode.apply(null, new Uint8Array(1)); } catch (__) { STR_APPLY_UIA_OK = false; }\n\n\n// Table with utf8 lengths (calculated by first byte of sequence)\n// Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,\n// because max possible codepoint is 0x10ffff\nconst _utf8len = new Uint8Array(256);\nfor (let q = 0; q < 256; q++) {\n _utf8len[q] = (q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1);\n}\n_utf8len[254] = _utf8len[254] = 1; // Invalid sequence start\n\n\n// convert string to array (typed, when possible)\nmodule.exports.string2buf = (str) => {\n if (typeof TextEncoder === 'function' && TextEncoder.prototype.encode) {\n return new TextEncoder().encode(str);\n }\n\n let buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;\n\n // count binary size\n for (m_pos = 0; m_pos < str_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\n }\n\n // allocate buffer\n buf = new Uint8Array(buf_len);\n\n // convert\n for (i = 0, m_pos = 0; i < buf_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n if (c < 0x80) {\n /* one byte */\n buf[i++] = c;\n } else if (c < 0x800) {\n /* two bytes */\n buf[i++] = 0xC0 | (c >>> 6);\n buf[i++] = 0x80 | (c & 0x3f);\n } else if (c < 0x10000) {\n /* three bytes */\n buf[i++] = 0xE0 | (c >>> 12);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n } else {\n /* four bytes */\n buf[i++] = 0xf0 | (c >>> 18);\n buf[i++] = 0x80 | (c >>> 12 & 0x3f);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n }\n\n return buf;\n};\n\n// Helper\nconst buf2binstring = (buf, len) => {\n // On Chrome, the arguments in a function call that are allowed is `65534`.\n // If the length of the buffer is smaller than that, we can use this optimization,\n // otherwise we will take a slower path.\n if (len < 65534) {\n if (buf.subarray && STR_APPLY_UIA_OK) {\n return String.fromCharCode.apply(null, buf.length === len ? buf : buf.subarray(0, len));\n }\n }\n\n let result = '';\n for (let i = 0; i < len; i++) {\n result += String.fromCharCode(buf[i]);\n }\n return result;\n};\n\n\n// convert array to string\nmodule.exports.buf2string = (buf, max) => {\n const len = max || buf.length;\n\n if (typeof TextDecoder === 'function' && TextDecoder.prototype.decode) {\n return new TextDecoder().decode(buf.subarray(0, max));\n }\n\n let i, out;\n\n // Reserve max possible length (2 words per char)\n // NB: by unknown reasons, Array is significantly faster for\n // String.fromCharCode.apply than Uint16Array.\n const utf16buf = new Array(len * 2);\n\n for (out = 0, i = 0; i < len;) {\n let c = buf[i++];\n // quick process ascii\n if (c < 0x80) { utf16buf[out++] = c; continue; }\n\n let c_len = _utf8len[c];\n // skip 5 & 6 byte codes\n if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len - 1; continue; }\n\n // apply mask on first byte\n c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;\n // join the rest\n while (c_len > 1 && i < len) {\n c = (c << 6) | (buf[i++] & 0x3f);\n c_len--;\n }\n\n // terminated by end of string?\n if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }\n\n if (c < 0x10000) {\n utf16buf[out++] = c;\n } else {\n c -= 0x10000;\n utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);\n utf16buf[out++] = 0xdc00 | (c & 0x3ff);\n }\n }\n\n return buf2binstring(utf16buf, out);\n};\n\n\n// Calculate max possible position in utf8 buffer,\n// that will not break sequence. If that's not possible\n// - (very small limits) return max size as is.\n//\n// buf[] - utf8 bytes array\n// max - length limit (mandatory);\nmodule.exports.utf8border = (buf, max) => {\n\n max = max || buf.length;\n if (max > buf.length) { max = buf.length; }\n\n // go back from last position, until start of sequence found\n let pos = max - 1;\n while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }\n\n // Very small and broken sequence,\n // return max, because we should return something anyway.\n if (pos < 0) { return max; }\n\n // If we came to start of buffer - that means buffer is too small,\n // return max too.\n if (pos === 0) { return max; }\n\n return (pos + _utf8len[buf[pos]] > max) ? pos : max;\n};\n","'use strict';\n\n// Note: adler32 takes 12% for level 0 and 2% for level 6.\n// It isn't worth it to make additional optimizations as in original.\n// Small size is preferable.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst adler32 = (adler, buf, len, pos) => {\n let s1 = (adler & 0xffff) |0,\n s2 = ((adler >>> 16) & 0xffff) |0,\n n = 0;\n\n while (len !== 0) {\n // Set limit ~ twice less than 5552, to keep\n // s2 in 31-bits, because we force signed ints.\n // in other case %= will fail.\n n = len > 2000 ? 2000 : len;\n len -= n;\n\n do {\n s1 = (s1 + buf[pos++]) |0;\n s2 = (s2 + s1) |0;\n } while (--n);\n\n s1 %= 65521;\n s2 %= 65521;\n }\n\n return (s1 | (s2 << 16)) |0;\n};\n\n\nmodule.exports = adler32;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nmodule.exports = {\n\n /* Allowed flush values; see deflate() and inflate() below for details */\n Z_NO_FLUSH: 0,\n Z_PARTIAL_FLUSH: 1,\n Z_SYNC_FLUSH: 2,\n Z_FULL_FLUSH: 3,\n Z_FINISH: 4,\n Z_BLOCK: 5,\n Z_TREES: 6,\n\n /* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\n Z_OK: 0,\n Z_STREAM_END: 1,\n Z_NEED_DICT: 2,\n Z_ERRNO: -1,\n Z_STREAM_ERROR: -2,\n Z_DATA_ERROR: -3,\n Z_MEM_ERROR: -4,\n Z_BUF_ERROR: -5,\n //Z_VERSION_ERROR: -6,\n\n /* compression levels */\n Z_NO_COMPRESSION: 0,\n Z_BEST_SPEED: 1,\n Z_BEST_COMPRESSION: 9,\n Z_DEFAULT_COMPRESSION: -1,\n\n\n Z_FILTERED: 1,\n Z_HUFFMAN_ONLY: 2,\n Z_RLE: 3,\n Z_FIXED: 4,\n Z_DEFAULT_STRATEGY: 0,\n\n /* Possible values of the data_type field (though see inflate()) */\n Z_BINARY: 0,\n Z_TEXT: 1,\n //Z_ASCII: 1, // = Z_TEXT (deprecated)\n Z_UNKNOWN: 2,\n\n /* The deflate compression method */\n Z_DEFLATED: 8\n //Z_NULL: null // Use -1 or null inline, depending on var type\n};\n","'use strict';\n\n// Note: we can't get significant speed boost here.\n// So write code to minimize size - no pregenerated tables\n// and array tools dependencies.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// Use ordinary array, since untyped makes no boost here\nconst makeTable = () => {\n let c, table = [];\n\n for (var n = 0; n < 256; n++) {\n c = n;\n for (var k = 0; k < 8; k++) {\n c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));\n }\n table[n] = c;\n }\n\n return table;\n};\n\n// Create table on load. Just 255 signed longs. Not a problem.\nconst crcTable = new Uint32Array(makeTable());\n\n\nconst crc32 = (crc, buf, len, pos) => {\n const t = crcTable;\n const end = pos + len;\n\n crc ^= -1;\n\n for (let i = pos; i < end; i++) {\n crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];\n }\n\n return (crc ^ (-1)); // >>> 0;\n};\n\n\nmodule.exports = crc32;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst { _tr_init, _tr_stored_block, _tr_flush_block, _tr_tally, _tr_align } = require('./trees');\nconst adler32 = require('./adler32');\nconst crc32 = require('./crc32');\nconst msg = require('./messages');\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_NO_FLUSH, Z_PARTIAL_FLUSH, Z_FULL_FLUSH, Z_FINISH, Z_BLOCK,\n Z_OK, Z_STREAM_END, Z_STREAM_ERROR, Z_DATA_ERROR, Z_BUF_ERROR,\n Z_DEFAULT_COMPRESSION,\n Z_FILTERED, Z_HUFFMAN_ONLY, Z_RLE, Z_FIXED, Z_DEFAULT_STRATEGY,\n Z_UNKNOWN,\n Z_DEFLATED\n} = require('./constants');\n\n/*============================================================================*/\n\n\nconst MAX_MEM_LEVEL = 9;\n/* Maximum value for memLevel in deflateInit2 */\nconst MAX_WBITS = 15;\n/* 32K LZ77 window */\nconst DEF_MEM_LEVEL = 8;\n\n\nconst LENGTH_CODES = 29;\n/* number of length codes, not counting the special END_BLOCK code */\nconst LITERALS = 256;\n/* number of literal bytes 0..255 */\nconst L_CODES = LITERALS + 1 + LENGTH_CODES;\n/* number of Literal or Length codes, including the END_BLOCK code */\nconst D_CODES = 30;\n/* number of distance codes */\nconst BL_CODES = 19;\n/* number of codes used to transfer the bit lengths */\nconst HEAP_SIZE = 2 * L_CODES + 1;\n/* maximum heap size */\nconst MAX_BITS = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nconst MIN_MATCH = 3;\nconst MAX_MATCH = 258;\nconst MIN_LOOKAHEAD = (MAX_MATCH + MIN_MATCH + 1);\n\nconst PRESET_DICT = 0x20;\n\nconst INIT_STATE = 42; /* zlib header -> BUSY_STATE */\n//#ifdef GZIP\nconst GZIP_STATE = 57; /* gzip header -> BUSY_STATE | EXTRA_STATE */\n//#endif\nconst EXTRA_STATE = 69; /* gzip extra block -> NAME_STATE */\nconst NAME_STATE = 73; /* gzip file name -> COMMENT_STATE */\nconst COMMENT_STATE = 91; /* gzip comment -> HCRC_STATE */\nconst HCRC_STATE = 103; /* gzip header CRC -> BUSY_STATE */\nconst BUSY_STATE = 113; /* deflate -> FINISH_STATE */\nconst FINISH_STATE = 666; /* stream complete */\n\nconst BS_NEED_MORE = 1; /* block not completed, need more input or more output */\nconst BS_BLOCK_DONE = 2; /* block flush performed */\nconst BS_FINISH_STARTED = 3; /* finish started, need only more output at next deflate */\nconst BS_FINISH_DONE = 4; /* finish done, accept no more input or output */\n\nconst OS_CODE = 0x03; // Unix :) . Don't detect, use this default.\n\nconst err = (strm, errorCode) => {\n strm.msg = msg[errorCode];\n return errorCode;\n};\n\nconst rank = (f) => {\n return ((f) * 2) - ((f) > 4 ? 9 : 0);\n};\n\nconst zero = (buf) => {\n let len = buf.length; while (--len >= 0) { buf[len] = 0; }\n};\n\n/* ===========================================================================\n * Slide the hash table when sliding the window down (could be avoided with 32\n * bit values at the expense of memory usage). We slide even when level == 0 to\n * keep the hash table consistent if we switch back to level > 0 later.\n */\nconst slide_hash = (s) => {\n let n, m;\n let p;\n let wsize = s.w_size;\n\n n = s.hash_size;\n p = n;\n do {\n m = s.head[--p];\n s.head[p] = (m >= wsize ? m - wsize : 0);\n } while (--n);\n n = wsize;\n//#ifndef FASTEST\n p = n;\n do {\n m = s.prev[--p];\n s.prev[p] = (m >= wsize ? m - wsize : 0);\n /* If n is not on any hash chain, prev[n] is garbage but\n * its value will never be used.\n */\n } while (--n);\n//#endif\n};\n\n/* eslint-disable new-cap */\nlet HASH_ZLIB = (s, prev, data) => ((prev << s.hash_shift) ^ data) & s.hash_mask;\n// This hash causes less collisions, https://github.com/nodeca/pako/issues/135\n// But breaks binary compatibility\n//let HASH_FAST = (s, prev, data) => ((prev << 8) + (prev >> 8) + (data << 4)) & s.hash_mask;\nlet HASH = HASH_ZLIB;\n\n\n/* =========================================================================\n * Flush as much pending output as possible. All deflate() output, except for\n * some deflate_stored() output, goes through this function so some\n * applications may wish to modify it to avoid allocating a large\n * strm->next_out buffer and copying into it. (See also read_buf()).\n */\nconst flush_pending = (strm) => {\n const s = strm.state;\n\n //_tr_flush_bits(s);\n let len = s.pending;\n if (len > strm.avail_out) {\n len = strm.avail_out;\n }\n if (len === 0) { return; }\n\n strm.output.set(s.pending_buf.subarray(s.pending_out, s.pending_out + len), strm.next_out);\n strm.next_out += len;\n s.pending_out += len;\n strm.total_out += len;\n strm.avail_out -= len;\n s.pending -= len;\n if (s.pending === 0) {\n s.pending_out = 0;\n }\n};\n\n\nconst flush_block_only = (s, last) => {\n _tr_flush_block(s, (s.block_start >= 0 ? s.block_start : -1), s.strstart - s.block_start, last);\n s.block_start = s.strstart;\n flush_pending(s.strm);\n};\n\n\nconst put_byte = (s, b) => {\n s.pending_buf[s.pending++] = b;\n};\n\n\n/* =========================================================================\n * Put a short in the pending buffer. The 16-bit value is put in MSB order.\n * IN assertion: the stream state is correct and there is enough room in\n * pending_buf.\n */\nconst putShortMSB = (s, b) => {\n\n // put_byte(s, (Byte)(b >> 8));\n// put_byte(s, (Byte)(b & 0xff));\n s.pending_buf[s.pending++] = (b >>> 8) & 0xff;\n s.pending_buf[s.pending++] = b & 0xff;\n};\n\n\n/* ===========================================================================\n * Read a new buffer from the current input stream, update the adler32\n * and total number of bytes read. All deflate() input goes through\n * this function so some applications may wish to modify it to avoid\n * allocating a large strm->input buffer and copying from it.\n * (See also flush_pending()).\n */\nconst read_buf = (strm, buf, start, size) => {\n\n let len = strm.avail_in;\n\n if (len > size) { len = size; }\n if (len === 0) { return 0; }\n\n strm.avail_in -= len;\n\n // zmemcpy(buf, strm->next_in, len);\n buf.set(strm.input.subarray(strm.next_in, strm.next_in + len), start);\n if (strm.state.wrap === 1) {\n strm.adler = adler32(strm.adler, buf, len, start);\n }\n\n else if (strm.state.wrap === 2) {\n strm.adler = crc32(strm.adler, buf, len, start);\n }\n\n strm.next_in += len;\n strm.total_in += len;\n\n return len;\n};\n\n\n/* ===========================================================================\n * Set match_start to the longest match starting at the given string and\n * return its length. Matches shorter or equal to prev_length are discarded,\n * in which case the result is equal to prev_length and match_start is\n * garbage.\n * IN assertions: cur_match is the head of the hash chain for the current\n * string (strstart) and its distance is <= MAX_DIST, and prev_length >= 1\n * OUT assertion: the match length is not greater than s->lookahead.\n */\nconst longest_match = (s, cur_match) => {\n\n let chain_length = s.max_chain_length; /* max hash chain length */\n let scan = s.strstart; /* current string */\n let match; /* matched string */\n let len; /* length of current match */\n let best_len = s.prev_length; /* best match length so far */\n let nice_match = s.nice_match; /* stop if match long enough */\n const limit = (s.strstart > (s.w_size - MIN_LOOKAHEAD)) ?\n s.strstart - (s.w_size - MIN_LOOKAHEAD) : 0/*NIL*/;\n\n const _win = s.window; // shortcut\n\n const wmask = s.w_mask;\n const prev = s.prev;\n\n /* Stop when cur_match becomes <= limit. To simplify the code,\n * we prevent matches with the string of window index 0.\n */\n\n const strend = s.strstart + MAX_MATCH;\n let scan_end1 = _win[scan + best_len - 1];\n let scan_end = _win[scan + best_len];\n\n /* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16.\n * It is easy to get rid of this optimization if necessary.\n */\n // Assert(s->hash_bits >= 8 && MAX_MATCH == 258, \"Code too clever\");\n\n /* Do not waste too much time if we already have a good match: */\n if (s.prev_length >= s.good_match) {\n chain_length >>= 2;\n }\n /* Do not look for matches beyond the end of the input. This is necessary\n * to make deflate deterministic.\n */\n if (nice_match > s.lookahead) { nice_match = s.lookahead; }\n\n // Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, \"need lookahead\");\n\n do {\n // Assert(cur_match < s->strstart, \"no future\");\n match = cur_match;\n\n /* Skip to next match if the match length cannot increase\n * or if the match length is less than 2. Note that the checks below\n * for insufficient lookahead only occur occasionally for performance\n * reasons. Therefore uninitialized memory will be accessed, and\n * conditional jumps will be made that depend on those values.\n * However the length of the match is limited to the lookahead, so\n * the output of deflate is not affected by the uninitialized values.\n */\n\n if (_win[match + best_len] !== scan_end ||\n _win[match + best_len - 1] !== scan_end1 ||\n _win[match] !== _win[scan] ||\n _win[++match] !== _win[scan + 1]) {\n continue;\n }\n\n /* The check at best_len-1 can be removed because it will be made\n * again later. (This heuristic is not always a win.)\n * It is not necessary to compare scan[2] and match[2] since they\n * are always equal when the other bytes match, given that\n * the hash keys are equal and that HASH_BITS >= 8.\n */\n scan += 2;\n match++;\n // Assert(*scan == *match, \"match[2]?\");\n\n /* We check for insufficient lookahead only every 8th comparison;\n * the 256th check will be made at strstart+258.\n */\n do {\n /*jshint noempty:false*/\n } while (_win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n scan < strend);\n\n // Assert(scan <= s->window+(unsigned)(s->window_size-1), \"wild scan\");\n\n len = MAX_MATCH - (strend - scan);\n scan = strend - MAX_MATCH;\n\n if (len > best_len) {\n s.match_start = cur_match;\n best_len = len;\n if (len >= nice_match) {\n break;\n }\n scan_end1 = _win[scan + best_len - 1];\n scan_end = _win[scan + best_len];\n }\n } while ((cur_match = prev[cur_match & wmask]) > limit && --chain_length !== 0);\n\n if (best_len <= s.lookahead) {\n return best_len;\n }\n return s.lookahead;\n};\n\n\n/* ===========================================================================\n * Fill the window when the lookahead becomes insufficient.\n * Updates strstart and lookahead.\n *\n * IN assertion: lookahead < MIN_LOOKAHEAD\n * OUT assertions: strstart <= window_size-MIN_LOOKAHEAD\n * At least one byte has been read, or avail_in == 0; reads are\n * performed for at least two bytes (required for the zip translate_eol\n * option -- not supported here).\n */\nconst fill_window = (s) => {\n\n const _w_size = s.w_size;\n let n, more, str;\n\n //Assert(s->lookahead < MIN_LOOKAHEAD, \"already enough lookahead\");\n\n do {\n more = s.window_size - s.lookahead - s.strstart;\n\n // JS ints have 32 bit, block below not needed\n /* Deal with !@#$% 64K limit: */\n //if (sizeof(int) <= 2) {\n // if (more == 0 && s->strstart == 0 && s->lookahead == 0) {\n // more = wsize;\n //\n // } else if (more == (unsigned)(-1)) {\n // /* Very unlikely, but possible on 16 bit machine if\n // * strstart == 0 && lookahead == 1 (input done a byte at time)\n // */\n // more--;\n // }\n //}\n\n\n /* If the window is almost full and there is insufficient lookahead,\n * move the upper half to the lower one to make room in the upper half.\n */\n if (s.strstart >= _w_size + (_w_size - MIN_LOOKAHEAD)) {\n\n s.window.set(s.window.subarray(_w_size, _w_size + _w_size - more), 0);\n s.match_start -= _w_size;\n s.strstart -= _w_size;\n /* we now have strstart >= MAX_DIST */\n s.block_start -= _w_size;\n if (s.insert > s.strstart) {\n s.insert = s.strstart;\n }\n slide_hash(s);\n more += _w_size;\n }\n if (s.strm.avail_in === 0) {\n break;\n }\n\n /* If there was no sliding:\n * strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 &&\n * more == window_size - lookahead - strstart\n * => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1)\n * => more >= window_size - 2*WSIZE + 2\n * In the BIG_MEM or MMAP case (not yet supported),\n * window_size == input_size + MIN_LOOKAHEAD &&\n * strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD.\n * Otherwise, window_size == 2*WSIZE so more >= 2.\n * If there was sliding, more >= WSIZE. So in all cases, more >= 2.\n */\n //Assert(more >= 2, \"more < 2\");\n n = read_buf(s.strm, s.window, s.strstart + s.lookahead, more);\n s.lookahead += n;\n\n /* Initialize the hash value now that we have some input: */\n if (s.lookahead + s.insert >= MIN_MATCH) {\n str = s.strstart - s.insert;\n s.ins_h = s.window[str];\n\n /* UPDATE_HASH(s, s->ins_h, s->window[str + 1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[str + 1]);\n//#if MIN_MATCH != 3\n// Call update_hash() MIN_MATCH-3 more times\n//#endif\n while (s.insert) {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[str + MIN_MATCH - 1]);\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = str;\n str++;\n s.insert--;\n if (s.lookahead + s.insert < MIN_MATCH) {\n break;\n }\n }\n }\n /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage,\n * but this is not important since only literal bytes will be emitted.\n */\n\n } while (s.lookahead < MIN_LOOKAHEAD && s.strm.avail_in !== 0);\n\n /* If the WIN_INIT bytes after the end of the current data have never been\n * written, then zero those bytes in order to avoid memory check reports of\n * the use of uninitialized (or uninitialised as Julian writes) bytes by\n * the longest match routines. Update the high water mark for the next\n * time through here. WIN_INIT is set to MAX_MATCH since the longest match\n * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead.\n */\n// if (s.high_water < s.window_size) {\n// const curr = s.strstart + s.lookahead;\n// let init = 0;\n//\n// if (s.high_water < curr) {\n// /* Previous high water mark below current data -- zero WIN_INIT\n// * bytes or up to end of window, whichever is less.\n// */\n// init = s.window_size - curr;\n// if (init > WIN_INIT)\n// init = WIN_INIT;\n// zmemzero(s->window + curr, (unsigned)init);\n// s->high_water = curr + init;\n// }\n// else if (s->high_water < (ulg)curr + WIN_INIT) {\n// /* High water mark at or above current data, but below current data\n// * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up\n// * to end of window, whichever is less.\n// */\n// init = (ulg)curr + WIN_INIT - s->high_water;\n// if (init > s->window_size - s->high_water)\n// init = s->window_size - s->high_water;\n// zmemzero(s->window + s->high_water, (unsigned)init);\n// s->high_water += init;\n// }\n// }\n//\n// Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD,\n// \"not enough room for search\");\n};\n\n/* ===========================================================================\n * Copy without compression as much as possible from the input stream, return\n * the current block state.\n *\n * In case deflateParams() is used to later switch to a non-zero compression\n * level, s->matches (otherwise unused when storing) keeps track of the number\n * of hash table slides to perform. If s->matches is 1, then one hash table\n * slide will be done when switching. If s->matches is 2, the maximum value\n * allowed here, then the hash table will be cleared, since two or more slides\n * is the same as a clear.\n *\n * deflate_stored() is written to minimize the number of times an input byte is\n * copied. It is most efficient with large input and output buffers, which\n * maximizes the opportunites to have a single copy from next_in to next_out.\n */\nconst deflate_stored = (s, flush) => {\n\n /* Smallest worthy block size when not flushing or finishing. By default\n * this is 32K. This can be as small as 507 bytes for memLevel == 1. For\n * large input and output buffers, the stored block size will be larger.\n */\n let min_block = s.pending_buf_size - 5 > s.w_size ? s.w_size : s.pending_buf_size - 5;\n\n /* Copy as many min_block or larger stored blocks directly to next_out as\n * possible. If flushing, copy the remaining available input to next_out as\n * stored blocks, if there is enough space.\n */\n let len, left, have, last = 0;\n let used = s.strm.avail_in;\n do {\n /* Set len to the maximum size block that we can copy directly with the\n * available input data and output space. Set left to how much of that\n * would be copied from what's left in the window.\n */\n len = 65535/* MAX_STORED */; /* maximum deflate stored block length */\n have = (s.bi_valid + 42) >> 3; /* number of header bytes */\n if (s.strm.avail_out < have) { /* need room for header */\n break;\n }\n /* maximum stored block length that will fit in avail_out: */\n have = s.strm.avail_out - have;\n left = s.strstart - s.block_start; /* bytes left in window */\n if (len > left + s.strm.avail_in) {\n len = left + s.strm.avail_in; /* limit len to the input */\n }\n if (len > have) {\n len = have; /* limit len to the output */\n }\n\n /* If the stored block would be less than min_block in length, or if\n * unable to copy all of the available input when flushing, then try\n * copying to the window and the pending buffer instead. Also don't\n * write an empty block when flushing -- deflate() does that.\n */\n if (len < min_block && ((len === 0 && flush !== Z_FINISH) ||\n flush === Z_NO_FLUSH ||\n len !== left + s.strm.avail_in)) {\n break;\n }\n\n /* Make a dummy stored block in pending to get the header bytes,\n * including any pending bits. This also updates the debugging counts.\n */\n last = flush === Z_FINISH && len === left + s.strm.avail_in ? 1 : 0;\n _tr_stored_block(s, 0, 0, last);\n\n /* Replace the lengths in the dummy stored block with len. */\n s.pending_buf[s.pending - 4] = len;\n s.pending_buf[s.pending - 3] = len >> 8;\n s.pending_buf[s.pending - 2] = ~len;\n s.pending_buf[s.pending - 1] = ~len >> 8;\n\n /* Write the stored block header bytes. */\n flush_pending(s.strm);\n\n//#ifdef ZLIB_DEBUG\n// /* Update debugging counts for the data about to be copied. */\n// s->compressed_len += len << 3;\n// s->bits_sent += len << 3;\n//#endif\n\n /* Copy uncompressed bytes from the window to next_out. */\n if (left) {\n if (left > len) {\n left = len;\n }\n //zmemcpy(s->strm->next_out, s->window + s->block_start, left);\n s.strm.output.set(s.window.subarray(s.block_start, s.block_start + left), s.strm.next_out);\n s.strm.next_out += left;\n s.strm.avail_out -= left;\n s.strm.total_out += left;\n s.block_start += left;\n len -= left;\n }\n\n /* Copy uncompressed bytes directly from next_in to next_out, updating\n * the check value.\n */\n if (len) {\n read_buf(s.strm, s.strm.output, s.strm.next_out, len);\n s.strm.next_out += len;\n s.strm.avail_out -= len;\n s.strm.total_out += len;\n }\n } while (last === 0);\n\n /* Update the sliding window with the last s->w_size bytes of the copied\n * data, or append all of the copied data to the existing window if less\n * than s->w_size bytes were copied. Also update the number of bytes to\n * insert in the hash tables, in the event that deflateParams() switches to\n * a non-zero compression level.\n */\n used -= s.strm.avail_in; /* number of input bytes directly copied */\n if (used) {\n /* If any input was used, then no unused input remains in the window,\n * therefore s->block_start == s->strstart.\n */\n if (used >= s.w_size) { /* supplant the previous history */\n s.matches = 2; /* clear hash */\n //zmemcpy(s->window, s->strm->next_in - s->w_size, s->w_size);\n s.window.set(s.strm.input.subarray(s.strm.next_in - s.w_size, s.strm.next_in), 0);\n s.strstart = s.w_size;\n s.insert = s.strstart;\n }\n else {\n if (s.window_size - s.strstart <= used) {\n /* Slide the window down. */\n s.strstart -= s.w_size;\n //zmemcpy(s->window, s->window + s->w_size, s->strstart);\n s.window.set(s.window.subarray(s.w_size, s.w_size + s.strstart), 0);\n if (s.matches < 2) {\n s.matches++; /* add a pending slide_hash() */\n }\n if (s.insert > s.strstart) {\n s.insert = s.strstart;\n }\n }\n //zmemcpy(s->window + s->strstart, s->strm->next_in - used, used);\n s.window.set(s.strm.input.subarray(s.strm.next_in - used, s.strm.next_in), s.strstart);\n s.strstart += used;\n s.insert += used > s.w_size - s.insert ? s.w_size - s.insert : used;\n }\n s.block_start = s.strstart;\n }\n if (s.high_water < s.strstart) {\n s.high_water = s.strstart;\n }\n\n /* If the last block was written to next_out, then done. */\n if (last) {\n return BS_FINISH_DONE;\n }\n\n /* If flushing and all input has been consumed, then done. */\n if (flush !== Z_NO_FLUSH && flush !== Z_FINISH &&\n s.strm.avail_in === 0 && s.strstart === s.block_start) {\n return BS_BLOCK_DONE;\n }\n\n /* Fill the window with any remaining input. */\n have = s.window_size - s.strstart;\n if (s.strm.avail_in > have && s.block_start >= s.w_size) {\n /* Slide the window down. */\n s.block_start -= s.w_size;\n s.strstart -= s.w_size;\n //zmemcpy(s->window, s->window + s->w_size, s->strstart);\n s.window.set(s.window.subarray(s.w_size, s.w_size + s.strstart), 0);\n if (s.matches < 2) {\n s.matches++; /* add a pending slide_hash() */\n }\n have += s.w_size; /* more space now */\n if (s.insert > s.strstart) {\n s.insert = s.strstart;\n }\n }\n if (have > s.strm.avail_in) {\n have = s.strm.avail_in;\n }\n if (have) {\n read_buf(s.strm, s.window, s.strstart, have);\n s.strstart += have;\n s.insert += have > s.w_size - s.insert ? s.w_size - s.insert : have;\n }\n if (s.high_water < s.strstart) {\n s.high_water = s.strstart;\n }\n\n /* There was not enough avail_out to write a complete worthy or flushed\n * stored block to next_out. Write a stored block to pending instead, if we\n * have enough input for a worthy block, or if flushing and there is enough\n * room for the remaining input as a stored block in the pending buffer.\n */\n have = (s.bi_valid + 42) >> 3; /* number of header bytes */\n /* maximum stored block length that will fit in pending: */\n have = s.pending_buf_size - have > 65535/* MAX_STORED */ ? 65535/* MAX_STORED */ : s.pending_buf_size - have;\n min_block = have > s.w_size ? s.w_size : have;\n left = s.strstart - s.block_start;\n if (left >= min_block ||\n ((left || flush === Z_FINISH) && flush !== Z_NO_FLUSH &&\n s.strm.avail_in === 0 && left <= have)) {\n len = left > have ? have : left;\n last = flush === Z_FINISH && s.strm.avail_in === 0 &&\n len === left ? 1 : 0;\n _tr_stored_block(s, s.block_start, len, last);\n s.block_start += len;\n flush_pending(s.strm);\n }\n\n /* We've done all we can with the available input and output. */\n return last ? BS_FINISH_STARTED : BS_NEED_MORE;\n};\n\n\n/* ===========================================================================\n * Compress as much as possible from the input stream, return the current\n * block state.\n * This function does not perform lazy evaluation of matches and inserts\n * new strings in the dictionary only for unmatched strings or for short\n * matches. It is used only for the fast compression options.\n */\nconst deflate_fast = (s, flush) => {\n\n let hash_head; /* head of the hash chain */\n let bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) {\n break; /* flush the current block */\n }\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n * At this point we have always match_length < MIN_MATCH\n */\n if (hash_head !== 0/*NIL*/ && ((s.strstart - hash_head) <= (s.w_size - MIN_LOOKAHEAD))) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n }\n if (s.match_length >= MIN_MATCH) {\n // check_match(s, s.strstart, s.match_start, s.match_length); // for debug only\n\n /*** _tr_tally_dist(s, s.strstart - s.match_start,\n s.match_length - MIN_MATCH, bflush); ***/\n bflush = _tr_tally(s, s.strstart - s.match_start, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n\n /* Insert new strings in the hash table only if the match length\n * is not too large. This saves time but degrades compression.\n */\n if (s.match_length <= s.max_lazy_match/*max_insert_length*/ && s.lookahead >= MIN_MATCH) {\n s.match_length--; /* string at strstart already in table */\n do {\n s.strstart++;\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n /* strstart never exceeds WSIZE-MAX_MATCH, so there are\n * always MIN_MATCH bytes ahead.\n */\n } while (--s.match_length !== 0);\n s.strstart++;\n } else\n {\n s.strstart += s.match_length;\n s.match_length = 0;\n s.ins_h = s.window[s.strstart];\n /* UPDATE_HASH(s, s.ins_h, s.window[s.strstart+1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + 1]);\n\n//#if MIN_MATCH != 3\n// Call UPDATE_HASH() MIN_MATCH-3 more times\n//#endif\n /* If lookahead < MIN_MATCH, ins_h is garbage, but it does not\n * matter since it will be recomputed at next deflate call.\n */\n }\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s.window[s.strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = ((s.strstart < (MIN_MATCH - 1)) ? s.strstart : MIN_MATCH - 1);\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.sym_next) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n};\n\n/* ===========================================================================\n * Same as above, but achieves better compression. We use a lazy\n * evaluation for matches: a match is finally adopted only if there is\n * no better match at the next window position.\n */\nconst deflate_slow = (s, flush) => {\n\n let hash_head; /* head of hash chain */\n let bflush; /* set if current block must be flushed */\n\n let max_insert;\n\n /* Process the input block. */\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n */\n s.prev_length = s.match_length;\n s.prev_match = s.match_start;\n s.match_length = MIN_MATCH - 1;\n\n if (hash_head !== 0/*NIL*/ && s.prev_length < s.max_lazy_match &&\n s.strstart - hash_head <= (s.w_size - MIN_LOOKAHEAD)/*MAX_DIST(s)*/) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n\n if (s.match_length <= 5 &&\n (s.strategy === Z_FILTERED || (s.match_length === MIN_MATCH && s.strstart - s.match_start > 4096/*TOO_FAR*/))) {\n\n /* If prev_match is also MIN_MATCH, match_start is garbage\n * but we will ignore the current match anyway.\n */\n s.match_length = MIN_MATCH - 1;\n }\n }\n /* If there was a match at the previous step and the current\n * match is not better, output the previous match:\n */\n if (s.prev_length >= MIN_MATCH && s.match_length <= s.prev_length) {\n max_insert = s.strstart + s.lookahead - MIN_MATCH;\n /* Do not insert strings in hash table beyond this. */\n\n //check_match(s, s.strstart-1, s.prev_match, s.prev_length);\n\n /***_tr_tally_dist(s, s.strstart - 1 - s.prev_match,\n s.prev_length - MIN_MATCH, bflush);***/\n bflush = _tr_tally(s, s.strstart - 1 - s.prev_match, s.prev_length - MIN_MATCH);\n /* Insert in hash table all strings up to the end of the match.\n * strstart-1 and strstart are already inserted. If there is not\n * enough lookahead, the last two strings are not inserted in\n * the hash table.\n */\n s.lookahead -= s.prev_length - 1;\n s.prev_length -= 2;\n do {\n if (++s.strstart <= max_insert) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n } while (--s.prev_length !== 0);\n s.match_available = 0;\n s.match_length = MIN_MATCH - 1;\n s.strstart++;\n\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n } else if (s.match_available) {\n /* If there was no match at the previous position, output a\n * single literal. If there was a match but the current match\n * is longer, truncate the previous match to a single literal.\n */\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart - 1]);\n\n if (bflush) {\n /*** FLUSH_BLOCK_ONLY(s, 0) ***/\n flush_block_only(s, false);\n /***/\n }\n s.strstart++;\n s.lookahead--;\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n } else {\n /* There is no previous match to compare with, wait for\n * the next step to decide.\n */\n s.match_available = 1;\n s.strstart++;\n s.lookahead--;\n }\n }\n //Assert (flush != Z_NO_FLUSH, \"no flush?\");\n if (s.match_available) {\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart - 1]);\n\n s.match_available = 0;\n }\n s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1;\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.sym_next) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n return BS_BLOCK_DONE;\n};\n\n\n/* ===========================================================================\n * For Z_RLE, simply look for runs of bytes, generate matches only of distance\n * one. Do not maintain a hash table. (It will be regenerated if this run of\n * deflate switches away from Z_RLE.)\n */\nconst deflate_rle = (s, flush) => {\n\n let bflush; /* set if current block must be flushed */\n let prev; /* byte at distance one to match */\n let scan, strend; /* scan goes up to strend for length of run */\n\n const _win = s.window;\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the longest run, plus one for the unrolled loop.\n */\n if (s.lookahead <= MAX_MATCH) {\n fill_window(s);\n if (s.lookahead <= MAX_MATCH && flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* See how many times the previous byte repeats */\n s.match_length = 0;\n if (s.lookahead >= MIN_MATCH && s.strstart > 0) {\n scan = s.strstart - 1;\n prev = _win[scan];\n if (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan]) {\n strend = s.strstart + MAX_MATCH;\n do {\n /*jshint noempty:false*/\n } while (prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n scan < strend);\n s.match_length = MAX_MATCH - (strend - scan);\n if (s.match_length > s.lookahead) {\n s.match_length = s.lookahead;\n }\n }\n //Assert(scan <= s->window+(uInt)(s->window_size-1), \"wild scan\");\n }\n\n /* Emit match if have run of MIN_MATCH or longer, else emit literal */\n if (s.match_length >= MIN_MATCH) {\n //check_match(s, s.strstart, s.strstart - 1, s.match_length);\n\n /*** _tr_tally_dist(s, 1, s.match_length - MIN_MATCH, bflush); ***/\n bflush = _tr_tally(s, 1, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n s.strstart += s.match_length;\n s.match_length = 0;\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.sym_next) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n};\n\n/* ===========================================================================\n * For Z_HUFFMAN_ONLY, do not look for matches. Do not maintain a hash table.\n * (It will be regenerated if this run of deflate switches away from Huffman.)\n */\nconst deflate_huff = (s, flush) => {\n\n let bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we have a literal to write. */\n if (s.lookahead === 0) {\n fill_window(s);\n if (s.lookahead === 0) {\n if (flush === Z_NO_FLUSH) {\n return BS_NEED_MORE;\n }\n break; /* flush the current block */\n }\n }\n\n /* Output a literal byte */\n s.match_length = 0;\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart]);\n s.lookahead--;\n s.strstart++;\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.sym_next) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n};\n\n/* Values for max_lazy_match, good_match and max_chain_length, depending on\n * the desired pack level (0..9). The values given below have been tuned to\n * exclude worst case performance for pathological files. Better values may be\n * found for specific files.\n */\nfunction Config(good_length, max_lazy, nice_length, max_chain, func) {\n\n this.good_length = good_length;\n this.max_lazy = max_lazy;\n this.nice_length = nice_length;\n this.max_chain = max_chain;\n this.func = func;\n}\n\nconst configuration_table = [\n /* good lazy nice chain */\n new Config(0, 0, 0, 0, deflate_stored), /* 0 store only */\n new Config(4, 4, 8, 4, deflate_fast), /* 1 max speed, no lazy matches */\n new Config(4, 5, 16, 8, deflate_fast), /* 2 */\n new Config(4, 6, 32, 32, deflate_fast), /* 3 */\n\n new Config(4, 4, 16, 16, deflate_slow), /* 4 lazy matches */\n new Config(8, 16, 32, 32, deflate_slow), /* 5 */\n new Config(8, 16, 128, 128, deflate_slow), /* 6 */\n new Config(8, 32, 128, 256, deflate_slow), /* 7 */\n new Config(32, 128, 258, 1024, deflate_slow), /* 8 */\n new Config(32, 258, 258, 4096, deflate_slow) /* 9 max compression */\n];\n\n\n/* ===========================================================================\n * Initialize the \"longest match\" routines for a new zlib stream\n */\nconst lm_init = (s) => {\n\n s.window_size = 2 * s.w_size;\n\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n\n /* Set the default configuration parameters:\n */\n s.max_lazy_match = configuration_table[s.level].max_lazy;\n s.good_match = configuration_table[s.level].good_length;\n s.nice_match = configuration_table[s.level].nice_length;\n s.max_chain_length = configuration_table[s.level].max_chain;\n\n s.strstart = 0;\n s.block_start = 0;\n s.lookahead = 0;\n s.insert = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n s.ins_h = 0;\n};\n\n\nfunction DeflateState() {\n this.strm = null; /* pointer back to this zlib stream */\n this.status = 0; /* as the name implies */\n this.pending_buf = null; /* output still pending */\n this.pending_buf_size = 0; /* size of pending_buf */\n this.pending_out = 0; /* next pending byte to output to the stream */\n this.pending = 0; /* nb of bytes in the pending buffer */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.gzhead = null; /* gzip header information to write */\n this.gzindex = 0; /* where in extra, name, or comment */\n this.method = Z_DEFLATED; /* can only be DEFLATED */\n this.last_flush = -1; /* value of flush param for previous deflate call */\n\n this.w_size = 0; /* LZ77 window size (32K by default) */\n this.w_bits = 0; /* log2(w_size) (8..16) */\n this.w_mask = 0; /* w_size - 1 */\n\n this.window = null;\n /* Sliding window. Input bytes are read into the second half of the window,\n * and move to the first half later to keep a dictionary of at least wSize\n * bytes. With this organization, matches are limited to a distance of\n * wSize-MAX_MATCH bytes, but this ensures that IO is always\n * performed with a length multiple of the block size.\n */\n\n this.window_size = 0;\n /* Actual size of window: 2*wSize, except when the user input buffer\n * is directly used as sliding window.\n */\n\n this.prev = null;\n /* Link to older string with same hash index. To limit the size of this\n * array to 64K, this link is maintained only for the last 32K strings.\n * An index in this array is thus a window index modulo 32K.\n */\n\n this.head = null; /* Heads of the hash chains or NIL. */\n\n this.ins_h = 0; /* hash index of string to be inserted */\n this.hash_size = 0; /* number of elements in hash table */\n this.hash_bits = 0; /* log2(hash_size) */\n this.hash_mask = 0; /* hash_size-1 */\n\n this.hash_shift = 0;\n /* Number of bits by which ins_h must be shifted at each input\n * step. It must be such that after MIN_MATCH steps, the oldest\n * byte no longer takes part in the hash key, that is:\n * hash_shift * MIN_MATCH >= hash_bits\n */\n\n this.block_start = 0;\n /* Window position at the beginning of the current output block. Gets\n * negative when the window is moved backwards.\n */\n\n this.match_length = 0; /* length of best match */\n this.prev_match = 0; /* previous match */\n this.match_available = 0; /* set if previous match exists */\n this.strstart = 0; /* start of string to insert */\n this.match_start = 0; /* start of matching string */\n this.lookahead = 0; /* number of valid bytes ahead in window */\n\n this.prev_length = 0;\n /* Length of the best match at previous step. Matches not greater than this\n * are discarded. This is used in the lazy match evaluation.\n */\n\n this.max_chain_length = 0;\n /* To speed up deflation, hash chains are never searched beyond this\n * length. A higher limit improves compression ratio but degrades the\n * speed.\n */\n\n this.max_lazy_match = 0;\n /* Attempt to find a better match only when the current match is strictly\n * smaller than this value. This mechanism is used only for compression\n * levels >= 4.\n */\n // That's alias to max_lazy_match, don't use directly\n //this.max_insert_length = 0;\n /* Insert new strings in the hash table only if the match length is not\n * greater than this length. This saves time but degrades compression.\n * max_insert_length is used only for compression levels <= 3.\n */\n\n this.level = 0; /* compression level (1..9) */\n this.strategy = 0; /* favor or force Huffman coding*/\n\n this.good_match = 0;\n /* Use a faster search when the previous match is longer than this */\n\n this.nice_match = 0; /* Stop searching when current match exceeds this */\n\n /* used by trees.c: */\n\n /* Didn't use ct_data typedef below to suppress compiler warning */\n\n // struct ct_data_s dyn_ltree[HEAP_SIZE]; /* literal and length tree */\n // struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */\n // struct ct_data_s bl_tree[2*BL_CODES+1]; /* Huffman tree for bit lengths */\n\n // Use flat array of DOUBLE size, with interleaved fata,\n // because JS does not support effective\n this.dyn_ltree = new Uint16Array(HEAP_SIZE * 2);\n this.dyn_dtree = new Uint16Array((2 * D_CODES + 1) * 2);\n this.bl_tree = new Uint16Array((2 * BL_CODES + 1) * 2);\n zero(this.dyn_ltree);\n zero(this.dyn_dtree);\n zero(this.bl_tree);\n\n this.l_desc = null; /* desc. for literal tree */\n this.d_desc = null; /* desc. for distance tree */\n this.bl_desc = null; /* desc. for bit length tree */\n\n //ush bl_count[MAX_BITS+1];\n this.bl_count = new Uint16Array(MAX_BITS + 1);\n /* number of codes at each bit length for an optimal tree */\n\n //int heap[2*L_CODES+1]; /* heap used to build the Huffman trees */\n this.heap = new Uint16Array(2 * L_CODES + 1); /* heap used to build the Huffman trees */\n zero(this.heap);\n\n this.heap_len = 0; /* number of elements in the heap */\n this.heap_max = 0; /* element of largest frequency */\n /* The sons of heap[n] are heap[2*n] and heap[2*n+1]. heap[0] is not used.\n * The same heap array is used to build all trees.\n */\n\n this.depth = new Uint16Array(2 * L_CODES + 1); //uch depth[2*L_CODES+1];\n zero(this.depth);\n /* Depth of each subtree used as tie breaker for trees of equal frequency\n */\n\n this.sym_buf = 0; /* buffer for distances and literals/lengths */\n\n this.lit_bufsize = 0;\n /* Size of match buffer for literals/lengths. There are 4 reasons for\n * limiting lit_bufsize to 64K:\n * - frequencies can be kept in 16 bit counters\n * - if compression is not successful for the first block, all input\n * data is still in the window so we can still emit a stored block even\n * when input comes from standard input. (This can also be done for\n * all blocks if lit_bufsize is not greater than 32K.)\n * - if compression is not successful for a file smaller than 64K, we can\n * even emit a stored file instead of a stored block (saving 5 bytes).\n * This is applicable only for zip (not gzip or zlib).\n * - creating new Huffman trees less frequently may not provide fast\n * adaptation to changes in the input data statistics. (Take for\n * example a binary file with poorly compressible code followed by\n * a highly compressible string table.) Smaller buffer sizes give\n * fast adaptation but have of course the overhead of transmitting\n * trees more frequently.\n * - I can't count above 4\n */\n\n this.sym_next = 0; /* running index in sym_buf */\n this.sym_end = 0; /* symbol table full when sym_next reaches this */\n\n this.opt_len = 0; /* bit length of current block with optimal trees */\n this.static_len = 0; /* bit length of current block with static trees */\n this.matches = 0; /* number of string matches in current block */\n this.insert = 0; /* bytes at end of window left to insert */\n\n\n this.bi_buf = 0;\n /* Output buffer. bits are inserted starting at the bottom (least\n * significant bits).\n */\n this.bi_valid = 0;\n /* Number of valid bits in bi_buf. All bits above the last valid bit\n * are always zero.\n */\n\n // Used for window memory init. We safely ignore it for JS. That makes\n // sense only for pointers and memory check tools.\n //this.high_water = 0;\n /* High water mark offset in window for initialized bytes -- bytes above\n * this are set to zero in order to avoid memory check warnings when\n * longest match routines access bytes past the input. This is then\n * updated to the new high water mark.\n */\n}\n\n\n/* =========================================================================\n * Check for a valid deflate stream state. Return 0 if ok, 1 if not.\n */\nconst deflateStateCheck = (strm) => {\n\n if (!strm) {\n return 1;\n }\n const s = strm.state;\n if (!s || s.strm !== strm || (s.status !== INIT_STATE &&\n//#ifdef GZIP\n s.status !== GZIP_STATE &&\n//#endif\n s.status !== EXTRA_STATE &&\n s.status !== NAME_STATE &&\n s.status !== COMMENT_STATE &&\n s.status !== HCRC_STATE &&\n s.status !== BUSY_STATE &&\n s.status !== FINISH_STATE)) {\n return 1;\n }\n return 0;\n};\n\n\nconst deflateResetKeep = (strm) => {\n\n if (deflateStateCheck(strm)) {\n return err(strm, Z_STREAM_ERROR);\n }\n\n strm.total_in = strm.total_out = 0;\n strm.data_type = Z_UNKNOWN;\n\n const s = strm.state;\n s.pending = 0;\n s.pending_out = 0;\n\n if (s.wrap < 0) {\n s.wrap = -s.wrap;\n /* was made negative by deflate(..., Z_FINISH); */\n }\n s.status =\n//#ifdef GZIP\n s.wrap === 2 ? GZIP_STATE :\n//#endif\n s.wrap ? INIT_STATE : BUSY_STATE;\n strm.adler = (s.wrap === 2) ?\n 0 // crc32(0, Z_NULL, 0)\n :\n 1; // adler32(0, Z_NULL, 0)\n s.last_flush = -2;\n _tr_init(s);\n return Z_OK;\n};\n\n\nconst deflateReset = (strm) => {\n\n const ret = deflateResetKeep(strm);\n if (ret === Z_OK) {\n lm_init(strm.state);\n }\n return ret;\n};\n\n\nconst deflateSetHeader = (strm, head) => {\n\n if (deflateStateCheck(strm) || strm.state.wrap !== 2) {\n return Z_STREAM_ERROR;\n }\n strm.state.gzhead = head;\n return Z_OK;\n};\n\n\nconst deflateInit2 = (strm, level, method, windowBits, memLevel, strategy) => {\n\n if (!strm) { // === Z_NULL\n return Z_STREAM_ERROR;\n }\n let wrap = 1;\n\n if (level === Z_DEFAULT_COMPRESSION) {\n level = 6;\n }\n\n if (windowBits < 0) { /* suppress zlib wrapper */\n wrap = 0;\n windowBits = -windowBits;\n }\n\n else if (windowBits > 15) {\n wrap = 2; /* write gzip wrapper instead */\n windowBits -= 16;\n }\n\n\n if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method !== Z_DEFLATED ||\n windowBits < 8 || windowBits > 15 || level < 0 || level > 9 ||\n strategy < 0 || strategy > Z_FIXED || (windowBits === 8 && wrap !== 1)) {\n return err(strm, Z_STREAM_ERROR);\n }\n\n\n if (windowBits === 8) {\n windowBits = 9;\n }\n /* until 256-byte window bug fixed */\n\n const s = new DeflateState();\n\n strm.state = s;\n s.strm = strm;\n s.status = INIT_STATE; /* to pass state test in deflateReset() */\n\n s.wrap = wrap;\n s.gzhead = null;\n s.w_bits = windowBits;\n s.w_size = 1 << s.w_bits;\n s.w_mask = s.w_size - 1;\n\n s.hash_bits = memLevel + 7;\n s.hash_size = 1 << s.hash_bits;\n s.hash_mask = s.hash_size - 1;\n s.hash_shift = ~~((s.hash_bits + MIN_MATCH - 1) / MIN_MATCH);\n\n s.window = new Uint8Array(s.w_size * 2);\n s.head = new Uint16Array(s.hash_size);\n s.prev = new Uint16Array(s.w_size);\n\n // Don't need mem init magic for JS.\n //s.high_water = 0; /* nothing written to s->window yet */\n\n s.lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */\n\n /* We overlay pending_buf and sym_buf. This works since the average size\n * for length/distance pairs over any compressed block is assured to be 31\n * bits or less.\n *\n * Analysis: The longest fixed codes are a length code of 8 bits plus 5\n * extra bits, for lengths 131 to 257. The longest fixed distance codes are\n * 5 bits plus 13 extra bits, for distances 16385 to 32768. The longest\n * possible fixed-codes length/distance pair is then 31 bits total.\n *\n * sym_buf starts one-fourth of the way into pending_buf. So there are\n * three bytes in sym_buf for every four bytes in pending_buf. Each symbol\n * in sym_buf is three bytes -- two for the distance and one for the\n * literal/length. As each symbol is consumed, the pointer to the next\n * sym_buf value to read moves forward three bytes. From that symbol, up to\n * 31 bits are written to pending_buf. The closest the written pending_buf\n * bits gets to the next sym_buf symbol to read is just before the last\n * code is written. At that time, 31*(n-2) bits have been written, just\n * after 24*(n-2) bits have been consumed from sym_buf. sym_buf starts at\n * 8*n bits into pending_buf. (Note that the symbol buffer fills when n-1\n * symbols are written.) The closest the writing gets to what is unread is\n * then n+14 bits. Here n is lit_bufsize, which is 16384 by default, and\n * can range from 128 to 32768.\n *\n * Therefore, at a minimum, there are 142 bits of space between what is\n * written and what is read in the overlain buffers, so the symbols cannot\n * be overwritten by the compressed data. That space is actually 139 bits,\n * due to the three-bit fixed-code block header.\n *\n * That covers the case where either Z_FIXED is specified, forcing fixed\n * codes, or when the use of fixed codes is chosen, because that choice\n * results in a smaller compressed block than dynamic codes. That latter\n * condition then assures that the above analysis also covers all dynamic\n * blocks. A dynamic-code block will only be chosen to be emitted if it has\n * fewer bits than a fixed-code block would for the same set of symbols.\n * Therefore its average symbol length is assured to be less than 31. So\n * the compressed data for a dynamic block also cannot overwrite the\n * symbols from which it is being constructed.\n */\n\n s.pending_buf_size = s.lit_bufsize * 4;\n s.pending_buf = new Uint8Array(s.pending_buf_size);\n\n // It is offset from `s.pending_buf` (size is `s.lit_bufsize * 2`)\n //s->sym_buf = s->pending_buf + s->lit_bufsize;\n s.sym_buf = s.lit_bufsize;\n\n //s->sym_end = (s->lit_bufsize - 1) * 3;\n s.sym_end = (s.lit_bufsize - 1) * 3;\n /* We avoid equality with lit_bufsize*3 because of wraparound at 64K\n * on 16 bit machines and because stored blocks are restricted to\n * 64K-1 bytes.\n */\n\n s.level = level;\n s.strategy = strategy;\n s.method = method;\n\n return deflateReset(strm);\n};\n\nconst deflateInit = (strm, level) => {\n\n return deflateInit2(strm, level, Z_DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY);\n};\n\n\n/* ========================================================================= */\nconst deflate = (strm, flush) => {\n\n if (deflateStateCheck(strm) || flush > Z_BLOCK || flush < 0) {\n return strm ? err(strm, Z_STREAM_ERROR) : Z_STREAM_ERROR;\n }\n\n const s = strm.state;\n\n if (!strm.output ||\n (strm.avail_in !== 0 && !strm.input) ||\n (s.status === FINISH_STATE && flush !== Z_FINISH)) {\n return err(strm, (strm.avail_out === 0) ? Z_BUF_ERROR : Z_STREAM_ERROR);\n }\n\n const old_flush = s.last_flush;\n s.last_flush = flush;\n\n /* Flush as much pending output as possible */\n if (s.pending !== 0) {\n flush_pending(strm);\n if (strm.avail_out === 0) {\n /* Since avail_out is 0, deflate will be called again with\n * more output space, but possibly with both pending and\n * avail_in equal to zero. There won't be anything to do,\n * but this is not an error situation so make sure we\n * return OK instead of BUF_ERROR at next call of deflate:\n */\n s.last_flush = -1;\n return Z_OK;\n }\n\n /* Make sure there is something to do and avoid duplicate consecutive\n * flushes. For repeated and useless calls with Z_FINISH, we keep\n * returning Z_STREAM_END instead of Z_BUF_ERROR.\n */\n } else if (strm.avail_in === 0 && rank(flush) <= rank(old_flush) &&\n flush !== Z_FINISH) {\n return err(strm, Z_BUF_ERROR);\n }\n\n /* User must not provide more input after the first FINISH: */\n if (s.status === FINISH_STATE && strm.avail_in !== 0) {\n return err(strm, Z_BUF_ERROR);\n }\n\n /* Write the header */\n if (s.status === INIT_STATE && s.wrap === 0) {\n s.status = BUSY_STATE;\n }\n if (s.status === INIT_STATE) {\n /* zlib header */\n let header = (Z_DEFLATED + ((s.w_bits - 8) << 4)) << 8;\n let level_flags = -1;\n\n if (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2) {\n level_flags = 0;\n } else if (s.level < 6) {\n level_flags = 1;\n } else if (s.level === 6) {\n level_flags = 2;\n } else {\n level_flags = 3;\n }\n header |= (level_flags << 6);\n if (s.strstart !== 0) { header |= PRESET_DICT; }\n header += 31 - (header % 31);\n\n putShortMSB(s, header);\n\n /* Save the adler32 of the preset dictionary: */\n if (s.strstart !== 0) {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n strm.adler = 1; // adler32(0L, Z_NULL, 0);\n s.status = BUSY_STATE;\n\n /* Compression must start with an empty pending buffer */\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK;\n }\n }\n//#ifdef GZIP\n if (s.status === GZIP_STATE) {\n /* gzip header */\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n put_byte(s, 31);\n put_byte(s, 139);\n put_byte(s, 8);\n if (!s.gzhead) { // s->gzhead == Z_NULL\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, OS_CODE);\n s.status = BUSY_STATE;\n\n /* Compression must start with an empty pending buffer */\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK;\n }\n }\n else {\n put_byte(s, (s.gzhead.text ? 1 : 0) +\n (s.gzhead.hcrc ? 2 : 0) +\n (!s.gzhead.extra ? 0 : 4) +\n (!s.gzhead.name ? 0 : 8) +\n (!s.gzhead.comment ? 0 : 16)\n );\n put_byte(s, s.gzhead.time & 0xff);\n put_byte(s, (s.gzhead.time >> 8) & 0xff);\n put_byte(s, (s.gzhead.time >> 16) & 0xff);\n put_byte(s, (s.gzhead.time >> 24) & 0xff);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, s.gzhead.os & 0xff);\n if (s.gzhead.extra && s.gzhead.extra.length) {\n put_byte(s, s.gzhead.extra.length & 0xff);\n put_byte(s, (s.gzhead.extra.length >> 8) & 0xff);\n }\n if (s.gzhead.hcrc) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending, 0);\n }\n s.gzindex = 0;\n s.status = EXTRA_STATE;\n }\n }\n if (s.status === EXTRA_STATE) {\n if (s.gzhead.extra/* != Z_NULL*/) {\n let beg = s.pending; /* start of bytes to update crc */\n let left = (s.gzhead.extra.length & 0xffff) - s.gzindex;\n while (s.pending + left > s.pending_buf_size) {\n let copy = s.pending_buf_size - s.pending;\n // zmemcpy(s.pending_buf + s.pending,\n // s.gzhead.extra + s.gzindex, copy);\n s.pending_buf.set(s.gzhead.extra.subarray(s.gzindex, s.gzindex + copy), s.pending);\n s.pending = s.pending_buf_size;\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n s.gzindex += copy;\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK;\n }\n beg = 0;\n left -= copy;\n }\n // JS specific: s.gzhead.extra may be TypedArray or Array for backward compatibility\n // TypedArray.slice and TypedArray.from don't exist in IE10-IE11\n let gzhead_extra = new Uint8Array(s.gzhead.extra);\n // zmemcpy(s->pending_buf + s->pending,\n // s->gzhead->extra + s->gzindex, left);\n s.pending_buf.set(gzhead_extra.subarray(s.gzindex, s.gzindex + left), s.pending);\n s.pending += left;\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n s.gzindex = 0;\n }\n s.status = NAME_STATE;\n }\n if (s.status === NAME_STATE) {\n if (s.gzhead.name/* != Z_NULL*/) {\n let beg = s.pending; /* start of bytes to update crc */\n let val;\n do {\n if (s.pending === s.pending_buf_size) {\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK;\n }\n beg = 0;\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.name.length) {\n val = s.gzhead.name.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n s.gzindex = 0;\n }\n s.status = COMMENT_STATE;\n }\n if (s.status === COMMENT_STATE) {\n if (s.gzhead.comment/* != Z_NULL*/) {\n let beg = s.pending; /* start of bytes to update crc */\n let val;\n do {\n if (s.pending === s.pending_buf_size) {\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK;\n }\n beg = 0;\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.comment.length) {\n val = s.gzhead.comment.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n }\n s.status = HCRC_STATE;\n }\n if (s.status === HCRC_STATE) {\n if (s.gzhead.hcrc) {\n if (s.pending + 2 > s.pending_buf_size) {\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK;\n }\n }\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n }\n s.status = BUSY_STATE;\n\n /* Compression must start with an empty pending buffer */\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK;\n }\n }\n//#endif\n\n /* Start a new block or continue the current one.\n */\n if (strm.avail_in !== 0 || s.lookahead !== 0 ||\n (flush !== Z_NO_FLUSH && s.status !== FINISH_STATE)) {\n let bstate = s.level === 0 ? deflate_stored(s, flush) :\n s.strategy === Z_HUFFMAN_ONLY ? deflate_huff(s, flush) :\n s.strategy === Z_RLE ? deflate_rle(s, flush) :\n configuration_table[s.level].func(s, flush);\n\n if (bstate === BS_FINISH_STARTED || bstate === BS_FINISH_DONE) {\n s.status = FINISH_STATE;\n }\n if (bstate === BS_NEED_MORE || bstate === BS_FINISH_STARTED) {\n if (strm.avail_out === 0) {\n s.last_flush = -1;\n /* avoid BUF_ERROR next call, see above */\n }\n return Z_OK;\n /* If flush != Z_NO_FLUSH && avail_out == 0, the next call\n * of deflate should use the same flush parameter to make sure\n * that the flush is complete. So we don't have to output an\n * empty block here, this will be done at next call. This also\n * ensures that for a very small output buffer, we emit at most\n * one empty block.\n */\n }\n if (bstate === BS_BLOCK_DONE) {\n if (flush === Z_PARTIAL_FLUSH) {\n _tr_align(s);\n }\n else if (flush !== Z_BLOCK) { /* FULL_FLUSH or SYNC_FLUSH */\n\n _tr_stored_block(s, 0, 0, false);\n /* For a full flush, this empty block will be recognized\n * as a special marker by inflate_sync().\n */\n if (flush === Z_FULL_FLUSH) {\n /*** CLEAR_HASH(s); ***/ /* forget history */\n zero(s.head); // Fill with NIL (= 0);\n\n if (s.lookahead === 0) {\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n }\n }\n flush_pending(strm);\n if (strm.avail_out === 0) {\n s.last_flush = -1; /* avoid BUF_ERROR at next call, see above */\n return Z_OK;\n }\n }\n }\n\n if (flush !== Z_FINISH) { return Z_OK; }\n if (s.wrap <= 0) { return Z_STREAM_END; }\n\n /* Write the trailer */\n if (s.wrap === 2) {\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n put_byte(s, (strm.adler >> 16) & 0xff);\n put_byte(s, (strm.adler >> 24) & 0xff);\n put_byte(s, strm.total_in & 0xff);\n put_byte(s, (strm.total_in >> 8) & 0xff);\n put_byte(s, (strm.total_in >> 16) & 0xff);\n put_byte(s, (strm.total_in >> 24) & 0xff);\n }\n else\n {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n\n flush_pending(strm);\n /* If avail_out is zero, the application will call deflate again\n * to flush the rest.\n */\n if (s.wrap > 0) { s.wrap = -s.wrap; }\n /* write the trailer only once! */\n return s.pending !== 0 ? Z_OK : Z_STREAM_END;\n};\n\n\nconst deflateEnd = (strm) => {\n\n if (deflateStateCheck(strm)) {\n return Z_STREAM_ERROR;\n }\n\n const status = strm.state.status;\n\n strm.state = null;\n\n return status === BUSY_STATE ? err(strm, Z_DATA_ERROR) : Z_OK;\n};\n\n\n/* =========================================================================\n * Initializes the compression dictionary from the given byte\n * sequence without producing any compressed output.\n */\nconst deflateSetDictionary = (strm, dictionary) => {\n\n let dictLength = dictionary.length;\n\n if (deflateStateCheck(strm)) {\n return Z_STREAM_ERROR;\n }\n\n const s = strm.state;\n const wrap = s.wrap;\n\n if (wrap === 2 || (wrap === 1 && s.status !== INIT_STATE) || s.lookahead) {\n return Z_STREAM_ERROR;\n }\n\n /* when using zlib wrappers, compute Adler-32 for provided dictionary */\n if (wrap === 1) {\n /* adler32(strm->adler, dictionary, dictLength); */\n strm.adler = adler32(strm.adler, dictionary, dictLength, 0);\n }\n\n s.wrap = 0; /* avoid computing Adler-32 in read_buf */\n\n /* if dictionary would fill window, just replace the history */\n if (dictLength >= s.w_size) {\n if (wrap === 0) { /* already empty otherwise */\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n /* use the tail */\n // dictionary = dictionary.slice(dictLength - s.w_size);\n let tmpDict = new Uint8Array(s.w_size);\n tmpDict.set(dictionary.subarray(dictLength - s.w_size, dictLength), 0);\n dictionary = tmpDict;\n dictLength = s.w_size;\n }\n /* insert dictionary into window and hash */\n const avail = strm.avail_in;\n const next = strm.next_in;\n const input = strm.input;\n strm.avail_in = dictLength;\n strm.next_in = 0;\n strm.input = dictionary;\n fill_window(s);\n while (s.lookahead >= MIN_MATCH) {\n let str = s.strstart;\n let n = s.lookahead - (MIN_MATCH - 1);\n do {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[str + MIN_MATCH - 1]);\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n\n s.head[s.ins_h] = str;\n str++;\n } while (--n);\n s.strstart = str;\n s.lookahead = MIN_MATCH - 1;\n fill_window(s);\n }\n s.strstart += s.lookahead;\n s.block_start = s.strstart;\n s.insert = s.lookahead;\n s.lookahead = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n strm.next_in = next;\n strm.input = input;\n strm.avail_in = avail;\n s.wrap = wrap;\n return Z_OK;\n};\n\n\nmodule.exports.deflateInit = deflateInit;\nmodule.exports.deflateInit2 = deflateInit2;\nmodule.exports.deflateReset = deflateReset;\nmodule.exports.deflateResetKeep = deflateResetKeep;\nmodule.exports.deflateSetHeader = deflateSetHeader;\nmodule.exports.deflate = deflate;\nmodule.exports.deflateEnd = deflateEnd;\nmodule.exports.deflateSetDictionary = deflateSetDictionary;\nmodule.exports.deflateInfo = 'pako deflate (from Nodeca project)';\n\n/* Not implemented\nmodule.exports.deflateBound = deflateBound;\nmodule.exports.deflateCopy = deflateCopy;\nmodule.exports.deflateGetDictionary = deflateGetDictionary;\nmodule.exports.deflateParams = deflateParams;\nmodule.exports.deflatePending = deflatePending;\nmodule.exports.deflatePrime = deflatePrime;\nmodule.exports.deflateTune = deflateTune;\n*/\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction GZheader() {\n /* true if compressed data believed to be text */\n this.text = 0;\n /* modification time */\n this.time = 0;\n /* extra flags (not used when writing a gzip file) */\n this.xflags = 0;\n /* operating system */\n this.os = 0;\n /* pointer to extra field or Z_NULL if none */\n this.extra = null;\n /* extra field length (valid if extra != Z_NULL) */\n this.extra_len = 0; // Actually, we don't need it in JS,\n // but leave for few code modifications\n\n //\n // Setup limits is not necessary because in js we should not preallocate memory\n // for inflate use constant limit in 65536 bytes\n //\n\n /* space at extra (only when reading header) */\n // this.extra_max = 0;\n /* pointer to zero-terminated file name or Z_NULL */\n this.name = '';\n /* space at name (only when reading header) */\n // this.name_max = 0;\n /* pointer to zero-terminated comment or Z_NULL */\n this.comment = '';\n /* space at comment (only when reading header) */\n // this.comm_max = 0;\n /* true if there was or will be a header crc */\n this.hcrc = 0;\n /* true when done reading gzip header (not used when writing a gzip file) */\n this.done = false;\n}\n\nmodule.exports = GZheader;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// See state defs from inflate.js\nconst BAD = 16209; /* got a data error -- remain here until reset */\nconst TYPE = 16191; /* i: waiting for type bits, including last-flag bit */\n\n/*\n Decode literal, length, and distance codes and write out the resulting\n literal and match bytes until either not enough input or output is\n available, an end-of-block is encountered, or a data error is encountered.\n When large enough input and output buffers are supplied to inflate(), for\n example, a 16K input buffer and a 64K output buffer, more than 95% of the\n inflate execution time is spent in this routine.\n\n Entry assumptions:\n\n state.mode === LEN\n strm.avail_in >= 6\n strm.avail_out >= 258\n start >= strm.avail_out\n state.bits < 8\n\n On return, state.mode is one of:\n\n LEN -- ran out of enough output space or enough available input\n TYPE -- reached end of block code, inflate() to interpret next block\n BAD -- error in block data\n\n Notes:\n\n - The maximum input bits used by a length/distance pair is 15 bits for the\n length code, 5 bits for the length extra, 15 bits for the distance code,\n and 13 bits for the distance extra. This totals 48 bits, or six bytes.\n Therefore if strm.avail_in >= 6, then there is enough input to avoid\n checking for available input while decoding.\n\n - The maximum bytes that a single length/distance pair can output is 258\n bytes, which is the maximum length that can be coded. inflate_fast()\n requires strm.avail_out >= 258 for each loop to avoid checking for\n output space.\n */\nmodule.exports = function inflate_fast(strm, start) {\n let _in; /* local strm.input */\n let last; /* have enough input while in < last */\n let _out; /* local strm.output */\n let beg; /* inflate()'s initial strm.output */\n let end; /* while out < end, enough space available */\n//#ifdef INFLATE_STRICT\n let dmax; /* maximum distance from zlib header */\n//#endif\n let wsize; /* window size or zero if not using window */\n let whave; /* valid bytes in the window */\n let wnext; /* window write index */\n // Use `s_window` instead `window`, avoid conflict with instrumentation tools\n let s_window; /* allocated sliding window, if wsize != 0 */\n let hold; /* local strm.hold */\n let bits; /* local strm.bits */\n let lcode; /* local strm.lencode */\n let dcode; /* local strm.distcode */\n let lmask; /* mask for first level of length codes */\n let dmask; /* mask for first level of distance codes */\n let here; /* retrieved table entry */\n let op; /* code bits, operation, extra bits, or */\n /* window position, window bytes to copy */\n let len; /* match length, unused bytes */\n let dist; /* match distance */\n let from; /* where to copy match from */\n let from_source;\n\n\n let input, output; // JS specific, because we have no pointers\n\n /* copy state to local variables */\n const state = strm.state;\n //here = state.here;\n _in = strm.next_in;\n input = strm.input;\n last = _in + (strm.avail_in - 5);\n _out = strm.next_out;\n output = strm.output;\n beg = _out - (start - strm.avail_out);\n end = _out + (strm.avail_out - 257);\n//#ifdef INFLATE_STRICT\n dmax = state.dmax;\n//#endif\n wsize = state.wsize;\n whave = state.whave;\n wnext = state.wnext;\n s_window = state.window;\n hold = state.hold;\n bits = state.bits;\n lcode = state.lencode;\n dcode = state.distcode;\n lmask = (1 << state.lenbits) - 1;\n dmask = (1 << state.distbits) - 1;\n\n\n /* decode literals and length/distances until end-of-block or not enough\n input data or output space */\n\n top:\n do {\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n\n here = lcode[hold & lmask];\n\n dolen:\n for (;;) { // Goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n if (op === 0) { /* literal */\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n output[_out++] = here & 0xffff/*here.val*/;\n }\n else if (op & 16) { /* length base */\n len = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (op) {\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n len += hold & ((1 << op) - 1);\n hold >>>= op;\n bits -= op;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", len));\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n here = dcode[hold & dmask];\n\n dodist:\n for (;;) { // goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n\n if (op & 16) { /* distance base */\n dist = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n }\n dist += hold & ((1 << op) - 1);\n//#ifdef INFLATE_STRICT\n if (dist > dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n//#endif\n hold >>>= op;\n bits -= op;\n //Tracevv((stderr, \"inflate: distance %u\\n\", dist));\n op = _out - beg; /* max distance in output */\n if (dist > op) { /* see if copy from window */\n op = dist - op; /* distance back in window */\n if (op > whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// if (len <= op - whave) {\n// do {\n// output[_out++] = 0;\n// } while (--len);\n// continue top;\n// }\n// len -= op - whave;\n// do {\n// output[_out++] = 0;\n// } while (--op > whave);\n// if (op === 0) {\n// from = _out - dist;\n// do {\n// output[_out++] = output[from++];\n// } while (--len);\n// continue top;\n// }\n//#endif\n }\n from = 0; // window index\n from_source = s_window;\n if (wnext === 0) { /* very common case */\n from += wsize - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n else if (wnext < op) { /* wrap around window */\n from += wsize + wnext - op;\n op -= wnext;\n if (op < len) { /* some from end of window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = 0;\n if (wnext < len) { /* some from start of window */\n op = wnext;\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n }\n else { /* contiguous in window */\n from += wnext - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n while (len > 2) {\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n len -= 3;\n }\n if (len) {\n output[_out++] = from_source[from++];\n if (len > 1) {\n output[_out++] = from_source[from++];\n }\n }\n }\n else {\n from = _out - dist; /* copy direct from output */\n do { /* minimum length is three */\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n len -= 3;\n } while (len > 2);\n if (len) {\n output[_out++] = output[from++];\n if (len > 1) {\n output[_out++] = output[from++];\n }\n }\n }\n }\n else if ((op & 64) === 0) { /* 2nd level distance code */\n here = dcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dodist;\n }\n else {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n }\n else if ((op & 64) === 0) { /* 2nd level length code */\n here = lcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dolen;\n }\n else if (op & 32) { /* end-of-block */\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.mode = TYPE;\n break top;\n }\n else {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n } while (_in < last && _out < end);\n\n /* return unused bytes (on entry, bits < 8, so in won't go too far back) */\n len = bits >> 3;\n _in -= len;\n bits -= len << 3;\n hold &= (1 << bits) - 1;\n\n /* update state and return */\n strm.next_in = _in;\n strm.next_out = _out;\n strm.avail_in = (_in < last ? 5 + (last - _in) : 5 - (_in - last));\n strm.avail_out = (_out < end ? 257 + (end - _out) : 257 - (_out - end));\n state.hold = hold;\n state.bits = bits;\n return;\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst adler32 = require('./adler32');\nconst crc32 = require('./crc32');\nconst inflate_fast = require('./inffast');\nconst inflate_table = require('./inftrees');\n\nconst CODES = 0;\nconst LENS = 1;\nconst DISTS = 2;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_FINISH, Z_BLOCK, Z_TREES,\n Z_OK, Z_STREAM_END, Z_NEED_DICT, Z_STREAM_ERROR, Z_DATA_ERROR, Z_MEM_ERROR, Z_BUF_ERROR,\n Z_DEFLATED\n} = require('./constants');\n\n\n/* STATES ====================================================================*/\n/* ===========================================================================*/\n\n\nconst HEAD = 16180; /* i: waiting for magic header */\nconst FLAGS = 16181; /* i: waiting for method and flags (gzip) */\nconst TIME = 16182; /* i: waiting for modification time (gzip) */\nconst OS = 16183; /* i: waiting for extra flags and operating system (gzip) */\nconst EXLEN = 16184; /* i: waiting for extra length (gzip) */\nconst EXTRA = 16185; /* i: waiting for extra bytes (gzip) */\nconst NAME = 16186; /* i: waiting for end of file name (gzip) */\nconst COMMENT = 16187; /* i: waiting for end of comment (gzip) */\nconst HCRC = 16188; /* i: waiting for header crc (gzip) */\nconst DICTID = 16189; /* i: waiting for dictionary check value */\nconst DICT = 16190; /* waiting for inflateSetDictionary() call */\nconst TYPE = 16191; /* i: waiting for type bits, including last-flag bit */\nconst TYPEDO = 16192; /* i: same, but skip check to exit inflate on new block */\nconst STORED = 16193; /* i: waiting for stored size (length and complement) */\nconst COPY_ = 16194; /* i/o: same as COPY below, but only first time in */\nconst COPY = 16195; /* i/o: waiting for input or output to copy stored block */\nconst TABLE = 16196; /* i: waiting for dynamic block table lengths */\nconst LENLENS = 16197; /* i: waiting for code length code lengths */\nconst CODELENS = 16198; /* i: waiting for length/lit and distance code lengths */\nconst LEN_ = 16199; /* i: same as LEN below, but only first time in */\nconst LEN = 16200; /* i: waiting for length/lit/eob code */\nconst LENEXT = 16201; /* i: waiting for length extra bits */\nconst DIST = 16202; /* i: waiting for distance code */\nconst DISTEXT = 16203; /* i: waiting for distance extra bits */\nconst MATCH = 16204; /* o: waiting for output space to copy string */\nconst LIT = 16205; /* o: waiting for output space to write literal */\nconst CHECK = 16206; /* i: waiting for 32-bit check value */\nconst LENGTH = 16207; /* i: waiting for 32-bit length (gzip) */\nconst DONE = 16208; /* finished check, done -- remain here until reset */\nconst BAD = 16209; /* got a data error -- remain here until reset */\nconst MEM = 16210; /* got an inflate() memory error -- remain here until reset */\nconst SYNC = 16211; /* looking for synchronization bytes to restart inflate() */\n\n/* ===========================================================================*/\n\n\n\nconst ENOUGH_LENS = 852;\nconst ENOUGH_DISTS = 592;\n//const ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nconst MAX_WBITS = 15;\n/* 32K LZ77 window */\nconst DEF_WBITS = MAX_WBITS;\n\n\nconst zswap32 = (q) => {\n\n return (((q >>> 24) & 0xff) +\n ((q >>> 8) & 0xff00) +\n ((q & 0xff00) << 8) +\n ((q & 0xff) << 24));\n};\n\n\nfunction InflateState() {\n this.strm = null; /* pointer back to this zlib stream */\n this.mode = 0; /* current inflate mode */\n this.last = false; /* true if processing last block */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip,\n bit 2 true to validate check value */\n this.havedict = false; /* true if dictionary provided */\n this.flags = 0; /* gzip header method and flags (0 if zlib), or\n -1 if raw or no header yet */\n this.dmax = 0; /* zlib header max distance (INFLATE_STRICT) */\n this.check = 0; /* protected copy of check value */\n this.total = 0; /* protected copy of output count */\n // TODO: may be {}\n this.head = null; /* where to save gzip header information */\n\n /* sliding window */\n this.wbits = 0; /* log base 2 of requested window size */\n this.wsize = 0; /* window size or zero if not using window */\n this.whave = 0; /* valid bytes in the window */\n this.wnext = 0; /* window write index */\n this.window = null; /* allocated sliding window, if needed */\n\n /* bit accumulator */\n this.hold = 0; /* input bit accumulator */\n this.bits = 0; /* number of bits in \"in\" */\n\n /* for string and stored block copying */\n this.length = 0; /* literal or length of data to copy */\n this.offset = 0; /* distance back to copy string from */\n\n /* for table and code decoding */\n this.extra = 0; /* extra bits needed */\n\n /* fixed and dynamic code tables */\n this.lencode = null; /* starting table for length/literal codes */\n this.distcode = null; /* starting table for distance codes */\n this.lenbits = 0; /* index bits for lencode */\n this.distbits = 0; /* index bits for distcode */\n\n /* dynamic table building */\n this.ncode = 0; /* number of code length code lengths */\n this.nlen = 0; /* number of length code lengths */\n this.ndist = 0; /* number of distance code lengths */\n this.have = 0; /* number of code lengths in lens[] */\n this.next = null; /* next available space in codes[] */\n\n this.lens = new Uint16Array(320); /* temporary storage for code lengths */\n this.work = new Uint16Array(288); /* work area for code table building */\n\n /*\n because we don't have pointers in js, we use lencode and distcode directly\n as buffers so we don't need codes\n */\n //this.codes = new Int32Array(ENOUGH); /* space for code tables */\n this.lendyn = null; /* dynamic table for length/literal codes (JS specific) */\n this.distdyn = null; /* dynamic table for distance codes (JS specific) */\n this.sane = 0; /* if false, allow invalid distance too far */\n this.back = 0; /* bits back of last unprocessed length/lit */\n this.was = 0; /* initial length of match */\n}\n\n\nconst inflateStateCheck = (strm) => {\n\n if (!strm) {\n return 1;\n }\n const state = strm.state;\n if (!state || state.strm !== strm ||\n state.mode < HEAD || state.mode > SYNC) {\n return 1;\n }\n return 0;\n};\n\n\nconst inflateResetKeep = (strm) => {\n\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR; }\n const state = strm.state;\n strm.total_in = strm.total_out = state.total = 0;\n strm.msg = ''; /*Z_NULL*/\n if (state.wrap) { /* to support ill-conceived Java test suite */\n strm.adler = state.wrap & 1;\n }\n state.mode = HEAD;\n state.last = 0;\n state.havedict = 0;\n state.flags = -1;\n state.dmax = 32768;\n state.head = null/*Z_NULL*/;\n state.hold = 0;\n state.bits = 0;\n //state.lencode = state.distcode = state.next = state.codes;\n state.lencode = state.lendyn = new Int32Array(ENOUGH_LENS);\n state.distcode = state.distdyn = new Int32Array(ENOUGH_DISTS);\n\n state.sane = 1;\n state.back = -1;\n //Tracev((stderr, \"inflate: reset\\n\"));\n return Z_OK;\n};\n\n\nconst inflateReset = (strm) => {\n\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR; }\n const state = strm.state;\n state.wsize = 0;\n state.whave = 0;\n state.wnext = 0;\n return inflateResetKeep(strm);\n\n};\n\n\nconst inflateReset2 = (strm, windowBits) => {\n let wrap;\n\n /* get the state */\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR; }\n const state = strm.state;\n\n /* extract wrap request from windowBits parameter */\n if (windowBits < 0) {\n wrap = 0;\n windowBits = -windowBits;\n }\n else {\n wrap = (windowBits >> 4) + 5;\n if (windowBits < 48) {\n windowBits &= 15;\n }\n }\n\n /* set number of window bits, free window if different */\n if (windowBits && (windowBits < 8 || windowBits > 15)) {\n return Z_STREAM_ERROR;\n }\n if (state.window !== null && state.wbits !== windowBits) {\n state.window = null;\n }\n\n /* update state and reset the rest of it */\n state.wrap = wrap;\n state.wbits = windowBits;\n return inflateReset(strm);\n};\n\n\nconst inflateInit2 = (strm, windowBits) => {\n\n if (!strm) { return Z_STREAM_ERROR; }\n //strm.msg = Z_NULL; /* in case we return an error */\n\n const state = new InflateState();\n\n //if (state === Z_NULL) return Z_MEM_ERROR;\n //Tracev((stderr, \"inflate: allocated\\n\"));\n strm.state = state;\n state.strm = strm;\n state.window = null/*Z_NULL*/;\n state.mode = HEAD; /* to pass state test in inflateReset2() */\n const ret = inflateReset2(strm, windowBits);\n if (ret !== Z_OK) {\n strm.state = null/*Z_NULL*/;\n }\n return ret;\n};\n\n\nconst inflateInit = (strm) => {\n\n return inflateInit2(strm, DEF_WBITS);\n};\n\n\n/*\n Return state with length and distance decoding tables and index sizes set to\n fixed code decoding. Normally this returns fixed tables from inffixed.h.\n If BUILDFIXED is defined, then instead this routine builds the tables the\n first time it's called, and returns those tables the first time and\n thereafter. This reduces the size of the code by about 2K bytes, in\n exchange for a little execution time. However, BUILDFIXED should not be\n used for threaded applications, since the rewriting of the tables and virgin\n may not be thread-safe.\n */\nlet virgin = true;\n\nlet lenfix, distfix; // We have no pointers in JS, so keep tables separate\n\n\nconst fixedtables = (state) => {\n\n /* build fixed huffman tables if first call (may not be thread safe) */\n if (virgin) {\n lenfix = new Int32Array(512);\n distfix = new Int32Array(32);\n\n /* literal/length table */\n let sym = 0;\n while (sym < 144) { state.lens[sym++] = 8; }\n while (sym < 256) { state.lens[sym++] = 9; }\n while (sym < 280) { state.lens[sym++] = 7; }\n while (sym < 288) { state.lens[sym++] = 8; }\n\n inflate_table(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });\n\n /* distance table */\n sym = 0;\n while (sym < 32) { state.lens[sym++] = 5; }\n\n inflate_table(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 });\n\n /* do this just once */\n virgin = false;\n }\n\n state.lencode = lenfix;\n state.lenbits = 9;\n state.distcode = distfix;\n state.distbits = 5;\n};\n\n\n/*\n Update the window with the last wsize (normally 32K) bytes written before\n returning. If window does not exist yet, create it. This is only called\n when a window is already in use, or when output has been written during this\n inflate call, but the end of the deflate stream has not been reached yet.\n It is also called to create a window for dictionary data when a dictionary\n is loaded.\n\n Providing output buffers larger than 32K to inflate() should provide a speed\n advantage, since only the last 32K of output is copied to the sliding window\n upon return from inflate(), and since all distances after the first 32K of\n output will fall in the output data, making match copies simpler and faster.\n The advantage may be dependent on the size of the processor's data caches.\n */\nconst updatewindow = (strm, src, end, copy) => {\n\n let dist;\n const state = strm.state;\n\n /* if it hasn't been done already, allocate space for the window */\n if (state.window === null) {\n state.wsize = 1 << state.wbits;\n state.wnext = 0;\n state.whave = 0;\n\n state.window = new Uint8Array(state.wsize);\n }\n\n /* copy state->wsize or less output bytes into the circular window */\n if (copy >= state.wsize) {\n state.window.set(src.subarray(end - state.wsize, end), 0);\n state.wnext = 0;\n state.whave = state.wsize;\n }\n else {\n dist = state.wsize - state.wnext;\n if (dist > copy) {\n dist = copy;\n }\n //zmemcpy(state->window + state->wnext, end - copy, dist);\n state.window.set(src.subarray(end - copy, end - copy + dist), state.wnext);\n copy -= dist;\n if (copy) {\n //zmemcpy(state->window, end - copy, copy);\n state.window.set(src.subarray(end - copy, end), 0);\n state.wnext = copy;\n state.whave = state.wsize;\n }\n else {\n state.wnext += dist;\n if (state.wnext === state.wsize) { state.wnext = 0; }\n if (state.whave < state.wsize) { state.whave += dist; }\n }\n }\n return 0;\n};\n\n\nconst inflate = (strm, flush) => {\n\n let state;\n let input, output; // input/output buffers\n let next; /* next input INDEX */\n let put; /* next output INDEX */\n let have, left; /* available input and output */\n let hold; /* bit buffer */\n let bits; /* bits in bit buffer */\n let _in, _out; /* save starting available input and output */\n let copy; /* number of stored or match bytes to copy */\n let from; /* where to copy match bytes from */\n let from_source;\n let here = 0; /* current decoding table entry */\n let here_bits, here_op, here_val; // paked \"here\" denormalized (JS specific)\n //let last; /* parent table entry */\n let last_bits, last_op, last_val; // paked \"last\" denormalized (JS specific)\n let len; /* length to copy for repeats, bits to drop */\n let ret; /* return code */\n const hbuf = new Uint8Array(4); /* buffer for gzip header crc calculation */\n let opts;\n\n let n; // temporary variable for NEED_BITS\n\n const order = /* permutation of code lengths */\n new Uint8Array([ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ]);\n\n\n if (inflateStateCheck(strm) || !strm.output ||\n (!strm.input && strm.avail_in !== 0)) {\n return Z_STREAM_ERROR;\n }\n\n state = strm.state;\n if (state.mode === TYPE) { state.mode = TYPEDO; } /* skip check */\n\n\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n _in = have;\n _out = left;\n ret = Z_OK;\n\n inf_leave: // goto emulation\n for (;;) {\n switch (state.mode) {\n case HEAD:\n if (state.wrap === 0) {\n state.mode = TYPEDO;\n break;\n }\n //=== NEEDBITS(16);\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 2) && hold === 0x8b1f) { /* gzip header */\n if (state.wbits === 0) {\n state.wbits = 15;\n }\n state.check = 0/*crc32(0L, Z_NULL, 0)*/;\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = FLAGS;\n break;\n }\n if (state.head) {\n state.head.done = false;\n }\n if (!(state.wrap & 1) || /* check if zlib header allowed */\n (((hold & 0xff)/*BITS(8)*/ << 8) + (hold >> 8)) % 31) {\n strm.msg = 'incorrect header check';\n state.mode = BAD;\n break;\n }\n if ((hold & 0x0f)/*BITS(4)*/ !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n len = (hold & 0x0f)/*BITS(4)*/ + 8;\n if (state.wbits === 0) {\n state.wbits = len;\n }\n if (len > 15 || len > state.wbits) {\n strm.msg = 'invalid window size';\n state.mode = BAD;\n break;\n }\n\n // !!! pako patch. Force use `options.windowBits` if passed.\n // Required to always use max window size by default.\n state.dmax = 1 << state.wbits;\n //state.dmax = 1 << len;\n\n state.flags = 0; /* indicate zlib header */\n //Tracev((stderr, \"inflate: zlib header ok\\n\"));\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = hold & 0x200 ? DICTID : TYPE;\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n break;\n case FLAGS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.flags = hold;\n if ((state.flags & 0xff) !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n if (state.flags & 0xe000) {\n strm.msg = 'unknown header flags set';\n state.mode = BAD;\n break;\n }\n if (state.head) {\n state.head.text = ((hold >> 8) & 1);\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = TIME;\n /* falls through */\n case TIME:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.time = hold;\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n //=== CRC4(state.check, hold)\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n hbuf[2] = (hold >>> 16) & 0xff;\n hbuf[3] = (hold >>> 24) & 0xff;\n state.check = crc32(state.check, hbuf, 4, 0);\n //===\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = OS;\n /* falls through */\n case OS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.xflags = (hold & 0xff);\n state.head.os = (hold >> 8);\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = EXLEN;\n /* falls through */\n case EXLEN:\n if (state.flags & 0x0400) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length = hold;\n if (state.head) {\n state.head.extra_len = hold;\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n else if (state.head) {\n state.head.extra = null/*Z_NULL*/;\n }\n state.mode = EXTRA;\n /* falls through */\n case EXTRA:\n if (state.flags & 0x0400) {\n copy = state.length;\n if (copy > have) { copy = have; }\n if (copy) {\n if (state.head) {\n len = state.head.extra_len - state.length;\n if (!state.head.extra) {\n // Use untyped array for more convenient processing later\n state.head.extra = new Uint8Array(state.head.extra_len);\n }\n state.head.extra.set(\n input.subarray(\n next,\n // extra field is limited to 65536 bytes\n // - no need for additional size check\n next + copy\n ),\n /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/\n len\n );\n //zmemcpy(state.head.extra + len, next,\n // len + copy > state.head.extra_max ?\n // state.head.extra_max - len : copy);\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n state.length -= copy;\n }\n if (state.length) { break inf_leave; }\n }\n state.length = 0;\n state.mode = NAME;\n /* falls through */\n case NAME:\n if (state.flags & 0x0800) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n // TODO: 2 or 1 bytes?\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.name_max*/)) {\n state.head.name += String.fromCharCode(len);\n }\n } while (len && copy < have);\n\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.name = null;\n }\n state.length = 0;\n state.mode = COMMENT;\n /* falls through */\n case COMMENT:\n if (state.flags & 0x1000) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.comm_max*/)) {\n state.head.comment += String.fromCharCode(len);\n }\n } while (len && copy < have);\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.comment = null;\n }\n state.mode = HCRC;\n /* falls through */\n case HCRC:\n if (state.flags & 0x0200) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 4) && hold !== (state.check & 0xffff)) {\n strm.msg = 'header crc mismatch';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n if (state.head) {\n state.head.hcrc = ((state.flags >> 9) & 1);\n state.head.done = true;\n }\n strm.adler = state.check = 0;\n state.mode = TYPE;\n break;\n case DICTID:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n strm.adler = state.check = zswap32(hold);\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = DICT;\n /* falls through */\n case DICT:\n if (state.havedict === 0) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n return Z_NEED_DICT;\n }\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = TYPE;\n /* falls through */\n case TYPE:\n if (flush === Z_BLOCK || flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case TYPEDO:\n if (state.last) {\n //--- BYTEBITS() ---//\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n state.mode = CHECK;\n break;\n }\n //=== NEEDBITS(3); */\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.last = (hold & 0x01)/*BITS(1)*/;\n //--- DROPBITS(1) ---//\n hold >>>= 1;\n bits -= 1;\n //---//\n\n switch ((hold & 0x03)/*BITS(2)*/) {\n case 0: /* stored block */\n //Tracev((stderr, \"inflate: stored block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = STORED;\n break;\n case 1: /* fixed block */\n fixedtables(state);\n //Tracev((stderr, \"inflate: fixed codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = LEN_; /* decode codes */\n if (flush === Z_TREES) {\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break inf_leave;\n }\n break;\n case 2: /* dynamic block */\n //Tracev((stderr, \"inflate: dynamic codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = TABLE;\n break;\n case 3:\n strm.msg = 'invalid block type';\n state.mode = BAD;\n }\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break;\n case STORED:\n //--- BYTEBITS() ---// /* go to byte boundary */\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {\n strm.msg = 'invalid stored block lengths';\n state.mode = BAD;\n break;\n }\n state.length = hold & 0xffff;\n //Tracev((stderr, \"inflate: stored length %u\\n\",\n // state.length));\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = COPY_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case COPY_:\n state.mode = COPY;\n /* falls through */\n case COPY:\n copy = state.length;\n if (copy) {\n if (copy > have) { copy = have; }\n if (copy > left) { copy = left; }\n if (copy === 0) { break inf_leave; }\n //--- zmemcpy(put, next, copy); ---\n output.set(input.subarray(next, next + copy), put);\n //---//\n have -= copy;\n next += copy;\n left -= copy;\n put += copy;\n state.length -= copy;\n break;\n }\n //Tracev((stderr, \"inflate: stored end\\n\"));\n state.mode = TYPE;\n break;\n case TABLE:\n //=== NEEDBITS(14); */\n while (bits < 14) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.nlen = (hold & 0x1f)/*BITS(5)*/ + 257;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ndist = (hold & 0x1f)/*BITS(5)*/ + 1;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ncode = (hold & 0x0f)/*BITS(4)*/ + 4;\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n//#ifndef PKZIP_BUG_WORKAROUND\n if (state.nlen > 286 || state.ndist > 30) {\n strm.msg = 'too many length or distance symbols';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracev((stderr, \"inflate: table sizes ok\\n\"));\n state.have = 0;\n state.mode = LENLENS;\n /* falls through */\n case LENLENS:\n while (state.have < state.ncode) {\n //=== NEEDBITS(3);\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.lens[order[state.have++]] = (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n while (state.have < 19) {\n state.lens[order[state.have++]] = 0;\n }\n // We have separate tables & no pointers. 2 commented lines below not needed.\n //state.next = state.codes;\n //state.lencode = state.next;\n // Switch to use dynamic table\n state.lencode = state.lendyn;\n state.lenbits = 7;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);\n state.lenbits = opts.bits;\n\n if (ret) {\n strm.msg = 'invalid code lengths set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, \"inflate: code lengths ok\\n\"));\n state.have = 0;\n state.mode = CODELENS;\n /* falls through */\n case CODELENS:\n while (state.have < state.nlen + state.ndist) {\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)];/*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_val < 16) {\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.lens[state.have++] = here_val;\n }\n else {\n if (here_val === 16) {\n //=== NEEDBITS(here.bits + 2);\n n = here_bits + 2;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n if (state.have === 0) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n len = state.lens[state.have - 1];\n copy = 3 + (hold & 0x03);//BITS(2);\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n }\n else if (here_val === 17) {\n //=== NEEDBITS(here.bits + 3);\n n = here_bits + 3;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 3 + (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n else {\n //=== NEEDBITS(here.bits + 7);\n n = here_bits + 7;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 11 + (hold & 0x7f);//BITS(7);\n //--- DROPBITS(7) ---//\n hold >>>= 7;\n bits -= 7;\n //---//\n }\n if (state.have + copy > state.nlen + state.ndist) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n while (copy--) {\n state.lens[state.have++] = len;\n }\n }\n }\n\n /* handle error breaks in while */\n if (state.mode === BAD) { break; }\n\n /* check for end-of-block code (better have one) */\n if (state.lens[256] === 0) {\n strm.msg = 'invalid code -- missing end-of-block';\n state.mode = BAD;\n break;\n }\n\n /* build code tables -- note: do not change the lenbits or distbits\n values here (9 and 6) without reading the comments in inftrees.h\n concerning the ENOUGH constants, which depend on those values */\n state.lenbits = 9;\n\n opts = { bits: state.lenbits };\n ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.lenbits = opts.bits;\n // state.lencode = state.next;\n\n if (ret) {\n strm.msg = 'invalid literal/lengths set';\n state.mode = BAD;\n break;\n }\n\n state.distbits = 6;\n //state.distcode.copy(state.codes);\n // Switch to use dynamic table\n state.distcode = state.distdyn;\n opts = { bits: state.distbits };\n ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.distbits = opts.bits;\n // state.distcode = state.next;\n\n if (ret) {\n strm.msg = 'invalid distances set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, 'inflate: codes ok\\n'));\n state.mode = LEN_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case LEN_:\n state.mode = LEN;\n /* falls through */\n case LEN:\n if (have >= 6 && left >= 258) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n inflate_fast(strm, _out);\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n if (state.mode === TYPE) {\n state.back = -1;\n }\n break;\n }\n state.back = 0;\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if (here_bits <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_op && (here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.lencode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n state.length = here_val;\n if (here_op === 0) {\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n state.mode = LIT;\n break;\n }\n if (here_op & 32) {\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.back = -1;\n state.mode = TYPE;\n break;\n }\n if (here_op & 64) {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break;\n }\n state.extra = here_op & 15;\n state.mode = LENEXT;\n /* falls through */\n case LENEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", state.length));\n state.was = state.length;\n state.mode = DIST;\n /* falls through */\n case DIST:\n for (;;) {\n here = state.distcode[hold & ((1 << state.distbits) - 1)];/*BITS(state.distbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if ((here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.distcode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n if (here_op & 64) {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break;\n }\n state.offset = here_val;\n state.extra = (here_op) & 15;\n state.mode = DISTEXT;\n /* falls through */\n case DISTEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.offset += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n//#ifdef INFLATE_STRICT\n if (state.offset > state.dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracevv((stderr, \"inflate: distance %u\\n\", state.offset));\n state.mode = MATCH;\n /* falls through */\n case MATCH:\n if (left === 0) { break inf_leave; }\n copy = _out - left;\n if (state.offset > copy) { /* copy from window */\n copy = state.offset - copy;\n if (copy > state.whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// Trace((stderr, \"inflate.c too far\\n\"));\n// copy -= state.whave;\n// if (copy > state.length) { copy = state.length; }\n// if (copy > left) { copy = left; }\n// left -= copy;\n// state.length -= copy;\n// do {\n// output[put++] = 0;\n// } while (--copy);\n// if (state.length === 0) { state.mode = LEN; }\n// break;\n//#endif\n }\n if (copy > state.wnext) {\n copy -= state.wnext;\n from = state.wsize - copy;\n }\n else {\n from = state.wnext - copy;\n }\n if (copy > state.length) { copy = state.length; }\n from_source = state.window;\n }\n else { /* copy from output */\n from_source = output;\n from = put - state.offset;\n copy = state.length;\n }\n if (copy > left) { copy = left; }\n left -= copy;\n state.length -= copy;\n do {\n output[put++] = from_source[from++];\n } while (--copy);\n if (state.length === 0) { state.mode = LEN; }\n break;\n case LIT:\n if (left === 0) { break inf_leave; }\n output[put++] = state.length;\n left--;\n state.mode = LEN;\n break;\n case CHECK:\n if (state.wrap) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n // Use '|' instead of '+' to make sure that result is signed\n hold |= input[next++] << bits;\n bits += 8;\n }\n //===//\n _out -= left;\n strm.total_out += _out;\n state.total += _out;\n if ((state.wrap & 4) && _out) {\n strm.adler = state.check =\n /*UPDATE_CHECK(state.check, put - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, put - _out) : adler32(state.check, output, _out, put - _out));\n\n }\n _out = left;\n // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too\n if ((state.wrap & 4) && (state.flags ? hold : zswap32(hold)) !== state.check) {\n strm.msg = 'incorrect data check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: check matches trailer\\n\"));\n }\n state.mode = LENGTH;\n /* falls through */\n case LENGTH:\n if (state.wrap && state.flags) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 4) && hold !== (state.total & 0xffffffff)) {\n strm.msg = 'incorrect length check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: length matches trailer\\n\"));\n }\n state.mode = DONE;\n /* falls through */\n case DONE:\n ret = Z_STREAM_END;\n break inf_leave;\n case BAD:\n ret = Z_DATA_ERROR;\n break inf_leave;\n case MEM:\n return Z_MEM_ERROR;\n case SYNC:\n /* falls through */\n default:\n return Z_STREAM_ERROR;\n }\n }\n\n // inf_leave <- here is real place for \"goto inf_leave\", emulated via \"break inf_leave\"\n\n /*\n Return from inflate(), updating the total counts and the check value.\n If there was no progress during the inflate() call, return a buffer\n error. Call updatewindow() to create and/or update the window state.\n Note: a memory error from inflate() is non-recoverable.\n */\n\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n\n if (state.wsize || (_out !== strm.avail_out && state.mode < BAD &&\n (state.mode < CHECK || flush !== Z_FINISH))) {\n if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n }\n _in -= strm.avail_in;\n _out -= strm.avail_out;\n strm.total_in += _in;\n strm.total_out += _out;\n state.total += _out;\n if ((state.wrap & 4) && _out) {\n strm.adler = state.check = /*UPDATE_CHECK(state.check, strm.next_out - _out, _out);*/\n (state.flags ? crc32(state.check, output, _out, strm.next_out - _out) : adler32(state.check, output, _out, strm.next_out - _out));\n }\n strm.data_type = state.bits + (state.last ? 64 : 0) +\n (state.mode === TYPE ? 128 : 0) +\n (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);\n if (((_in === 0 && _out === 0) || flush === Z_FINISH) && ret === Z_OK) {\n ret = Z_BUF_ERROR;\n }\n return ret;\n};\n\n\nconst inflateEnd = (strm) => {\n\n if (inflateStateCheck(strm)) {\n return Z_STREAM_ERROR;\n }\n\n let state = strm.state;\n if (state.window) {\n state.window = null;\n }\n strm.state = null;\n return Z_OK;\n};\n\n\nconst inflateGetHeader = (strm, head) => {\n\n /* check state */\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR; }\n const state = strm.state;\n if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR; }\n\n /* save header structure */\n state.head = head;\n head.done = false;\n return Z_OK;\n};\n\n\nconst inflateSetDictionary = (strm, dictionary) => {\n const dictLength = dictionary.length;\n\n let state;\n let dictid;\n let ret;\n\n /* check state */\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR; }\n state = strm.state;\n\n if (state.wrap !== 0 && state.mode !== DICT) {\n return Z_STREAM_ERROR;\n }\n\n /* check for correct dictionary identifier */\n if (state.mode === DICT) {\n dictid = 1; /* adler32(0, null, 0)*/\n /* dictid = adler32(dictid, dictionary, dictLength); */\n dictid = adler32(dictid, dictionary, dictLength, 0);\n if (dictid !== state.check) {\n return Z_DATA_ERROR;\n }\n }\n /* copy dictionary to window using updatewindow(), which will amend the\n existing dictionary if appropriate */\n ret = updatewindow(strm, dictionary, dictLength, dictLength);\n if (ret) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n state.havedict = 1;\n // Tracev((stderr, \"inflate: dictionary set\\n\"));\n return Z_OK;\n};\n\n\nmodule.exports.inflateReset = inflateReset;\nmodule.exports.inflateReset2 = inflateReset2;\nmodule.exports.inflateResetKeep = inflateResetKeep;\nmodule.exports.inflateInit = inflateInit;\nmodule.exports.inflateInit2 = inflateInit2;\nmodule.exports.inflate = inflate;\nmodule.exports.inflateEnd = inflateEnd;\nmodule.exports.inflateGetHeader = inflateGetHeader;\nmodule.exports.inflateSetDictionary = inflateSetDictionary;\nmodule.exports.inflateInfo = 'pako inflate (from Nodeca project)';\n\n/* Not implemented\nmodule.exports.inflateCodesUsed = inflateCodesUsed;\nmodule.exports.inflateCopy = inflateCopy;\nmodule.exports.inflateGetDictionary = inflateGetDictionary;\nmodule.exports.inflateMark = inflateMark;\nmodule.exports.inflatePrime = inflatePrime;\nmodule.exports.inflateSync = inflateSync;\nmodule.exports.inflateSyncPoint = inflateSyncPoint;\nmodule.exports.inflateUndermine = inflateUndermine;\nmodule.exports.inflateValidate = inflateValidate;\n*/\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst MAXBITS = 15;\nconst ENOUGH_LENS = 852;\nconst ENOUGH_DISTS = 592;\n//const ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nconst CODES = 0;\nconst LENS = 1;\nconst DISTS = 2;\n\nconst lbase = new Uint16Array([ /* Length codes 257..285 base */\n 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,\n 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0\n]);\n\nconst lext = new Uint8Array([ /* Length codes 257..285 extra */\n 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,\n 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78\n]);\n\nconst dbase = new Uint16Array([ /* Distance codes 0..29 base */\n 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,\n 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,\n 8193, 12289, 16385, 24577, 0, 0\n]);\n\nconst dext = new Uint8Array([ /* Distance codes 0..29 extra */\n 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,\n 23, 23, 24, 24, 25, 25, 26, 26, 27, 27,\n 28, 28, 29, 29, 64, 64\n]);\n\nconst inflate_table = (type, lens, lens_index, codes, table, table_index, work, opts) =>\n{\n const bits = opts.bits;\n //here = opts.here; /* table entry for duplication */\n\n let len = 0; /* a code's length in bits */\n let sym = 0; /* index of code symbols */\n let min = 0, max = 0; /* minimum and maximum code lengths */\n let root = 0; /* number of index bits for root table */\n let curr = 0; /* number of index bits for current table */\n let drop = 0; /* code bits to drop for sub-table */\n let left = 0; /* number of prefix codes available */\n let used = 0; /* code entries in table used */\n let huff = 0; /* Huffman code */\n let incr; /* for incrementing code, index */\n let fill; /* index for replicating entries */\n let low; /* low bits for current root entry */\n let mask; /* mask for low root bits */\n let next; /* next available space in table */\n let base = null; /* base value table to use */\n// let shoextra; /* extra bits table to use */\n let match; /* use base and extra for symbol >= match */\n const count = new Uint16Array(MAXBITS + 1); //[MAXBITS+1]; /* number of codes of each length */\n const offs = new Uint16Array(MAXBITS + 1); //[MAXBITS+1]; /* offsets in table for each length */\n let extra = null;\n\n let here_bits, here_op, here_val;\n\n /*\n Process a set of code lengths to create a canonical Huffman code. The\n code lengths are lens[0..codes-1]. Each length corresponds to the\n symbols 0..codes-1. The Huffman code is generated by first sorting the\n symbols by length from short to long, and retaining the symbol order\n for codes with equal lengths. Then the code starts with all zero bits\n for the first code of the shortest length, and the codes are integer\n increments for the same length, and zeros are appended as the length\n increases. For the deflate format, these bits are stored backwards\n from their more natural integer increment ordering, and so when the\n decoding tables are built in the large loop below, the integer codes\n are incremented backwards.\n\n This routine assumes, but does not check, that all of the entries in\n lens[] are in the range 0..MAXBITS. The caller must assure this.\n 1..MAXBITS is interpreted as that code length. zero means that that\n symbol does not occur in this code.\n\n The codes are sorted by computing a count of codes for each length,\n creating from that a table of starting indices for each length in the\n sorted table, and then entering the symbols in order in the sorted\n table. The sorted table is work[], with that space being provided by\n the caller.\n\n The length counts are used for other purposes as well, i.e. finding\n the minimum and maximum length codes, determining if there are any\n codes at all, checking for a valid set of lengths, and looking ahead\n at length counts to determine sub-table sizes when building the\n decoding tables.\n */\n\n /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */\n for (len = 0; len <= MAXBITS; len++) {\n count[len] = 0;\n }\n for (sym = 0; sym < codes; sym++) {\n count[lens[lens_index + sym]]++;\n }\n\n /* bound code lengths, force root to be within code lengths */\n root = bits;\n for (max = MAXBITS; max >= 1; max--) {\n if (count[max] !== 0) { break; }\n }\n if (root > max) {\n root = max;\n }\n if (max === 0) { /* no symbols to code at all */\n //table.op[opts.table_index] = 64; //here.op = (var char)64; /* invalid code marker */\n //table.bits[opts.table_index] = 1; //here.bits = (var char)1;\n //table.val[opts.table_index++] = 0; //here.val = (var short)0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n\n //table.op[opts.table_index] = 64;\n //table.bits[opts.table_index] = 1;\n //table.val[opts.table_index++] = 0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n opts.bits = 1;\n return 0; /* no symbols, but wait for decoding to report error */\n }\n for (min = 1; min < max; min++) {\n if (count[min] !== 0) { break; }\n }\n if (root < min) {\n root = min;\n }\n\n /* check for an over-subscribed or incomplete set of lengths */\n left = 1;\n for (len = 1; len <= MAXBITS; len++) {\n left <<= 1;\n left -= count[len];\n if (left < 0) {\n return -1;\n } /* over-subscribed */\n }\n if (left > 0 && (type === CODES || max !== 1)) {\n return -1; /* incomplete set */\n }\n\n /* generate offsets into symbol table for each length for sorting */\n offs[1] = 0;\n for (len = 1; len < MAXBITS; len++) {\n offs[len + 1] = offs[len] + count[len];\n }\n\n /* sort symbols by length, by symbol order within each length */\n for (sym = 0; sym < codes; sym++) {\n if (lens[lens_index + sym] !== 0) {\n work[offs[lens[lens_index + sym]]++] = sym;\n }\n }\n\n /*\n Create and fill in decoding tables. In this loop, the table being\n filled is at next and has curr index bits. The code being used is huff\n with length len. That code is converted to an index by dropping drop\n bits off of the bottom. For codes where len is less than drop + curr,\n those top drop + curr - len bits are incremented through all values to\n fill the table with replicated entries.\n\n root is the number of index bits for the root table. When len exceeds\n root, sub-tables are created pointed to by the root entry with an index\n of the low root bits of huff. This is saved in low to check for when a\n new sub-table should be started. drop is zero when the root table is\n being filled, and drop is root when sub-tables are being filled.\n\n When a new sub-table is needed, it is necessary to look ahead in the\n code lengths to determine what size sub-table is needed. The length\n counts are used for this, and so count[] is decremented as codes are\n entered in the tables.\n\n used keeps track of how many table entries have been allocated from the\n provided *table space. It is checked for LENS and DIST tables against\n the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in\n the initial root table size constants. See the comments in inftrees.h\n for more information.\n\n sym increments through all symbols, and the loop terminates when\n all codes of length max, i.e. all codes, have been processed. This\n routine permits incomplete codes, so another loop after this one fills\n in the rest of the decoding tables with invalid code markers.\n */\n\n /* set up for code type */\n // poor man optimization - use if-else instead of switch,\n // to avoid deopts in old v8\n if (type === CODES) {\n base = extra = work; /* dummy value--not used */\n match = 20;\n\n } else if (type === LENS) {\n base = lbase;\n extra = lext;\n match = 257;\n\n } else { /* DISTS */\n base = dbase;\n extra = dext;\n match = 0;\n }\n\n /* initialize opts for loop */\n huff = 0; /* starting code */\n sym = 0; /* starting code symbol */\n len = min; /* starting code length */\n next = table_index; /* current table to fill in */\n curr = root; /* current table index bits */\n drop = 0; /* current bits to drop from code for index */\n low = -1; /* trigger new sub-table when len > root */\n used = 1 << root; /* use root table entries */\n mask = used - 1; /* mask for comparing low */\n\n /* check available table space */\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* process all codes and make table entries */\n for (;;) {\n /* create table entry */\n here_bits = len - drop;\n if (work[sym] + 1 < match) {\n here_op = 0;\n here_val = work[sym];\n }\n else if (work[sym] >= match) {\n here_op = extra[work[sym] - match];\n here_val = base[work[sym] - match];\n }\n else {\n here_op = 32 + 64; /* end of block */\n here_val = 0;\n }\n\n /* replicate for those indices with low len bits equal to huff */\n incr = 1 << (len - drop);\n fill = 1 << curr;\n min = fill; /* save offset to next table */\n do {\n fill -= incr;\n table[next + (huff >> drop) + fill] = (here_bits << 24) | (here_op << 16) | here_val |0;\n } while (fill !== 0);\n\n /* backwards increment the len-bit code huff */\n incr = 1 << (len - 1);\n while (huff & incr) {\n incr >>= 1;\n }\n if (incr !== 0) {\n huff &= incr - 1;\n huff += incr;\n } else {\n huff = 0;\n }\n\n /* go to next symbol, update count, len */\n sym++;\n if (--count[len] === 0) {\n if (len === max) { break; }\n len = lens[lens_index + work[sym]];\n }\n\n /* create new sub-table if needed */\n if (len > root && (huff & mask) !== low) {\n /* if first time, transition to sub-tables */\n if (drop === 0) {\n drop = root;\n }\n\n /* increment past last table */\n next += min; /* here min is 1 << curr */\n\n /* determine length of next table */\n curr = len - drop;\n left = 1 << curr;\n while (curr + drop < max) {\n left -= count[curr + drop];\n if (left <= 0) { break; }\n curr++;\n left <<= 1;\n }\n\n /* check for enough space */\n used += 1 << curr;\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n\n /* point entry in root table to sub-table */\n low = huff & mask;\n /*table.op[low] = curr;\n table.bits[low] = root;\n table.val[low] = next - opts.table_index;*/\n table[low] = (root << 24) | (curr << 16) | (next - table_index) |0;\n }\n }\n\n /* fill in remaining table entry if code is incomplete (guaranteed to have\n at most one remaining entry, since if the code is incomplete, the\n maximum code length that was allowed to get this far is one bit) */\n if (huff !== 0) {\n //table.op[next + huff] = 64; /* invalid code marker */\n //table.bits[next + huff] = len - drop;\n //table.val[next + huff] = 0;\n table[next + huff] = ((len - drop) << 24) | (64 << 16) |0;\n }\n\n /* set return parameters */\n //opts.table_index += used;\n opts.bits = root;\n return 0;\n};\n\n\nmodule.exports = inflate_table;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nmodule.exports = {\n 2: 'need dictionary', /* Z_NEED_DICT 2 */\n 1: 'stream end', /* Z_STREAM_END 1 */\n 0: '', /* Z_OK 0 */\n '-1': 'file error', /* Z_ERRNO (-1) */\n '-2': 'stream error', /* Z_STREAM_ERROR (-2) */\n '-3': 'data error', /* Z_DATA_ERROR (-3) */\n '-4': 'insufficient memory', /* Z_MEM_ERROR (-4) */\n '-5': 'buffer error', /* Z_BUF_ERROR (-5) */\n '-6': 'incompatible version' /* Z_VERSION_ERROR (-6) */\n};\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n/* eslint-disable space-unary-ops */\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n//const Z_FILTERED = 1;\n//const Z_HUFFMAN_ONLY = 2;\n//const Z_RLE = 3;\nconst Z_FIXED = 4;\n//const Z_DEFAULT_STRATEGY = 0;\n\n/* Possible values of the data_type field (though see inflate()) */\nconst Z_BINARY = 0;\nconst Z_TEXT = 1;\n//const Z_ASCII = 1; // = Z_TEXT\nconst Z_UNKNOWN = 2;\n\n/*============================================================================*/\n\n\nfunction zero(buf) { let len = buf.length; while (--len >= 0) { buf[len] = 0; } }\n\n// From zutil.h\n\nconst STORED_BLOCK = 0;\nconst STATIC_TREES = 1;\nconst DYN_TREES = 2;\n/* The three kinds of block type */\n\nconst MIN_MATCH = 3;\nconst MAX_MATCH = 258;\n/* The minimum and maximum match lengths */\n\n// From deflate.h\n/* ===========================================================================\n * Internal compression state.\n */\n\nconst LENGTH_CODES = 29;\n/* number of length codes, not counting the special END_BLOCK code */\n\nconst LITERALS = 256;\n/* number of literal bytes 0..255 */\n\nconst L_CODES = LITERALS + 1 + LENGTH_CODES;\n/* number of Literal or Length codes, including the END_BLOCK code */\n\nconst D_CODES = 30;\n/* number of distance codes */\n\nconst BL_CODES = 19;\n/* number of codes used to transfer the bit lengths */\n\nconst HEAP_SIZE = 2 * L_CODES + 1;\n/* maximum heap size */\n\nconst MAX_BITS = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nconst Buf_size = 16;\n/* size of bit buffer in bi_buf */\n\n\n/* ===========================================================================\n * Constants\n */\n\nconst MAX_BL_BITS = 7;\n/* Bit length codes must not exceed MAX_BL_BITS bits */\n\nconst END_BLOCK = 256;\n/* end of block literal code */\n\nconst REP_3_6 = 16;\n/* repeat previous bit length 3-6 times (2 bits of repeat count) */\n\nconst REPZ_3_10 = 17;\n/* repeat a zero length 3-10 times (3 bits of repeat count) */\n\nconst REPZ_11_138 = 18;\n/* repeat a zero length 11-138 times (7 bits of repeat count) */\n\n/* eslint-disable comma-spacing,array-bracket-spacing */\nconst extra_lbits = /* extra bits for each length code */\n new Uint8Array([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0]);\n\nconst extra_dbits = /* extra bits for each distance code */\n new Uint8Array([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13]);\n\nconst extra_blbits = /* extra bits for each bit length code */\n new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]);\n\nconst bl_order =\n new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);\n/* eslint-enable comma-spacing,array-bracket-spacing */\n\n/* The lengths of the bit length codes are sent in order of decreasing\n * probability, to avoid transmitting the lengths for unused bit length codes.\n */\n\n/* ===========================================================================\n * Local data. These are initialized only once.\n */\n\n// We pre-fill arrays with 0 to avoid uninitialized gaps\n\nconst DIST_CODE_LEN = 512; /* see definition of array dist_code below */\n\n// !!!! Use flat array instead of structure, Freq = i*2, Len = i*2+1\nconst static_ltree = new Array((L_CODES + 2) * 2);\nzero(static_ltree);\n/* The static literal tree. Since the bit lengths are imposed, there is no\n * need for the L_CODES extra codes used during heap construction. However\n * The codes 286 and 287 are needed to build a canonical tree (see _tr_init\n * below).\n */\n\nconst static_dtree = new Array(D_CODES * 2);\nzero(static_dtree);\n/* The static distance tree. (Actually a trivial tree since all codes use\n * 5 bits.)\n */\n\nconst _dist_code = new Array(DIST_CODE_LEN);\nzero(_dist_code);\n/* Distance codes. The first 256 values correspond to the distances\n * 3 .. 258, the last 256 values correspond to the top 8 bits of\n * the 15 bit distances.\n */\n\nconst _length_code = new Array(MAX_MATCH - MIN_MATCH + 1);\nzero(_length_code);\n/* length code for each normalized match length (0 == MIN_MATCH) */\n\nconst base_length = new Array(LENGTH_CODES);\nzero(base_length);\n/* First normalized length for each code (0 = MIN_MATCH) */\n\nconst base_dist = new Array(D_CODES);\nzero(base_dist);\n/* First normalized distance for each code (0 = distance of 1) */\n\n\nfunction StaticTreeDesc(static_tree, extra_bits, extra_base, elems, max_length) {\n\n this.static_tree = static_tree; /* static tree or NULL */\n this.extra_bits = extra_bits; /* extra bits for each code or NULL */\n this.extra_base = extra_base; /* base index for extra_bits */\n this.elems = elems; /* max number of elements in the tree */\n this.max_length = max_length; /* max bit length for the codes */\n\n // show if `static_tree` has data or dummy - needed for monomorphic objects\n this.has_stree = static_tree && static_tree.length;\n}\n\n\nlet static_l_desc;\nlet static_d_desc;\nlet static_bl_desc;\n\n\nfunction TreeDesc(dyn_tree, stat_desc) {\n this.dyn_tree = dyn_tree; /* the dynamic tree */\n this.max_code = 0; /* largest code with non zero frequency */\n this.stat_desc = stat_desc; /* the corresponding static tree */\n}\n\n\n\nconst d_code = (dist) => {\n\n return dist < 256 ? _dist_code[dist] : _dist_code[256 + (dist >>> 7)];\n};\n\n\n/* ===========================================================================\n * Output a short LSB first on the stream.\n * IN assertion: there is enough room in pendingBuf.\n */\nconst put_short = (s, w) => {\n// put_byte(s, (uch)((w) & 0xff));\n// put_byte(s, (uch)((ush)(w) >> 8));\n s.pending_buf[s.pending++] = (w) & 0xff;\n s.pending_buf[s.pending++] = (w >>> 8) & 0xff;\n};\n\n\n/* ===========================================================================\n * Send a value on a given number of bits.\n * IN assertion: length <= 16 and value fits in length bits.\n */\nconst send_bits = (s, value, length) => {\n\n if (s.bi_valid > (Buf_size - length)) {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n put_short(s, s.bi_buf);\n s.bi_buf = value >> (Buf_size - s.bi_valid);\n s.bi_valid += length - Buf_size;\n } else {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n s.bi_valid += length;\n }\n};\n\n\nconst send_code = (s, c, tree) => {\n\n send_bits(s, tree[c * 2]/*.Code*/, tree[c * 2 + 1]/*.Len*/);\n};\n\n\n/* ===========================================================================\n * Reverse the first len bits of a code, using straightforward code (a faster\n * method would use a table)\n * IN assertion: 1 <= len <= 15\n */\nconst bi_reverse = (code, len) => {\n\n let res = 0;\n do {\n res |= code & 1;\n code >>>= 1;\n res <<= 1;\n } while (--len > 0);\n return res >>> 1;\n};\n\n\n/* ===========================================================================\n * Flush the bit buffer, keeping at most 7 bits in it.\n */\nconst bi_flush = (s) => {\n\n if (s.bi_valid === 16) {\n put_short(s, s.bi_buf);\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n } else if (s.bi_valid >= 8) {\n s.pending_buf[s.pending++] = s.bi_buf & 0xff;\n s.bi_buf >>= 8;\n s.bi_valid -= 8;\n }\n};\n\n\n/* ===========================================================================\n * Compute the optimal bit lengths for a tree and update the total bit length\n * for the current block.\n * IN assertion: the fields freq and dad are set, heap[heap_max] and\n * above are the tree nodes sorted by increasing frequency.\n * OUT assertions: the field len is set to the optimal bit length, the\n * array bl_count contains the frequencies for each bit length.\n * The length opt_len is updated; static_len is also updated if stree is\n * not null.\n */\nconst gen_bitlen = (s, desc) => {\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n\n const tree = desc.dyn_tree;\n const max_code = desc.max_code;\n const stree = desc.stat_desc.static_tree;\n const has_stree = desc.stat_desc.has_stree;\n const extra = desc.stat_desc.extra_bits;\n const base = desc.stat_desc.extra_base;\n const max_length = desc.stat_desc.max_length;\n let h; /* heap index */\n let n, m; /* iterate over the tree elements */\n let bits; /* bit length */\n let xbits; /* extra bits */\n let f; /* frequency */\n let overflow = 0; /* number of elements with bit length too large */\n\n for (bits = 0; bits <= MAX_BITS; bits++) {\n s.bl_count[bits] = 0;\n }\n\n /* In a first pass, compute the optimal bit lengths (which may\n * overflow in the case of the bit length tree).\n */\n tree[s.heap[s.heap_max] * 2 + 1]/*.Len*/ = 0; /* root of the heap */\n\n for (h = s.heap_max + 1; h < HEAP_SIZE; h++) {\n n = s.heap[h];\n bits = tree[tree[n * 2 + 1]/*.Dad*/ * 2 + 1]/*.Len*/ + 1;\n if (bits > max_length) {\n bits = max_length;\n overflow++;\n }\n tree[n * 2 + 1]/*.Len*/ = bits;\n /* We overwrite tree[n].Dad which is no longer needed */\n\n if (n > max_code) { continue; } /* not a leaf node */\n\n s.bl_count[bits]++;\n xbits = 0;\n if (n >= base) {\n xbits = extra[n - base];\n }\n f = tree[n * 2]/*.Freq*/;\n s.opt_len += f * (bits + xbits);\n if (has_stree) {\n s.static_len += f * (stree[n * 2 + 1]/*.Len*/ + xbits);\n }\n }\n if (overflow === 0) { return; }\n\n // Tracev((stderr,\"\\nbit length overflow\\n\"));\n /* This happens for example on obj2 and pic of the Calgary corpus */\n\n /* Find the first bit length which could increase: */\n do {\n bits = max_length - 1;\n while (s.bl_count[bits] === 0) { bits--; }\n s.bl_count[bits]--; /* move one leaf down the tree */\n s.bl_count[bits + 1] += 2; /* move one overflow item as its brother */\n s.bl_count[max_length]--;\n /* The brother of the overflow item also moves one step up,\n * but this does not affect bl_count[max_length]\n */\n overflow -= 2;\n } while (overflow > 0);\n\n /* Now recompute all bit lengths, scanning in increasing frequency.\n * h is still equal to HEAP_SIZE. (It is simpler to reconstruct all\n * lengths instead of fixing only the wrong ones. This idea is taken\n * from 'ar' written by Haruhiko Okumura.)\n */\n for (bits = max_length; bits !== 0; bits--) {\n n = s.bl_count[bits];\n while (n !== 0) {\n m = s.heap[--h];\n if (m > max_code) { continue; }\n if (tree[m * 2 + 1]/*.Len*/ !== bits) {\n // Tracev((stderr,\"code %d bits %d->%d\\n\", m, tree[m].Len, bits));\n s.opt_len += (bits - tree[m * 2 + 1]/*.Len*/) * tree[m * 2]/*.Freq*/;\n tree[m * 2 + 1]/*.Len*/ = bits;\n }\n n--;\n }\n }\n};\n\n\n/* ===========================================================================\n * Generate the codes for a given tree and bit counts (which need not be\n * optimal).\n * IN assertion: the array bl_count contains the bit length statistics for\n * the given tree and the field len is set for all tree elements.\n * OUT assertion: the field code is set for all tree elements of non\n * zero code length.\n */\nconst gen_codes = (tree, max_code, bl_count) => {\n// ct_data *tree; /* the tree to decorate */\n// int max_code; /* largest code with non zero frequency */\n// ushf *bl_count; /* number of codes at each bit length */\n\n const next_code = new Array(MAX_BITS + 1); /* next code value for each bit length */\n let code = 0; /* running code value */\n let bits; /* bit index */\n let n; /* code index */\n\n /* The distribution counts are first used to generate the code values\n * without bit reversal.\n */\n for (bits = 1; bits <= MAX_BITS; bits++) {\n code = (code + bl_count[bits - 1]) << 1;\n next_code[bits] = code;\n }\n /* Check that the bit counts in bl_count are consistent. The last code\n * must be all ones.\n */\n //Assert (code + bl_count[MAX_BITS]-1 == (1< {\n\n let n; /* iterates over tree elements */\n let bits; /* bit counter */\n let length; /* length value */\n let code; /* code value */\n let dist; /* distance index */\n const bl_count = new Array(MAX_BITS + 1);\n /* number of codes at each bit length for an optimal tree */\n\n // do check in _tr_init()\n //if (static_init_done) return;\n\n /* For some embedded targets, global variables are not initialized: */\n/*#ifdef NO_INIT_GLOBAL_POINTERS\n static_l_desc.static_tree = static_ltree;\n static_l_desc.extra_bits = extra_lbits;\n static_d_desc.static_tree = static_dtree;\n static_d_desc.extra_bits = extra_dbits;\n static_bl_desc.extra_bits = extra_blbits;\n#endif*/\n\n /* Initialize the mapping length (0..255) -> length code (0..28) */\n length = 0;\n for (code = 0; code < LENGTH_CODES - 1; code++) {\n base_length[code] = length;\n for (n = 0; n < (1 << extra_lbits[code]); n++) {\n _length_code[length++] = code;\n }\n }\n //Assert (length == 256, \"tr_static_init: length != 256\");\n /* Note that the length 255 (match length 258) can be represented\n * in two different ways: code 284 + 5 bits or code 285, so we\n * overwrite length_code[255] to use the best encoding:\n */\n _length_code[length - 1] = code;\n\n /* Initialize the mapping dist (0..32K) -> dist code (0..29) */\n dist = 0;\n for (code = 0; code < 16; code++) {\n base_dist[code] = dist;\n for (n = 0; n < (1 << extra_dbits[code]); n++) {\n _dist_code[dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: dist != 256\");\n dist >>= 7; /* from now on, all distances are divided by 128 */\n for (; code < D_CODES; code++) {\n base_dist[code] = dist << 7;\n for (n = 0; n < (1 << (extra_dbits[code] - 7)); n++) {\n _dist_code[256 + dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: 256+dist != 512\");\n\n /* Construct the codes of the static literal tree */\n for (bits = 0; bits <= MAX_BITS; bits++) {\n bl_count[bits] = 0;\n }\n\n n = 0;\n while (n <= 143) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n while (n <= 255) {\n static_ltree[n * 2 + 1]/*.Len*/ = 9;\n n++;\n bl_count[9]++;\n }\n while (n <= 279) {\n static_ltree[n * 2 + 1]/*.Len*/ = 7;\n n++;\n bl_count[7]++;\n }\n while (n <= 287) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n /* Codes 286 and 287 do not exist, but we must include them in the\n * tree construction to get a canonical Huffman tree (longest code\n * all ones)\n */\n gen_codes(static_ltree, L_CODES + 1, bl_count);\n\n /* The static distance tree is trivial: */\n for (n = 0; n < D_CODES; n++) {\n static_dtree[n * 2 + 1]/*.Len*/ = 5;\n static_dtree[n * 2]/*.Code*/ = bi_reverse(n, 5);\n }\n\n // Now data ready and we can init static trees\n static_l_desc = new StaticTreeDesc(static_ltree, extra_lbits, LITERALS + 1, L_CODES, MAX_BITS);\n static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0, D_CODES, MAX_BITS);\n static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0, BL_CODES, MAX_BL_BITS);\n\n //static_init_done = true;\n};\n\n\n/* ===========================================================================\n * Initialize a new block.\n */\nconst init_block = (s) => {\n\n let n; /* iterates over tree elements */\n\n /* Initialize the trees. */\n for (n = 0; n < L_CODES; n++) { s.dyn_ltree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < D_CODES; n++) { s.dyn_dtree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < BL_CODES; n++) { s.bl_tree[n * 2]/*.Freq*/ = 0; }\n\n s.dyn_ltree[END_BLOCK * 2]/*.Freq*/ = 1;\n s.opt_len = s.static_len = 0;\n s.sym_next = s.matches = 0;\n};\n\n\n/* ===========================================================================\n * Flush the bit buffer and align the output on a byte boundary\n */\nconst bi_windup = (s) =>\n{\n if (s.bi_valid > 8) {\n put_short(s, s.bi_buf);\n } else if (s.bi_valid > 0) {\n //put_byte(s, (Byte)s->bi_buf);\n s.pending_buf[s.pending++] = s.bi_buf;\n }\n s.bi_buf = 0;\n s.bi_valid = 0;\n};\n\n/* ===========================================================================\n * Compares to subtrees, using the tree depth as tie breaker when\n * the subtrees have equal frequency. This minimizes the worst case length.\n */\nconst smaller = (tree, n, m, depth) => {\n\n const _n2 = n * 2;\n const _m2 = m * 2;\n return (tree[_n2]/*.Freq*/ < tree[_m2]/*.Freq*/ ||\n (tree[_n2]/*.Freq*/ === tree[_m2]/*.Freq*/ && depth[n] <= depth[m]));\n};\n\n/* ===========================================================================\n * Restore the heap property by moving down the tree starting at node k,\n * exchanging a node with the smallest of its two sons if necessary, stopping\n * when the heap property is re-established (each father smaller than its\n * two sons).\n */\nconst pqdownheap = (s, tree, k) => {\n// deflate_state *s;\n// ct_data *tree; /* the tree to restore */\n// int k; /* node to move down */\n\n const v = s.heap[k];\n let j = k << 1; /* left son of k */\n while (j <= s.heap_len) {\n /* Set j to the smallest of the two sons: */\n if (j < s.heap_len &&\n smaller(tree, s.heap[j + 1], s.heap[j], s.depth)) {\n j++;\n }\n /* Exit if v is smaller than both sons */\n if (smaller(tree, v, s.heap[j], s.depth)) { break; }\n\n /* Exchange v with the smallest son */\n s.heap[k] = s.heap[j];\n k = j;\n\n /* And continue down the tree, setting j to the left son of k */\n j <<= 1;\n }\n s.heap[k] = v;\n};\n\n\n// inlined manually\n// const SMALLEST = 1;\n\n/* ===========================================================================\n * Send the block data compressed using the given Huffman trees\n */\nconst compress_block = (s, ltree, dtree) => {\n// deflate_state *s;\n// const ct_data *ltree; /* literal tree */\n// const ct_data *dtree; /* distance tree */\n\n let dist; /* distance of matched string */\n let lc; /* match length or unmatched char (if dist == 0) */\n let sx = 0; /* running index in sym_buf */\n let code; /* the code to send */\n let extra; /* number of extra bits to send */\n\n if (s.sym_next !== 0) {\n do {\n dist = s.pending_buf[s.sym_buf + sx++] & 0xff;\n dist += (s.pending_buf[s.sym_buf + sx++] & 0xff) << 8;\n lc = s.pending_buf[s.sym_buf + sx++];\n if (dist === 0) {\n send_code(s, lc, ltree); /* send a literal byte */\n //Tracecv(isgraph(lc), (stderr,\" '%c' \", lc));\n } else {\n /* Here, lc is the match length - MIN_MATCH */\n code = _length_code[lc];\n send_code(s, code + LITERALS + 1, ltree); /* send the length code */\n extra = extra_lbits[code];\n if (extra !== 0) {\n lc -= base_length[code];\n send_bits(s, lc, extra); /* send the extra length bits */\n }\n dist--; /* dist is now the match distance - 1 */\n code = d_code(dist);\n //Assert (code < D_CODES, \"bad d_code\");\n\n send_code(s, code, dtree); /* send the distance code */\n extra = extra_dbits[code];\n if (extra !== 0) {\n dist -= base_dist[code];\n send_bits(s, dist, extra); /* send the extra distance bits */\n }\n } /* literal or match pair ? */\n\n /* Check that the overlay between pending_buf and sym_buf is ok: */\n //Assert(s->pending < s->lit_bufsize + sx, \"pendingBuf overflow\");\n\n } while (sx < s.sym_next);\n }\n\n send_code(s, END_BLOCK, ltree);\n};\n\n\n/* ===========================================================================\n * Construct one Huffman tree and assigns the code bit strings and lengths.\n * Update the total bit length for the current block.\n * IN assertion: the field freq is set for all tree elements.\n * OUT assertions: the fields len and code are set to the optimal bit length\n * and corresponding code. The length opt_len is updated; static_len is\n * also updated if stree is not null. The field max_code is set.\n */\nconst build_tree = (s, desc) => {\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n\n const tree = desc.dyn_tree;\n const stree = desc.stat_desc.static_tree;\n const has_stree = desc.stat_desc.has_stree;\n const elems = desc.stat_desc.elems;\n let n, m; /* iterate over heap elements */\n let max_code = -1; /* largest code with non zero frequency */\n let node; /* new node being created */\n\n /* Construct the initial heap, with least frequent element in\n * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1].\n * heap[0] is not used.\n */\n s.heap_len = 0;\n s.heap_max = HEAP_SIZE;\n\n for (n = 0; n < elems; n++) {\n if (tree[n * 2]/*.Freq*/ !== 0) {\n s.heap[++s.heap_len] = max_code = n;\n s.depth[n] = 0;\n\n } else {\n tree[n * 2 + 1]/*.Len*/ = 0;\n }\n }\n\n /* The pkzip format requires that at least one distance code exists,\n * and that at least one bit should be sent even if there is only one\n * possible code. So to avoid special checks later on we force at least\n * two codes of non zero frequency.\n */\n while (s.heap_len < 2) {\n node = s.heap[++s.heap_len] = (max_code < 2 ? ++max_code : 0);\n tree[node * 2]/*.Freq*/ = 1;\n s.depth[node] = 0;\n s.opt_len--;\n\n if (has_stree) {\n s.static_len -= stree[node * 2 + 1]/*.Len*/;\n }\n /* node is 0 or 1 so it does not have extra bits */\n }\n desc.max_code = max_code;\n\n /* The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree,\n * establish sub-heaps of increasing lengths:\n */\n for (n = (s.heap_len >> 1/*int /2*/); n >= 1; n--) { pqdownheap(s, tree, n); }\n\n /* Construct the Huffman tree by repeatedly combining the least two\n * frequent nodes.\n */\n node = elems; /* next internal node of the tree */\n do {\n //pqremove(s, tree, n); /* n = node of least frequency */\n /*** pqremove ***/\n n = s.heap[1/*SMALLEST*/];\n s.heap[1/*SMALLEST*/] = s.heap[s.heap_len--];\n pqdownheap(s, tree, 1/*SMALLEST*/);\n /***/\n\n m = s.heap[1/*SMALLEST*/]; /* m = node of next least frequency */\n\n s.heap[--s.heap_max] = n; /* keep the nodes sorted by frequency */\n s.heap[--s.heap_max] = m;\n\n /* Create a new node father of n and m */\n tree[node * 2]/*.Freq*/ = tree[n * 2]/*.Freq*/ + tree[m * 2]/*.Freq*/;\n s.depth[node] = (s.depth[n] >= s.depth[m] ? s.depth[n] : s.depth[m]) + 1;\n tree[n * 2 + 1]/*.Dad*/ = tree[m * 2 + 1]/*.Dad*/ = node;\n\n /* and insert the new node in the heap */\n s.heap[1/*SMALLEST*/] = node++;\n pqdownheap(s, tree, 1/*SMALLEST*/);\n\n } while (s.heap_len >= 2);\n\n s.heap[--s.heap_max] = s.heap[1/*SMALLEST*/];\n\n /* At this point, the fields freq and dad are set. We can now\n * generate the bit lengths.\n */\n gen_bitlen(s, desc);\n\n /* The field len is now set, we can generate the bit codes */\n gen_codes(tree, max_code, s.bl_count);\n};\n\n\n/* ===========================================================================\n * Scan a literal or distance tree to determine the frequencies of the codes\n * in the bit length tree.\n */\nconst scan_tree = (s, tree, max_code) => {\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n\n let n; /* iterates over all tree elements */\n let prevlen = -1; /* last emitted length */\n let curlen; /* length of current code */\n\n let nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n let count = 0; /* repeat count of the current code */\n let max_count = 7; /* max repeat count */\n let min_count = 4; /* min repeat count */\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n tree[(max_code + 1) * 2 + 1]/*.Len*/ = 0xffff; /* guard */\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n s.bl_tree[curlen * 2]/*.Freq*/ += count;\n\n } else if (curlen !== 0) {\n\n if (curlen !== prevlen) { s.bl_tree[curlen * 2]/*.Freq*/++; }\n s.bl_tree[REP_3_6 * 2]/*.Freq*/++;\n\n } else if (count <= 10) {\n s.bl_tree[REPZ_3_10 * 2]/*.Freq*/++;\n\n } else {\n s.bl_tree[REPZ_11_138 * 2]/*.Freq*/++;\n }\n\n count = 0;\n prevlen = curlen;\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n};\n\n\n/* ===========================================================================\n * Send a literal or distance tree in compressed form, using the codes in\n * bl_tree.\n */\nconst send_tree = (s, tree, max_code) => {\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n\n let n; /* iterates over all tree elements */\n let prevlen = -1; /* last emitted length */\n let curlen; /* length of current code */\n\n let nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n let count = 0; /* repeat count of the current code */\n let max_count = 7; /* max repeat count */\n let min_count = 4; /* min repeat count */\n\n /* tree[max_code+1].Len = -1; */ /* guard already set */\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n do { send_code(s, curlen, s.bl_tree); } while (--count !== 0);\n\n } else if (curlen !== 0) {\n if (curlen !== prevlen) {\n send_code(s, curlen, s.bl_tree);\n count--;\n }\n //Assert(count >= 3 && count <= 6, \" 3_6?\");\n send_code(s, REP_3_6, s.bl_tree);\n send_bits(s, count - 3, 2);\n\n } else if (count <= 10) {\n send_code(s, REPZ_3_10, s.bl_tree);\n send_bits(s, count - 3, 3);\n\n } else {\n send_code(s, REPZ_11_138, s.bl_tree);\n send_bits(s, count - 11, 7);\n }\n\n count = 0;\n prevlen = curlen;\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n};\n\n\n/* ===========================================================================\n * Construct the Huffman tree for the bit lengths and return the index in\n * bl_order of the last bit length code to send.\n */\nconst build_bl_tree = (s) => {\n\n let max_blindex; /* index of last bit length code of non zero freq */\n\n /* Determine the bit length frequencies for literal and distance trees */\n scan_tree(s, s.dyn_ltree, s.l_desc.max_code);\n scan_tree(s, s.dyn_dtree, s.d_desc.max_code);\n\n /* Build the bit length tree: */\n build_tree(s, s.bl_desc);\n /* opt_len now includes the length of the tree representations, except\n * the lengths of the bit lengths codes and the 5+5+4 bits for the counts.\n */\n\n /* Determine the number of bit length codes to send. The pkzip format\n * requires that at least 4 bit length codes be sent. (appnote.txt says\n * 3 but the actual value used is 4.)\n */\n for (max_blindex = BL_CODES - 1; max_blindex >= 3; max_blindex--) {\n if (s.bl_tree[bl_order[max_blindex] * 2 + 1]/*.Len*/ !== 0) {\n break;\n }\n }\n /* Update opt_len to include the bit length tree and counts */\n s.opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4;\n //Tracev((stderr, \"\\ndyn trees: dyn %ld, stat %ld\",\n // s->opt_len, s->static_len));\n\n return max_blindex;\n};\n\n\n/* ===========================================================================\n * Send the header for a block using dynamic Huffman trees: the counts, the\n * lengths of the bit length codes, the literal tree and the distance tree.\n * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4.\n */\nconst send_all_trees = (s, lcodes, dcodes, blcodes) => {\n// deflate_state *s;\n// int lcodes, dcodes, blcodes; /* number of codes for each tree */\n\n let rank; /* index in bl_order */\n\n //Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, \"not enough codes\");\n //Assert (lcodes <= L_CODES && dcodes <= D_CODES && blcodes <= BL_CODES,\n // \"too many codes\");\n //Tracev((stderr, \"\\nbl counts: \"));\n send_bits(s, lcodes - 257, 5); /* not +255 as stated in appnote.txt */\n send_bits(s, dcodes - 1, 5);\n send_bits(s, blcodes - 4, 4); /* not -3 as stated in appnote.txt */\n for (rank = 0; rank < blcodes; rank++) {\n //Tracev((stderr, \"\\nbl code %2d \", bl_order[rank]));\n send_bits(s, s.bl_tree[bl_order[rank] * 2 + 1]/*.Len*/, 3);\n }\n //Tracev((stderr, \"\\nbl tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_ltree, lcodes - 1); /* literal tree */\n //Tracev((stderr, \"\\nlit tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_dtree, dcodes - 1); /* distance tree */\n //Tracev((stderr, \"\\ndist tree: sent %ld\", s->bits_sent));\n};\n\n\n/* ===========================================================================\n * Check if the data type is TEXT or BINARY, using the following algorithm:\n * - TEXT if the two conditions below are satisfied:\n * a) There are no non-portable control characters belonging to the\n * \"block list\" (0..6, 14..25, 28..31).\n * b) There is at least one printable character belonging to the\n * \"allow list\" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255).\n * - BINARY otherwise.\n * - The following partially-portable control characters form a\n * \"gray list\" that is ignored in this detection algorithm:\n * (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}).\n * IN assertion: the fields Freq of dyn_ltree are set.\n */\nconst detect_data_type = (s) => {\n /* block_mask is the bit mask of block-listed bytes\n * set bits 0..6, 14..25, and 28..31\n * 0xf3ffc07f = binary 11110011111111111100000001111111\n */\n let block_mask = 0xf3ffc07f;\n let n;\n\n /* Check for non-textual (\"block-listed\") bytes. */\n for (n = 0; n <= 31; n++, block_mask >>>= 1) {\n if ((block_mask & 1) && (s.dyn_ltree[n * 2]/*.Freq*/ !== 0)) {\n return Z_BINARY;\n }\n }\n\n /* Check for textual (\"allow-listed\") bytes. */\n if (s.dyn_ltree[9 * 2]/*.Freq*/ !== 0 || s.dyn_ltree[10 * 2]/*.Freq*/ !== 0 ||\n s.dyn_ltree[13 * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n for (n = 32; n < LITERALS; n++) {\n if (s.dyn_ltree[n * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n }\n\n /* There are no \"block-listed\" or \"allow-listed\" bytes:\n * this stream either is empty or has tolerated (\"gray-listed\") bytes only.\n */\n return Z_BINARY;\n};\n\n\nlet static_init_done = false;\n\n/* ===========================================================================\n * Initialize the tree data structures for a new zlib stream.\n */\nconst _tr_init = (s) =>\n{\n\n if (!static_init_done) {\n tr_static_init();\n static_init_done = true;\n }\n\n s.l_desc = new TreeDesc(s.dyn_ltree, static_l_desc);\n s.d_desc = new TreeDesc(s.dyn_dtree, static_d_desc);\n s.bl_desc = new TreeDesc(s.bl_tree, static_bl_desc);\n\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n /* Initialize the first block of the first file: */\n init_block(s);\n};\n\n\n/* ===========================================================================\n * Send a stored block\n */\nconst _tr_stored_block = (s, buf, stored_len, last) => {\n//DeflateState *s;\n//charf *buf; /* input block */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n\n send_bits(s, (STORED_BLOCK << 1) + (last ? 1 : 0), 3); /* send block type */\n bi_windup(s); /* align on byte boundary */\n put_short(s, stored_len);\n put_short(s, ~stored_len);\n if (stored_len) {\n s.pending_buf.set(s.window.subarray(buf, buf + stored_len), s.pending);\n }\n s.pending += stored_len;\n};\n\n\n/* ===========================================================================\n * Send one empty static block to give enough lookahead for inflate.\n * This takes 10 bits, of which 7 may remain in the bit buffer.\n */\nconst _tr_align = (s) => {\n send_bits(s, STATIC_TREES << 1, 3);\n send_code(s, END_BLOCK, static_ltree);\n bi_flush(s);\n};\n\n\n/* ===========================================================================\n * Determine the best encoding for the current block: dynamic trees, static\n * trees or store, and write out the encoded block.\n */\nconst _tr_flush_block = (s, buf, stored_len, last) => {\n//DeflateState *s;\n//charf *buf; /* input block, or NULL if too old */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n\n let opt_lenb, static_lenb; /* opt_len and static_len in bytes */\n let max_blindex = 0; /* index of last bit length code of non zero freq */\n\n /* Build the Huffman trees unless a stored block is forced */\n if (s.level > 0) {\n\n /* Check if the file is binary or text */\n if (s.strm.data_type === Z_UNKNOWN) {\n s.strm.data_type = detect_data_type(s);\n }\n\n /* Construct the literal and distance trees */\n build_tree(s, s.l_desc);\n // Tracev((stderr, \"\\nlit data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n\n build_tree(s, s.d_desc);\n // Tracev((stderr, \"\\ndist data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n /* At this point, opt_len and static_len are the total bit lengths of\n * the compressed block data, excluding the tree representations.\n */\n\n /* Build the bit length tree for the above two trees, and get the index\n * in bl_order of the last bit length code to send.\n */\n max_blindex = build_bl_tree(s);\n\n /* Determine the best encoding. Compute the block lengths in bytes. */\n opt_lenb = (s.opt_len + 3 + 7) >>> 3;\n static_lenb = (s.static_len + 3 + 7) >>> 3;\n\n // Tracev((stderr, \"\\nopt %lu(%lu) stat %lu(%lu) stored %lu lit %u \",\n // opt_lenb, s->opt_len, static_lenb, s->static_len, stored_len,\n // s->sym_next / 3));\n\n if (static_lenb <= opt_lenb) { opt_lenb = static_lenb; }\n\n } else {\n // Assert(buf != (char*)0, \"lost buf\");\n opt_lenb = static_lenb = stored_len + 5; /* force a stored block */\n }\n\n if ((stored_len + 4 <= opt_lenb) && (buf !== -1)) {\n /* 4: two words for the lengths */\n\n /* The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE.\n * Otherwise we can't have processed more than WSIZE input bytes since\n * the last block flush, because compression would have been\n * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to\n * transform a block into a stored block.\n */\n _tr_stored_block(s, buf, stored_len, last);\n\n } else if (s.strategy === Z_FIXED || static_lenb === opt_lenb) {\n\n send_bits(s, (STATIC_TREES << 1) + (last ? 1 : 0), 3);\n compress_block(s, static_ltree, static_dtree);\n\n } else {\n send_bits(s, (DYN_TREES << 1) + (last ? 1 : 0), 3);\n send_all_trees(s, s.l_desc.max_code + 1, s.d_desc.max_code + 1, max_blindex + 1);\n compress_block(s, s.dyn_ltree, s.dyn_dtree);\n }\n // Assert (s->compressed_len == s->bits_sent, \"bad compressed size\");\n /* The above check is made mod 2^32, for files larger than 512 MB\n * and uLong implemented on 32 bits.\n */\n init_block(s);\n\n if (last) {\n bi_windup(s);\n }\n // Tracev((stderr,\"\\ncomprlen %lu(%lu) \", s->compressed_len>>3,\n // s->compressed_len-7*last));\n};\n\n/* ===========================================================================\n * Save the match info and tally the frequency counts. Return true if\n * the current block must be flushed.\n */\nconst _tr_tally = (s, dist, lc) => {\n// deflate_state *s;\n// unsigned dist; /* distance of matched string */\n// unsigned lc; /* match length-MIN_MATCH or unmatched char (if dist==0) */\n\n s.pending_buf[s.sym_buf + s.sym_next++] = dist;\n s.pending_buf[s.sym_buf + s.sym_next++] = dist >> 8;\n s.pending_buf[s.sym_buf + s.sym_next++] = lc;\n if (dist === 0) {\n /* lc is the unmatched char */\n s.dyn_ltree[lc * 2]/*.Freq*/++;\n } else {\n s.matches++;\n /* Here, lc is the match length - MIN_MATCH */\n dist--; /* dist = match distance - 1 */\n //Assert((ush)dist < (ush)MAX_DIST(s) &&\n // (ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) &&\n // (ush)d_code(dist) < (ush)D_CODES, \"_tr_tally: bad match\");\n\n s.dyn_ltree[(_length_code[lc] + LITERALS + 1) * 2]/*.Freq*/++;\n s.dyn_dtree[d_code(dist) * 2]/*.Freq*/++;\n }\n\n return (s.sym_next === s.sym_end);\n};\n\nmodule.exports._tr_init = _tr_init;\nmodule.exports._tr_stored_block = _tr_stored_block;\nmodule.exports._tr_flush_block = _tr_flush_block;\nmodule.exports._tr_tally = _tr_tally;\nmodule.exports._tr_align = _tr_align;\n","'use strict';\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction ZStream() {\n /* next input byte */\n this.input = null; // JS specific, because we have no pointers\n this.next_in = 0;\n /* number of bytes available at input */\n this.avail_in = 0;\n /* total number of input bytes read so far */\n this.total_in = 0;\n /* next output byte should be put there */\n this.output = null; // JS specific, because we have no pointers\n this.next_out = 0;\n /* remaining free space at output */\n this.avail_out = 0;\n /* total number of bytes output so far */\n this.total_out = 0;\n /* last error message, NULL if no error */\n this.msg = ''/*Z_NULL*/;\n /* not visible by applications */\n this.state = null;\n /* best guess about the data type: binary or text */\n this.data_type = 2/*Z_UNKNOWN*/;\n /* adler32 value of the uncompressed data */\n this.adler = 0;\n}\n\nmodule.exports = ZStream;\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","// Unique ID creation requires a high quality random # generator. In the browser we therefore\n// require the crypto API and do not support built-in fallback to lower quality random number\n// generators (like Math.random()).\nvar getRandomValues;\nvar rnds8 = new Uint8Array(16);\nexport default function rng() {\n // lazy load so that environments that need to polyfill have a chance to do so\n if (!getRandomValues) {\n // getRandomValues needs to be invoked in a context where \"this\" is a Crypto implementation. Also,\n // find the complete implementation of crypto (msCrypto) on IE11.\n getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto) || typeof msCrypto !== 'undefined' && typeof msCrypto.getRandomValues === 'function' && msCrypto.getRandomValues.bind(msCrypto);\n\n if (!getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n }\n\n return getRandomValues(rnds8);\n}","export default /^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i;","import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nvar byteToHex = [];\n\nfor (var i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).substr(1));\n}\n\nfunction stringify(arr) {\n var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n // Note: Be careful editing this code! It's been tuned for performance\n // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n var uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID. If this throws, it's likely due to one\n // of the following:\n // - One or more input array values don't map to a hex octet (leading to\n // \"undefined\" in the uuid)\n // - Invalid input values for the RFC `version` or `variant` fields\n\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n\n return uuid;\n}\n\nexport default stringify;","import REGEX from './regex.js';\n\nfunction validate(uuid) {\n return typeof uuid === 'string' && REGEX.test(uuid);\n}\n\nexport default validate;","import rng from './rng.js';\nimport stringify from './stringify.js'; // **`v1()` - Generate time-based UUID**\n//\n// Inspired by https://github.com/LiosK/UUID.js\n// and http://docs.python.org/library/uuid.html\n\nvar _nodeId;\n\nvar _clockseq; // Previous uuid creation time\n\n\nvar _lastMSecs = 0;\nvar _lastNSecs = 0; // See https://github.com/uuidjs/uuid for API details\n\nfunction v1(options, buf, offset) {\n var i = buf && offset || 0;\n var b = buf || new Array(16);\n options = options || {};\n var node = options.node || _nodeId;\n var clockseq = options.clockseq !== undefined ? options.clockseq : _clockseq; // node and clockseq need to be initialized to random values if they're not\n // specified. We do this lazily to minimize issues related to insufficient\n // system entropy. See #189\n\n if (node == null || clockseq == null) {\n var seedBytes = options.random || (options.rng || rng)();\n\n if (node == null) {\n // Per 4.5, create and 48-bit node id, (47 random bits + multicast bit = 1)\n node = _nodeId = [seedBytes[0] | 0x01, seedBytes[1], seedBytes[2], seedBytes[3], seedBytes[4], seedBytes[5]];\n }\n\n if (clockseq == null) {\n // Per 4.2.2, randomize (14 bit) clockseq\n clockseq = _clockseq = (seedBytes[6] << 8 | seedBytes[7]) & 0x3fff;\n }\n } // UUID timestamps are 100 nano-second units since the Gregorian epoch,\n // (1582-10-15 00:00). JSNumbers aren't precise enough for this, so\n // time is handled internally as 'msecs' (integer milliseconds) and 'nsecs'\n // (100-nanoseconds offset from msecs) since unix epoch, 1970-01-01 00:00.\n\n\n var msecs = options.msecs !== undefined ? options.msecs : Date.now(); // Per 4.2.1.2, use count of uuid's generated during the current clock\n // cycle to simulate higher resolution clock\n\n var nsecs = options.nsecs !== undefined ? options.nsecs : _lastNSecs + 1; // Time since last uuid creation (in msecs)\n\n var dt = msecs - _lastMSecs + (nsecs - _lastNSecs) / 10000; // Per 4.2.1.2, Bump clockseq on clock regression\n\n if (dt < 0 && options.clockseq === undefined) {\n clockseq = clockseq + 1 & 0x3fff;\n } // Reset nsecs if clock regresses (new clockseq) or we've moved onto a new\n // time interval\n\n\n if ((dt < 0 || msecs > _lastMSecs) && options.nsecs === undefined) {\n nsecs = 0;\n } // Per 4.2.1.2 Throw error if too many uuids are requested\n\n\n if (nsecs >= 10000) {\n throw new Error(\"uuid.v1(): Can't create more than 10M uuids/sec\");\n }\n\n _lastMSecs = msecs;\n _lastNSecs = nsecs;\n _clockseq = clockseq; // Per 4.1.4 - Convert from unix epoch to Gregorian epoch\n\n msecs += 12219292800000; // `time_low`\n\n var tl = ((msecs & 0xfffffff) * 10000 + nsecs) % 0x100000000;\n b[i++] = tl >>> 24 & 0xff;\n b[i++] = tl >>> 16 & 0xff;\n b[i++] = tl >>> 8 & 0xff;\n b[i++] = tl & 0xff; // `time_mid`\n\n var tmh = msecs / 0x100000000 * 10000 & 0xfffffff;\n b[i++] = tmh >>> 8 & 0xff;\n b[i++] = tmh & 0xff; // `time_high_and_version`\n\n b[i++] = tmh >>> 24 & 0xf | 0x10; // include version\n\n b[i++] = tmh >>> 16 & 0xff; // `clock_seq_hi_and_reserved` (Per 4.2.2 - include variant)\n\n b[i++] = clockseq >>> 8 | 0x80; // `clock_seq_low`\n\n b[i++] = clockseq & 0xff; // `node`\n\n for (var n = 0; n < 6; ++n) {\n b[i + n] = node[n];\n }\n\n return buf || stringify(b);\n}\n\nexport default v1;","import validate from './validate.js';\n\nfunction parse(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n var v;\n var arr = new Uint8Array(16); // Parse ########-....-....-....-............\n\n arr[0] = (v = parseInt(uuid.slice(0, 8), 16)) >>> 24;\n arr[1] = v >>> 16 & 0xff;\n arr[2] = v >>> 8 & 0xff;\n arr[3] = v & 0xff; // Parse ........-####-....-....-............\n\n arr[4] = (v = parseInt(uuid.slice(9, 13), 16)) >>> 8;\n arr[5] = v & 0xff; // Parse ........-....-####-....-............\n\n arr[6] = (v = parseInt(uuid.slice(14, 18), 16)) >>> 8;\n arr[7] = v & 0xff; // Parse ........-....-....-####-............\n\n arr[8] = (v = parseInt(uuid.slice(19, 23), 16)) >>> 8;\n arr[9] = v & 0xff; // Parse ........-....-....-....-############\n // (Use \"/\" to avoid 32-bit truncation when bit-shifting high-order bytes)\n\n arr[10] = (v = parseInt(uuid.slice(24, 36), 16)) / 0x10000000000 & 0xff;\n arr[11] = v / 0x100000000 & 0xff;\n arr[12] = v >>> 24 & 0xff;\n arr[13] = v >>> 16 & 0xff;\n arr[14] = v >>> 8 & 0xff;\n arr[15] = v & 0xff;\n return arr;\n}\n\nexport default parse;","import stringify from './stringify.js';\nimport parse from './parse.js';\n\nfunction stringToBytes(str) {\n str = unescape(encodeURIComponent(str)); // UTF8 escape\n\n var bytes = [];\n\n for (var i = 0; i < str.length; ++i) {\n bytes.push(str.charCodeAt(i));\n }\n\n return bytes;\n}\n\nexport var DNS = '6ba7b810-9dad-11d1-80b4-00c04fd430c8';\nexport var URL = '6ba7b811-9dad-11d1-80b4-00c04fd430c8';\nexport default function (name, version, hashfunc) {\n function generateUUID(value, namespace, buf, offset) {\n if (typeof value === 'string') {\n value = stringToBytes(value);\n }\n\n if (typeof namespace === 'string') {\n namespace = parse(namespace);\n }\n\n if (namespace.length !== 16) {\n throw TypeError('Namespace must be array-like (16 iterable integer values, 0-255)');\n } // Compute hash of namespace and value, Per 4.3\n // Future: Use spread syntax when supported on all platforms, e.g. `bytes =\n // hashfunc([...namespace, ... value])`\n\n\n var bytes = new Uint8Array(16 + value.length);\n bytes.set(namespace);\n bytes.set(value, namespace.length);\n bytes = hashfunc(bytes);\n bytes[6] = bytes[6] & 0x0f | version;\n bytes[8] = bytes[8] & 0x3f | 0x80;\n\n if (buf) {\n offset = offset || 0;\n\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = bytes[i];\n }\n\n return buf;\n }\n\n return stringify(bytes);\n } // Function#name is not settable on some platforms (#270)\n\n\n try {\n generateUUID.name = name; // eslint-disable-next-line no-empty\n } catch (err) {} // For CommonJS default export support\n\n\n generateUUID.DNS = DNS;\n generateUUID.URL = URL;\n return generateUUID;\n}","/*\n * Browser-compatible JavaScript MD5\n *\n * Modification of JavaScript MD5\n * https://github.com/blueimp/JavaScript-MD5\n *\n * Copyright 2011, Sebastian Tschan\n * https://blueimp.net\n *\n * Licensed under the MIT license:\n * https://opensource.org/licenses/MIT\n *\n * Based on\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\n * Digest Algorithm, as defined in RFC 1321.\n * Version 2.2 Copyright (C) Paul Johnston 1999 - 2009\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for more info.\n */\nfunction md5(bytes) {\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = new Uint8Array(msg.length);\n\n for (var i = 0; i < msg.length; ++i) {\n bytes[i] = msg.charCodeAt(i);\n }\n }\n\n return md5ToHexEncodedArray(wordsToMd5(bytesToWords(bytes), bytes.length * 8));\n}\n/*\n * Convert an array of little-endian words to an array of bytes\n */\n\n\nfunction md5ToHexEncodedArray(input) {\n var output = [];\n var length32 = input.length * 32;\n var hexTab = '0123456789abcdef';\n\n for (var i = 0; i < length32; i += 8) {\n var x = input[i >> 5] >>> i % 32 & 0xff;\n var hex = parseInt(hexTab.charAt(x >>> 4 & 0x0f) + hexTab.charAt(x & 0x0f), 16);\n output.push(hex);\n }\n\n return output;\n}\n/**\n * Calculate output length with padding and bit length\n */\n\n\nfunction getOutputLength(inputLength8) {\n return (inputLength8 + 64 >>> 9 << 4) + 14 + 1;\n}\n/*\n * Calculate the MD5 of an array of little-endian words, and a bit length.\n */\n\n\nfunction wordsToMd5(x, len) {\n /* append padding */\n x[len >> 5] |= 0x80 << len % 32;\n x[getOutputLength(len) - 1] = len;\n var a = 1732584193;\n var b = -271733879;\n var c = -1732584194;\n var d = 271733878;\n\n for (var i = 0; i < x.length; i += 16) {\n var olda = a;\n var oldb = b;\n var oldc = c;\n var oldd = d;\n a = md5ff(a, b, c, d, x[i], 7, -680876936);\n d = md5ff(d, a, b, c, x[i + 1], 12, -389564586);\n c = md5ff(c, d, a, b, x[i + 2], 17, 606105819);\n b = md5ff(b, c, d, a, x[i + 3], 22, -1044525330);\n a = md5ff(a, b, c, d, x[i + 4], 7, -176418897);\n d = md5ff(d, a, b, c, x[i + 5], 12, 1200080426);\n c = md5ff(c, d, a, b, x[i + 6], 17, -1473231341);\n b = md5ff(b, c, d, a, x[i + 7], 22, -45705983);\n a = md5ff(a, b, c, d, x[i + 8], 7, 1770035416);\n d = md5ff(d, a, b, c, x[i + 9], 12, -1958414417);\n c = md5ff(c, d, a, b, x[i + 10], 17, -42063);\n b = md5ff(b, c, d, a, x[i + 11], 22, -1990404162);\n a = md5ff(a, b, c, d, x[i + 12], 7, 1804603682);\n d = md5ff(d, a, b, c, x[i + 13], 12, -40341101);\n c = md5ff(c, d, a, b, x[i + 14], 17, -1502002290);\n b = md5ff(b, c, d, a, x[i + 15], 22, 1236535329);\n a = md5gg(a, b, c, d, x[i + 1], 5, -165796510);\n d = md5gg(d, a, b, c, x[i + 6], 9, -1069501632);\n c = md5gg(c, d, a, b, x[i + 11], 14, 643717713);\n b = md5gg(b, c, d, a, x[i], 20, -373897302);\n a = md5gg(a, b, c, d, x[i + 5], 5, -701558691);\n d = md5gg(d, a, b, c, x[i + 10], 9, 38016083);\n c = md5gg(c, d, a, b, x[i + 15], 14, -660478335);\n b = md5gg(b, c, d, a, x[i + 4], 20, -405537848);\n a = md5gg(a, b, c, d, x[i + 9], 5, 568446438);\n d = md5gg(d, a, b, c, x[i + 14], 9, -1019803690);\n c = md5gg(c, d, a, b, x[i + 3], 14, -187363961);\n b = md5gg(b, c, d, a, x[i + 8], 20, 1163531501);\n a = md5gg(a, b, c, d, x[i + 13], 5, -1444681467);\n d = md5gg(d, a, b, c, x[i + 2], 9, -51403784);\n c = md5gg(c, d, a, b, x[i + 7], 14, 1735328473);\n b = md5gg(b, c, d, a, x[i + 12], 20, -1926607734);\n a = md5hh(a, b, c, d, x[i + 5], 4, -378558);\n d = md5hh(d, a, b, c, x[i + 8], 11, -2022574463);\n c = md5hh(c, d, a, b, x[i + 11], 16, 1839030562);\n b = md5hh(b, c, d, a, x[i + 14], 23, -35309556);\n a = md5hh(a, b, c, d, x[i + 1], 4, -1530992060);\n d = md5hh(d, a, b, c, x[i + 4], 11, 1272893353);\n c = md5hh(c, d, a, b, x[i + 7], 16, -155497632);\n b = md5hh(b, c, d, a, x[i + 10], 23, -1094730640);\n a = md5hh(a, b, c, d, x[i + 13], 4, 681279174);\n d = md5hh(d, a, b, c, x[i], 11, -358537222);\n c = md5hh(c, d, a, b, x[i + 3], 16, -722521979);\n b = md5hh(b, c, d, a, x[i + 6], 23, 76029189);\n a = md5hh(a, b, c, d, x[i + 9], 4, -640364487);\n d = md5hh(d, a, b, c, x[i + 12], 11, -421815835);\n c = md5hh(c, d, a, b, x[i + 15], 16, 530742520);\n b = md5hh(b, c, d, a, x[i + 2], 23, -995338651);\n a = md5ii(a, b, c, d, x[i], 6, -198630844);\n d = md5ii(d, a, b, c, x[i + 7], 10, 1126891415);\n c = md5ii(c, d, a, b, x[i + 14], 15, -1416354905);\n b = md5ii(b, c, d, a, x[i + 5], 21, -57434055);\n a = md5ii(a, b, c, d, x[i + 12], 6, 1700485571);\n d = md5ii(d, a, b, c, x[i + 3], 10, -1894986606);\n c = md5ii(c, d, a, b, x[i + 10], 15, -1051523);\n b = md5ii(b, c, d, a, x[i + 1], 21, -2054922799);\n a = md5ii(a, b, c, d, x[i + 8], 6, 1873313359);\n d = md5ii(d, a, b, c, x[i + 15], 10, -30611744);\n c = md5ii(c, d, a, b, x[i + 6], 15, -1560198380);\n b = md5ii(b, c, d, a, x[i + 13], 21, 1309151649);\n a = md5ii(a, b, c, d, x[i + 4], 6, -145523070);\n d = md5ii(d, a, b, c, x[i + 11], 10, -1120210379);\n c = md5ii(c, d, a, b, x[i + 2], 15, 718787259);\n b = md5ii(b, c, d, a, x[i + 9], 21, -343485551);\n a = safeAdd(a, olda);\n b = safeAdd(b, oldb);\n c = safeAdd(c, oldc);\n d = safeAdd(d, oldd);\n }\n\n return [a, b, c, d];\n}\n/*\n * Convert an array bytes to an array of little-endian words\n * Characters >255 have their high-byte silently ignored.\n */\n\n\nfunction bytesToWords(input) {\n if (input.length === 0) {\n return [];\n }\n\n var length8 = input.length * 8;\n var output = new Uint32Array(getOutputLength(length8));\n\n for (var i = 0; i < length8; i += 8) {\n output[i >> 5] |= (input[i / 8] & 0xff) << i % 32;\n }\n\n return output;\n}\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\n\n\nfunction safeAdd(x, y) {\n var lsw = (x & 0xffff) + (y & 0xffff);\n var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n return msw << 16 | lsw & 0xffff;\n}\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\n\n\nfunction bitRotateLeft(num, cnt) {\n return num << cnt | num >>> 32 - cnt;\n}\n/*\n * These functions implement the four basic operations the algorithm uses.\n */\n\n\nfunction md5cmn(q, a, b, x, s, t) {\n return safeAdd(bitRotateLeft(safeAdd(safeAdd(a, q), safeAdd(x, t)), s), b);\n}\n\nfunction md5ff(a, b, c, d, x, s, t) {\n return md5cmn(b & c | ~b & d, a, b, x, s, t);\n}\n\nfunction md5gg(a, b, c, d, x, s, t) {\n return md5cmn(b & d | c & ~d, a, b, x, s, t);\n}\n\nfunction md5hh(a, b, c, d, x, s, t) {\n return md5cmn(b ^ c ^ d, a, b, x, s, t);\n}\n\nfunction md5ii(a, b, c, d, x, s, t) {\n return md5cmn(c ^ (b | ~d), a, b, x, s, t);\n}\n\nexport default md5;","import v35 from './v35.js';\nimport md5 from './md5.js';\nvar v3 = v35('v3', 0x30, md5);\nexport default v3;","import rng from './rng.js';\nimport stringify from './stringify.js';\n\nfunction v4(options, buf, offset) {\n options = options || {};\n var rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n rnds[6] = rnds[6] & 0x0f | 0x40;\n rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n if (buf) {\n offset = offset || 0;\n\n for (var i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n\n return buf;\n }\n\n return stringify(rnds);\n}\n\nexport default v4;","// Adapted from Chris Veness' SHA1 code at\n// http://www.movable-type.co.uk/scripts/sha1.html\nfunction f(s, x, y, z) {\n switch (s) {\n case 0:\n return x & y ^ ~x & z;\n\n case 1:\n return x ^ y ^ z;\n\n case 2:\n return x & y ^ x & z ^ y & z;\n\n case 3:\n return x ^ y ^ z;\n }\n}\n\nfunction ROTL(x, n) {\n return x << n | x >>> 32 - n;\n}\n\nfunction sha1(bytes) {\n var K = [0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xca62c1d6];\n var H = [0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0];\n\n if (typeof bytes === 'string') {\n var msg = unescape(encodeURIComponent(bytes)); // UTF8 escape\n\n bytes = [];\n\n for (var i = 0; i < msg.length; ++i) {\n bytes.push(msg.charCodeAt(i));\n }\n } else if (!Array.isArray(bytes)) {\n // Convert Array-like to Array\n bytes = Array.prototype.slice.call(bytes);\n }\n\n bytes.push(0x80);\n var l = bytes.length / 4 + 2;\n var N = Math.ceil(l / 16);\n var M = new Array(N);\n\n for (var _i = 0; _i < N; ++_i) {\n var arr = new Uint32Array(16);\n\n for (var j = 0; j < 16; ++j) {\n arr[j] = bytes[_i * 64 + j * 4] << 24 | bytes[_i * 64 + j * 4 + 1] << 16 | bytes[_i * 64 + j * 4 + 2] << 8 | bytes[_i * 64 + j * 4 + 3];\n }\n\n M[_i] = arr;\n }\n\n M[N - 1][14] = (bytes.length - 1) * 8 / Math.pow(2, 32);\n M[N - 1][14] = Math.floor(M[N - 1][14]);\n M[N - 1][15] = (bytes.length - 1) * 8 & 0xffffffff;\n\n for (var _i2 = 0; _i2 < N; ++_i2) {\n var W = new Uint32Array(80);\n\n for (var t = 0; t < 16; ++t) {\n W[t] = M[_i2][t];\n }\n\n for (var _t = 16; _t < 80; ++_t) {\n W[_t] = ROTL(W[_t - 3] ^ W[_t - 8] ^ W[_t - 14] ^ W[_t - 16], 1);\n }\n\n var a = H[0];\n var b = H[1];\n var c = H[2];\n var d = H[3];\n var e = H[4];\n\n for (var _t2 = 0; _t2 < 80; ++_t2) {\n var s = Math.floor(_t2 / 20);\n var T = ROTL(a, 5) + f(s, b, c, d) + e + K[s] + W[_t2] >>> 0;\n e = d;\n d = c;\n c = ROTL(b, 30) >>> 0;\n b = a;\n a = T;\n }\n\n H[0] = H[0] + a >>> 0;\n H[1] = H[1] + b >>> 0;\n H[2] = H[2] + c >>> 0;\n H[3] = H[3] + d >>> 0;\n H[4] = H[4] + e >>> 0;\n }\n\n return [H[0] >> 24 & 0xff, H[0] >> 16 & 0xff, H[0] >> 8 & 0xff, H[0] & 0xff, H[1] >> 24 & 0xff, H[1] >> 16 & 0xff, H[1] >> 8 & 0xff, H[1] & 0xff, H[2] >> 24 & 0xff, H[2] >> 16 & 0xff, H[2] >> 8 & 0xff, H[2] & 0xff, H[3] >> 24 & 0xff, H[3] >> 16 & 0xff, H[3] >> 8 & 0xff, H[3] & 0xff, H[4] >> 24 & 0xff, H[4] >> 16 & 0xff, H[4] >> 8 & 0xff, H[4] & 0xff];\n}\n\nexport default sha1;","import v35 from './v35.js';\nimport sha1 from './sha1.js';\nvar v5 = v35('v5', 0x50, sha1);\nexport default v5;","export default '00000000-0000-0000-0000-000000000000';","import validate from './validate.js';\n\nfunction version(uuid) {\n if (!validate(uuid)) {\n throw TypeError('Invalid UUID');\n }\n\n return parseInt(uuid.substr(14, 1), 16);\n}\n\nexport default version;","\n var doc = {\"kind\":\"Document\",\"definitions\":[{\"kind\":\"OperationDefinition\",\"operation\":\"query\",\"name\":{\"kind\":\"Name\",\"value\":\"GetElectionLogEntries\"},\"variableDefinitions\":[{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"electionUniqueId\"}},\"type\":{\"kind\":\"NonNullType\",\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}}},\"directives\":[]},{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"after\"}},\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}},\"directives\":[]},{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"types\"}},\"type\":{\"kind\":\"ListType\",\"type\":{\"kind\":\"NonNullType\",\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}}}},\"directives\":[]}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"election\"},\"arguments\":[{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"uniqueId\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"electionUniqueId\"}}}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"logEntries\"},\"arguments\":[{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"after\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"after\"}}},{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"types\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"types\"}}}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"id\"},\"arguments\":[],\"directives\":[]},{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"},\"arguments\":[],\"directives\":[]},{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"},\"arguments\":[],\"directives\":[]},{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"chainedHash\"},\"arguments\":[],\"directives\":[]}]}}]}}]}}],\"loc\":{\"start\":0,\"end\":260}};\n doc.loc.source = {\"body\":\"query GetElectionLogEntries(\\n $electionUniqueId: String!\\n $after: String\\n $types: [String!]\\n) {\\n election(uniqueId: $electionUniqueId) {\\n logEntries(after: $after, types: $types) {\\n id\\n messageId\\n signedData\\n chainedHash\\n }\\n }\\n}\\n\",\"name\":\"GraphQL request\",\"locationOffset\":{\"line\":1,\"column\":1}};\n \n\n var names = {};\n function unique(defs) {\n return defs.filter(\n function(def) {\n if (def.kind !== 'FragmentDefinition') return true;\n var name = def.name.value\n if (names[name]) {\n return false;\n } else {\n names[name] = true;\n return true;\n }\n }\n )\n }\n \n\n // Collect any fragment/type references from a node, adding them to the refs Set\n function collectFragmentReferences(node, refs) {\n if (node.kind === \"FragmentSpread\") {\n refs.add(node.name.value);\n } else if (node.kind === \"VariableDefinition\") {\n var type = node.type;\n if (type.kind === \"NamedType\") {\n refs.add(type.name.value);\n }\n }\n\n if (node.selectionSet) {\n node.selectionSet.selections.forEach(function(selection) {\n collectFragmentReferences(selection, refs);\n });\n }\n\n if (node.variableDefinitions) {\n node.variableDefinitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n\n if (node.definitions) {\n node.definitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n }\n\n var definitionRefs = {};\n (function extractReferences() {\n doc.definitions.forEach(function(def) {\n if (def.name) {\n var refs = new Set();\n collectFragmentReferences(def, refs);\n definitionRefs[def.name.value] = refs;\n }\n });\n })();\n\n function findOperation(doc, name) {\n for (var i = 0; i < doc.definitions.length; i++) {\n var element = doc.definitions[i];\n if (element.name && element.name.value == name) {\n return element;\n }\n }\n }\n\n function oneQuery(doc, operationName) {\n // Copy the DocumentNode, but clear out the definitions\n var newDoc = {\n kind: doc.kind,\n definitions: [findOperation(doc, operationName)]\n };\n if (doc.hasOwnProperty(\"loc\")) {\n newDoc.loc = doc.loc;\n }\n\n // Now, for the operation we're running, find any fragments referenced by\n // it or the fragments it references\n var opRefs = definitionRefs[operationName] || new Set();\n var allRefs = new Set();\n var newRefs = new Set();\n\n // IE 11 doesn't support \"new Set(iterable)\", so we add the members of opRefs to newRefs one by one\n opRefs.forEach(function(refName) {\n newRefs.add(refName);\n });\n\n while (newRefs.size > 0) {\n var prevRefs = newRefs;\n newRefs = new Set();\n\n prevRefs.forEach(function(refName) {\n if (!allRefs.has(refName)) {\n allRefs.add(refName);\n var childRefs = definitionRefs[refName] || new Set();\n childRefs.forEach(function(childRef) {\n newRefs.add(childRef);\n });\n }\n });\n }\n\n allRefs.forEach(function(refName) {\n var op = findOperation(doc, refName);\n if (op) {\n newDoc.definitions.push(op);\n }\n });\n\n return newDoc;\n }\n \n module.exports = doc;\n \n module.exports[\"GetElectionLogEntries\"] = oneQuery(doc, \"GetElectionLogEntries\");\n \n","\n var doc = {\"kind\":\"Document\",\"definitions\":[{\"kind\":\"OperationDefinition\",\"operation\":\"query\",\"name\":{\"kind\":\"Name\",\"value\":\"GetLogEntry\"},\"variableDefinitions\":[{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"electionUniqueId\"}},\"type\":{\"kind\":\"NonNullType\",\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}}},\"directives\":[]},{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"contentHash\"}},\"type\":{\"kind\":\"NonNullType\",\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}}},\"directives\":[]}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"logEntry\"},\"arguments\":[{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"electionUniqueId\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"electionUniqueId\"}}},{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"contentHash\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"contentHash\"}}}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"},\"arguments\":[],\"directives\":[]},{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"},\"arguments\":[],\"directives\":[]},{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"contentHash\"},\"arguments\":[],\"directives\":[]}]}}]}}],\"loc\":{\"start\":0,\"end\":199}};\n doc.loc.source = {\"body\":\"query GetLogEntry($electionUniqueId: String!, $contentHash: String!) {\\n logEntry(electionUniqueId: $electionUniqueId, contentHash: $contentHash) {\\n messageId\\n signedData\\n contentHash\\n }\\n}\\n\",\"name\":\"GraphQL request\",\"locationOffset\":{\"line\":1,\"column\":1}};\n \n\n var names = {};\n function unique(defs) {\n return defs.filter(\n function(def) {\n if (def.kind !== 'FragmentDefinition') return true;\n var name = def.name.value\n if (names[name]) {\n return false;\n } else {\n names[name] = true;\n return true;\n }\n }\n )\n }\n \n\n // Collect any fragment/type references from a node, adding them to the refs Set\n function collectFragmentReferences(node, refs) {\n if (node.kind === \"FragmentSpread\") {\n refs.add(node.name.value);\n } else if (node.kind === \"VariableDefinition\") {\n var type = node.type;\n if (type.kind === \"NamedType\") {\n refs.add(type.name.value);\n }\n }\n\n if (node.selectionSet) {\n node.selectionSet.selections.forEach(function(selection) {\n collectFragmentReferences(selection, refs);\n });\n }\n\n if (node.variableDefinitions) {\n node.variableDefinitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n\n if (node.definitions) {\n node.definitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n }\n\n var definitionRefs = {};\n (function extractReferences() {\n doc.definitions.forEach(function(def) {\n if (def.name) {\n var refs = new Set();\n collectFragmentReferences(def, refs);\n definitionRefs[def.name.value] = refs;\n }\n });\n })();\n\n function findOperation(doc, name) {\n for (var i = 0; i < doc.definitions.length; i++) {\n var element = doc.definitions[i];\n if (element.name && element.name.value == name) {\n return element;\n }\n }\n }\n\n function oneQuery(doc, operationName) {\n // Copy the DocumentNode, but clear out the definitions\n var newDoc = {\n kind: doc.kind,\n definitions: [findOperation(doc, operationName)]\n };\n if (doc.hasOwnProperty(\"loc\")) {\n newDoc.loc = doc.loc;\n }\n\n // Now, for the operation we're running, find any fragments referenced by\n // it or the fragments it references\n var opRefs = definitionRefs[operationName] || new Set();\n var allRefs = new Set();\n var newRefs = new Set();\n\n // IE 11 doesn't support \"new Set(iterable)\", so we add the members of opRefs to newRefs one by one\n opRefs.forEach(function(refName) {\n newRefs.add(refName);\n });\n\n while (newRefs.size > 0) {\n var prevRefs = newRefs;\n newRefs = new Set();\n\n prevRefs.forEach(function(refName) {\n if (!allRefs.has(refName)) {\n allRefs.add(refName);\n var childRefs = definitionRefs[refName] || new Set();\n childRefs.forEach(function(childRef) {\n newRefs.add(childRef);\n });\n }\n });\n }\n\n allRefs.forEach(function(refName) {\n var op = findOperation(doc, refName);\n if (op) {\n newDoc.definitions.push(op);\n }\n });\n\n return newDoc;\n }\n \n module.exports = doc;\n \n module.exports[\"GetLogEntry\"] = oneQuery(doc, \"GetLogEntry\");\n \n","\n var doc = {\"kind\":\"Document\",\"definitions\":[{\"kind\":\"OperationDefinition\",\"operation\":\"query\",\"name\":{\"kind\":\"Name\",\"value\":\"GetPendingMessageByMessageId\"},\"variableDefinitions\":[{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"}},\"type\":{\"kind\":\"NonNullType\",\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}}},\"directives\":[]}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"pendingMessage\"},\"arguments\":[{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"}}}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"status\"},\"arguments\":[],\"directives\":[]}]}}]}}],\"loc\":{\"start\":0,\"end\":117}};\n doc.loc.source = {\"body\":\"query GetPendingMessageByMessageId($messageId: String!) {\\n pendingMessage(messageId: $messageId) {\\n status\\n }\\n}\\n\",\"name\":\"GraphQL request\",\"locationOffset\":{\"line\":1,\"column\":1}};\n \n\n var names = {};\n function unique(defs) {\n return defs.filter(\n function(def) {\n if (def.kind !== 'FragmentDefinition') return true;\n var name = def.name.value\n if (names[name]) {\n return false;\n } else {\n names[name] = true;\n return true;\n }\n }\n )\n }\n \n\n // Collect any fragment/type references from a node, adding them to the refs Set\n function collectFragmentReferences(node, refs) {\n if (node.kind === \"FragmentSpread\") {\n refs.add(node.name.value);\n } else if (node.kind === \"VariableDefinition\") {\n var type = node.type;\n if (type.kind === \"NamedType\") {\n refs.add(type.name.value);\n }\n }\n\n if (node.selectionSet) {\n node.selectionSet.selections.forEach(function(selection) {\n collectFragmentReferences(selection, refs);\n });\n }\n\n if (node.variableDefinitions) {\n node.variableDefinitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n\n if (node.definitions) {\n node.definitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n }\n\n var definitionRefs = {};\n (function extractReferences() {\n doc.definitions.forEach(function(def) {\n if (def.name) {\n var refs = new Set();\n collectFragmentReferences(def, refs);\n definitionRefs[def.name.value] = refs;\n }\n });\n })();\n\n function findOperation(doc, name) {\n for (var i = 0; i < doc.definitions.length; i++) {\n var element = doc.definitions[i];\n if (element.name && element.name.value == name) {\n return element;\n }\n }\n }\n\n function oneQuery(doc, operationName) {\n // Copy the DocumentNode, but clear out the definitions\n var newDoc = {\n kind: doc.kind,\n definitions: [findOperation(doc, operationName)]\n };\n if (doc.hasOwnProperty(\"loc\")) {\n newDoc.loc = doc.loc;\n }\n\n // Now, for the operation we're running, find any fragments referenced by\n // it or the fragments it references\n var opRefs = definitionRefs[operationName] || new Set();\n var allRefs = new Set();\n var newRefs = new Set();\n\n // IE 11 doesn't support \"new Set(iterable)\", so we add the members of opRefs to newRefs one by one\n opRefs.forEach(function(refName) {\n newRefs.add(refName);\n });\n\n while (newRefs.size > 0) {\n var prevRefs = newRefs;\n newRefs = new Set();\n\n prevRefs.forEach(function(refName) {\n if (!allRefs.has(refName)) {\n allRefs.add(refName);\n var childRefs = definitionRefs[refName] || new Set();\n childRefs.forEach(function(childRef) {\n newRefs.add(childRef);\n });\n }\n });\n }\n\n allRefs.forEach(function(refName) {\n var op = findOperation(doc, refName);\n if (op) {\n newDoc.definitions.push(op);\n }\n });\n\n return newDoc;\n }\n \n module.exports = doc;\n \n module.exports[\"GetPendingMessageByMessageId\"] = oneQuery(doc, \"GetPendingMessageByMessageId\");\n \n","\n var doc = {\"kind\":\"Document\",\"definitions\":[{\"kind\":\"OperationDefinition\",\"operation\":\"mutation\",\"name\":{\"kind\":\"Name\",\"value\":\"ProcessKeyCeremonyStep\"},\"variableDefinitions\":[{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"}},\"type\":{\"kind\":\"NonNullType\",\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}}},\"directives\":[]},{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"}},\"type\":{\"kind\":\"NonNullType\",\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}}},\"directives\":[]}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"processKeyCeremonyStep\"},\"arguments\":[{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"}}},{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"}}}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"pendingMessage\"},\"arguments\":[],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"},\"arguments\":[],\"directives\":[]}]}},{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"error\"},\"arguments\":[],\"directives\":[]}]}}]}}],\"loc\":{\"start\":0,\"end\":212}};\n doc.loc.source = {\"body\":\"mutation ProcessKeyCeremonyStep($messageId: String!, $signedData: String!) {\\n processKeyCeremonyStep(messageId: $messageId, signedData: $signedData) {\\n pendingMessage {\\n signedData\\n }\\n error\\n }\\n}\\n\",\"name\":\"GraphQL request\",\"locationOffset\":{\"line\":1,\"column\":1}};\n \n\n var names = {};\n function unique(defs) {\n return defs.filter(\n function(def) {\n if (def.kind !== 'FragmentDefinition') return true;\n var name = def.name.value\n if (names[name]) {\n return false;\n } else {\n names[name] = true;\n return true;\n }\n }\n )\n }\n \n\n // Collect any fragment/type references from a node, adding them to the refs Set\n function collectFragmentReferences(node, refs) {\n if (node.kind === \"FragmentSpread\") {\n refs.add(node.name.value);\n } else if (node.kind === \"VariableDefinition\") {\n var type = node.type;\n if (type.kind === \"NamedType\") {\n refs.add(type.name.value);\n }\n }\n\n if (node.selectionSet) {\n node.selectionSet.selections.forEach(function(selection) {\n collectFragmentReferences(selection, refs);\n });\n }\n\n if (node.variableDefinitions) {\n node.variableDefinitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n\n if (node.definitions) {\n node.definitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n }\n\n var definitionRefs = {};\n (function extractReferences() {\n doc.definitions.forEach(function(def) {\n if (def.name) {\n var refs = new Set();\n collectFragmentReferences(def, refs);\n definitionRefs[def.name.value] = refs;\n }\n });\n })();\n\n function findOperation(doc, name) {\n for (var i = 0; i < doc.definitions.length; i++) {\n var element = doc.definitions[i];\n if (element.name && element.name.value == name) {\n return element;\n }\n }\n }\n\n function oneQuery(doc, operationName) {\n // Copy the DocumentNode, but clear out the definitions\n var newDoc = {\n kind: doc.kind,\n definitions: [findOperation(doc, operationName)]\n };\n if (doc.hasOwnProperty(\"loc\")) {\n newDoc.loc = doc.loc;\n }\n\n // Now, for the operation we're running, find any fragments referenced by\n // it or the fragments it references\n var opRefs = definitionRefs[operationName] || new Set();\n var allRefs = new Set();\n var newRefs = new Set();\n\n // IE 11 doesn't support \"new Set(iterable)\", so we add the members of opRefs to newRefs one by one\n opRefs.forEach(function(refName) {\n newRefs.add(refName);\n });\n\n while (newRefs.size > 0) {\n var prevRefs = newRefs;\n newRefs = new Set();\n\n prevRefs.forEach(function(refName) {\n if (!allRefs.has(refName)) {\n allRefs.add(refName);\n var childRefs = definitionRefs[refName] || new Set();\n childRefs.forEach(function(childRef) {\n newRefs.add(childRef);\n });\n }\n });\n }\n\n allRefs.forEach(function(refName) {\n var op = findOperation(doc, refName);\n if (op) {\n newDoc.definitions.push(op);\n }\n });\n\n return newDoc;\n }\n \n module.exports = doc;\n \n module.exports[\"ProcessKeyCeremonyStep\"] = oneQuery(doc, \"ProcessKeyCeremonyStep\");\n \n","\n var doc = {\"kind\":\"Document\",\"definitions\":[{\"kind\":\"OperationDefinition\",\"operation\":\"mutation\",\"name\":{\"kind\":\"Name\",\"value\":\"ProcessTallyStep\"},\"variableDefinitions\":[{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"}},\"type\":{\"kind\":\"NonNullType\",\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}}},\"directives\":[]},{\"kind\":\"VariableDefinition\",\"variable\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"}},\"type\":{\"kind\":\"NonNullType\",\"type\":{\"kind\":\"NamedType\",\"name\":{\"kind\":\"Name\",\"value\":\"String\"}}},\"directives\":[]}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"processTallyStep\"},\"arguments\":[{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"messageId\"}}},{\"kind\":\"Argument\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"},\"value\":{\"kind\":\"Variable\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"}}}],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"pendingMessage\"},\"arguments\":[],\"directives\":[],\"selectionSet\":{\"kind\":\"SelectionSet\",\"selections\":[{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"signedData\"},\"arguments\":[],\"directives\":[]}]}},{\"kind\":\"Field\",\"name\":{\"kind\":\"Name\",\"value\":\"error\"},\"arguments\":[],\"directives\":[]}]}}]}}],\"loc\":{\"start\":0,\"end\":200}};\n doc.loc.source = {\"body\":\"mutation ProcessTallyStep($messageId: String!, $signedData: String!) {\\n processTallyStep(messageId: $messageId, signedData: $signedData) {\\n pendingMessage {\\n signedData\\n }\\n error\\n }\\n}\\n\",\"name\":\"GraphQL request\",\"locationOffset\":{\"line\":1,\"column\":1}};\n \n\n var names = {};\n function unique(defs) {\n return defs.filter(\n function(def) {\n if (def.kind !== 'FragmentDefinition') return true;\n var name = def.name.value\n if (names[name]) {\n return false;\n } else {\n names[name] = true;\n return true;\n }\n }\n )\n }\n \n\n // Collect any fragment/type references from a node, adding them to the refs Set\n function collectFragmentReferences(node, refs) {\n if (node.kind === \"FragmentSpread\") {\n refs.add(node.name.value);\n } else if (node.kind === \"VariableDefinition\") {\n var type = node.type;\n if (type.kind === \"NamedType\") {\n refs.add(type.name.value);\n }\n }\n\n if (node.selectionSet) {\n node.selectionSet.selections.forEach(function(selection) {\n collectFragmentReferences(selection, refs);\n });\n }\n\n if (node.variableDefinitions) {\n node.variableDefinitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n\n if (node.definitions) {\n node.definitions.forEach(function(def) {\n collectFragmentReferences(def, refs);\n });\n }\n }\n\n var definitionRefs = {};\n (function extractReferences() {\n doc.definitions.forEach(function(def) {\n if (def.name) {\n var refs = new Set();\n collectFragmentReferences(def, refs);\n definitionRefs[def.name.value] = refs;\n }\n });\n })();\n\n function findOperation(doc, name) {\n for (var i = 0; i < doc.definitions.length; i++) {\n var element = doc.definitions[i];\n if (element.name && element.name.value == name) {\n return element;\n }\n }\n }\n\n function oneQuery(doc, operationName) {\n // Copy the DocumentNode, but clear out the definitions\n var newDoc = {\n kind: doc.kind,\n definitions: [findOperation(doc, operationName)]\n };\n if (doc.hasOwnProperty(\"loc\")) {\n newDoc.loc = doc.loc;\n }\n\n // Now, for the operation we're running, find any fragments referenced by\n // it or the fragments it references\n var opRefs = definitionRefs[operationName] || new Set();\n var allRefs = new Set();\n var newRefs = new Set();\n\n // IE 11 doesn't support \"new Set(iterable)\", so we add the members of opRefs to newRefs one by one\n opRefs.forEach(function(refName) {\n newRefs.add(refName);\n });\n\n while (newRefs.size > 0) {\n var prevRefs = newRefs;\n newRefs = new Set();\n\n prevRefs.forEach(function(refName) {\n if (!allRefs.has(refName)) {\n allRefs.add(refName);\n var childRefs = definitionRefs[refName] || new Set();\n childRefs.forEach(function(childRef) {\n newRefs.add(childRef);\n });\n }\n });\n }\n\n allRefs.forEach(function(refName) {\n var op = findOperation(doc, refName);\n if (op) {\n newDoc.definitions.push(op);\n }\n });\n\n return newDoc;\n }\n \n module.exports = doc;\n \n module.exports[\"ProcessTallyStep\"] = oneQuery(doc, \"ProcessTallyStep\");\n \n","// GENERATED FILE. DO NOT EDIT.\nvar Long = (function(exports) {\n \"use strict\";\n \n Object.defineProperty(exports, \"__esModule\", {\n value: true\n });\n exports.default = void 0;\n \n /**\n * @license\n * Copyright 2009 The Closure Library Authors\n * Copyright 2020 Daniel Wirtz / The long.js Authors.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n *\n * SPDX-License-Identifier: Apache-2.0\n */\n // WebAssembly optimizations to do native i64 multiplication and divide\n var wasm = null;\n \n try {\n wasm = new WebAssembly.Instance(new WebAssembly.Module(new Uint8Array([0, 97, 115, 109, 1, 0, 0, 0, 1, 13, 2, 96, 0, 1, 127, 96, 4, 127, 127, 127, 127, 1, 127, 3, 7, 6, 0, 1, 1, 1, 1, 1, 6, 6, 1, 127, 1, 65, 0, 11, 7, 50, 6, 3, 109, 117, 108, 0, 1, 5, 100, 105, 118, 95, 115, 0, 2, 5, 100, 105, 118, 95, 117, 0, 3, 5, 114, 101, 109, 95, 115, 0, 4, 5, 114, 101, 109, 95, 117, 0, 5, 8, 103, 101, 116, 95, 104, 105, 103, 104, 0, 0, 10, 191, 1, 6, 4, 0, 35, 0, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 126, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 127, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 128, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 129, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11, 36, 1, 1, 126, 32, 0, 173, 32, 1, 173, 66, 32, 134, 132, 32, 2, 173, 32, 3, 173, 66, 32, 134, 132, 130, 34, 4, 66, 32, 135, 167, 36, 0, 32, 4, 167, 11])), {}).exports;\n } catch (e) {// no wasm support :(\n }\n /**\n * Constructs a 64 bit two's-complement integer, given its low and high 32 bit values as *signed* integers.\n * See the from* functions below for more convenient ways of constructing Longs.\n * @exports Long\n * @class A Long class for representing a 64 bit two's-complement integer value.\n * @param {number} low The low (signed) 32 bits of the long\n * @param {number} high The high (signed) 32 bits of the long\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @constructor\n */\n \n \n function Long(low, high, unsigned) {\n /**\n * The low 32 bits as a signed value.\n * @type {number}\n */\n this.low = low | 0;\n /**\n * The high 32 bits as a signed value.\n * @type {number}\n */\n \n this.high = high | 0;\n /**\n * Whether unsigned or not.\n * @type {boolean}\n */\n \n this.unsigned = !!unsigned;\n } // The internal representation of a long is the two given signed, 32-bit values.\n // We use 32-bit pieces because these are the size of integers on which\n // Javascript performs bit-operations. For operations like addition and\n // multiplication, we split each number into 16 bit pieces, which can easily be\n // multiplied within Javascript's floating-point representation without overflow\n // or change in sign.\n //\n // In the algorithms below, we frequently reduce the negative case to the\n // positive case by negating the input(s) and then post-processing the result.\n // Note that we must ALWAYS check specially whether those values are MIN_VALUE\n // (-2^63) because -MIN_VALUE == MIN_VALUE (since 2^63 cannot be represented as\n // a positive number, it overflows back into a negative). Not handling this\n // case would often result in infinite recursion.\n //\n // Common constant values ZERO, ONE, NEG_ONE, etc. are defined below the from*\n // methods on which they depend.\n \n /**\n * An indicator used to reliably determine if an object is a Long or not.\n * @type {boolean}\n * @const\n * @private\n */\n \n \n Long.prototype.__isLong__;\n Object.defineProperty(Long.prototype, \"__isLong__\", {\n value: true\n });\n /**\n * @function\n * @param {*} obj Object\n * @returns {boolean}\n * @inner\n */\n \n function isLong(obj) {\n return (obj && obj[\"__isLong__\"]) === true;\n }\n /**\n * @function\n * @param {*} value number\n * @returns {number}\n * @inner\n */\n \n \n function ctz32(value) {\n var c = Math.clz32(value & -value);\n return value ? 31 - c : c;\n }\n /**\n * Tests if the specified object is a Long.\n * @function\n * @param {*} obj Object\n * @returns {boolean}\n */\n \n \n Long.isLong = isLong;\n /**\n * A cache of the Long representations of small integer values.\n * @type {!Object}\n * @inner\n */\n \n var INT_CACHE = {};\n /**\n * A cache of the Long representations of small unsigned integer values.\n * @type {!Object}\n * @inner\n */\n \n var UINT_CACHE = {};\n /**\n * @param {number} value\n * @param {boolean=} unsigned\n * @returns {!Long}\n * @inner\n */\n \n function fromInt(value, unsigned) {\n var obj, cachedObj, cache;\n \n if (unsigned) {\n value >>>= 0;\n \n if (cache = 0 <= value && value < 256) {\n cachedObj = UINT_CACHE[value];\n if (cachedObj) return cachedObj;\n }\n \n obj = fromBits(value, 0, true);\n if (cache) UINT_CACHE[value] = obj;\n return obj;\n } else {\n value |= 0;\n \n if (cache = -128 <= value && value < 128) {\n cachedObj = INT_CACHE[value];\n if (cachedObj) return cachedObj;\n }\n \n obj = fromBits(value, value < 0 ? -1 : 0, false);\n if (cache) INT_CACHE[value] = obj;\n return obj;\n }\n }\n /**\n * Returns a Long representing the given 32 bit integer value.\n * @function\n * @param {number} value The 32 bit integer in question\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {!Long} The corresponding Long value\n */\n \n \n Long.fromInt = fromInt;\n /**\n * @param {number} value\n * @param {boolean=} unsigned\n * @returns {!Long}\n * @inner\n */\n \n function fromNumber(value, unsigned) {\n if (isNaN(value)) return unsigned ? UZERO : ZERO;\n \n if (unsigned) {\n if (value < 0) return UZERO;\n if (value >= TWO_PWR_64_DBL) return MAX_UNSIGNED_VALUE;\n } else {\n if (value <= -TWO_PWR_63_DBL) return MIN_VALUE;\n if (value + 1 >= TWO_PWR_63_DBL) return MAX_VALUE;\n }\n \n if (value < 0) return fromNumber(-value, unsigned).neg();\n return fromBits(value % TWO_PWR_32_DBL | 0, value / TWO_PWR_32_DBL | 0, unsigned);\n }\n /**\n * Returns a Long representing the given value, provided that it is a finite number. Otherwise, zero is returned.\n * @function\n * @param {number} value The number in question\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {!Long} The corresponding Long value\n */\n \n \n Long.fromNumber = fromNumber;\n /**\n * @param {number} lowBits\n * @param {number} highBits\n * @param {boolean=} unsigned\n * @returns {!Long}\n * @inner\n */\n \n function fromBits(lowBits, highBits, unsigned) {\n return new Long(lowBits, highBits, unsigned);\n }\n /**\n * Returns a Long representing the 64 bit integer that comes by concatenating the given low and high bits. Each is\n * assumed to use 32 bits.\n * @function\n * @param {number} lowBits The low 32 bits\n * @param {number} highBits The high 32 bits\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {!Long} The corresponding Long value\n */\n \n \n Long.fromBits = fromBits;\n /**\n * @function\n * @param {number} base\n * @param {number} exponent\n * @returns {number}\n * @inner\n */\n \n var pow_dbl = Math.pow; // Used 4 times (4*8 to 15+4)\n \n /**\n * @param {string} str\n * @param {(boolean|number)=} unsigned\n * @param {number=} radix\n * @returns {!Long}\n * @inner\n */\n \n function fromString(str, unsigned, radix) {\n if (str.length === 0) throw Error('empty string');\n \n if (typeof unsigned === 'number') {\n // For goog.math.long compatibility\n radix = unsigned;\n unsigned = false;\n } else {\n unsigned = !!unsigned;\n }\n \n if (str === \"NaN\" || str === \"Infinity\" || str === \"+Infinity\" || str === \"-Infinity\") return unsigned ? UZERO : ZERO;\n radix = radix || 10;\n if (radix < 2 || 36 < radix) throw RangeError('radix');\n var p;\n if ((p = str.indexOf('-')) > 0) throw Error('interior hyphen');else if (p === 0) {\n return fromString(str.substring(1), unsigned, radix).neg();\n } // Do several (8) digits each time through the loop, so as to\n // minimize the calls to the very expensive emulated div.\n \n var radixToPower = fromNumber(pow_dbl(radix, 8));\n var result = ZERO;\n \n for (var i = 0; i < str.length; i += 8) {\n var size = Math.min(8, str.length - i),\n value = parseInt(str.substring(i, i + size), radix);\n \n if (size < 8) {\n var power = fromNumber(pow_dbl(radix, size));\n result = result.mul(power).add(fromNumber(value));\n } else {\n result = result.mul(radixToPower);\n result = result.add(fromNumber(value));\n }\n }\n \n result.unsigned = unsigned;\n return result;\n }\n /**\n * Returns a Long representation of the given string, written using the specified radix.\n * @function\n * @param {string} str The textual representation of the Long\n * @param {(boolean|number)=} unsigned Whether unsigned or not, defaults to signed\n * @param {number=} radix The radix in which the text is written (2-36), defaults to 10\n * @returns {!Long} The corresponding Long value\n */\n \n \n Long.fromString = fromString;\n /**\n * @function\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val\n * @param {boolean=} unsigned\n * @returns {!Long}\n * @inner\n */\n \n function fromValue(val, unsigned) {\n if (typeof val === 'number') return fromNumber(val, unsigned);\n if (typeof val === 'string') return fromString(val, unsigned); // Throws for non-objects, converts non-instanceof Long:\n \n return fromBits(val.low, val.high, typeof unsigned === 'boolean' ? unsigned : val.unsigned);\n }\n /**\n * Converts the specified value to a Long using the appropriate from* function for its type.\n * @function\n * @param {!Long|number|string|!{low: number, high: number, unsigned: boolean}} val Value\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {!Long}\n */\n \n \n Long.fromValue = fromValue; // NOTE: the compiler should inline these constant values below and then remove these variables, so there should be\n // no runtime penalty for these.\n \n /**\n * @type {number}\n * @const\n * @inner\n */\n \n var TWO_PWR_16_DBL = 1 << 16;\n /**\n * @type {number}\n * @const\n * @inner\n */\n \n var TWO_PWR_24_DBL = 1 << 24;\n /**\n * @type {number}\n * @const\n * @inner\n */\n \n var TWO_PWR_32_DBL = TWO_PWR_16_DBL * TWO_PWR_16_DBL;\n /**\n * @type {number}\n * @const\n * @inner\n */\n \n var TWO_PWR_64_DBL = TWO_PWR_32_DBL * TWO_PWR_32_DBL;\n /**\n * @type {number}\n * @const\n * @inner\n */\n \n var TWO_PWR_63_DBL = TWO_PWR_64_DBL / 2;\n /**\n * @type {!Long}\n * @const\n * @inner\n */\n \n var TWO_PWR_24 = fromInt(TWO_PWR_24_DBL);\n /**\n * @type {!Long}\n * @inner\n */\n \n var ZERO = fromInt(0);\n /**\n * Signed zero.\n * @type {!Long}\n */\n \n Long.ZERO = ZERO;\n /**\n * @type {!Long}\n * @inner\n */\n \n var UZERO = fromInt(0, true);\n /**\n * Unsigned zero.\n * @type {!Long}\n */\n \n Long.UZERO = UZERO;\n /**\n * @type {!Long}\n * @inner\n */\n \n var ONE = fromInt(1);\n /**\n * Signed one.\n * @type {!Long}\n */\n \n Long.ONE = ONE;\n /**\n * @type {!Long}\n * @inner\n */\n \n var UONE = fromInt(1, true);\n /**\n * Unsigned one.\n * @type {!Long}\n */\n \n Long.UONE = UONE;\n /**\n * @type {!Long}\n * @inner\n */\n \n var NEG_ONE = fromInt(-1);\n /**\n * Signed negative one.\n * @type {!Long}\n */\n \n Long.NEG_ONE = NEG_ONE;\n /**\n * @type {!Long}\n * @inner\n */\n \n var MAX_VALUE = fromBits(0xFFFFFFFF | 0, 0x7FFFFFFF | 0, false);\n /**\n * Maximum signed value.\n * @type {!Long}\n */\n \n Long.MAX_VALUE = MAX_VALUE;\n /**\n * @type {!Long}\n * @inner\n */\n \n var MAX_UNSIGNED_VALUE = fromBits(0xFFFFFFFF | 0, 0xFFFFFFFF | 0, true);\n /**\n * Maximum unsigned value.\n * @type {!Long}\n */\n \n Long.MAX_UNSIGNED_VALUE = MAX_UNSIGNED_VALUE;\n /**\n * @type {!Long}\n * @inner\n */\n \n var MIN_VALUE = fromBits(0, 0x80000000 | 0, false);\n /**\n * Minimum signed value.\n * @type {!Long}\n */\n \n Long.MIN_VALUE = MIN_VALUE;\n /**\n * @alias Long.prototype\n * @inner\n */\n \n var LongPrototype = Long.prototype;\n /**\n * Converts the Long to a 32 bit integer, assuming it is a 32 bit integer.\n * @this {!Long}\n * @returns {number}\n */\n \n LongPrototype.toInt = function toInt() {\n return this.unsigned ? this.low >>> 0 : this.low;\n };\n /**\n * Converts the Long to a the nearest floating-point representation of this value (double, 53 bit mantissa).\n * @this {!Long}\n * @returns {number}\n */\n \n \n LongPrototype.toNumber = function toNumber() {\n if (this.unsigned) return (this.high >>> 0) * TWO_PWR_32_DBL + (this.low >>> 0);\n return this.high * TWO_PWR_32_DBL + (this.low >>> 0);\n };\n /**\n * Converts the Long to a string written in the specified radix.\n * @this {!Long}\n * @param {number=} radix Radix (2-36), defaults to 10\n * @returns {string}\n * @override\n * @throws {RangeError} If `radix` is out of range\n */\n \n \n LongPrototype.toString = function toString(radix) {\n radix = radix || 10;\n if (radix < 2 || 36 < radix) throw RangeError('radix');\n if (this.isZero()) return '0';\n \n if (this.isNegative()) {\n // Unsigned Longs are never negative\n if (this.eq(MIN_VALUE)) {\n // We need to change the Long value before it can be negated, so we remove\n // the bottom-most digit in this base and then recurse to do the rest.\n var radixLong = fromNumber(radix),\n div = this.div(radixLong),\n rem1 = div.mul(radixLong).sub(this);\n return div.toString(radix) + rem1.toInt().toString(radix);\n } else return '-' + this.neg().toString(radix);\n } // Do several (6) digits each time through the loop, so as to\n // minimize the calls to the very expensive emulated div.\n \n \n var radixToPower = fromNumber(pow_dbl(radix, 6), this.unsigned),\n rem = this;\n var result = '';\n \n while (true) {\n var remDiv = rem.div(radixToPower),\n intval = rem.sub(remDiv.mul(radixToPower)).toInt() >>> 0,\n digits = intval.toString(radix);\n rem = remDiv;\n if (rem.isZero()) return digits + result;else {\n while (digits.length < 6) digits = '0' + digits;\n \n result = '' + digits + result;\n }\n }\n };\n /**\n * Gets the high 32 bits as a signed integer.\n * @this {!Long}\n * @returns {number} Signed high bits\n */\n \n \n LongPrototype.getHighBits = function getHighBits() {\n return this.high;\n };\n /**\n * Gets the high 32 bits as an unsigned integer.\n * @this {!Long}\n * @returns {number} Unsigned high bits\n */\n \n \n LongPrototype.getHighBitsUnsigned = function getHighBitsUnsigned() {\n return this.high >>> 0;\n };\n /**\n * Gets the low 32 bits as a signed integer.\n * @this {!Long}\n * @returns {number} Signed low bits\n */\n \n \n LongPrototype.getLowBits = function getLowBits() {\n return this.low;\n };\n /**\n * Gets the low 32 bits as an unsigned integer.\n * @this {!Long}\n * @returns {number} Unsigned low bits\n */\n \n \n LongPrototype.getLowBitsUnsigned = function getLowBitsUnsigned() {\n return this.low >>> 0;\n };\n /**\n * Gets the number of bits needed to represent the absolute value of this Long.\n * @this {!Long}\n * @returns {number}\n */\n \n \n LongPrototype.getNumBitsAbs = function getNumBitsAbs() {\n if (this.isNegative()) // Unsigned Longs are never negative\n return this.eq(MIN_VALUE) ? 64 : this.neg().getNumBitsAbs();\n var val = this.high != 0 ? this.high : this.low;\n \n for (var bit = 31; bit > 0; bit--) if ((val & 1 << bit) != 0) break;\n \n return this.high != 0 ? bit + 33 : bit + 1;\n };\n /**\n * Tests if this Long's value equals zero.\n * @this {!Long}\n * @returns {boolean}\n */\n \n \n LongPrototype.isZero = function isZero() {\n return this.high === 0 && this.low === 0;\n };\n /**\n * Tests if this Long's value equals zero. This is an alias of {@link Long#isZero}.\n * @returns {boolean}\n */\n \n \n LongPrototype.eqz = LongPrototype.isZero;\n /**\n * Tests if this Long's value is negative.\n * @this {!Long}\n * @returns {boolean}\n */\n \n LongPrototype.isNegative = function isNegative() {\n return !this.unsigned && this.high < 0;\n };\n /**\n * Tests if this Long's value is positive or zero.\n * @this {!Long}\n * @returns {boolean}\n */\n \n \n LongPrototype.isPositive = function isPositive() {\n return this.unsigned || this.high >= 0;\n };\n /**\n * Tests if this Long's value is odd.\n * @this {!Long}\n * @returns {boolean}\n */\n \n \n LongPrototype.isOdd = function isOdd() {\n return (this.low & 1) === 1;\n };\n /**\n * Tests if this Long's value is even.\n * @this {!Long}\n * @returns {boolean}\n */\n \n \n LongPrototype.isEven = function isEven() {\n return (this.low & 1) === 0;\n };\n /**\n * Tests if this Long's value equals the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n \n LongPrototype.equals = function equals(other) {\n if (!isLong(other)) other = fromValue(other);\n if (this.unsigned !== other.unsigned && this.high >>> 31 === 1 && other.high >>> 31 === 1) return false;\n return this.high === other.high && this.low === other.low;\n };\n /**\n * Tests if this Long's value equals the specified's. This is an alias of {@link Long#equals}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n \n LongPrototype.eq = LongPrototype.equals;\n /**\n * Tests if this Long's value differs from the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n LongPrototype.notEquals = function notEquals(other) {\n return !this.eq(\n /* validates */\n other);\n };\n /**\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n \n LongPrototype.neq = LongPrototype.notEquals;\n /**\n * Tests if this Long's value differs from the specified's. This is an alias of {@link Long#notEquals}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n LongPrototype.ne = LongPrototype.notEquals;\n /**\n * Tests if this Long's value is less than the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n LongPrototype.lessThan = function lessThan(other) {\n return this.comp(\n /* validates */\n other) < 0;\n };\n /**\n * Tests if this Long's value is less than the specified's. This is an alias of {@link Long#lessThan}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n \n LongPrototype.lt = LongPrototype.lessThan;\n /**\n * Tests if this Long's value is less than or equal the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n LongPrototype.lessThanOrEqual = function lessThanOrEqual(other) {\n return this.comp(\n /* validates */\n other) <= 0;\n };\n /**\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n \n LongPrototype.lte = LongPrototype.lessThanOrEqual;\n /**\n * Tests if this Long's value is less than or equal the specified's. This is an alias of {@link Long#lessThanOrEqual}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n LongPrototype.le = LongPrototype.lessThanOrEqual;\n /**\n * Tests if this Long's value is greater than the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n LongPrototype.greaterThan = function greaterThan(other) {\n return this.comp(\n /* validates */\n other) > 0;\n };\n /**\n * Tests if this Long's value is greater than the specified's. This is an alias of {@link Long#greaterThan}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n \n LongPrototype.gt = LongPrototype.greaterThan;\n /**\n * Tests if this Long's value is greater than or equal the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n LongPrototype.greaterThanOrEqual = function greaterThanOrEqual(other) {\n return this.comp(\n /* validates */\n other) >= 0;\n };\n /**\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n \n LongPrototype.gte = LongPrototype.greaterThanOrEqual;\n /**\n * Tests if this Long's value is greater than or equal the specified's. This is an alias of {@link Long#greaterThanOrEqual}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {boolean}\n */\n \n LongPrototype.ge = LongPrototype.greaterThanOrEqual;\n /**\n * Compares this Long's value with the specified's.\n * @this {!Long}\n * @param {!Long|number|string} other Other value\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\n * if the given one is greater\n */\n \n LongPrototype.compare = function compare(other) {\n if (!isLong(other)) other = fromValue(other);\n if (this.eq(other)) return 0;\n var thisNeg = this.isNegative(),\n otherNeg = other.isNegative();\n if (thisNeg && !otherNeg) return -1;\n if (!thisNeg && otherNeg) return 1; // At this point the sign bits are the same\n \n if (!this.unsigned) return this.sub(other).isNegative() ? -1 : 1; // Both are positive if at least one is unsigned\n \n return other.high >>> 0 > this.high >>> 0 || other.high === this.high && other.low >>> 0 > this.low >>> 0 ? -1 : 1;\n };\n /**\n * Compares this Long's value with the specified's. This is an alias of {@link Long#compare}.\n * @function\n * @param {!Long|number|string} other Other value\n * @returns {number} 0 if they are the same, 1 if the this is greater and -1\n * if the given one is greater\n */\n \n \n LongPrototype.comp = LongPrototype.compare;\n /**\n * Negates this Long's value.\n * @this {!Long}\n * @returns {!Long} Negated Long\n */\n \n LongPrototype.negate = function negate() {\n if (!this.unsigned && this.eq(MIN_VALUE)) return MIN_VALUE;\n return this.not().add(ONE);\n };\n /**\n * Negates this Long's value. This is an alias of {@link Long#negate}.\n * @function\n * @returns {!Long} Negated Long\n */\n \n \n LongPrototype.neg = LongPrototype.negate;\n /**\n * Returns the sum of this and the specified Long.\n * @this {!Long}\n * @param {!Long|number|string} addend Addend\n * @returns {!Long} Sum\n */\n \n LongPrototype.add = function add(addend) {\n if (!isLong(addend)) addend = fromValue(addend); // Divide each number into 4 chunks of 16 bits, and then sum the chunks.\n \n var a48 = this.high >>> 16;\n var a32 = this.high & 0xFFFF;\n var a16 = this.low >>> 16;\n var a00 = this.low & 0xFFFF;\n var b48 = addend.high >>> 16;\n var b32 = addend.high & 0xFFFF;\n var b16 = addend.low >>> 16;\n var b00 = addend.low & 0xFFFF;\n var c48 = 0,\n c32 = 0,\n c16 = 0,\n c00 = 0;\n c00 += a00 + b00;\n c16 += c00 >>> 16;\n c00 &= 0xFFFF;\n c16 += a16 + b16;\n c32 += c16 >>> 16;\n c16 &= 0xFFFF;\n c32 += a32 + b32;\n c48 += c32 >>> 16;\n c32 &= 0xFFFF;\n c48 += a48 + b48;\n c48 &= 0xFFFF;\n return fromBits(c16 << 16 | c00, c48 << 16 | c32, this.unsigned);\n };\n /**\n * Returns the difference of this and the specified Long.\n * @this {!Long}\n * @param {!Long|number|string} subtrahend Subtrahend\n * @returns {!Long} Difference\n */\n \n \n LongPrototype.subtract = function subtract(subtrahend) {\n if (!isLong(subtrahend)) subtrahend = fromValue(subtrahend);\n return this.add(subtrahend.neg());\n };\n /**\n * Returns the difference of this and the specified Long. This is an alias of {@link Long#subtract}.\n * @function\n * @param {!Long|number|string} subtrahend Subtrahend\n * @returns {!Long} Difference\n */\n \n \n LongPrototype.sub = LongPrototype.subtract;\n /**\n * Returns the product of this and the specified Long.\n * @this {!Long}\n * @param {!Long|number|string} multiplier Multiplier\n * @returns {!Long} Product\n */\n \n LongPrototype.multiply = function multiply(multiplier) {\n if (this.isZero()) return this;\n if (!isLong(multiplier)) multiplier = fromValue(multiplier); // use wasm support if present\n \n if (wasm) {\n var low = wasm[\"mul\"](this.low, this.high, multiplier.low, multiplier.high);\n return fromBits(low, wasm[\"get_high\"](), this.unsigned);\n }\n \n if (multiplier.isZero()) return this.unsigned ? UZERO : ZERO;\n if (this.eq(MIN_VALUE)) return multiplier.isOdd() ? MIN_VALUE : ZERO;\n if (multiplier.eq(MIN_VALUE)) return this.isOdd() ? MIN_VALUE : ZERO;\n \n if (this.isNegative()) {\n if (multiplier.isNegative()) return this.neg().mul(multiplier.neg());else return this.neg().mul(multiplier).neg();\n } else if (multiplier.isNegative()) return this.mul(multiplier.neg()).neg(); // If both longs are small, use float multiplication\n \n \n if (this.lt(TWO_PWR_24) && multiplier.lt(TWO_PWR_24)) return fromNumber(this.toNumber() * multiplier.toNumber(), this.unsigned); // Divide each long into 4 chunks of 16 bits, and then add up 4x4 products.\n // We can skip products that would overflow.\n \n var a48 = this.high >>> 16;\n var a32 = this.high & 0xFFFF;\n var a16 = this.low >>> 16;\n var a00 = this.low & 0xFFFF;\n var b48 = multiplier.high >>> 16;\n var b32 = multiplier.high & 0xFFFF;\n var b16 = multiplier.low >>> 16;\n var b00 = multiplier.low & 0xFFFF;\n var c48 = 0,\n c32 = 0,\n c16 = 0,\n c00 = 0;\n c00 += a00 * b00;\n c16 += c00 >>> 16;\n c00 &= 0xFFFF;\n c16 += a16 * b00;\n c32 += c16 >>> 16;\n c16 &= 0xFFFF;\n c16 += a00 * b16;\n c32 += c16 >>> 16;\n c16 &= 0xFFFF;\n c32 += a32 * b00;\n c48 += c32 >>> 16;\n c32 &= 0xFFFF;\n c32 += a16 * b16;\n c48 += c32 >>> 16;\n c32 &= 0xFFFF;\n c32 += a00 * b32;\n c48 += c32 >>> 16;\n c32 &= 0xFFFF;\n c48 += a48 * b00 + a32 * b16 + a16 * b32 + a00 * b48;\n c48 &= 0xFFFF;\n return fromBits(c16 << 16 | c00, c48 << 16 | c32, this.unsigned);\n };\n /**\n * Returns the product of this and the specified Long. This is an alias of {@link Long#multiply}.\n * @function\n * @param {!Long|number|string} multiplier Multiplier\n * @returns {!Long} Product\n */\n \n \n LongPrototype.mul = LongPrototype.multiply;\n /**\n * Returns this Long divided by the specified. The result is signed if this Long is signed or\n * unsigned if this Long is unsigned.\n * @this {!Long}\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Quotient\n */\n \n LongPrototype.divide = function divide(divisor) {\n if (!isLong(divisor)) divisor = fromValue(divisor);\n if (divisor.isZero()) throw Error('division by zero'); // use wasm support if present\n \n if (wasm) {\n // guard against signed division overflow: the largest\n // negative number / -1 would be 1 larger than the largest\n // positive number, due to two's complement.\n if (!this.unsigned && this.high === -0x80000000 && divisor.low === -1 && divisor.high === -1) {\n // be consistent with non-wasm code path\n return this;\n }\n \n var low = (this.unsigned ? wasm[\"div_u\"] : wasm[\"div_s\"])(this.low, this.high, divisor.low, divisor.high);\n return fromBits(low, wasm[\"get_high\"](), this.unsigned);\n }\n \n if (this.isZero()) return this.unsigned ? UZERO : ZERO;\n var approx, rem, res;\n \n if (!this.unsigned) {\n // This section is only relevant for signed longs and is derived from the\n // closure library as a whole.\n if (this.eq(MIN_VALUE)) {\n if (divisor.eq(ONE) || divisor.eq(NEG_ONE)) return MIN_VALUE; // recall that -MIN_VALUE == MIN_VALUE\n else if (divisor.eq(MIN_VALUE)) return ONE;else {\n // At this point, we have |other| >= 2, so |this/other| < |MIN_VALUE|.\n var halfThis = this.shr(1);\n approx = halfThis.div(divisor).shl(1);\n \n if (approx.eq(ZERO)) {\n return divisor.isNegative() ? ONE : NEG_ONE;\n } else {\n rem = this.sub(divisor.mul(approx));\n res = approx.add(rem.div(divisor));\n return res;\n }\n }\n } else if (divisor.eq(MIN_VALUE)) return this.unsigned ? UZERO : ZERO;\n \n if (this.isNegative()) {\n if (divisor.isNegative()) return this.neg().div(divisor.neg());\n return this.neg().div(divisor).neg();\n } else if (divisor.isNegative()) return this.div(divisor.neg()).neg();\n \n res = ZERO;\n } else {\n // The algorithm below has not been made for unsigned longs. It's therefore\n // required to take special care of the MSB prior to running it.\n if (!divisor.unsigned) divisor = divisor.toUnsigned();\n if (divisor.gt(this)) return UZERO;\n if (divisor.gt(this.shru(1))) // 15 >>> 1 = 7 ; with divisor = 8 ; true\n return UONE;\n res = UZERO;\n } // Repeat the following until the remainder is less than other: find a\n // floating-point that approximates remainder / other *from below*, add this\n // into the result, and subtract it from the remainder. It is critical that\n // the approximate value is less than or equal to the real value so that the\n // remainder never becomes negative.\n \n \n rem = this;\n \n while (rem.gte(divisor)) {\n // Approximate the result of division. This may be a little greater or\n // smaller than the actual value.\n approx = Math.max(1, Math.floor(rem.toNumber() / divisor.toNumber())); // We will tweak the approximate result by changing it in the 48-th digit or\n // the smallest non-fractional digit, whichever is larger.\n \n var log2 = Math.ceil(Math.log(approx) / Math.LN2),\n delta = log2 <= 48 ? 1 : pow_dbl(2, log2 - 48),\n // Decrease the approximation until it is smaller than the remainder. Note\n // that if it is too large, the product overflows and is negative.\n approxRes = fromNumber(approx),\n approxRem = approxRes.mul(divisor);\n \n while (approxRem.isNegative() || approxRem.gt(rem)) {\n approx -= delta;\n approxRes = fromNumber(approx, this.unsigned);\n approxRem = approxRes.mul(divisor);\n } // We know the answer can't be zero... and actually, zero would cause\n // infinite recursion since we would make no progress.\n \n \n if (approxRes.isZero()) approxRes = ONE;\n res = res.add(approxRes);\n rem = rem.sub(approxRem);\n }\n \n return res;\n };\n /**\n * Returns this Long divided by the specified. This is an alias of {@link Long#divide}.\n * @function\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Quotient\n */\n \n \n LongPrototype.div = LongPrototype.divide;\n /**\n * Returns this Long modulo the specified.\n * @this {!Long}\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Remainder\n */\n \n LongPrototype.modulo = function modulo(divisor) {\n if (!isLong(divisor)) divisor = fromValue(divisor); // use wasm support if present\n \n if (wasm) {\n var low = (this.unsigned ? wasm[\"rem_u\"] : wasm[\"rem_s\"])(this.low, this.high, divisor.low, divisor.high);\n return fromBits(low, wasm[\"get_high\"](), this.unsigned);\n }\n \n return this.sub(this.div(divisor).mul(divisor));\n };\n /**\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\n * @function\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Remainder\n */\n \n \n LongPrototype.mod = LongPrototype.modulo;\n /**\n * Returns this Long modulo the specified. This is an alias of {@link Long#modulo}.\n * @function\n * @param {!Long|number|string} divisor Divisor\n * @returns {!Long} Remainder\n */\n \n LongPrototype.rem = LongPrototype.modulo;\n /**\n * Returns the bitwise NOT of this Long.\n * @this {!Long}\n * @returns {!Long}\n */\n \n LongPrototype.not = function not() {\n return fromBits(~this.low, ~this.high, this.unsigned);\n };\n /**\n * Returns count leading zeros of this Long.\n * @this {!Long}\n * @returns {!number}\n */\n \n \n LongPrototype.countLeadingZeros = function countLeadingZeros() {\n return this.high ? Math.clz32(this.high) : Math.clz32(this.low) + 32;\n };\n /**\n * Returns count leading zeros. This is an alias of {@link Long#countLeadingZeros}.\n * @function\n * @param {!Long}\n * @returns {!number}\n */\n \n \n LongPrototype.clz = LongPrototype.countLeadingZeros;\n /**\n * Returns count trailing zeros of this Long.\n * @this {!Long}\n * @returns {!number}\n */\n \n LongPrototype.countTrailingZeros = function countTrailingZeros() {\n return this.low ? ctz32(this.low) : ctz32(this.high) + 32;\n };\n /**\n * Returns count trailing zeros. This is an alias of {@link Long#countTrailingZeros}.\n * @function\n * @param {!Long}\n * @returns {!number}\n */\n \n \n LongPrototype.ctz = LongPrototype.countTrailingZeros;\n /**\n * Returns the bitwise AND of this Long and the specified.\n * @this {!Long}\n * @param {!Long|number|string} other Other Long\n * @returns {!Long}\n */\n \n LongPrototype.and = function and(other) {\n if (!isLong(other)) other = fromValue(other);\n return fromBits(this.low & other.low, this.high & other.high, this.unsigned);\n };\n /**\n * Returns the bitwise OR of this Long and the specified.\n * @this {!Long}\n * @param {!Long|number|string} other Other Long\n * @returns {!Long}\n */\n \n \n LongPrototype.or = function or(other) {\n if (!isLong(other)) other = fromValue(other);\n return fromBits(this.low | other.low, this.high | other.high, this.unsigned);\n };\n /**\n * Returns the bitwise XOR of this Long and the given one.\n * @this {!Long}\n * @param {!Long|number|string} other Other Long\n * @returns {!Long}\n */\n \n \n LongPrototype.xor = function xor(other) {\n if (!isLong(other)) other = fromValue(other);\n return fromBits(this.low ^ other.low, this.high ^ other.high, this.unsigned);\n };\n /**\n * Returns this Long with bits shifted to the left by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n \n \n LongPrototype.shiftLeft = function shiftLeft(numBits) {\n if (isLong(numBits)) numBits = numBits.toInt();\n if ((numBits &= 63) === 0) return this;else if (numBits < 32) return fromBits(this.low << numBits, this.high << numBits | this.low >>> 32 - numBits, this.unsigned);else return fromBits(0, this.low << numBits - 32, this.unsigned);\n };\n /**\n * Returns this Long with bits shifted to the left by the given amount. This is an alias of {@link Long#shiftLeft}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n \n \n LongPrototype.shl = LongPrototype.shiftLeft;\n /**\n * Returns this Long with bits arithmetically shifted to the right by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n \n LongPrototype.shiftRight = function shiftRight(numBits) {\n if (isLong(numBits)) numBits = numBits.toInt();\n if ((numBits &= 63) === 0) return this;else if (numBits < 32) return fromBits(this.low >>> numBits | this.high << 32 - numBits, this.high >> numBits, this.unsigned);else return fromBits(this.high >> numBits - 32, this.high >= 0 ? 0 : -1, this.unsigned);\n };\n /**\n * Returns this Long with bits arithmetically shifted to the right by the given amount. This is an alias of {@link Long#shiftRight}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n \n \n LongPrototype.shr = LongPrototype.shiftRight;\n /**\n * Returns this Long with bits logically shifted to the right by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n \n LongPrototype.shiftRightUnsigned = function shiftRightUnsigned(numBits) {\n if (isLong(numBits)) numBits = numBits.toInt();\n if ((numBits &= 63) === 0) return this;\n if (numBits < 32) return fromBits(this.low >>> numBits | this.high << 32 - numBits, this.high >>> numBits, this.unsigned);\n if (numBits === 32) return fromBits(this.high, 0, this.unsigned);\n return fromBits(this.high >>> numBits - 32, 0, this.unsigned);\n };\n /**\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n \n \n LongPrototype.shru = LongPrototype.shiftRightUnsigned;\n /**\n * Returns this Long with bits logically shifted to the right by the given amount. This is an alias of {@link Long#shiftRightUnsigned}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Shifted Long\n */\n \n LongPrototype.shr_u = LongPrototype.shiftRightUnsigned;\n /**\n * Returns this Long with bits rotated to the left by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Rotated Long\n */\n \n LongPrototype.rotateLeft = function rotateLeft(numBits) {\n var b;\n if (isLong(numBits)) numBits = numBits.toInt();\n if ((numBits &= 63) === 0) return this;\n if (numBits === 32) return fromBits(this.high, this.low, this.unsigned);\n \n if (numBits < 32) {\n b = 32 - numBits;\n return fromBits(this.low << numBits | this.high >>> b, this.high << numBits | this.low >>> b, this.unsigned);\n }\n \n numBits -= 32;\n b = 32 - numBits;\n return fromBits(this.high << numBits | this.low >>> b, this.low << numBits | this.high >>> b, this.unsigned);\n };\n /**\n * Returns this Long with bits rotated to the left by the given amount. This is an alias of {@link Long#rotateLeft}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Rotated Long\n */\n \n \n LongPrototype.rotl = LongPrototype.rotateLeft;\n /**\n * Returns this Long with bits rotated to the right by the given amount.\n * @this {!Long}\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Rotated Long\n */\n \n LongPrototype.rotateRight = function rotateRight(numBits) {\n var b;\n if (isLong(numBits)) numBits = numBits.toInt();\n if ((numBits &= 63) === 0) return this;\n if (numBits === 32) return fromBits(this.high, this.low, this.unsigned);\n \n if (numBits < 32) {\n b = 32 - numBits;\n return fromBits(this.high << b | this.low >>> numBits, this.low << b | this.high >>> numBits, this.unsigned);\n }\n \n numBits -= 32;\n b = 32 - numBits;\n return fromBits(this.low << b | this.high >>> numBits, this.high << b | this.low >>> numBits, this.unsigned);\n };\n /**\n * Returns this Long with bits rotated to the right by the given amount. This is an alias of {@link Long#rotateRight}.\n * @function\n * @param {number|!Long} numBits Number of bits\n * @returns {!Long} Rotated Long\n */\n \n \n LongPrototype.rotr = LongPrototype.rotateRight;\n /**\n * Converts this Long to signed.\n * @this {!Long}\n * @returns {!Long} Signed long\n */\n \n LongPrototype.toSigned = function toSigned() {\n if (!this.unsigned) return this;\n return fromBits(this.low, this.high, false);\n };\n /**\n * Converts this Long to unsigned.\n * @this {!Long}\n * @returns {!Long} Unsigned long\n */\n \n \n LongPrototype.toUnsigned = function toUnsigned() {\n if (this.unsigned) return this;\n return fromBits(this.low, this.high, true);\n };\n /**\n * Converts this Long to its byte representation.\n * @param {boolean=} le Whether little or big endian, defaults to big endian\n * @this {!Long}\n * @returns {!Array.} Byte representation\n */\n \n \n LongPrototype.toBytes = function toBytes(le) {\n return le ? this.toBytesLE() : this.toBytesBE();\n };\n /**\n * Converts this Long to its little endian byte representation.\n * @this {!Long}\n * @returns {!Array.} Little endian byte representation\n */\n \n \n LongPrototype.toBytesLE = function toBytesLE() {\n var hi = this.high,\n lo = this.low;\n return [lo & 0xff, lo >>> 8 & 0xff, lo >>> 16 & 0xff, lo >>> 24, hi & 0xff, hi >>> 8 & 0xff, hi >>> 16 & 0xff, hi >>> 24];\n };\n /**\n * Converts this Long to its big endian byte representation.\n * @this {!Long}\n * @returns {!Array.} Big endian byte representation\n */\n \n \n LongPrototype.toBytesBE = function toBytesBE() {\n var hi = this.high,\n lo = this.low;\n return [hi >>> 24, hi >>> 16 & 0xff, hi >>> 8 & 0xff, hi & 0xff, lo >>> 24, lo >>> 16 & 0xff, lo >>> 8 & 0xff, lo & 0xff];\n };\n /**\n * Creates a Long from its byte representation.\n * @param {!Array.} bytes Byte representation\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @param {boolean=} le Whether little or big endian, defaults to big endian\n * @returns {Long} The corresponding Long value\n */\n \n \n Long.fromBytes = function fromBytes(bytes, unsigned, le) {\n return le ? Long.fromBytesLE(bytes, unsigned) : Long.fromBytesBE(bytes, unsigned);\n };\n /**\n * Creates a Long from its little endian byte representation.\n * @param {!Array.} bytes Little endian byte representation\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {Long} The corresponding Long value\n */\n \n \n Long.fromBytesLE = function fromBytesLE(bytes, unsigned) {\n return new Long(bytes[0] | bytes[1] << 8 | bytes[2] << 16 | bytes[3] << 24, bytes[4] | bytes[5] << 8 | bytes[6] << 16 | bytes[7] << 24, unsigned);\n };\n /**\n * Creates a Long from its big endian byte representation.\n * @param {!Array.} bytes Big endian byte representation\n * @param {boolean=} unsigned Whether unsigned or not, defaults to signed\n * @returns {Long} The corresponding Long value\n */\n \n \n Long.fromBytesBE = function fromBytesBE(bytes, unsigned) {\n return new Long(bytes[4] << 24 | bytes[5] << 16 | bytes[6] << 8 | bytes[7], bytes[0] << 24 | bytes[1] << 16 | bytes[2] << 8 | bytes[3], unsigned);\n };\n \n var _default = Long;\n exports.default = _default;\n return \"default\" in exports ? exports.default : exports;\n})({});\nif (typeof define === 'function' && define.amd) define([], function() { return Long; });\nelse if (typeof module === 'object' && typeof exports === 'object') module.exports = Long;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = function(module) {\n\tvar getter = module && module.__esModule ?\n\t\tfunction() { return module['default']; } :\n\t\tfunction() { return module; };\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = function(exports, definition) {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); }","// define __esModule on exports\n__webpack_require__.r = function(exports) {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nmd = function(module) {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","__webpack_require__.p = \"/decidim-packs/\";","/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol */\n\nvar extendStatics = function(d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n};\n\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\n\nexport var __assign = function() {\n __assign = Object.assign || function __assign(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)) t[p] = s[p];\n }\n return t;\n }\n return __assign.apply(this, arguments);\n}\n\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n}\n\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\n\nexport function __param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n}\n\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n var _, done = false;\n for (var i = decorators.length - 1; i >= 0; i--) {\n var context = {};\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\n if (kind === \"accessor\") {\n if (result === void 0) continue;\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n if (_ = accept(result.get)) descriptor.get = _;\n if (_ = accept(result.set)) descriptor.set = _;\n if (_ = accept(result.init)) initializers.unshift(_);\n }\n else if (_ = accept(result)) {\n if (kind === \"field\") initializers.unshift(_);\n else descriptor[key] = _;\n }\n }\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\n done = true;\n};\n\nexport function __runInitializers(thisArg, initializers, value) {\n var useValue = arguments.length > 2;\n for (var i = 0; i < initializers.length; i++) {\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n }\n return useValue ? value : void 0;\n};\n\nexport function __propKey(x) {\n return typeof x === \"symbol\" ? x : \"\".concat(x);\n};\n\nexport function __setFunctionName(f, name, prefix) {\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\n};\n\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\n\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\n\nexport function __generator(thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n}\n\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\n\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\n\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\n\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++)\n ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n}\n\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\n\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\n\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\n function fulfill(value) { resume(\"next\", value); }\n function reject(value) { resume(\"throw\", value); }\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\n}\n\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\n}\n\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator], i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\n}\n\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\n return cooked;\n};\n\nvar __setModuleDefault = Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n};\n\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n}\n\nexport function __importDefault(mod) {\n return (mod && mod.__esModule) ? mod : { default: mod };\n}\n\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\n\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n}\n\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\n\nexport function __addDisposableResource(env, value, async) {\n if (value !== null && value !== void 0) {\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n var dispose;\n if (async) {\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n dispose = value[Symbol.asyncDispose];\n }\n if (dispose === void 0) {\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n dispose = value[Symbol.dispose];\n }\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n env.stack.push({ value: value, dispose: dispose, async: async });\n }\n else if (async) {\n env.stack.push({ async: true });\n }\n return value;\n}\n\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n var e = new Error(message);\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\n\nexport function __disposeResources(env) {\n function fail(e) {\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n env.hasError = true;\n }\n function next() {\n while (env.stack.length) {\n var rec = env.stack.pop();\n try {\n var result = rec.dispose && rec.dispose.call(rec.value);\n if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\n }\n catch (e) {\n fail(e);\n }\n }\n if (env.hasError) throw env.error;\n }\n return next();\n}\n\nexport default {\n __extends,\n __assign,\n __rest,\n __decorate,\n __param,\n __metadata,\n __awaiter,\n __generator,\n __createBinding,\n __exportStar,\n __values,\n __read,\n __spread,\n __spreadArrays,\n __spreadArray,\n __await,\n __asyncGenerator,\n __asyncDelegator,\n __asyncValues,\n __makeTemplateObject,\n __importStar,\n __importDefault,\n __classPrivateFieldGet,\n __classPrivateFieldSet,\n __classPrivateFieldIn,\n __addDisposableResource,\n __disposeResources,\n};\n","const genericMessage = \"Invariant Violation\";\nconst {\n setPrototypeOf = function (obj: any, proto: any) {\n obj.__proto__ = proto;\n return obj;\n },\n} = Object as any;\n\nexport class InvariantError extends Error {\n framesToPop = 1;\n name = genericMessage;\n constructor(message: string | number = genericMessage) {\n super(\n typeof message === \"number\"\n ? `${genericMessage}: ${message} (see https://github.com/apollographql/invariant-packages)`\n : message\n );\n setPrototypeOf(this, InvariantError.prototype);\n }\n}\n\nexport function invariant(\n condition: any,\n message?: string | number,\n): asserts condition {\n if (!condition) {\n throw new InvariantError(message);\n }\n}\n\nconst verbosityLevels = [\"debug\", \"log\", \"warn\", \"error\", \"silent\"] as const;\nexport type VerbosityLevel = (typeof verbosityLevels)[number];\nexport type ConsoleMethodName = Exclude;\nlet verbosityLevel = verbosityLevels.indexOf(\"log\");\n\nfunction wrapConsoleMethod(name: M) {\n return function () {\n if (verbosityLevels.indexOf(name) >= verbosityLevel) {\n // Default to console.log if this host environment happens not to provide\n // all the console.* methods we need.\n const method = console[name] || console.log;\n return method.apply(console, arguments as any);\n }\n } as (typeof console)[M];\n}\n\nexport namespace invariant {\n export const debug = wrapConsoleMethod(\"debug\");\n export const log = wrapConsoleMethod(\"log\");\n export const warn = wrapConsoleMethod(\"warn\");\n export const error = wrapConsoleMethod(\"error\");\n}\n\nexport function setVerbosity(level: VerbosityLevel): VerbosityLevel {\n const old = verbosityLevels[verbosityLevel];\n verbosityLevel = Math.max(0, verbosityLevels.indexOf(level));\n return old;\n}\n\nexport default invariant;\n","export const version = \"local\";\n","export function maybe(thunk: () => T): T | undefined {\n try {\n return thunk();\n } catch {}\n}\n","import { maybe } from \"./maybe.js\";\n\ndeclare global {\n const __DEV__: boolean; // will be removed in `dist` by the `postprocessDist` script\n interface Window {\n __DEV__?: boolean;\n }\n}\n\nexport default (maybe(() => globalThis) ||\n maybe(() => window) ||\n maybe(() => self) ||\n maybe(() => global) ||\n // We don't expect the Function constructor ever to be invoked at runtime, as\n // long as at least one of globalThis, window, self, or global is defined, so\n // we are under no obligation to make it easy for static analysis tools to\n // detect syntactic usage of the Function constructor. If you think you can\n // improve your static analysis to detect this obfuscation, think again. This\n // is an arms race you cannot win, at least not in JavaScript.\n maybe(function () {\n return maybe.constructor(\"return this\")();\n })) as typeof globalThis & Window;\n","const prefixCounts = new Map();\n\n// These IDs won't be globally unique, but they will be unique within this\n// process, thanks to the counter, and unguessable thanks to the random suffix.\nexport function makeUniqueId(prefix: string) {\n const count = prefixCounts.get(prefix) || 1;\n prefixCounts.set(prefix, count + 1);\n return `${prefix}:${count}:${Math.random().toString(36).slice(2)}`;\n}\n","import { makeUniqueId } from \"./makeUniqueId.js\";\n\nexport function stringifyForDisplay(value: any, space = 0): string {\n const undefId = makeUniqueId(\"stringifyForDisplay\");\n return JSON.stringify(\n value,\n (key, value) => {\n return value === void 0 ? undefId : value;\n },\n space\n )\n .split(JSON.stringify(undefId))\n .join(\"\");\n}\n","import { invariant as originalInvariant, InvariantError } from \"ts-invariant\";\nimport { version } from \"../../version.js\";\nimport global from \"./global.js\";\nimport type { ErrorCodes } from \"../../invariantErrorCodes.js\";\nimport { stringifyForDisplay } from \"../common/stringifyForDisplay.js\";\n\nfunction wrap(fn: (msg?: string, ...args: any[]) => void) {\n return function (message?: string | number, ...args: any[]) {\n if (typeof message === \"number\") {\n const arg0 = message;\n message = getHandledErrorMsg(arg0);\n if (!message) {\n message = getFallbackErrorMsg(arg0, args);\n args = [];\n }\n }\n fn(...[message].concat(args));\n };\n}\n\ntype LogFunction = {\n /**\n * Logs a `$level` message if the user used `ts-invariant`'s `setVerbosity` to set\n * a verbosity level of `$level` or lower. (defaults to `\"log\"`).\n *\n * The user will either be presented with a link to the documentation for the message,\n * or they can use the `loadDevMessages` to add the message strings to the bundle.\n * The documentation will display the message without argument substitution.\n * Instead, the arguments will be printed on the console after the link.\n *\n * `message` can only be a string, a concatenation of strings, or a ternary statement\n * that results in a string. This will be enforced on build, where the message will\n * be replaced with a message number.\n *\n * String substitutions like %s, %o, %d or %f are supported.\n */\n (message?: any, ...optionalParams: unknown[]): void;\n};\n\ntype WrappedInvariant = {\n /**\n * Throws and InvariantError with the given message if the condition is false.\n *\n * `message` can only be a string, a concatenation of strings, or a ternary statement\n * that results in a string. This will be enforced on build, where the message will\n * be replaced with a message number.\n *\n * The user will either be presented with a link to the documentation for the message,\n * or they can use the `loadErrorMessages` to add the message strings to the bundle.\n * The documentation will display the message with the arguments substituted.\n *\n * String substitutions with %s are supported and will also return\n * pretty-stringified objects.\n * Excess `optionalParams` will be swallowed.\n */\n (\n condition: any,\n message?: string | number,\n ...optionalParams: unknown[]\n ): asserts condition;\n\n debug: LogFunction;\n log: LogFunction;\n warn: LogFunction;\n error: LogFunction;\n};\nconst invariant: WrappedInvariant = Object.assign(\n function invariant(\n condition: any,\n message?: string | number,\n ...args: unknown[]\n ): asserts condition {\n if (!condition) {\n originalInvariant(\n condition,\n getHandledErrorMsg(message, args) || getFallbackErrorMsg(message, args)\n );\n }\n },\n {\n debug: wrap(originalInvariant.debug),\n log: wrap(originalInvariant.log),\n warn: wrap(originalInvariant.warn),\n error: wrap(originalInvariant.error),\n }\n);\n\n/**\n * Returns an InvariantError.\n *\n * `message` can only be a string, a concatenation of strings, or a ternary statement\n * that results in a string. This will be enforced on build, where the message will\n * be replaced with a message number.\n * String substitutions with %s are supported and will also return\n * pretty-stringified objects.\n * Excess `optionalParams` will be swallowed.\n */\nfunction newInvariantError(\n message?: string | number,\n ...optionalParams: unknown[]\n) {\n return new InvariantError(\n getHandledErrorMsg(message, optionalParams) ||\n getFallbackErrorMsg(message, optionalParams)\n );\n}\n\nconst ApolloErrorMessageHandler = Symbol.for(\n \"ApolloErrorMessageHandler_\" + version\n);\ndeclare global {\n interface Window {\n [ApolloErrorMessageHandler]?: {\n (message: string | number, args: string[]): string | undefined;\n } & ErrorCodes;\n }\n}\n\nfunction stringify(arg: any) {\n return typeof arg == \"string\" ? arg : (\n stringifyForDisplay(arg, 2).slice(0, 1000)\n );\n}\n\nfunction getHandledErrorMsg(\n message?: string | number,\n messageArgs: unknown[] = []\n) {\n if (!message) return;\n return (\n global[ApolloErrorMessageHandler] &&\n global[ApolloErrorMessageHandler](message, messageArgs.map(stringify))\n );\n}\n\nfunction getFallbackErrorMsg(\n message?: string | number,\n messageArgs: unknown[] = []\n) {\n if (!message) return;\n return `An error occurred! For more details, see the full error text at https://go.apollo.dev/c/err#${encodeURIComponent(\n JSON.stringify({\n version,\n message,\n args: messageArgs.map(stringify),\n })\n )}`;\n}\n\nexport {\n invariant,\n InvariantError,\n newInvariantError,\n ApolloErrorMessageHandler,\n};\n","import {\n invariant,\n newInvariantError,\n InvariantError,\n} from \"./invariantWrappers.js\";\n\nexport { maybe } from \"./maybe.js\";\nexport { default as global } from \"./global.js\";\nexport { invariant, newInvariantError, InvariantError };\n\n/**\n * @deprecated we do not use this internally anymore,\n * it is just exported for backwards compatibility\n */\n// this file is extempt from automatic `__DEV__` replacement\n// so we have to write it out here\n// @ts-ignore\nexport const DEV = globalThis.__DEV__ !== false;\nexport { DEV as __DEV__ };\n","function _createForOfIteratorHelperLoose(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (it) return (it = it.call(o)).next.bind(it); if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; return function () { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n// === Symbol Support ===\nvar hasSymbols = function () {\n return typeof Symbol === 'function';\n};\n\nvar hasSymbol = function (name) {\n return hasSymbols() && Boolean(Symbol[name]);\n};\n\nvar getSymbol = function (name) {\n return hasSymbol(name) ? Symbol[name] : '@@' + name;\n};\n\nif (hasSymbols() && !hasSymbol('observable')) {\n Symbol.observable = Symbol('observable');\n}\n\nvar SymbolIterator = getSymbol('iterator');\nvar SymbolObservable = getSymbol('observable');\nvar SymbolSpecies = getSymbol('species'); // === Abstract Operations ===\n\nfunction getMethod(obj, key) {\n var value = obj[key];\n if (value == null) return undefined;\n if (typeof value !== 'function') throw new TypeError(value + ' is not a function');\n return value;\n}\n\nfunction getSpecies(obj) {\n var ctor = obj.constructor;\n\n if (ctor !== undefined) {\n ctor = ctor[SymbolSpecies];\n\n if (ctor === null) {\n ctor = undefined;\n }\n }\n\n return ctor !== undefined ? ctor : Observable;\n}\n\nfunction isObservable(x) {\n return x instanceof Observable; // SPEC: Brand check\n}\n\nfunction hostReportError(e) {\n if (hostReportError.log) {\n hostReportError.log(e);\n } else {\n setTimeout(function () {\n throw e;\n });\n }\n}\n\nfunction enqueue(fn) {\n Promise.resolve().then(function () {\n try {\n fn();\n } catch (e) {\n hostReportError(e);\n }\n });\n}\n\nfunction cleanupSubscription(subscription) {\n var cleanup = subscription._cleanup;\n if (cleanup === undefined) return;\n subscription._cleanup = undefined;\n\n if (!cleanup) {\n return;\n }\n\n try {\n if (typeof cleanup === 'function') {\n cleanup();\n } else {\n var unsubscribe = getMethod(cleanup, 'unsubscribe');\n\n if (unsubscribe) {\n unsubscribe.call(cleanup);\n }\n }\n } catch (e) {\n hostReportError(e);\n }\n}\n\nfunction closeSubscription(subscription) {\n subscription._observer = undefined;\n subscription._queue = undefined;\n subscription._state = 'closed';\n}\n\nfunction flushSubscription(subscription) {\n var queue = subscription._queue;\n\n if (!queue) {\n return;\n }\n\n subscription._queue = undefined;\n subscription._state = 'ready';\n\n for (var i = 0; i < queue.length; ++i) {\n notifySubscription(subscription, queue[i].type, queue[i].value);\n if (subscription._state === 'closed') break;\n }\n}\n\nfunction notifySubscription(subscription, type, value) {\n subscription._state = 'running';\n var observer = subscription._observer;\n\n try {\n var m = getMethod(observer, type);\n\n switch (type) {\n case 'next':\n if (m) m.call(observer, value);\n break;\n\n case 'error':\n closeSubscription(subscription);\n if (m) m.call(observer, value);else throw value;\n break;\n\n case 'complete':\n closeSubscription(subscription);\n if (m) m.call(observer);\n break;\n }\n } catch (e) {\n hostReportError(e);\n }\n\n if (subscription._state === 'closed') cleanupSubscription(subscription);else if (subscription._state === 'running') subscription._state = 'ready';\n}\n\nfunction onNotify(subscription, type, value) {\n if (subscription._state === 'closed') return;\n\n if (subscription._state === 'buffering') {\n subscription._queue.push({\n type: type,\n value: value\n });\n\n return;\n }\n\n if (subscription._state !== 'ready') {\n subscription._state = 'buffering';\n subscription._queue = [{\n type: type,\n value: value\n }];\n enqueue(function () {\n return flushSubscription(subscription);\n });\n return;\n }\n\n notifySubscription(subscription, type, value);\n}\n\nvar Subscription = /*#__PURE__*/function () {\n function Subscription(observer, subscriber) {\n // ASSERT: observer is an object\n // ASSERT: subscriber is callable\n this._cleanup = undefined;\n this._observer = observer;\n this._queue = undefined;\n this._state = 'initializing';\n var subscriptionObserver = new SubscriptionObserver(this);\n\n try {\n this._cleanup = subscriber.call(undefined, subscriptionObserver);\n } catch (e) {\n subscriptionObserver.error(e);\n }\n\n if (this._state === 'initializing') this._state = 'ready';\n }\n\n var _proto = Subscription.prototype;\n\n _proto.unsubscribe = function unsubscribe() {\n if (this._state !== 'closed') {\n closeSubscription(this);\n cleanupSubscription(this);\n }\n };\n\n _createClass(Subscription, [{\n key: \"closed\",\n get: function () {\n return this._state === 'closed';\n }\n }]);\n\n return Subscription;\n}();\n\nvar SubscriptionObserver = /*#__PURE__*/function () {\n function SubscriptionObserver(subscription) {\n this._subscription = subscription;\n }\n\n var _proto2 = SubscriptionObserver.prototype;\n\n _proto2.next = function next(value) {\n onNotify(this._subscription, 'next', value);\n };\n\n _proto2.error = function error(value) {\n onNotify(this._subscription, 'error', value);\n };\n\n _proto2.complete = function complete() {\n onNotify(this._subscription, 'complete');\n };\n\n _createClass(SubscriptionObserver, [{\n key: \"closed\",\n get: function () {\n return this._subscription._state === 'closed';\n }\n }]);\n\n return SubscriptionObserver;\n}();\n\nvar Observable = /*#__PURE__*/function () {\n function Observable(subscriber) {\n if (!(this instanceof Observable)) throw new TypeError('Observable cannot be called as a function');\n if (typeof subscriber !== 'function') throw new TypeError('Observable initializer must be a function');\n this._subscriber = subscriber;\n }\n\n var _proto3 = Observable.prototype;\n\n _proto3.subscribe = function subscribe(observer) {\n if (typeof observer !== 'object' || observer === null) {\n observer = {\n next: observer,\n error: arguments[1],\n complete: arguments[2]\n };\n }\n\n return new Subscription(observer, this._subscriber);\n };\n\n _proto3.forEach = function forEach(fn) {\n var _this = this;\n\n return new Promise(function (resolve, reject) {\n if (typeof fn !== 'function') {\n reject(new TypeError(fn + ' is not a function'));\n return;\n }\n\n function done() {\n subscription.unsubscribe();\n resolve();\n }\n\n var subscription = _this.subscribe({\n next: function (value) {\n try {\n fn(value, done);\n } catch (e) {\n reject(e);\n subscription.unsubscribe();\n }\n },\n error: reject,\n complete: resolve\n });\n });\n };\n\n _proto3.map = function map(fn) {\n var _this2 = this;\n\n if (typeof fn !== 'function') throw new TypeError(fn + ' is not a function');\n var C = getSpecies(this);\n return new C(function (observer) {\n return _this2.subscribe({\n next: function (value) {\n try {\n value = fn(value);\n } catch (e) {\n return observer.error(e);\n }\n\n observer.next(value);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n observer.complete();\n }\n });\n });\n };\n\n _proto3.filter = function filter(fn) {\n var _this3 = this;\n\n if (typeof fn !== 'function') throw new TypeError(fn + ' is not a function');\n var C = getSpecies(this);\n return new C(function (observer) {\n return _this3.subscribe({\n next: function (value) {\n try {\n if (!fn(value)) return;\n } catch (e) {\n return observer.error(e);\n }\n\n observer.next(value);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n observer.complete();\n }\n });\n });\n };\n\n _proto3.reduce = function reduce(fn) {\n var _this4 = this;\n\n if (typeof fn !== 'function') throw new TypeError(fn + ' is not a function');\n var C = getSpecies(this);\n var hasSeed = arguments.length > 1;\n var hasValue = false;\n var seed = arguments[1];\n var acc = seed;\n return new C(function (observer) {\n return _this4.subscribe({\n next: function (value) {\n var first = !hasValue;\n hasValue = true;\n\n if (!first || hasSeed) {\n try {\n acc = fn(acc, value);\n } catch (e) {\n return observer.error(e);\n }\n } else {\n acc = value;\n }\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n if (!hasValue && !hasSeed) return observer.error(new TypeError('Cannot reduce an empty sequence'));\n observer.next(acc);\n observer.complete();\n }\n });\n });\n };\n\n _proto3.concat = function concat() {\n var _this5 = this;\n\n for (var _len = arguments.length, sources = new Array(_len), _key = 0; _key < _len; _key++) {\n sources[_key] = arguments[_key];\n }\n\n var C = getSpecies(this);\n return new C(function (observer) {\n var subscription;\n var index = 0;\n\n function startNext(next) {\n subscription = next.subscribe({\n next: function (v) {\n observer.next(v);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n if (index === sources.length) {\n subscription = undefined;\n observer.complete();\n } else {\n startNext(C.from(sources[index++]));\n }\n }\n });\n }\n\n startNext(_this5);\n return function () {\n if (subscription) {\n subscription.unsubscribe();\n subscription = undefined;\n }\n };\n });\n };\n\n _proto3.flatMap = function flatMap(fn) {\n var _this6 = this;\n\n if (typeof fn !== 'function') throw new TypeError(fn + ' is not a function');\n var C = getSpecies(this);\n return new C(function (observer) {\n var subscriptions = [];\n\n var outer = _this6.subscribe({\n next: function (value) {\n if (fn) {\n try {\n value = fn(value);\n } catch (e) {\n return observer.error(e);\n }\n }\n\n var inner = C.from(value).subscribe({\n next: function (value) {\n observer.next(value);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n var i = subscriptions.indexOf(inner);\n if (i >= 0) subscriptions.splice(i, 1);\n completeIfDone();\n }\n });\n subscriptions.push(inner);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n completeIfDone();\n }\n });\n\n function completeIfDone() {\n if (outer.closed && subscriptions.length === 0) observer.complete();\n }\n\n return function () {\n subscriptions.forEach(function (s) {\n return s.unsubscribe();\n });\n outer.unsubscribe();\n };\n });\n };\n\n _proto3[SymbolObservable] = function () {\n return this;\n };\n\n Observable.from = function from(x) {\n var C = typeof this === 'function' ? this : Observable;\n if (x == null) throw new TypeError(x + ' is not an object');\n var method = getMethod(x, SymbolObservable);\n\n if (method) {\n var observable = method.call(x);\n if (Object(observable) !== observable) throw new TypeError(observable + ' is not an object');\n if (isObservable(observable) && observable.constructor === C) return observable;\n return new C(function (observer) {\n return observable.subscribe(observer);\n });\n }\n\n if (hasSymbol('iterator')) {\n method = getMethod(x, SymbolIterator);\n\n if (method) {\n return new C(function (observer) {\n enqueue(function () {\n if (observer.closed) return;\n\n for (var _iterator = _createForOfIteratorHelperLoose(method.call(x)), _step; !(_step = _iterator()).done;) {\n var item = _step.value;\n observer.next(item);\n if (observer.closed) return;\n }\n\n observer.complete();\n });\n });\n }\n }\n\n if (Array.isArray(x)) {\n return new C(function (observer) {\n enqueue(function () {\n if (observer.closed) return;\n\n for (var i = 0; i < x.length; ++i) {\n observer.next(x[i]);\n if (observer.closed) return;\n }\n\n observer.complete();\n });\n });\n }\n\n throw new TypeError(x + ' is not observable');\n };\n\n Observable.of = function of() {\n for (var _len2 = arguments.length, items = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n items[_key2] = arguments[_key2];\n }\n\n var C = typeof this === 'function' ? this : Observable;\n return new C(function (observer) {\n enqueue(function () {\n if (observer.closed) return;\n\n for (var i = 0; i < items.length; ++i) {\n observer.next(items[i]);\n if (observer.closed) return;\n }\n\n observer.complete();\n });\n });\n };\n\n _createClass(Observable, null, [{\n key: SymbolSpecies,\n get: function () {\n return this;\n }\n }]);\n\n return Observable;\n}();\n\nif (hasSymbols()) {\n Object.defineProperty(Observable, Symbol('extensions'), {\n value: {\n symbol: SymbolObservable,\n hostReportError: hostReportError\n },\n configurable: true\n });\n}\n\nexport { Observable };\n","export function isNonNullObject(obj: any): obj is Record {\n return obj !== null && typeof obj === \"object\";\n}\n\nexport function isPlainObject(obj: any): obj is Record {\n return (\n obj !== null &&\n typeof obj === \"object\" &&\n (Object.getPrototypeOf(obj) === Object.prototype ||\n Object.getPrototypeOf(obj) === null)\n );\n}\n","import { invariant, newInvariantError } from \"../globals/index.js\";\n\nimport type {\n DocumentNode,\n FragmentDefinitionNode,\n InlineFragmentNode,\n SelectionNode,\n} from \"graphql\";\n\n// TODO(brian): A hack until this issue is resolved (https://github.com/graphql/graphql-js/issues/3356)\ntype Kind = any;\ntype OperationTypeNode = any;\n/**\n * Returns a query document which adds a single query operation that only\n * spreads the target fragment inside of it.\n *\n * So for example a document of:\n *\n * ```graphql\n * fragment foo on Foo { a b c }\n * ```\n *\n * Turns into:\n *\n * ```graphql\n * { ...foo }\n *\n * fragment foo on Foo { a b c }\n * ```\n *\n * The target fragment will either be the only fragment in the document, or a\n * fragment specified by the provided `fragmentName`. If there is more than one\n * fragment, but a `fragmentName` was not defined then an error will be thrown.\n */\nexport function getFragmentQueryDocument(\n document: DocumentNode,\n fragmentName?: string\n): DocumentNode {\n let actualFragmentName = fragmentName;\n\n // Build an array of all our fragment definitions that will be used for\n // validations. We also do some validations on the other definitions in the\n // document while building this list.\n const fragments: Array = [];\n document.definitions.forEach((definition) => {\n // Throw an error if we encounter an operation definition because we will\n // define our own operation definition later on.\n if (definition.kind === \"OperationDefinition\") {\n throw newInvariantError(\n `Found a %s operation%s. ` +\n \"No operations are allowed when using a fragment as a query. Only fragments are allowed.\",\n definition.operation,\n definition.name ? ` named '${definition.name.value}'` : \"\"\n );\n }\n // Add our definition to the fragments array if it is a fragment\n // definition.\n if (definition.kind === \"FragmentDefinition\") {\n fragments.push(definition);\n }\n });\n\n // If the user did not give us a fragment name then let us try to get a\n // name from a single fragment in the definition.\n if (typeof actualFragmentName === \"undefined\") {\n invariant(\n fragments.length === 1,\n `Found %s fragments. \\`fragmentName\\` must be provided when there is not exactly 1 fragment.`,\n fragments.length\n );\n actualFragmentName = fragments[0].name.value;\n }\n\n // Generate a query document with an operation that simply spreads the\n // fragment inside of it.\n const query: DocumentNode = {\n ...document,\n definitions: [\n {\n kind: \"OperationDefinition\" as Kind,\n // OperationTypeNode is an enum\n operation: \"query\" as OperationTypeNode,\n selectionSet: {\n kind: \"SelectionSet\" as Kind,\n selections: [\n {\n kind: \"FragmentSpread\" as Kind,\n name: {\n kind: \"Name\" as Kind,\n value: actualFragmentName,\n },\n },\n ],\n },\n },\n ...document.definitions,\n ],\n };\n\n return query;\n}\n\n/**\n * This is an interface that describes a map from fragment names to fragment definitions.\n */\nexport interface FragmentMap {\n [fragmentName: string]: FragmentDefinitionNode;\n}\n\nexport type FragmentMapFunction = (\n fragmentName: string\n) => FragmentDefinitionNode | null;\n\n// Utility function that takes a list of fragment definitions and makes a hash out of them\n// that maps the name of the fragment to the fragment definition.\nexport function createFragmentMap(\n fragments: FragmentDefinitionNode[] = []\n): FragmentMap {\n const symTable: FragmentMap = {};\n fragments.forEach((fragment) => {\n symTable[fragment.name.value] = fragment;\n });\n return symTable;\n}\n\nexport function getFragmentFromSelection(\n selection: SelectionNode,\n fragmentMap?: FragmentMap | FragmentMapFunction\n): InlineFragmentNode | FragmentDefinitionNode | null {\n switch (selection.kind) {\n case \"InlineFragment\":\n return selection;\n case \"FragmentSpread\": {\n const fragmentName = selection.name.value;\n if (typeof fragmentMap === \"function\") {\n return fragmentMap(fragmentName);\n }\n const fragment = fragmentMap && fragmentMap[fragmentName];\n invariant(fragment, `No fragment named %s`, fragmentName);\n return fragment || null;\n }\n default:\n return null;\n }\n}\n",null,null,"import { WeakCache, StrongCache } from \"@wry/caches\";\n\ninterface CleanableCache {\n size: number;\n max?: number;\n clean: () => void;\n}\nconst scheduledCleanup = new WeakSet();\nfunction schedule(cache: CleanableCache) {\n if (cache.size <= (cache.max || -1)) {\n return;\n }\n if (!scheduledCleanup.has(cache)) {\n scheduledCleanup.add(cache);\n setTimeout(() => {\n cache.clean();\n scheduledCleanup.delete(cache);\n }, 100);\n }\n}\n/**\n * @internal\n * A version of WeakCache that will auto-schedule a cleanup of the cache when\n * a new item is added and the cache reached maximum size.\n * Throttled to once per 100ms.\n *\n * @privateRemarks\n * Should be used throughout the rest of the codebase instead of WeakCache,\n * with the notable exception of usage in `wrap` from `optimism` - that one\n * already handles cleanup and should remain a `WeakCache`.\n */\nexport const AutoCleanedWeakCache = function (\n max?: number | undefined,\n dispose?: ((value: any, key: any) => void) | undefined\n) {\n /*\n Some builds of `WeakCache` are function prototypes, some are classes.\n This library still builds with an ES5 target, so we can't extend the\n real classes.\n Instead, we have to use this workaround until we switch to a newer build\n target.\n */\n const cache = new WeakCache(max, dispose);\n cache.set = function (key: any, value: any) {\n const ret = WeakCache.prototype.set.call(this, key, value);\n schedule(this as any as CleanableCache);\n return ret;\n };\n return cache;\n} as any as typeof WeakCache;\n/**\n * @internal\n */\nexport type AutoCleanedWeakCache = WeakCache;\n\n/**\n * @internal\n * A version of StrongCache that will auto-schedule a cleanup of the cache when\n * a new item is added and the cache reached maximum size.\n * Throttled to once per 100ms.\n *\n * @privateRemarks\n * Should be used throughout the rest of the codebase instead of StrongCache,\n * with the notable exception of usage in `wrap` from `optimism` - that one\n * already handles cleanup and should remain a `StrongCache`.\n */\nexport const AutoCleanedStrongCache = function (\n max?: number | undefined,\n dispose?: ((value: any, key: any) => void) | undefined\n) {\n /*\n Some builds of `StrongCache` are function prototypes, some are classes.\n This library still builds with an ES5 target, so we can't extend the\n real classes.\n Instead, we have to use this workaround until we switch to a newer build\n target.\n */\n const cache = new StrongCache(max, dispose);\n cache.set = function (key: any, value: any) {\n const ret = StrongCache.prototype.set.call(this, key, value);\n schedule(this as any as CleanableCache);\n return ret;\n };\n return cache;\n} as any as typeof StrongCache;\n/**\n * @internal\n */\nexport type AutoCleanedStrongCache = StrongCache;\n","import { global } from \"../globals/index.js\";\n\ndeclare global {\n interface Window {\n [cacheSizeSymbol]?: Partial;\n }\n}\n\n/**\n * The cache sizes used by various Apollo Client caches.\n *\n * @remarks\n * All configurable caches hold memoized values. If an item is\n * cache-collected, it incurs only a small performance impact and\n * doesn't cause data loss. A smaller cache size might save you memory.\n *\n * You should choose cache sizes appropriate for storing a reasonable\n * number of values rather than every value. To prevent too much recalculation,\n * choose cache sizes that are at least large enough to hold memoized values for\n * all hooks/queries on the screen at any given time.\n */\n/*\n * We assume a \"base value\" of 1000 here, which is already very generous.\n * In most applications, it will be very unlikely that 1000 different queries\n * are on screen at the same time.\n */\nexport interface CacheSizes {\n /**\n * Cache size for the [`print`](https://github.com/apollographql/apollo-client/blob/main/src/utilities/graphql/print.ts) function.\n *\n * It is called with transformed `DocumentNode`s.\n *\n * @defaultValue\n * Defaults to `2000`.\n *\n * @remarks\n * This method is called to transform a GraphQL query AST parsed by `gql`\n * back into a GraphQL string.\n *\n * @privateRemarks\n * This method is called from the `QueryManager` and various `ApolloLink`s,\n * always with the \"serverQuery\", so the server-facing part of a transformed\n * `DocumentNode`.\n */\n print: number;\n /**\n * Cache size for the [`parser`](https://github.com/apollographql/apollo-client/blob/main/src/react/parser/index.ts) function.\n *\n * It is called with user-provided `DocumentNode`s.\n *\n * @defaultValue\n * Defaults to `1000`.\n *\n * @remarks\n * This method is called by HOCs and hooks.\n *\n * @privateRemarks\n * This function is used directly in HOCs, and nowadays mainly accessed by\n * calling `verifyDocumentType` from various hooks.\n * It is called with a user-provided DocumentNode.\n */\n parser: number;\n /**\n * Cache size for the cache of [`DocumentTransform`](https://github.com/apollographql/apollo-client/blob/main/src/utilities/graphql/DocumentTransform.ts)\n * instances with the `cache` option set to `true`.\n *\n * Can be called with user-defined or already-transformed `DocumentNode`s.\n *\n * @defaultValue\n * Defaults to `2000`.\n *\n * @remarks\n * The cache size here should be chosen with other `DocumentTransform`s in mind.\n * For example, if there was a `DocumentTransform` that would take `x` `DocumentNode`s,\n * and returned a differently-transformed `DocumentNode` depending if the app is\n * online or offline, then we assume that the cache returns `2*x` documents.\n * If that were concatenated with another `DocumentTransform` that would\n * also duplicate the cache size, you'd need to account for `4*x` documents\n * returned by the second transform.\n *\n * Due to an implementation detail of Apollo Client, if you use custom document\n * transforms you should always add `n` (the \"base\" number of user-provided\n * Documents) to the resulting cache size.\n *\n * If we assume that the user-provided transforms receive `n` documents and\n * return `n` documents, the cache size should be `2*n`.\n *\n * If we assume that the chain of user-provided transforms receive `n` documents and\n * return `4*n` documents, the cache size should be `5*n`.\n *\n * This size should also then be used in every other cache that mentions that\n * it operates on a \"transformed\" `DocumentNode`.\n *\n * @privateRemarks\n * Cache size for the `performWork` method of each [`DocumentTransform`](https://github.com/apollographql/apollo-client/blob/main/src/utilities/graphql/DocumentTransform.ts).\n *\n * No user-provided DocumentNode will actually be \"the last one\", as we run the\n * `defaultDocumentTransform` before *and* after the user-provided transforms.\n * For that reason, we need the extra `n` here - `n` for \"before transformation\"\n * plus the actual maximum cache size of the user-provided transform chain.\n *\n * This method is called from `transformDocument`, which is called from\n * `QueryManager` with a user-provided DocumentNode.\n * It is also called with already-transformed DocumentNodes, assuming the\n * user provided additional transforms.\n *\n */\n \"documentTransform.cache\": number;\n /**\n * A cache inside of [`QueryManager`](https://github.com/apollographql/apollo-client/blob/main/src/core/QueryManager.ts).\n *\n * It is called with transformed `DocumentNode`s.\n *\n * @defaultValue\n * Defaults to `2000`.\n *\n * @privateRemarks\n * Cache size for the `transformCache` used in the `getDocumentInfo` method of `QueryManager`.\n * Called throughout the `QueryManager` with transformed DocumentNodes.\n */\n \"queryManager.getDocumentInfo\": number;\n /**\n * A cache inside of [`PersistedQueryLink`](https://github.com/apollographql/apollo-client/blob/main/src/link/persisted-queries/index.ts).\n *\n * It is called with transformed `DocumentNode`s.\n *\n * @defaultValue\n * Defaults to `2000`.\n *\n * @remarks\n * This cache is used to cache the hashes of persisted queries.\n *\n * @privateRemarks\n * Cache size for the `hashesByQuery` cache in the `PersistedQueryLink`.\n */\n \"PersistedQueryLink.persistedQueryHashes\": number;\n /**\n * Cache used by [`canonicalStringify`](https://github.com/apollographql/apollo-client/blob/main/src/utilities/common/canonicalStringify.ts).\n *\n * @defaultValue\n * Defaults to `1000`.\n *\n * @remarks\n * This cache contains the sorted keys of objects that are stringified by\n * `canonicalStringify`.\n * It uses the stringified unsorted keys of objects as keys.\n * The cache will not grow beyond the size of different object **shapes**\n * encountered in an application, no matter how much actual data gets stringified.\n *\n * @privateRemarks\n * Cache size for the `sortingMap` in `canonicalStringify`.\n */\n canonicalStringify: number;\n /**\n * A cache inside of [`FragmentRegistry`](https://github.com/apollographql/apollo-client/blob/main/src/cache/inmemory/fragmentRegistry.ts).\n *\n * Can be called with user-defined or already-transformed `DocumentNode`s.\n *\n * @defaultValue\n * Defaults to `2000`.\n *\n * @privateRemarks\n *\n * Cache size for the `transform` method of FragmentRegistry.\n * This function is called as part of the `defaultDocumentTransform` which will be called with\n * user-provided and already-transformed DocumentNodes.\n *\n */\n \"fragmentRegistry.transform\": number;\n /**\n * A cache inside of [`FragmentRegistry`](https://github.com/apollographql/apollo-client/blob/main/src/cache/inmemory/fragmentRegistry.ts).\n *\n * This function is called with fragment names in the form of a string.\n *\n * @defaultValue\n * Defaults to `1000`.\n *\n * @remarks\n * The size of this case should be chosen with the number of fragments in\n * your application in mind.\n *\n * Note:\n * This function is a dependency of `fragmentRegistry.transform`, so having too small of a cache size here\n * might involuntarily invalidate values in the `transform` cache.\n *\n * @privateRemarks\n * Cache size for the `lookup` method of FragmentRegistry.\n */\n \"fragmentRegistry.lookup\": number;\n /**\n * Cache size for the `findFragmentSpreads` method of [`FragmentRegistry`](https://github.com/apollographql/apollo-client/blob/main/src/cache/inmemory/fragmentRegistry.ts).\n *\n * This function is called with transformed `DocumentNode`s, as well as recursively\n * with every fragment spread referenced within that, or a fragment referenced by a\n * fragment spread.\n *\n * @defaultValue\n * Defaults to `4000`.\n *\n * @remarks\n *\n * Note: This function is a dependency of `fragmentRegistry.transform`, so having too small of cache size here\n * might involuntarily invalidate values in the `transform` cache.\n */\n \"fragmentRegistry.findFragmentSpreads\": number;\n /**\n * Cache size for the `getFragmentDoc` method of [`ApolloCache`](https://github.com/apollographql/apollo-client/blob/main/src/cache/core/cache.ts).\n *\n * This function is called with user-provided fragment definitions.\n *\n * @defaultValue\n * Defaults to `1000`.\n *\n * @remarks\n * This function is called from `readFragment` with user-provided fragment definitions.\n */\n \"cache.fragmentQueryDocuments\": number;\n /**\n * Cache used in [`removeTypenameFromVariables`](https://github.com/apollographql/apollo-client/blob/main/src/link/remove-typename/removeTypenameFromVariables.ts).\n *\n * This function is called transformed `DocumentNode`s.\n *\n * @defaultValue\n * Defaults to `2000`.\n *\n * @privateRemarks\n * Cache size for the `getVariableDefinitions` function of `removeTypenameFromVariables`.\n */\n \"removeTypenameFromVariables.getVariableDefinitions\": number;\n /**\n * Cache size for the `maybeBroadcastWatch` method on [`InMemoryCache`](https://github.com/apollographql/apollo-client/blob/main/src/cache/inmemory/inMemoryCache.ts).\n *\n * Note: `maybeBroadcastWatch` will be set to the `resultCacheMaxSize` option and\n * will fall back to this configuration value if the option is not set.\n *\n * @defaultValue\n * Defaults to `5000`.\n *\n * @remarks\n * This method is used for dependency tracking in the `InMemoryCache` and\n * prevents from unnecessary re-renders.\n * It is recommended to keep this value significantly higher than the number of\n * possible subscribers you will have active at the same time in your application\n * at any time.\n */\n \"inMemoryCache.maybeBroadcastWatch\": number;\n /**\n * Cache size for the `executeSelectionSet` method on [`StoreReader`](https://github.com/apollographql/apollo-client/blob/main/src/cache/inmemory/readFromStore.ts).\n *\n * Note:\n * `executeSelectionSet` will be set to the `resultCacheMaxSize` option and\n * will fall back to this configuration value if the option is not set.\n *\n * @defaultValue\n * Defaults to `10000`.\n *\n * @remarks\n * Every object that is read from the cache will be cached here, so it is\n * recommended to set this to a high value.\n */\n \"inMemoryCache.executeSelectionSet\": number;\n /**\n * Cache size for the `executeSubSelectedArray` method on [`StoreReader`](https://github.com/apollographql/apollo-client/blob/main/src/cache/inmemory/readFromStore.ts).\n *\n * Note:\n * `executeSubSelectedArray` will be set to the `resultCacheMaxSize` option and\n * will fall back to this configuration value if the option is not set.\n *\n * @defaultValue\n * Defaults to `5000`.\n *\n * @remarks\n * Every array that is read from the cache will be cached here, so it is\n * recommended to set this to a high value.\n */\n \"inMemoryCache.executeSubSelectedArray\": number;\n}\n\nconst cacheSizeSymbol = Symbol.for(\"apollo.cacheSize\");\n/**\n *\n * The global cache size configuration for Apollo Client.\n *\n * @remarks\n *\n * You can directly modify this object, but any modification will\n * only have an effect on caches that are created after the modification.\n *\n * So for global caches, such as `parser`, `canonicalStringify` and `print`,\n * you might need to call `.reset` on them, which will essentially re-create them.\n *\n * Alternatively, you can set `globalThis[Symbol.for(\"apollo.cacheSize\")]` before\n * you load the Apollo Client package:\n *\n * @example\n * ```ts\n * globalThis[Symbol.for(\"apollo.cacheSize\")] = {\n * parser: 100\n * } satisfies Partial // the `satisfies` is optional if using TypeScript\n * ```\n */\nexport const cacheSizes: Partial = { ...global[cacheSizeSymbol] };\n\nexport const enum defaultCacheSizes {\n parser = 1000,\n canonicalStringify = 1000,\n print = 2000,\n \"documentTransform.cache\" = 2000,\n \"queryManager.getDocumentInfo\" = 2000,\n \"PersistedQueryLink.persistedQueryHashes\" = 2000,\n \"fragmentRegistry.transform\" = 2000,\n \"fragmentRegistry.lookup\" = 1000,\n \"fragmentRegistry.findFragmentSpreads\" = 4000,\n \"cache.fragmentQueryDocuments\" = 1000,\n \"removeTypenameFromVariables.getVariableDefinitions\" = 2000,\n \"inMemoryCache.maybeBroadcastWatch\" = 5000,\n \"inMemoryCache.executeSelectionSet\" = 50000,\n \"inMemoryCache.executeSubSelectedArray\" = 10000,\n}\n","import type { OptimisticWrapperFunction } from \"optimism\";\nimport type {\n InMemoryCache,\n DocumentTransform,\n ApolloLink,\n ApolloCache,\n} from \"../../core/index.js\";\nimport type { ApolloClient } from \"../../core/index.js\";\nimport type { CacheSizes } from \"./sizes.js\";\nimport { cacheSizes, defaultCacheSizes } from \"./sizes.js\";\n\nconst globalCaches: {\n print?: () => number;\n parser?: () => number;\n canonicalStringify?: () => number;\n} = {};\n\nexport function registerGlobalCache(\n name: keyof typeof globalCaches,\n getSize: () => number\n) {\n globalCaches[name] = getSize;\n}\n\n/**\n * Transformative helper type to turn a function of the form\n * ```ts\n * (this: any) => R\n * ```\n * into a function of the form\n * ```ts\n * () => R\n * ```\n * preserving the return type, but removing the `this` parameter.\n *\n * @remarks\n *\n * Further down in the definitions of `_getApolloClientMemoryInternals`,\n * `_getApolloCacheMemoryInternals` and `_getInMemoryCacheMemoryInternals`,\n * having the `this` parameter annotation is extremely useful for type checking\n * inside the function.\n *\n * If this is preserved in the exported types, though, it leads to a situation\n * where `ApolloCache.getMemoryInternals` is a function that requires a `this`\n * of the type `ApolloCache`, while the extending class `InMemoryCache` has a\n * `getMemoryInternals` function that requires a `this` of the type\n * `InMemoryCache`.\n * This is not compatible with TypeScript's inheritence system (although it is\n * perfectly correct), and so TypeScript will complain loudly.\n *\n * We still want to define our functions with the `this` annotation, though,\n * and have the return type inferred.\n * (This requirement for return type inference here makes it impossible to use\n * a function overload that is more explicit on the inner overload than it is\n * on the external overload.)\n *\n * So in the end, we use this helper to remove the `this` annotation from the\n * exported function types, while keeping it in the internal implementation.\n *\n */\ntype RemoveThis = T extends (this: any) => infer R ? () => R : never;\n\n/**\n * For internal purposes only - please call `ApolloClient.getMemoryInternals` instead\n * @internal\n */\nexport const getApolloClientMemoryInternals =\n __DEV__ ?\n (_getApolloClientMemoryInternals as RemoveThis<\n typeof _getApolloClientMemoryInternals\n >)\n : undefined;\n\n/**\n * For internal purposes only - please call `ApolloClient.getMemoryInternals` instead\n * @internal\n */\nexport const getInMemoryCacheMemoryInternals =\n __DEV__ ?\n (_getInMemoryCacheMemoryInternals as RemoveThis<\n typeof _getInMemoryCacheMemoryInternals\n >)\n : undefined;\n\n/**\n * For internal purposes only - please call `ApolloClient.getMemoryInternals` instead\n * @internal\n */\nexport const getApolloCacheMemoryInternals =\n __DEV__ ?\n (_getApolloCacheMemoryInternals as RemoveThis<\n typeof _getApolloCacheMemoryInternals\n >)\n : undefined;\n\nfunction getCurrentCacheSizes() {\n // `defaultCacheSizes` is a `const enum` that will be inlined during build, so we have to reconstruct it's shape here\n const defaults: Record = {\n parser: defaultCacheSizes[\"parser\"],\n canonicalStringify: defaultCacheSizes[\"canonicalStringify\"],\n print: defaultCacheSizes[\"print\"],\n \"documentTransform.cache\": defaultCacheSizes[\"documentTransform.cache\"],\n \"queryManager.getDocumentInfo\":\n defaultCacheSizes[\"queryManager.getDocumentInfo\"],\n \"PersistedQueryLink.persistedQueryHashes\":\n defaultCacheSizes[\"PersistedQueryLink.persistedQueryHashes\"],\n \"fragmentRegistry.transform\":\n defaultCacheSizes[\"fragmentRegistry.transform\"],\n \"fragmentRegistry.lookup\": defaultCacheSizes[\"fragmentRegistry.lookup\"],\n \"fragmentRegistry.findFragmentSpreads\":\n defaultCacheSizes[\"fragmentRegistry.findFragmentSpreads\"],\n \"cache.fragmentQueryDocuments\":\n defaultCacheSizes[\"cache.fragmentQueryDocuments\"],\n \"removeTypenameFromVariables.getVariableDefinitions\":\n defaultCacheSizes[\"removeTypenameFromVariables.getVariableDefinitions\"],\n \"inMemoryCache.maybeBroadcastWatch\":\n defaultCacheSizes[\"inMemoryCache.maybeBroadcastWatch\"],\n \"inMemoryCache.executeSelectionSet\":\n defaultCacheSizes[\"inMemoryCache.executeSelectionSet\"],\n \"inMemoryCache.executeSubSelectedArray\":\n defaultCacheSizes[\"inMemoryCache.executeSubSelectedArray\"],\n };\n return Object.fromEntries(\n Object.entries(defaults).map(([k, v]) => [\n k,\n cacheSizes[k as keyof CacheSizes] || v,\n ])\n );\n}\n\nfunction _getApolloClientMemoryInternals(this: ApolloClient) {\n if (!__DEV__) throw new Error(\"only supported in development mode\");\n\n return {\n limits: getCurrentCacheSizes(),\n sizes: {\n print: globalCaches.print?.(),\n parser: globalCaches.parser?.(),\n canonicalStringify: globalCaches.canonicalStringify?.(),\n links: linkInfo(this.link),\n queryManager: {\n getDocumentInfo: this[\"queryManager\"][\"transformCache\"].size,\n documentTransforms: transformInfo(\n this[\"queryManager\"].documentTransform\n ),\n },\n ...(this.cache.getMemoryInternals?.() as Partial<\n ReturnType\n > &\n Partial>),\n },\n };\n}\n\nfunction _getApolloCacheMemoryInternals(this: ApolloCache) {\n return {\n cache: {\n fragmentQueryDocuments: getWrapperInformation(this[\"getFragmentDoc\"]),\n },\n };\n}\n\nfunction _getInMemoryCacheMemoryInternals(this: InMemoryCache) {\n const fragments = this.config.fragments as\n | undefined\n | {\n findFragmentSpreads?: Function;\n transform?: Function;\n lookup?: Function;\n };\n\n return {\n ..._getApolloCacheMemoryInternals.apply(this as any),\n addTypenameDocumentTransform: transformInfo(this[\"addTypenameTransform\"]),\n inMemoryCache: {\n executeSelectionSet: getWrapperInformation(\n this[\"storeReader\"][\"executeSelectionSet\"]\n ),\n executeSubSelectedArray: getWrapperInformation(\n this[\"storeReader\"][\"executeSubSelectedArray\"]\n ),\n maybeBroadcastWatch: getWrapperInformation(this[\"maybeBroadcastWatch\"]),\n },\n fragmentRegistry: {\n findFragmentSpreads: getWrapperInformation(\n fragments?.findFragmentSpreads\n ),\n lookup: getWrapperInformation(fragments?.lookup),\n transform: getWrapperInformation(fragments?.transform),\n },\n };\n}\n\nfunction isWrapper(f?: Function): f is OptimisticWrapperFunction {\n return !!f && \"dirtyKey\" in f;\n}\n\nfunction getWrapperInformation(f?: Function) {\n return isWrapper(f) ? f.size : undefined;\n}\n\nfunction isDefined(value: T | undefined | null): value is T {\n return value != null;\n}\n\nfunction transformInfo(transform?: DocumentTransform) {\n return recurseTransformInfo(transform).map((cache) => ({ cache }));\n}\n\nfunction recurseTransformInfo(transform?: DocumentTransform): number[] {\n return transform ?\n [\n getWrapperInformation(transform?.[\"performWork\"]),\n ...recurseTransformInfo(transform?.[\"left\"]),\n ...recurseTransformInfo(transform?.[\"right\"]),\n ].filter(isDefined)\n : [];\n}\n\nfunction linkInfo(link?: ApolloLink): unknown[] {\n return link ?\n [\n link?.getMemoryInternals?.(),\n ...linkInfo(link?.left),\n ...linkInfo(link?.right),\n ].filter(isDefined)\n : [];\n}\n","import {\n AutoCleanedStrongCache,\n cacheSizes,\n defaultCacheSizes,\n} from \"../../utilities/caching/index.js\";\nimport { registerGlobalCache } from \"../caching/getMemoryInternals.js\";\n\n/**\n * Like JSON.stringify, but with object keys always sorted in the same order.\n *\n * To achieve performant sorting, this function uses a Map from JSON-serialized\n * arrays of keys (in any order) to sorted arrays of the same keys, with a\n * single sorted array reference shared by all permutations of the keys.\n *\n * As a drawback, this function will add a little bit more memory for every\n * object encountered that has different (more, less, a different order of) keys\n * than in the past.\n *\n * In a typical application, this extra memory usage should not play a\n * significant role, as `canonicalStringify` will be called for only a limited\n * number of object shapes, and the cache will not grow beyond a certain point.\n * But in some edge cases, this could be a problem, so we provide\n * canonicalStringify.reset() as a way of clearing the cache.\n * */\nexport const canonicalStringify = Object.assign(\n function canonicalStringify(value: any): string {\n return JSON.stringify(value, stableObjectReplacer);\n },\n {\n reset() {\n // Clearing the sortingMap will reclaim all cached memory, without\n // affecting the logical results of canonicalStringify, but potentially\n // sacrificing performance until the cache is refilled.\n sortingMap = new AutoCleanedStrongCache(\n cacheSizes.canonicalStringify || defaultCacheSizes.canonicalStringify\n );\n },\n }\n);\n\nif (__DEV__) {\n registerGlobalCache(\"canonicalStringify\", () => sortingMap.size);\n}\n\n// Values are JSON-serialized arrays of object keys (in any order), and values\n// are sorted arrays of the same keys.\nlet sortingMap!: AutoCleanedStrongCache;\ncanonicalStringify.reset();\n\n// The JSON.stringify function takes an optional second argument called a\n// replacer function. This function is called for each key-value pair in the\n// object being stringified, and its return value is used instead of the\n// original value. If the replacer function returns a new value, that value is\n// stringified as JSON instead of the original value of the property.\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#the_replacer_parameter\nfunction stableObjectReplacer(key: string, value: any) {\n if (value && typeof value === \"object\") {\n const proto = Object.getPrototypeOf(value);\n // We don't want to mess with objects that are not \"plain\" objects, which\n // means their prototype is either Object.prototype or null. This check also\n // prevents needlessly rearranging the indices of arrays.\n if (proto === Object.prototype || proto === null) {\n const keys = Object.keys(value);\n // If keys is already sorted, let JSON.stringify serialize the original\n // value instead of creating a new object with keys in the same order.\n if (keys.every(everyKeyInOrder)) return value;\n const unsortedKey = JSON.stringify(keys);\n let sortedKeys = sortingMap.get(unsortedKey);\n if (!sortedKeys) {\n keys.sort();\n const sortedKey = JSON.stringify(keys);\n // Checking for sortedKey in the sortingMap allows us to share the same\n // sorted array reference for all permutations of the same set of keys.\n sortedKeys = sortingMap.get(sortedKey) || keys;\n sortingMap.set(unsortedKey, sortedKeys);\n sortingMap.set(sortedKey, sortedKeys);\n }\n const sortedObject = Object.create(proto);\n // Reassigning the keys in sorted order will cause JSON.stringify to\n // serialize them in sorted order.\n sortedKeys.forEach((key) => {\n sortedObject[key] = value[key];\n });\n return sortedObject;\n }\n }\n return value;\n}\n\n// Since everything that happens in stableObjectReplacer benefits from being as\n// efficient as possible, we use a static function as the callback for\n// keys.every in order to test if the provided keys are already sorted without\n// allocating extra memory for a callback.\nfunction everyKeyInOrder(\n key: string,\n i: number,\n keys: readonly string[]\n): boolean {\n return i === 0 || keys[i - 1] <= key;\n}\n","import { newInvariantError } from \"../globals/index.js\";\n\nimport type {\n DirectiveNode,\n FieldNode,\n IntValueNode,\n FloatValueNode,\n StringValueNode,\n BooleanValueNode,\n ObjectValueNode,\n ListValueNode,\n EnumValueNode,\n NullValueNode,\n VariableNode,\n InlineFragmentNode,\n ValueNode,\n SelectionNode,\n NameNode,\n SelectionSetNode,\n DocumentNode,\n FragmentSpreadNode,\n} from \"graphql\";\n\nimport { isNonNullObject } from \"../common/objects.js\";\nimport type { FragmentMap } from \"./fragments.js\";\nimport { getFragmentFromSelection } from \"./fragments.js\";\nimport { canonicalStringify } from \"../common/canonicalStringify.js\";\n\nexport interface Reference {\n readonly __ref: string;\n}\n\nexport function makeReference(id: string): Reference {\n return { __ref: String(id) };\n}\n\nexport function isReference(obj: any): obj is Reference {\n return Boolean(\n obj && typeof obj === \"object\" && typeof obj.__ref === \"string\"\n );\n}\n\nexport type StoreValue =\n | number\n | string\n | string[]\n | Reference\n | Reference[]\n | null\n | undefined\n | void\n | Object;\n\nexport interface StoreObject {\n __typename?: string;\n [storeFieldName: string]: StoreValue;\n}\n\n/**\n * Workaround for a TypeScript quirk:\n * types per default have an implicit index signature that makes them\n * assignable to `StoreObject`.\n * interfaces do not have that implicit index signature, so they cannot\n * be assigned to `StoreObject`.\n * This type just maps over a type or interface that is passed in,\n * implicitly adding the index signature.\n * That way, the result can be assigned to `StoreObject`.\n *\n * This is important if some user-defined interface is used e.g.\n * in cache.modify, where the `toReference` method expects a\n * `StoreObject` as input.\n */\nexport type AsStoreObject = {\n [K in keyof T]: T[K];\n};\n\nexport function isDocumentNode(value: any): value is DocumentNode {\n return (\n isNonNullObject(value) &&\n (value as DocumentNode).kind === \"Document\" &&\n Array.isArray((value as DocumentNode).definitions)\n );\n}\n\nfunction isStringValue(value: ValueNode): value is StringValueNode {\n return value.kind === \"StringValue\";\n}\n\nfunction isBooleanValue(value: ValueNode): value is BooleanValueNode {\n return value.kind === \"BooleanValue\";\n}\n\nfunction isIntValue(value: ValueNode): value is IntValueNode {\n return value.kind === \"IntValue\";\n}\n\nfunction isFloatValue(value: ValueNode): value is FloatValueNode {\n return value.kind === \"FloatValue\";\n}\n\nfunction isVariable(value: ValueNode): value is VariableNode {\n return value.kind === \"Variable\";\n}\n\nfunction isObjectValue(value: ValueNode): value is ObjectValueNode {\n return value.kind === \"ObjectValue\";\n}\n\nfunction isListValue(value: ValueNode): value is ListValueNode {\n return value.kind === \"ListValue\";\n}\n\nfunction isEnumValue(value: ValueNode): value is EnumValueNode {\n return value.kind === \"EnumValue\";\n}\n\nfunction isNullValue(value: ValueNode): value is NullValueNode {\n return value.kind === \"NullValue\";\n}\n\nexport function valueToObjectRepresentation(\n argObj: any,\n name: NameNode,\n value: ValueNode,\n variables?: Object\n) {\n if (isIntValue(value) || isFloatValue(value)) {\n argObj[name.value] = Number(value.value);\n } else if (isBooleanValue(value) || isStringValue(value)) {\n argObj[name.value] = value.value;\n } else if (isObjectValue(value)) {\n const nestedArgObj = {};\n value.fields.map((obj) =>\n valueToObjectRepresentation(nestedArgObj, obj.name, obj.value, variables)\n );\n argObj[name.value] = nestedArgObj;\n } else if (isVariable(value)) {\n const variableValue = (variables || ({} as any))[value.name.value];\n argObj[name.value] = variableValue;\n } else if (isListValue(value)) {\n argObj[name.value] = value.values.map((listValue) => {\n const nestedArgArrayObj = {};\n valueToObjectRepresentation(\n nestedArgArrayObj,\n name,\n listValue,\n variables\n );\n return (nestedArgArrayObj as any)[name.value];\n });\n } else if (isEnumValue(value)) {\n argObj[name.value] = (value as EnumValueNode).value;\n } else if (isNullValue(value)) {\n argObj[name.value] = null;\n } else {\n throw newInvariantError(\n `The inline argument \"%s\" of kind \"%s\"` +\n \"is not supported. Use variables instead of inline arguments to \" +\n \"overcome this limitation.\",\n name.value,\n (value as any).kind\n );\n }\n}\n\nexport function storeKeyNameFromField(\n field: FieldNode,\n variables?: Object\n): string {\n let directivesObj: any = null;\n if (field.directives) {\n directivesObj = {};\n field.directives.forEach((directive) => {\n directivesObj[directive.name.value] = {};\n\n if (directive.arguments) {\n directive.arguments.forEach(({ name, value }) =>\n valueToObjectRepresentation(\n directivesObj[directive.name.value],\n name,\n value,\n variables\n )\n );\n }\n });\n }\n\n let argObj: any = null;\n if (field.arguments && field.arguments.length) {\n argObj = {};\n field.arguments.forEach(({ name, value }) =>\n valueToObjectRepresentation(argObj, name, value, variables)\n );\n }\n\n return getStoreKeyName(field.name.value, argObj, directivesObj);\n}\n\nexport type Directives = {\n [directiveName: string]: {\n [argName: string]: any;\n };\n};\n\nconst KNOWN_DIRECTIVES: string[] = [\n \"connection\",\n \"include\",\n \"skip\",\n \"client\",\n \"rest\",\n \"export\",\n \"nonreactive\",\n];\n\n// Default stable JSON.stringify implementation used by getStoreKeyName. Can be\n// updated/replaced with something better by calling\n// getStoreKeyName.setStringify(newStringifyFunction).\nlet storeKeyNameStringify: (value: any) => string = canonicalStringify;\n\nexport const getStoreKeyName = Object.assign(\n function (\n fieldName: string,\n args?: Record | null,\n directives?: Directives\n ): string {\n if (\n args &&\n directives &&\n directives[\"connection\"] &&\n directives[\"connection\"][\"key\"]\n ) {\n if (\n directives[\"connection\"][\"filter\"] &&\n (directives[\"connection\"][\"filter\"] as string[]).length > 0\n ) {\n const filterKeys =\n directives[\"connection\"][\"filter\"] ?\n (directives[\"connection\"][\"filter\"] as string[])\n : [];\n filterKeys.sort();\n\n const filteredArgs = {} as { [key: string]: any };\n filterKeys.forEach((key) => {\n filteredArgs[key] = args[key];\n });\n\n return `${directives[\"connection\"][\"key\"]}(${storeKeyNameStringify(\n filteredArgs\n )})`;\n } else {\n return directives[\"connection\"][\"key\"];\n }\n }\n\n let completeFieldName: string = fieldName;\n\n if (args) {\n // We can't use `JSON.stringify` here since it's non-deterministic,\n // and can lead to different store key names being created even though\n // the `args` object used during creation has the same properties/values.\n const stringifiedArgs: string = storeKeyNameStringify(args);\n completeFieldName += `(${stringifiedArgs})`;\n }\n\n if (directives) {\n Object.keys(directives).forEach((key) => {\n if (KNOWN_DIRECTIVES.indexOf(key) !== -1) return;\n if (directives[key] && Object.keys(directives[key]).length) {\n completeFieldName += `@${key}(${storeKeyNameStringify(\n directives[key]\n )})`;\n } else {\n completeFieldName += `@${key}`;\n }\n });\n }\n\n return completeFieldName;\n },\n {\n setStringify(s: typeof storeKeyNameStringify) {\n const previous = storeKeyNameStringify;\n storeKeyNameStringify = s;\n return previous;\n },\n }\n);\n\nexport function argumentsObjectFromField(\n field: FieldNode | DirectiveNode,\n variables?: Record\n): Object | null {\n if (field.arguments && field.arguments.length) {\n const argObj: Object = {};\n field.arguments.forEach(({ name, value }) =>\n valueToObjectRepresentation(argObj, name, value, variables)\n );\n return argObj;\n }\n return null;\n}\n\nexport function resultKeyNameFromField(field: FieldNode): string {\n return field.alias ? field.alias.value : field.name.value;\n}\n\nexport function getTypenameFromResult(\n result: Record,\n selectionSet: SelectionSetNode,\n fragmentMap?: FragmentMap\n): string | undefined {\n let fragments: undefined | Array;\n for (const selection of selectionSet.selections) {\n if (isField(selection)) {\n if (selection.name.value === \"__typename\") {\n return result[resultKeyNameFromField(selection)];\n }\n } else if (fragments) {\n fragments.push(selection);\n } else {\n fragments = [selection];\n }\n }\n if (typeof result.__typename === \"string\") {\n return result.__typename;\n }\n if (fragments) {\n for (const selection of fragments) {\n const typename = getTypenameFromResult(\n result,\n getFragmentFromSelection(selection, fragmentMap)!.selectionSet,\n fragmentMap\n );\n if (typeof typename === \"string\") {\n return typename;\n }\n }\n }\n}\n\nexport function isField(selection: SelectionNode): selection is FieldNode {\n return selection.kind === \"Field\";\n}\n\nexport function isInlineFragment(\n selection: SelectionNode\n): selection is InlineFragmentNode {\n return selection.kind === \"InlineFragment\";\n}\n\nexport type VariableValue = (node: VariableNode) => any;\n","import { invariant, newInvariantError } from \"../globals/index.js\";\n\nimport type {\n DocumentNode,\n OperationDefinitionNode,\n FragmentDefinitionNode,\n ValueNode,\n} from \"graphql\";\n\nimport { valueToObjectRepresentation } from \"./storeUtils.js\";\n\ntype OperationDefinitionWithName = OperationDefinitionNode & {\n name: NonNullable;\n};\n\n// Checks the document for errors and throws an exception if there is an error.\nexport function checkDocument(doc: DocumentNode) {\n invariant(\n doc && doc.kind === \"Document\",\n `Expecting a parsed GraphQL document. Perhaps you need to wrap the query \\\nstring in a \"gql\" tag? http://docs.apollostack.com/apollo-client/core.html#gql`\n );\n\n const operations = doc.definitions\n .filter((d) => d.kind !== \"FragmentDefinition\")\n .map((definition) => {\n if (definition.kind !== \"OperationDefinition\") {\n throw newInvariantError(\n `Schema type definitions not allowed in queries. Found: \"%s\"`,\n definition.kind\n );\n }\n return definition;\n });\n\n invariant(\n operations.length <= 1,\n `Ambiguous GraphQL document: contains %s operations`,\n operations.length\n );\n\n return doc;\n}\n\nexport function getOperationDefinition(\n doc: DocumentNode\n): OperationDefinitionNode | undefined {\n checkDocument(doc);\n return doc.definitions.filter(\n (definition): definition is OperationDefinitionNode =>\n definition.kind === \"OperationDefinition\"\n )[0];\n}\n\nexport function getOperationName(doc: DocumentNode): string | null {\n return (\n doc.definitions\n .filter(\n (definition): definition is OperationDefinitionWithName =>\n definition.kind === \"OperationDefinition\" && !!definition.name\n )\n .map((x) => x.name.value)[0] || null\n );\n}\n\n// Returns the FragmentDefinitions from a particular document as an array\nexport function getFragmentDefinitions(\n doc: DocumentNode\n): FragmentDefinitionNode[] {\n return doc.definitions.filter(\n (definition): definition is FragmentDefinitionNode =>\n definition.kind === \"FragmentDefinition\"\n );\n}\n\nexport function getQueryDefinition(doc: DocumentNode): OperationDefinitionNode {\n const queryDef = getOperationDefinition(doc)!;\n\n invariant(\n queryDef && queryDef.operation === \"query\",\n \"Must contain a query definition.\"\n );\n\n return queryDef;\n}\n\nexport function getFragmentDefinition(\n doc: DocumentNode\n): FragmentDefinitionNode {\n invariant(\n doc.kind === \"Document\",\n `Expecting a parsed GraphQL document. Perhaps you need to wrap the query \\\nstring in a \"gql\" tag? http://docs.apollostack.com/apollo-client/core.html#gql`\n );\n\n invariant(\n doc.definitions.length <= 1,\n \"Fragment must have exactly one definition.\"\n );\n\n const fragmentDef = doc.definitions[0] as FragmentDefinitionNode;\n\n invariant(\n fragmentDef.kind === \"FragmentDefinition\",\n \"Must be a fragment definition.\"\n );\n\n return fragmentDef as FragmentDefinitionNode;\n}\n\n/**\n * Returns the first operation definition found in this document.\n * If no operation definition is found, the first fragment definition will be returned.\n * If no definitions are found, an error will be thrown.\n */\nexport function getMainDefinition(\n queryDoc: DocumentNode\n): OperationDefinitionNode | FragmentDefinitionNode {\n checkDocument(queryDoc);\n\n let fragmentDefinition;\n\n for (let definition of queryDoc.definitions) {\n if (definition.kind === \"OperationDefinition\") {\n const operation = (definition as OperationDefinitionNode).operation;\n if (\n operation === \"query\" ||\n operation === \"mutation\" ||\n operation === \"subscription\"\n ) {\n return definition as OperationDefinitionNode;\n }\n }\n if (definition.kind === \"FragmentDefinition\" && !fragmentDefinition) {\n // we do this because we want to allow multiple fragment definitions\n // to precede an operation definition.\n fragmentDefinition = definition as FragmentDefinitionNode;\n }\n }\n\n if (fragmentDefinition) {\n return fragmentDefinition;\n }\n\n throw newInvariantError(\n \"Expected a parsed GraphQL query with a query, mutation, subscription, or a fragment.\"\n );\n}\n\nexport function getDefaultValues(\n definition: OperationDefinitionNode | undefined\n): Record {\n const defaultValues = Object.create(null);\n const defs = definition && definition.variableDefinitions;\n if (defs && defs.length) {\n defs.forEach((def) => {\n if (def.defaultValue) {\n valueToObjectRepresentation(\n defaultValues,\n def.variable.name,\n def.defaultValue as ValueNode\n );\n }\n });\n }\n return defaultValues;\n}\n","import { newInvariantError, invariant } from \"../../utilities/globals/index.js\";\n\nimport type { Observer } from \"../../utilities/index.js\";\nimport { Observable } from \"../../utilities/index.js\";\nimport type {\n NextLink,\n Operation,\n RequestHandler,\n FetchResult,\n GraphQLRequest,\n} from \"./types.js\";\nimport {\n validateOperation,\n createOperation,\n transformOperation,\n} from \"../utils/index.js\";\n\nfunction passthrough(op: Operation, forward: NextLink) {\n return (forward ? forward(op) : Observable.of()) as Observable;\n}\n\nfunction toLink(handler: RequestHandler | ApolloLink) {\n return typeof handler === \"function\" ? new ApolloLink(handler) : handler;\n}\n\nfunction isTerminating(link: ApolloLink): boolean {\n return link.request.length <= 1;\n}\n\nexport class ApolloLink {\n public static empty(): ApolloLink {\n return new ApolloLink(() => Observable.of());\n }\n\n public static from(links: (ApolloLink | RequestHandler)[]): ApolloLink {\n if (links.length === 0) return ApolloLink.empty();\n return links.map(toLink).reduce((x, y) => x.concat(y)) as ApolloLink;\n }\n\n public static split(\n test: (op: Operation) => boolean,\n left: ApolloLink | RequestHandler,\n right?: ApolloLink | RequestHandler\n ): ApolloLink {\n const leftLink = toLink(left);\n const rightLink = toLink(right || new ApolloLink(passthrough));\n\n let ret: ApolloLink;\n if (isTerminating(leftLink) && isTerminating(rightLink)) {\n ret = new ApolloLink((operation) => {\n return test(operation) ?\n leftLink.request(operation) || Observable.of()\n : rightLink.request(operation) || Observable.of();\n });\n } else {\n ret = new ApolloLink((operation, forward) => {\n return test(operation) ?\n leftLink.request(operation, forward) || Observable.of()\n : rightLink.request(operation, forward) || Observable.of();\n });\n }\n return Object.assign(ret, { left: leftLink, right: rightLink });\n }\n\n public static execute(\n link: ApolloLink,\n operation: GraphQLRequest\n ): Observable {\n return (\n link.request(\n createOperation(\n operation.context,\n transformOperation(validateOperation(operation))\n )\n ) || Observable.of()\n );\n }\n\n public static concat(\n first: ApolloLink | RequestHandler,\n second: ApolloLink | RequestHandler\n ) {\n const firstLink = toLink(first);\n if (isTerminating(firstLink)) {\n invariant.warn(\n `You are calling concat on a terminating link, which will have no effect %o`,\n firstLink\n );\n return firstLink;\n }\n const nextLink = toLink(second);\n\n let ret: ApolloLink;\n if (isTerminating(nextLink)) {\n ret = new ApolloLink(\n (operation) =>\n firstLink.request(\n operation,\n (op) => nextLink.request(op) || Observable.of()\n ) || Observable.of()\n );\n } else {\n ret = new ApolloLink((operation, forward) => {\n return (\n firstLink.request(operation, (op) => {\n return nextLink.request(op, forward) || Observable.of();\n }) || Observable.of()\n );\n });\n }\n return Object.assign(ret, { left: firstLink, right: nextLink });\n }\n\n constructor(request?: RequestHandler) {\n if (request) this.request = request;\n }\n\n public split(\n test: (op: Operation) => boolean,\n left: ApolloLink | RequestHandler,\n right?: ApolloLink | RequestHandler\n ): ApolloLink {\n return this.concat(\n ApolloLink.split(test, left, right || new ApolloLink(passthrough))\n );\n }\n\n public concat(next: ApolloLink | RequestHandler): ApolloLink {\n return ApolloLink.concat(this, next);\n }\n\n public request(\n operation: Operation,\n forward?: NextLink\n ): Observable | null {\n throw newInvariantError(\"request is not implemented\");\n }\n\n protected onError(\n error: any,\n observer?: Observer\n ): false | void {\n if (observer && observer.error) {\n observer.error(error);\n // Returning false indicates that observer.error does not need to be\n // called again, since it was already called (on the previous line).\n // Calling observer.error again would not cause any real problems,\n // since only the first call matters, but custom onError functions\n // might have other reasons for wanting to prevent the default\n // behavior by returning false.\n return false;\n }\n // Throw errors will be passed to observer.error.\n throw error;\n }\n\n public setOnError(fn: ApolloLink[\"onError\"]): this {\n this.onError = fn;\n return this;\n }\n\n /**\n * @internal\n * Used to iterate through all links that are concatenations or `split` links.\n */\n readonly left?: ApolloLink;\n /**\n * @internal\n * Used to iterate through all links that are concatenations or `split` links.\n */\n readonly right?: ApolloLink;\n\n /**\n * @internal\n * Can be provided by a link that has an internal cache to report it's memory details.\n */\n getMemoryInternals?: () => unknown;\n}\n","import type { GraphQLRequest, Operation } from \"../core/index.js\";\n\nexport function createOperation(\n starting: any,\n operation: GraphQLRequest\n): Operation {\n let context = { ...starting };\n const setContext: Operation[\"setContext\"] = (next) => {\n if (typeof next === \"function\") {\n context = { ...context, ...next(context) };\n } else {\n context = { ...context, ...next };\n }\n };\n const getContext: Operation[\"getContext\"] = () => ({ ...context });\n\n Object.defineProperty(operation, \"setContext\", {\n enumerable: false,\n value: setContext,\n });\n\n Object.defineProperty(operation, \"getContext\", {\n enumerable: false,\n value: getContext,\n });\n\n return operation as Operation;\n}\n","import type { GraphQLRequest, Operation } from \"../core/index.js\";\nimport { getOperationName } from \"../../utilities/index.js\";\n\nexport function transformOperation(operation: GraphQLRequest): GraphQLRequest {\n const transformedOperation: GraphQLRequest = {\n variables: operation.variables || {},\n extensions: operation.extensions || {},\n operationName: operation.operationName,\n query: operation.query,\n };\n\n // Best guess at an operation name\n if (!transformedOperation.operationName) {\n transformedOperation.operationName =\n typeof transformedOperation.query !== \"string\" ?\n getOperationName(transformedOperation.query) || undefined\n : \"\";\n }\n\n return transformedOperation as Operation;\n}\n","import { newInvariantError } from \"../../utilities/globals/index.js\";\nimport type { GraphQLRequest } from \"../core/index.js\";\n\nexport function validateOperation(operation: GraphQLRequest): GraphQLRequest {\n const OPERATION_FIELDS = [\n \"query\",\n \"operationName\",\n \"variables\",\n \"extensions\",\n \"context\",\n ];\n for (let key of Object.keys(operation)) {\n if (OPERATION_FIELDS.indexOf(key) < 0) {\n throw newInvariantError(`illegal argument: %s`, key);\n }\n }\n\n return operation;\n}\n","export function devAssert(condition, message) {\n const booleanCondition = Boolean(condition);\n\n if (!booleanCondition) {\n throw new Error(message);\n }\n}\n","const MAX_ARRAY_LENGTH = 10;\nconst MAX_RECURSIVE_DEPTH = 2;\n/**\n * Used to print values in error messages.\n */\n\nexport function inspect(value) {\n return formatValue(value, []);\n}\n\nfunction formatValue(value, seenValues) {\n switch (typeof value) {\n case 'string':\n return JSON.stringify(value);\n\n case 'function':\n return value.name ? `[function ${value.name}]` : '[function]';\n\n case 'object':\n return formatObjectValue(value, seenValues);\n\n default:\n return String(value);\n }\n}\n\nfunction formatObjectValue(value, previouslySeenValues) {\n if (value === null) {\n return 'null';\n }\n\n if (previouslySeenValues.includes(value)) {\n return '[Circular]';\n }\n\n const seenValues = [...previouslySeenValues, value];\n\n if (isJSONable(value)) {\n const jsonValue = value.toJSON(); // check for infinite recursion\n\n if (jsonValue !== value) {\n return typeof jsonValue === 'string'\n ? jsonValue\n : formatValue(jsonValue, seenValues);\n }\n } else if (Array.isArray(value)) {\n return formatArray(value, seenValues);\n }\n\n return formatObject(value, seenValues);\n}\n\nfunction isJSONable(value) {\n return typeof value.toJSON === 'function';\n}\n\nfunction formatObject(object, seenValues) {\n const entries = Object.entries(object);\n\n if (entries.length === 0) {\n return '{}';\n }\n\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[' + getObjectTag(object) + ']';\n }\n\n const properties = entries.map(\n ([key, value]) => key + ': ' + formatValue(value, seenValues),\n );\n return '{ ' + properties.join(', ') + ' }';\n}\n\nfunction formatArray(array, seenValues) {\n if (array.length === 0) {\n return '[]';\n }\n\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[Array]';\n }\n\n const len = Math.min(MAX_ARRAY_LENGTH, array.length);\n const remaining = array.length - len;\n const items = [];\n\n for (let i = 0; i < len; ++i) {\n items.push(formatValue(array[i], seenValues));\n }\n\n if (remaining === 1) {\n items.push('... 1 more item');\n } else if (remaining > 1) {\n items.push(`... ${remaining} more items`);\n }\n\n return '[' + items.join(', ') + ']';\n}\n\nfunction getObjectTag(object) {\n const tag = Object.prototype.toString\n .call(object)\n .replace(/^\\[object /, '')\n .replace(/]$/, '');\n\n if (tag === 'Object' && typeof object.constructor === 'function') {\n const name = object.constructor.name;\n\n if (typeof name === 'string' && name !== '') {\n return name;\n }\n }\n\n return tag;\n}\n","/**\n * Contains a range of UTF-8 character offsets and token references that\n * identify the region of the source from which the AST derived.\n */\nexport class Location {\n /**\n * The character offset at which this Node begins.\n */\n\n /**\n * The character offset at which this Node ends.\n */\n\n /**\n * The Token at which this Node begins.\n */\n\n /**\n * The Token at which this Node ends.\n */\n\n /**\n * The Source document the AST represents.\n */\n constructor(startToken, endToken, source) {\n this.start = startToken.start;\n this.end = endToken.end;\n this.startToken = startToken;\n this.endToken = endToken;\n this.source = source;\n }\n\n get [Symbol.toStringTag]() {\n return 'Location';\n }\n\n toJSON() {\n return {\n start: this.start,\n end: this.end,\n };\n }\n}\n/**\n * Represents a range of characters represented by a lexical token\n * within a Source.\n */\n\nexport class Token {\n /**\n * The kind of Token.\n */\n\n /**\n * The character offset at which this Node begins.\n */\n\n /**\n * The character offset at which this Node ends.\n */\n\n /**\n * The 1-indexed line number on which this Token appears.\n */\n\n /**\n * The 1-indexed column number at which this Token begins.\n */\n\n /**\n * For non-punctuation tokens, represents the interpreted value of the token.\n *\n * Note: is undefined for punctuation tokens, but typed as string for\n * convenience in the parser.\n */\n\n /**\n * Tokens exist as nodes in a double-linked-list amongst all tokens\n * including ignored tokens. is always the first node and \n * the last.\n */\n constructor(kind, start, end, line, column, value) {\n this.kind = kind;\n this.start = start;\n this.end = end;\n this.line = line;\n this.column = column; // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n\n this.value = value;\n this.prev = null;\n this.next = null;\n }\n\n get [Symbol.toStringTag]() {\n return 'Token';\n }\n\n toJSON() {\n return {\n kind: this.kind,\n value: this.value,\n line: this.line,\n column: this.column,\n };\n }\n}\n/**\n * The list of all possible AST node types.\n */\n\n/**\n * @internal\n */\nexport const QueryDocumentKeys = {\n Name: [],\n Document: ['definitions'],\n OperationDefinition: [\n 'name',\n 'variableDefinitions',\n 'directives',\n 'selectionSet',\n ],\n VariableDefinition: ['variable', 'type', 'defaultValue', 'directives'],\n Variable: ['name'],\n SelectionSet: ['selections'],\n Field: ['alias', 'name', 'arguments', 'directives', 'selectionSet'],\n Argument: ['name', 'value'],\n FragmentSpread: ['name', 'directives'],\n InlineFragment: ['typeCondition', 'directives', 'selectionSet'],\n FragmentDefinition: [\n 'name', // Note: fragment variable definitions are deprecated and will removed in v17.0.0\n 'variableDefinitions',\n 'typeCondition',\n 'directives',\n 'selectionSet',\n ],\n IntValue: [],\n FloatValue: [],\n StringValue: [],\n BooleanValue: [],\n NullValue: [],\n EnumValue: [],\n ListValue: ['values'],\n ObjectValue: ['fields'],\n ObjectField: ['name', 'value'],\n Directive: ['name', 'arguments'],\n NamedType: ['name'],\n ListType: ['type'],\n NonNullType: ['type'],\n SchemaDefinition: ['description', 'directives', 'operationTypes'],\n OperationTypeDefinition: ['type'],\n ScalarTypeDefinition: ['description', 'name', 'directives'],\n ObjectTypeDefinition: [\n 'description',\n 'name',\n 'interfaces',\n 'directives',\n 'fields',\n ],\n FieldDefinition: ['description', 'name', 'arguments', 'type', 'directives'],\n InputValueDefinition: [\n 'description',\n 'name',\n 'type',\n 'defaultValue',\n 'directives',\n ],\n InterfaceTypeDefinition: [\n 'description',\n 'name',\n 'interfaces',\n 'directives',\n 'fields',\n ],\n UnionTypeDefinition: ['description', 'name', 'directives', 'types'],\n EnumTypeDefinition: ['description', 'name', 'directives', 'values'],\n EnumValueDefinition: ['description', 'name', 'directives'],\n InputObjectTypeDefinition: ['description', 'name', 'directives', 'fields'],\n DirectiveDefinition: ['description', 'name', 'arguments', 'locations'],\n SchemaExtension: ['directives', 'operationTypes'],\n ScalarTypeExtension: ['name', 'directives'],\n ObjectTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n InterfaceTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n UnionTypeExtension: ['name', 'directives', 'types'],\n EnumTypeExtension: ['name', 'directives', 'values'],\n InputObjectTypeExtension: ['name', 'directives', 'fields'],\n};\nconst kindValues = new Set(Object.keys(QueryDocumentKeys));\n/**\n * @internal\n */\n\nexport function isNode(maybeNode) {\n const maybeKind =\n maybeNode === null || maybeNode === void 0 ? void 0 : maybeNode.kind;\n return typeof maybeKind === 'string' && kindValues.has(maybeKind);\n}\n/** Name */\n\nvar OperationTypeNode;\n\n(function (OperationTypeNode) {\n OperationTypeNode['QUERY'] = 'query';\n OperationTypeNode['MUTATION'] = 'mutation';\n OperationTypeNode['SUBSCRIPTION'] = 'subscription';\n})(OperationTypeNode || (OperationTypeNode = {}));\n\nexport { OperationTypeNode };\n","/**\n * The set of allowed kind values for AST nodes.\n */\nvar Kind;\n\n(function (Kind) {\n Kind['NAME'] = 'Name';\n Kind['DOCUMENT'] = 'Document';\n Kind['OPERATION_DEFINITION'] = 'OperationDefinition';\n Kind['VARIABLE_DEFINITION'] = 'VariableDefinition';\n Kind['SELECTION_SET'] = 'SelectionSet';\n Kind['FIELD'] = 'Field';\n Kind['ARGUMENT'] = 'Argument';\n Kind['FRAGMENT_SPREAD'] = 'FragmentSpread';\n Kind['INLINE_FRAGMENT'] = 'InlineFragment';\n Kind['FRAGMENT_DEFINITION'] = 'FragmentDefinition';\n Kind['VARIABLE'] = 'Variable';\n Kind['INT'] = 'IntValue';\n Kind['FLOAT'] = 'FloatValue';\n Kind['STRING'] = 'StringValue';\n Kind['BOOLEAN'] = 'BooleanValue';\n Kind['NULL'] = 'NullValue';\n Kind['ENUM'] = 'EnumValue';\n Kind['LIST'] = 'ListValue';\n Kind['OBJECT'] = 'ObjectValue';\n Kind['OBJECT_FIELD'] = 'ObjectField';\n Kind['DIRECTIVE'] = 'Directive';\n Kind['NAMED_TYPE'] = 'NamedType';\n Kind['LIST_TYPE'] = 'ListType';\n Kind['NON_NULL_TYPE'] = 'NonNullType';\n Kind['SCHEMA_DEFINITION'] = 'SchemaDefinition';\n Kind['OPERATION_TYPE_DEFINITION'] = 'OperationTypeDefinition';\n Kind['SCALAR_TYPE_DEFINITION'] = 'ScalarTypeDefinition';\n Kind['OBJECT_TYPE_DEFINITION'] = 'ObjectTypeDefinition';\n Kind['FIELD_DEFINITION'] = 'FieldDefinition';\n Kind['INPUT_VALUE_DEFINITION'] = 'InputValueDefinition';\n Kind['INTERFACE_TYPE_DEFINITION'] = 'InterfaceTypeDefinition';\n Kind['UNION_TYPE_DEFINITION'] = 'UnionTypeDefinition';\n Kind['ENUM_TYPE_DEFINITION'] = 'EnumTypeDefinition';\n Kind['ENUM_VALUE_DEFINITION'] = 'EnumValueDefinition';\n Kind['INPUT_OBJECT_TYPE_DEFINITION'] = 'InputObjectTypeDefinition';\n Kind['DIRECTIVE_DEFINITION'] = 'DirectiveDefinition';\n Kind['SCHEMA_EXTENSION'] = 'SchemaExtension';\n Kind['SCALAR_TYPE_EXTENSION'] = 'ScalarTypeExtension';\n Kind['OBJECT_TYPE_EXTENSION'] = 'ObjectTypeExtension';\n Kind['INTERFACE_TYPE_EXTENSION'] = 'InterfaceTypeExtension';\n Kind['UNION_TYPE_EXTENSION'] = 'UnionTypeExtension';\n Kind['ENUM_TYPE_EXTENSION'] = 'EnumTypeExtension';\n Kind['INPUT_OBJECT_TYPE_EXTENSION'] = 'InputObjectTypeExtension';\n})(Kind || (Kind = {}));\n\nexport { Kind };\n/**\n * The enum type representing the possible kind values of AST nodes.\n *\n * @deprecated Please use `Kind`. Will be remove in v17.\n */\n","import { devAssert } from '../jsutils/devAssert.mjs';\nimport { inspect } from '../jsutils/inspect.mjs';\nimport { isNode, QueryDocumentKeys } from './ast.mjs';\nimport { Kind } from './kinds.mjs';\n/**\n * A visitor is provided to visit, it contains the collection of\n * relevant functions to be called during the visitor's traversal.\n */\n\nexport const BREAK = Object.freeze({});\n/**\n * visit() will walk through an AST using a depth-first traversal, calling\n * the visitor's enter function at each node in the traversal, and calling the\n * leave function after visiting that node and all of its child nodes.\n *\n * By returning different values from the enter and leave functions, the\n * behavior of the visitor can be altered, including skipping over a sub-tree of\n * the AST (by returning false), editing the AST by returning a value or null\n * to remove the value, or to stop the whole traversal by returning BREAK.\n *\n * When using visit() to edit an AST, the original AST will not be modified, and\n * a new version of the AST with the changes applied will be returned from the\n * visit function.\n *\n * ```ts\n * const editedAST = visit(ast, {\n * enter(node, key, parent, path, ancestors) {\n * // @return\n * // undefined: no action\n * // false: skip visiting this node\n * // visitor.BREAK: stop visiting altogether\n * // null: delete this node\n * // any value: replace this node with the returned value\n * },\n * leave(node, key, parent, path, ancestors) {\n * // @return\n * // undefined: no action\n * // false: no action\n * // visitor.BREAK: stop visiting altogether\n * // null: delete this node\n * // any value: replace this node with the returned value\n * }\n * });\n * ```\n *\n * Alternatively to providing enter() and leave() functions, a visitor can\n * instead provide functions named the same as the kinds of AST nodes, or\n * enter/leave visitors at a named key, leading to three permutations of the\n * visitor API:\n *\n * 1) Named visitors triggered when entering a node of a specific kind.\n *\n * ```ts\n * visit(ast, {\n * Kind(node) {\n * // enter the \"Kind\" node\n * }\n * })\n * ```\n *\n * 2) Named visitors that trigger upon entering and leaving a node of a specific kind.\n *\n * ```ts\n * visit(ast, {\n * Kind: {\n * enter(node) {\n * // enter the \"Kind\" node\n * }\n * leave(node) {\n * // leave the \"Kind\" node\n * }\n * }\n * })\n * ```\n *\n * 3) Generic visitors that trigger upon entering and leaving any node.\n *\n * ```ts\n * visit(ast, {\n * enter(node) {\n * // enter any node\n * },\n * leave(node) {\n * // leave any node\n * }\n * })\n * ```\n */\n\nexport function visit(root, visitor, visitorKeys = QueryDocumentKeys) {\n const enterLeaveMap = new Map();\n\n for (const kind of Object.values(Kind)) {\n enterLeaveMap.set(kind, getEnterLeaveForKind(visitor, kind));\n }\n /* eslint-disable no-undef-init */\n\n let stack = undefined;\n let inArray = Array.isArray(root);\n let keys = [root];\n let index = -1;\n let edits = [];\n let node = root;\n let key = undefined;\n let parent = undefined;\n const path = [];\n const ancestors = [];\n /* eslint-enable no-undef-init */\n\n do {\n index++;\n const isLeaving = index === keys.length;\n const isEdited = isLeaving && edits.length !== 0;\n\n if (isLeaving) {\n key = ancestors.length === 0 ? undefined : path[path.length - 1];\n node = parent;\n parent = ancestors.pop();\n\n if (isEdited) {\n if (inArray) {\n node = node.slice();\n let editOffset = 0;\n\n for (const [editKey, editValue] of edits) {\n const arrayKey = editKey - editOffset;\n\n if (editValue === null) {\n node.splice(arrayKey, 1);\n editOffset++;\n } else {\n node[arrayKey] = editValue;\n }\n }\n } else {\n node = Object.defineProperties(\n {},\n Object.getOwnPropertyDescriptors(node),\n );\n\n for (const [editKey, editValue] of edits) {\n node[editKey] = editValue;\n }\n }\n }\n\n index = stack.index;\n keys = stack.keys;\n edits = stack.edits;\n inArray = stack.inArray;\n stack = stack.prev;\n } else if (parent) {\n key = inArray ? index : keys[index];\n node = parent[key];\n\n if (node === null || node === undefined) {\n continue;\n }\n\n path.push(key);\n }\n\n let result;\n\n if (!Array.isArray(node)) {\n var _enterLeaveMap$get, _enterLeaveMap$get2;\n\n isNode(node) || devAssert(false, `Invalid AST Node: ${inspect(node)}.`);\n const visitFn = isLeaving\n ? (_enterLeaveMap$get = enterLeaveMap.get(node.kind)) === null ||\n _enterLeaveMap$get === void 0\n ? void 0\n : _enterLeaveMap$get.leave\n : (_enterLeaveMap$get2 = enterLeaveMap.get(node.kind)) === null ||\n _enterLeaveMap$get2 === void 0\n ? void 0\n : _enterLeaveMap$get2.enter;\n result =\n visitFn === null || visitFn === void 0\n ? void 0\n : visitFn.call(visitor, node, key, parent, path, ancestors);\n\n if (result === BREAK) {\n break;\n }\n\n if (result === false) {\n if (!isLeaving) {\n path.pop();\n continue;\n }\n } else if (result !== undefined) {\n edits.push([key, result]);\n\n if (!isLeaving) {\n if (isNode(result)) {\n node = result;\n } else {\n path.pop();\n continue;\n }\n }\n }\n }\n\n if (result === undefined && isEdited) {\n edits.push([key, node]);\n }\n\n if (isLeaving) {\n path.pop();\n } else {\n var _node$kind;\n\n stack = {\n inArray,\n index,\n keys,\n edits,\n prev: stack,\n };\n inArray = Array.isArray(node);\n keys = inArray\n ? node\n : (_node$kind = visitorKeys[node.kind]) !== null &&\n _node$kind !== void 0\n ? _node$kind\n : [];\n index = -1;\n edits = [];\n\n if (parent) {\n ancestors.push(parent);\n }\n\n parent = node;\n }\n } while (stack !== undefined);\n\n if (edits.length !== 0) {\n // New root\n return edits[edits.length - 1][1];\n }\n\n return root;\n}\n/**\n * Creates a new visitor instance which delegates to many visitors to run in\n * parallel. Each visitor will be visited for each node before moving on.\n *\n * If a prior visitor edits a node, no following visitors will see that node.\n */\n\nexport function visitInParallel(visitors) {\n const skipping = new Array(visitors.length).fill(null);\n const mergedVisitor = Object.create(null);\n\n for (const kind of Object.values(Kind)) {\n let hasVisitor = false;\n const enterList = new Array(visitors.length).fill(undefined);\n const leaveList = new Array(visitors.length).fill(undefined);\n\n for (let i = 0; i < visitors.length; ++i) {\n const { enter, leave } = getEnterLeaveForKind(visitors[i], kind);\n hasVisitor || (hasVisitor = enter != null || leave != null);\n enterList[i] = enter;\n leaveList[i] = leave;\n }\n\n if (!hasVisitor) {\n continue;\n }\n\n const mergedEnterLeave = {\n enter(...args) {\n const node = args[0];\n\n for (let i = 0; i < visitors.length; i++) {\n if (skipping[i] === null) {\n var _enterList$i;\n\n const result =\n (_enterList$i = enterList[i]) === null || _enterList$i === void 0\n ? void 0\n : _enterList$i.apply(visitors[i], args);\n\n if (result === false) {\n skipping[i] = node;\n } else if (result === BREAK) {\n skipping[i] = BREAK;\n } else if (result !== undefined) {\n return result;\n }\n }\n }\n },\n\n leave(...args) {\n const node = args[0];\n\n for (let i = 0; i < visitors.length; i++) {\n if (skipping[i] === null) {\n var _leaveList$i;\n\n const result =\n (_leaveList$i = leaveList[i]) === null || _leaveList$i === void 0\n ? void 0\n : _leaveList$i.apply(visitors[i], args);\n\n if (result === BREAK) {\n skipping[i] = BREAK;\n } else if (result !== undefined && result !== false) {\n return result;\n }\n } else if (skipping[i] === node) {\n skipping[i] = null;\n }\n }\n },\n };\n mergedVisitor[kind] = mergedEnterLeave;\n }\n\n return mergedVisitor;\n}\n/**\n * Given a visitor instance and a node kind, return EnterLeaveVisitor for that kind.\n */\n\nexport function getEnterLeaveForKind(visitor, kind) {\n const kindVisitor = visitor[kind];\n\n if (typeof kindVisitor === 'object') {\n // { Kind: { enter() {}, leave() {} } }\n return kindVisitor;\n } else if (typeof kindVisitor === 'function') {\n // { Kind() {} }\n return {\n enter: kindVisitor,\n leave: undefined,\n };\n } // { enter() {}, leave() {} }\n\n return {\n enter: visitor.enter,\n leave: visitor.leave,\n };\n}\n/**\n * Given a visitor instance, if it is leaving or not, and a node kind, return\n * the function the visitor runtime should call.\n *\n * @deprecated Please use `getEnterLeaveForKind` instead. Will be removed in v17\n */\n\n/* c8 ignore next 8 */\n\nexport function getVisitFn(visitor, kind, isLeaving) {\n const { enter, leave } = getEnterLeaveForKind(visitor, kind);\n return isLeaving ? leave : enter;\n}\n","import { invariant } from \"../globals/index.js\";\n\n// Provides the methods that allow QueryManager to handle the `skip` and\n// `include` directives within GraphQL.\nimport type {\n SelectionNode,\n VariableNode,\n BooleanValueNode,\n DirectiveNode,\n DocumentNode,\n ArgumentNode,\n ValueNode,\n ASTNode,\n} from \"graphql\";\nimport { visit, BREAK } from \"graphql\";\n\nexport type DirectiveInfo = {\n [fieldName: string]: { [argName: string]: any };\n};\n\nexport function shouldInclude(\n { directives }: SelectionNode,\n variables?: Record\n): boolean {\n if (!directives || !directives.length) {\n return true;\n }\n return getInclusionDirectives(directives).every(\n ({ directive, ifArgument }) => {\n let evaledValue: boolean = false;\n if (ifArgument.value.kind === \"Variable\") {\n evaledValue =\n variables && variables[(ifArgument.value as VariableNode).name.value];\n invariant(\n evaledValue !== void 0,\n `Invalid variable referenced in @%s directive.`,\n directive.name.value\n );\n } else {\n evaledValue = (ifArgument.value as BooleanValueNode).value;\n }\n return directive.name.value === \"skip\" ? !evaledValue : evaledValue;\n }\n );\n}\n\nexport function getDirectiveNames(root: ASTNode) {\n const names: string[] = [];\n\n visit(root, {\n Directive(node: DirectiveNode) {\n names.push(node.name.value);\n },\n });\n\n return names;\n}\n\nexport const hasAnyDirectives = (names: string[], root: ASTNode) =>\n hasDirectives(names, root, false);\n\nexport const hasAllDirectives = (names: string[], root: ASTNode) =>\n hasDirectives(names, root, true);\n\nexport function hasDirectives(names: string[], root: ASTNode, all?: boolean) {\n const nameSet = new Set(names);\n const uniqueCount = nameSet.size;\n\n visit(root, {\n Directive(node) {\n if (nameSet.delete(node.name.value) && (!all || !nameSet.size)) {\n return BREAK;\n }\n },\n });\n\n // If we found all the names, nameSet will be empty. If we only care about\n // finding some of them, the < condition is sufficient.\n return all ? !nameSet.size : nameSet.size < uniqueCount;\n}\n\nexport function hasClientExports(document: DocumentNode) {\n return document && hasDirectives([\"client\", \"export\"], document, true);\n}\n\nexport type InclusionDirectives = Array<{\n directive: DirectiveNode;\n ifArgument: ArgumentNode;\n}>;\n\nfunction isInclusionDirective({ name: { value } }: DirectiveNode): boolean {\n return value === \"skip\" || value === \"include\";\n}\n\nexport function getInclusionDirectives(\n directives: ReadonlyArray\n): InclusionDirectives {\n const result: InclusionDirectives = [];\n\n if (directives && directives.length) {\n directives.forEach((directive) => {\n if (!isInclusionDirective(directive)) return;\n\n const directiveArguments = directive.arguments;\n const directiveName = directive.name.value;\n\n invariant(\n directiveArguments && directiveArguments.length === 1,\n `Incorrect number of arguments for the @%s directive.`,\n directiveName\n );\n\n const ifArgument = directiveArguments![0];\n invariant(\n ifArgument.name && ifArgument.name.value === \"if\",\n `Invalid argument for the @%s directive.`,\n directiveName\n );\n\n const ifValue: ValueNode = ifArgument.value;\n\n // means it has to be a variable value if this is a valid @skip or @include directive\n invariant(\n ifValue &&\n (ifValue.kind === \"Variable\" || ifValue.kind === \"BooleanValue\"),\n `Argument for the @%s directive must be a variable or a boolean value.`,\n directiveName\n );\n\n result.push({ directive, ifArgument });\n });\n }\n\n return result;\n}\n","import { newInvariantError } from \"../../utilities/globals/index.js\";\nimport type { InvariantError } from \"../../utilities/globals/index.js\";\n\nexport type ClientParseError = InvariantError & {\n parseError: Error;\n};\n\nexport const serializeFetchParameter = (p: any, label: string) => {\n let serialized;\n try {\n serialized = JSON.stringify(p);\n } catch (e: any) {\n const parseError = newInvariantError(\n `Network request failed. %s is not serializable: %s`,\n label,\n e.message\n ) as ClientParseError;\n parseError.parseError = e;\n throw parseError;\n }\n return serialized;\n};\n","import { maybe } from \"../globals/index.js\";\n\nexport const canUseWeakMap =\n typeof WeakMap === \"function\" &&\n !maybe(\n () => navigator.product == \"ReactNative\" && !(global as any).HermesInternal\n );\n\nexport const canUseWeakSet = typeof WeakSet === \"function\";\n\nexport const canUseSymbol =\n typeof Symbol === \"function\" && typeof Symbol.for === \"function\";\n\nexport const canUseAsyncIteratorSymbol = canUseSymbol && Symbol.asyncIterator;\n\nexport const canUseDOM =\n typeof maybe(() => window.document.createElement) === \"function\";\n\nconst usingJSDOM: boolean =\n // Following advice found in this comment from @domenic (maintainer of jsdom):\n // https://github.com/jsdom/jsdom/issues/1537#issuecomment-229405327\n //\n // Since we control the version of Jest and jsdom used when running Apollo\n // Client tests, and that version is recent enought to include \" jsdom/x.y.z\"\n // at the end of the user agent string, I believe this case is all we need to\n // check. Testing for \"Node.js\" was recommended for backwards compatibility\n // with older version of jsdom, but we don't have that problem.\n maybe(() => navigator.userAgent.indexOf(\"jsdom\") >= 0) || false;\n\n// Our tests should all continue to pass if we remove this !usingJSDOM\n// condition, thereby allowing useLayoutEffect when using jsdom. Unfortunately,\n// if we allow useLayoutEffect, then useSyncExternalStore generates many\n// warnings about useLayoutEffect doing nothing on the server. While these\n// warnings are harmless, this !usingJSDOM condition seems to be the best way to\n// prevent them (i.e. skipping useLayoutEffect when using jsdom).\nexport const canUseLayoutEffect = canUseDOM && !usingJSDOM;\n","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/iterators/nodeStream.ts\n */\n\nimport type { Readable as NodeReadableStream } from \"stream\";\nimport { canUseAsyncIteratorSymbol } from \"../../../utilities/index.js\";\n\ninterface NodeStreamIterator {\n next(): Promise>;\n [Symbol.asyncIterator]?(): AsyncIterator;\n}\n\nexport default function nodeStreamIterator(\n stream: NodeReadableStream\n): AsyncIterableIterator {\n let cleanup: (() => void) | null = null;\n let error: Error | null = null;\n let done = false;\n const data: unknown[] = [];\n\n const waiting: [\n (\n value:\n | IteratorResult\n | PromiseLike>\n ) => void,\n (reason?: any) => void,\n ][] = [];\n\n function onData(chunk: any) {\n if (error) return;\n if (waiting.length) {\n const shiftedArr = waiting.shift();\n if (Array.isArray(shiftedArr) && shiftedArr[0]) {\n return shiftedArr[0]({ value: chunk, done: false });\n }\n }\n data.push(chunk);\n }\n function onError(err: Error) {\n error = err;\n const all = waiting.slice();\n all.forEach(function (pair) {\n pair[1](err);\n });\n !cleanup || cleanup();\n }\n function onEnd() {\n done = true;\n const all = waiting.slice();\n all.forEach(function (pair) {\n pair[0]({ value: undefined, done: true });\n });\n !cleanup || cleanup();\n }\n\n cleanup = function () {\n cleanup = null;\n stream.removeListener(\"data\", onData);\n stream.removeListener(\"error\", onError);\n stream.removeListener(\"end\", onEnd);\n stream.removeListener(\"finish\", onEnd);\n stream.removeListener(\"close\", onEnd);\n };\n stream.on(\"data\", onData);\n stream.on(\"error\", onError);\n stream.on(\"end\", onEnd);\n stream.on(\"finish\", onEnd);\n stream.on(\"close\", onEnd);\n\n function getNext(): Promise> {\n return new Promise(function (resolve, reject) {\n if (error) return reject(error);\n if (data.length)\n return resolve({ value: data.shift() as T, done: false });\n if (done) return resolve({ value: undefined, done: true });\n waiting.push([resolve, reject]);\n });\n }\n\n const iterator: NodeStreamIterator = {\n next(): Promise> {\n return getNext();\n },\n };\n\n if (canUseAsyncIteratorSymbol) {\n iterator[Symbol.asyncIterator] = function (): AsyncIterator {\n return this;\n };\n }\n\n return iterator as AsyncIterableIterator;\n}\n","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/iterators/reader.ts\n */\n\nimport { canUseAsyncIteratorSymbol } from \"../../../utilities/index.js\";\n\ninterface ReaderIterator {\n next(): Promise>;\n [Symbol.asyncIterator]?(): AsyncIterator;\n}\n\nexport default function readerIterator(\n reader: ReadableStreamDefaultReader\n): AsyncIterableIterator {\n const iterator: ReaderIterator = {\n next() {\n return reader.read() as Promise<\n | ReadableStreamReadValueResult\n // DoneResult has `value` optional, which doesn't comply with an\n // `IteratorResult`, so we assert it to `T | undefined` instead\n | Required>\n >;\n },\n };\n\n if (canUseAsyncIteratorSymbol) {\n iterator[Symbol.asyncIterator] = function (): AsyncIterator<\n T,\n T | undefined\n > {\n return this;\n };\n }\n\n return iterator as AsyncIterableIterator;\n}\n","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/index.ts\n */\n\nimport type { Response as NodeResponse } from \"node-fetch\";\nimport type { Readable as NodeReadableStream } from \"stream\";\nimport { canUseAsyncIteratorSymbol } from \"../../utilities/index.js\";\n\nimport asyncIterator from \"./iterators/async.js\";\nimport nodeStreamIterator from \"./iterators/nodeStream.js\";\nimport promiseIterator from \"./iterators/promise.js\";\nimport readerIterator from \"./iterators/reader.js\";\n\nfunction isNodeResponse(value: any): value is NodeResponse {\n return !!(value as NodeResponse).body;\n}\n\nfunction isReadableStream(value: any): value is ReadableStream {\n return !!(value as ReadableStream).getReader;\n}\n\nfunction isAsyncIterableIterator(\n value: any\n): value is AsyncIterableIterator {\n return !!(\n canUseAsyncIteratorSymbol &&\n (value as AsyncIterableIterator)[Symbol.asyncIterator]\n );\n}\n\nfunction isStreamableBlob(value: any): value is Blob {\n return !!(value as Blob).stream;\n}\n\nfunction isBlob(value: any): value is Blob {\n return !!(value as Blob).arrayBuffer;\n}\n\nfunction isNodeReadableStream(value: any): value is NodeReadableStream {\n return !!(value as NodeReadableStream).pipe;\n}\n\nexport function responseIterator(\n response: Response | NodeResponse\n): AsyncIterableIterator {\n let body: unknown = response;\n\n if (isNodeResponse(response)) body = response.body;\n\n if (isAsyncIterableIterator(body)) return asyncIterator(body);\n\n if (isReadableStream(body)) return readerIterator(body.getReader());\n\n // this errors without casting to ReadableStream\n // because Blob.stream() returns a NodeJS ReadableStream\n if (isStreamableBlob(body)) {\n return readerIterator(\n (body.stream() as unknown as ReadableStream).getReader()\n );\n }\n\n if (isBlob(body)) return promiseIterator(body.arrayBuffer());\n\n if (isNodeReadableStream(body)) return nodeStreamIterator(body);\n\n throw new Error(\n \"Unknown body type for responseIterator. Please pass a streamable response.\"\n );\n}\n","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/iterators/promise.ts\n */\n\nimport { canUseAsyncIteratorSymbol } from \"../../../utilities/index.js\";\n\ninterface PromiseIterator {\n next(): Promise>;\n [Symbol.asyncIterator]?(): AsyncIterator;\n}\n\nexport default function promiseIterator(\n promise: Promise\n): AsyncIterableIterator {\n let resolved = false;\n\n const iterator: PromiseIterator = {\n next(): Promise> {\n if (resolved)\n return Promise.resolve({\n value: undefined,\n done: true,\n });\n resolved = true;\n return new Promise(function (resolve, reject) {\n promise\n .then(function (value) {\n resolve({ value: value as unknown as T, done: false });\n })\n .catch(reject);\n });\n },\n };\n\n if (canUseAsyncIteratorSymbol) {\n iterator[Symbol.asyncIterator] = function (): AsyncIterator {\n return this;\n };\n }\n\n return iterator as AsyncIterableIterator;\n}\n","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/iterators/async.ts\n */\n\nexport default function asyncIterator(\n source: AsyncIterableIterator\n): AsyncIterableIterator {\n const iterator = source[Symbol.asyncIterator]();\n return {\n next(): Promise> {\n return iterator.next();\n },\n [Symbol.asyncIterator](): AsyncIterableIterator {\n return this;\n },\n };\n}\n","export type ServerError = Error & {\n response: Response;\n result: Record | string;\n statusCode: number;\n};\n\nexport const throwServerError = (\n response: Response,\n result: any,\n message: string\n) => {\n const error = new Error(message) as ServerError;\n error.name = \"ServerError\";\n error.response = response;\n error.statusCode = response.status;\n error.result = result;\n throw error;\n};\n","import \"../utilities/globals/index.js\";\n\nimport type { GraphQLError, GraphQLErrorExtensions } from \"graphql\";\n\nimport { isNonNullObject } from \"../utilities/index.js\";\nimport type { ServerParseError } from \"../link/http/index.js\";\nimport type { ServerError } from \"../link/utils/index.js\";\nimport type { FetchResult } from \"../link/core/index.js\";\n\n// This Symbol allows us to pass transport-specific errors from the link chain\n// into QueryManager/client internals without risking a naming collision within\n// extensions (which implementers can use as they see fit).\nexport const PROTOCOL_ERRORS_SYMBOL: unique symbol = Symbol();\n\ntype FetchResultWithSymbolExtensions = FetchResult & {\n extensions: Record;\n};\n\nexport interface ApolloErrorOptions {\n graphQLErrors?: ReadonlyArray;\n protocolErrors?: ReadonlyArray<{\n message: string;\n extensions?: GraphQLErrorExtensions[];\n }>;\n clientErrors?: ReadonlyArray;\n networkError?: Error | ServerParseError | ServerError | null;\n errorMessage?: string;\n extraInfo?: any;\n}\n\nexport function graphQLResultHasProtocolErrors(\n result: FetchResult\n): result is FetchResultWithSymbolExtensions {\n if (result.extensions) {\n return Array.isArray(\n (result as FetchResultWithSymbolExtensions).extensions[\n PROTOCOL_ERRORS_SYMBOL\n ]\n );\n }\n return false;\n}\n\nexport function isApolloError(err: Error): err is ApolloError {\n return err.hasOwnProperty(\"graphQLErrors\");\n}\n\n// Sets the error message on this error according to the\n// the GraphQL and network errors that are present.\n// If the error message has already been set through the\n// constructor or otherwise, this function is a nop.\nconst generateErrorMessage = (err: ApolloError) => {\n const errors = [\n ...err.graphQLErrors,\n ...err.clientErrors,\n ...err.protocolErrors,\n ];\n if (err.networkError) errors.push(err.networkError);\n return (\n errors\n // The rest of the code sometimes unsafely types non-Error objects as GraphQLErrors\n .map(\n (err) =>\n (isNonNullObject(err) && err.message) || \"Error message not found.\"\n )\n .join(\"\\n\")\n );\n};\n\nexport type GraphQLErrors = ReadonlyArray;\n\nexport type NetworkError = Error | ServerParseError | ServerError | null;\n\nexport class ApolloError extends Error {\n public name: string;\n public message: string;\n public graphQLErrors: GraphQLErrors;\n public protocolErrors: ReadonlyArray<{\n message: string;\n extensions?: GraphQLErrorExtensions[];\n }>;\n public clientErrors: ReadonlyArray;\n public networkError: Error | ServerParseError | ServerError | null;\n\n // An object that can be used to provide some additional information\n // about an error, e.g. specifying the type of error this is. Used\n // internally within Apollo Client.\n public extraInfo: any;\n\n // Constructs an instance of ApolloError given a GraphQLError\n // or a network error. Note that one of these has to be a valid\n // value or the constructed error will be meaningless.\n constructor({\n graphQLErrors,\n protocolErrors,\n clientErrors,\n networkError,\n errorMessage,\n extraInfo,\n }: ApolloErrorOptions) {\n super(errorMessage);\n this.name = \"ApolloError\";\n this.graphQLErrors = graphQLErrors || [];\n this.protocolErrors = protocolErrors || [];\n this.clientErrors = clientErrors || [];\n this.networkError = networkError || null;\n this.message = errorMessage || generateErrorMessage(this);\n this.extraInfo = extraInfo;\n\n // We're not using `Object.setPrototypeOf` here as it isn't fully\n // supported on Android (see issue #3236).\n (this as any).__proto__ = ApolloError.prototype;\n }\n}\n","// A version of Array.isArray that works better with readonly arrays.\nexport const isArray: (a: any) => a is any[] | readonly any[] = Array.isArray;\n\nexport function isNonEmptyArray(value?: ArrayLike): value is Array {\n return Array.isArray(value) && value.length > 0;\n}\n","import { isNonNullObject } from \"./objects.js\";\n\nconst { hasOwnProperty } = Object.prototype;\n\n// These mergeDeep and mergeDeepArray utilities merge any number of objects\n// together, sharing as much memory as possible with the source objects, while\n// remaining careful to avoid modifying any source objects.\n\n// Logically, the return type of mergeDeep should be the intersection of\n// all the argument types. The binary call signature is by far the most\n// common, but we support 0- through 5-ary as well. After that, the\n// resulting type is just the inferred array element type. Note to nerds:\n// there is a more clever way of doing this that converts the tuple type\n// first to a union type (easy enough: T[number]) and then converts the\n// union to an intersection type using distributive conditional type\n// inference, but that approach has several fatal flaws (boolean becomes\n// true & false, and the inferred type ends up as unknown in many cases),\n// in addition to being nearly impossible to explain/understand.\nexport type TupleToIntersection =\n T extends [infer A] ? A\n : T extends [infer A, infer B] ? A & B\n : T extends [infer A, infer B, infer C] ? A & B & C\n : T extends [infer A, infer B, infer C, infer D] ? A & B & C & D\n : T extends [infer A, infer B, infer C, infer D, infer E] ? A & B & C & D & E\n : T extends (infer U)[] ? U\n : any;\n\nexport function mergeDeep(\n ...sources: T\n): TupleToIntersection {\n return mergeDeepArray(sources);\n}\n\n// In almost any situation where you could succeed in getting the\n// TypeScript compiler to infer a tuple type for the sources array, you\n// could just use mergeDeep instead of mergeDeepArray, so instead of\n// trying to convert T[] to an intersection type we just infer the array\n// element type, which works perfectly when the sources array has a\n// consistent element type.\nexport function mergeDeepArray(sources: T[]): T {\n let target = sources[0] || ({} as T);\n const count = sources.length;\n if (count > 1) {\n const merger = new DeepMerger();\n for (let i = 1; i < count; ++i) {\n target = merger.merge(target, sources[i]);\n }\n }\n return target;\n}\n\nexport type ReconcilerFunction = (\n this: DeepMerger,\n target: Record,\n source: Record,\n property: string | number,\n ...context: TContextArgs\n) => any;\n\nconst defaultReconciler: ReconcilerFunction = function (\n target,\n source,\n property\n) {\n return this.merge(target[property], source[property]);\n};\n\nexport class DeepMerger {\n constructor(\n private reconciler: ReconcilerFunction = defaultReconciler as any as ReconcilerFunction\n ) {}\n\n public merge(target: any, source: any, ...context: TContextArgs): any {\n if (isNonNullObject(source) && isNonNullObject(target)) {\n Object.keys(source).forEach((sourceKey) => {\n if (hasOwnProperty.call(target, sourceKey)) {\n const targetValue = target[sourceKey];\n if (source[sourceKey] !== targetValue) {\n const result = this.reconciler(\n target,\n source,\n sourceKey,\n ...context\n );\n // A well-implemented reconciler may return targetValue to indicate\n // the merge changed nothing about the structure of the target.\n if (result !== targetValue) {\n target = this.shallowCopyForMerge(target);\n target[sourceKey] = result;\n }\n }\n } else {\n // If there is no collision, the target can safely share memory with\n // the source, and the recursion can terminate here.\n target = this.shallowCopyForMerge(target);\n target[sourceKey] = source[sourceKey];\n }\n });\n\n return target;\n }\n\n // If source (or target) is not an object, let source replace target.\n return source;\n }\n\n public isObject = isNonNullObject;\n\n private pastCopies = new Set();\n\n public shallowCopyForMerge(value: T): T {\n if (isNonNullObject(value)) {\n if (!this.pastCopies.has(value)) {\n if (Array.isArray(value)) {\n value = (value as any).slice(0);\n } else {\n value = {\n __proto__: Object.getPrototypeOf(value),\n ...value,\n };\n }\n this.pastCopies.add(value);\n }\n }\n return value;\n }\n}\n","import type {\n ExecutionPatchIncrementalResult,\n ExecutionPatchInitialResult,\n ExecutionPatchResult,\n ApolloPayloadResult,\n FetchResult,\n} from \"../../link/core/index.js\";\nimport { isNonNullObject } from \"./objects.js\";\nimport { isNonEmptyArray } from \"./arrays.js\";\nimport { DeepMerger } from \"./mergeDeep.js\";\n\nexport function isExecutionPatchIncrementalResult(\n value: FetchResult\n): value is ExecutionPatchIncrementalResult {\n return \"incremental\" in value;\n}\n\nexport function isExecutionPatchInitialResult(\n value: FetchResult\n): value is ExecutionPatchInitialResult {\n return \"hasNext\" in value && \"data\" in value;\n}\n\nexport function isExecutionPatchResult(\n value: FetchResult\n): value is ExecutionPatchResult {\n return (\n isExecutionPatchIncrementalResult(value) ||\n isExecutionPatchInitialResult(value)\n );\n}\n\n// This function detects an Apollo payload result before it is transformed\n// into a FetchResult via HttpLink; it cannot detect an ApolloPayloadResult\n// once it leaves the link chain.\nexport function isApolloPayloadResult(\n value: unknown\n): value is ApolloPayloadResult {\n return isNonNullObject(value) && \"payload\" in value;\n}\n\nexport function mergeIncrementalData(\n prevResult: TData,\n result: ExecutionPatchResult\n) {\n let mergedData = prevResult;\n const merger = new DeepMerger();\n if (\n isExecutionPatchIncrementalResult(result) &&\n isNonEmptyArray(result.incremental)\n ) {\n result.incremental.forEach(({ data, path }) => {\n for (let i = path.length - 1; i >= 0; --i) {\n const key = path[i];\n const isNumericKey = !isNaN(+key);\n const parent: Record = isNumericKey ? [] : {};\n parent[key] = data;\n data = parent as typeof data;\n }\n mergedData = merger.merge(mergedData, data);\n });\n }\n return mergedData as TData;\n}\n","import { responseIterator } from \"./responseIterator.js\";\nimport type { Operation } from \"../core/index.js\";\nimport { throwServerError } from \"../utils/index.js\";\nimport { PROTOCOL_ERRORS_SYMBOL } from \"../../errors/index.js\";\nimport { isApolloPayloadResult } from \"../../utilities/common/incrementalResult.js\";\nimport type { SubscriptionObserver } from \"zen-observable-ts\";\n\nconst { hasOwnProperty } = Object.prototype;\n\nexport type ServerParseError = Error & {\n response: Response;\n statusCode: number;\n bodyText: string;\n};\n\nexport async function readMultipartBody<\n T extends object = Record,\n>(response: Response, nextValue: (value: T) => void) {\n if (TextDecoder === undefined) {\n throw new Error(\n \"TextDecoder must be defined in the environment: please import a polyfill.\"\n );\n }\n const decoder = new TextDecoder(\"utf-8\");\n const contentType = response.headers?.get(\"content-type\");\n const delimiter = \"boundary=\";\n\n // parse boundary value and ignore any subsequent name/value pairs after ;\n // https://www.rfc-editor.org/rfc/rfc9110.html#name-parameters\n // e.g. multipart/mixed;boundary=\"graphql\";deferSpec=20220824\n // if no boundary is specified, default to -\n const boundaryVal =\n contentType?.includes(delimiter) ?\n contentType\n ?.substring(contentType?.indexOf(delimiter) + delimiter.length)\n .replace(/['\"]/g, \"\")\n .replace(/\\;(.*)/gm, \"\")\n .trim()\n : \"-\";\n\n const boundary = `\\r\\n--${boundaryVal}`;\n let buffer = \"\";\n const iterator = responseIterator(response);\n let running = true;\n\n while (running) {\n const { value, done } = await iterator.next();\n const chunk = typeof value === \"string\" ? value : decoder.decode(value);\n const searchFrom = buffer.length - boundary.length + 1;\n running = !done;\n buffer += chunk;\n let bi = buffer.indexOf(boundary, searchFrom);\n\n while (bi > -1) {\n let message: string;\n [message, buffer] = [\n buffer.slice(0, bi),\n buffer.slice(bi + boundary.length),\n ];\n const i = message.indexOf(\"\\r\\n\\r\\n\");\n const headers = parseHeaders(message.slice(0, i));\n const contentType = headers[\"content-type\"];\n if (\n contentType &&\n contentType.toLowerCase().indexOf(\"application/json\") === -1\n ) {\n throw new Error(\n \"Unsupported patch content type: application/json is required.\"\n );\n }\n // nb: Technically you'd want to slice off the beginning \"\\r\\n\" but since\n // this is going to be `JSON.parse`d there is no need.\n const body = message.slice(i);\n\n if (body) {\n const result = parseJsonBody(response, body);\n if (\n Object.keys(result).length > 1 ||\n \"data\" in result ||\n \"incremental\" in result ||\n \"errors\" in result ||\n \"payload\" in result\n ) {\n if (isApolloPayloadResult(result)) {\n let next = {};\n if (\"payload\" in result) {\n if (Object.keys(result).length === 1 && result.payload === null) {\n return;\n }\n next = { ...result.payload };\n }\n if (\"errors\" in result) {\n next = {\n ...next,\n extensions: {\n ...(\"extensions\" in next ? next.extensions : (null as any)),\n [PROTOCOL_ERRORS_SYMBOL]: result.errors,\n },\n };\n }\n nextValue(next as T);\n } else {\n // for the last chunk with only `hasNext: false`\n // we don't need to call observer.next as there is no data/errors\n nextValue(result);\n }\n } else if (\n // If the chunk contains only a \"hasNext: false\", we can call\n // observer.complete() immediately.\n Object.keys(result).length === 1 &&\n \"hasNext\" in result &&\n !result.hasNext\n ) {\n return;\n }\n }\n bi = buffer.indexOf(boundary);\n }\n }\n}\n\nexport function parseHeaders(headerText: string): Record {\n const headersInit: Record = {};\n headerText.split(\"\\n\").forEach((line) => {\n const i = line.indexOf(\":\");\n if (i > -1) {\n // normalize headers to lowercase\n const name = line.slice(0, i).trim().toLowerCase();\n const value = line.slice(i + 1).trim();\n headersInit[name] = value;\n }\n });\n return headersInit;\n}\n\nexport function parseJsonBody(response: Response, bodyText: string): T {\n if (response.status >= 300) {\n // Network error\n const getResult = (): Record | string => {\n try {\n return JSON.parse(bodyText);\n } catch (err) {\n return bodyText;\n }\n };\n throwServerError(\n response,\n getResult(),\n `Response not successful: Received status code ${response.status}`\n );\n }\n\n try {\n return JSON.parse(bodyText) as T;\n } catch (err) {\n const parseError = err as ServerParseError;\n parseError.name = \"ServerParseError\";\n parseError.response = response;\n parseError.statusCode = response.status;\n parseError.bodyText = bodyText;\n throw parseError;\n }\n}\n\nexport function handleError(err: any, observer: SubscriptionObserver) {\n // if it is a network error, BUT there is graphql result info fire\n // the next observer before calling error this gives apollo-client\n // (and react-apollo) the `graphqlErrors` and `networkErrors` to\n // pass to UI this should only happen if we *also* have data as\n // part of the response key per the spec\n if (err.result && err.result.errors && err.result.data) {\n // if we don't call next, the UI can only show networkError\n // because AC didn't get any graphqlErrors this is graphql\n // execution result info (i.e errors and possibly data) this is\n // because there is no formal spec how errors should translate to\n // http status codes. So an auth error (401) could have both data\n // from a public field, errors from a private field, and a status\n // of 401\n // {\n // user { // this will have errors\n // firstName\n // }\n // products { // this is public so will have data\n // cost\n // }\n // }\n //\n // the result of above *could* look like this:\n // {\n // data: { products: [{ cost: \"$10\" }] },\n // errors: [{\n // message: 'your session has timed out',\n // path: []\n // }]\n // }\n // status code of above would be a 401\n // in the UI you want to show data where you can, errors as data where you can\n // and use correct http status codes\n observer.next(err.result);\n }\n\n observer.error(err);\n}\n\nexport function parseAndCheckHttpResponse(operations: Operation | Operation[]) {\n return (response: Response) =>\n response\n .text()\n .then((bodyText) => parseJsonBody(response, bodyText))\n .then((result: any) => {\n if (\n !Array.isArray(result) &&\n !hasOwnProperty.call(result, \"data\") &&\n !hasOwnProperty.call(result, \"errors\")\n ) {\n // Data error\n throwServerError(\n response,\n result,\n `Server response was missing for query '${\n Array.isArray(operations) ?\n operations.map((op) => op.operationName)\n : operations.operationName\n }'.`\n );\n }\n return result;\n });\n}\n","/**\n * ```\n * WhiteSpace ::\n * - \"Horizontal Tab (U+0009)\"\n * - \"Space (U+0020)\"\n * ```\n * @internal\n */\nexport function isWhiteSpace(code) {\n return code === 0x0009 || code === 0x0020;\n}\n/**\n * ```\n * Digit :: one of\n * - `0` `1` `2` `3` `4` `5` `6` `7` `8` `9`\n * ```\n * @internal\n */\n\nexport function isDigit(code) {\n return code >= 0x0030 && code <= 0x0039;\n}\n/**\n * ```\n * Letter :: one of\n * - `A` `B` `C` `D` `E` `F` `G` `H` `I` `J` `K` `L` `M`\n * - `N` `O` `P` `Q` `R` `S` `T` `U` `V` `W` `X` `Y` `Z`\n * - `a` `b` `c` `d` `e` `f` `g` `h` `i` `j` `k` `l` `m`\n * - `n` `o` `p` `q` `r` `s` `t` `u` `v` `w` `x` `y` `z`\n * ```\n * @internal\n */\n\nexport function isLetter(code) {\n return (\n (code >= 0x0061 && code <= 0x007a) || // A-Z\n (code >= 0x0041 && code <= 0x005a) // a-z\n );\n}\n/**\n * ```\n * NameStart ::\n * - Letter\n * - `_`\n * ```\n * @internal\n */\n\nexport function isNameStart(code) {\n return isLetter(code) || code === 0x005f;\n}\n/**\n * ```\n * NameContinue ::\n * - Letter\n * - Digit\n * - `_`\n * ```\n * @internal\n */\n\nexport function isNameContinue(code) {\n return isLetter(code) || isDigit(code) || code === 0x005f;\n}\n","/**\n * Prints a string as a GraphQL StringValue literal. Replaces control characters\n * and excluded characters (\" U+0022 and \\\\ U+005C) with escape sequences.\n */\nexport function printString(str) {\n return `\"${str.replace(escapedRegExp, escapedReplacer)}\"`;\n} // eslint-disable-next-line no-control-regex\n\nconst escapedRegExp = /[\\x00-\\x1f\\x22\\x5c\\x7f-\\x9f]/g;\n\nfunction escapedReplacer(str) {\n return escapeSequences[str.charCodeAt(0)];\n} // prettier-ignore\n\nconst escapeSequences = [\n '\\\\u0000',\n '\\\\u0001',\n '\\\\u0002',\n '\\\\u0003',\n '\\\\u0004',\n '\\\\u0005',\n '\\\\u0006',\n '\\\\u0007',\n '\\\\b',\n '\\\\t',\n '\\\\n',\n '\\\\u000B',\n '\\\\f',\n '\\\\r',\n '\\\\u000E',\n '\\\\u000F',\n '\\\\u0010',\n '\\\\u0011',\n '\\\\u0012',\n '\\\\u0013',\n '\\\\u0014',\n '\\\\u0015',\n '\\\\u0016',\n '\\\\u0017',\n '\\\\u0018',\n '\\\\u0019',\n '\\\\u001A',\n '\\\\u001B',\n '\\\\u001C',\n '\\\\u001D',\n '\\\\u001E',\n '\\\\u001F',\n '',\n '',\n '\\\\\"',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '', // 2F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '', // 3F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '', // 4F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '\\\\\\\\',\n '',\n '',\n '', // 5F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '', // 6F\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '',\n '\\\\u007F',\n '\\\\u0080',\n '\\\\u0081',\n '\\\\u0082',\n '\\\\u0083',\n '\\\\u0084',\n '\\\\u0085',\n '\\\\u0086',\n '\\\\u0087',\n '\\\\u0088',\n '\\\\u0089',\n '\\\\u008A',\n '\\\\u008B',\n '\\\\u008C',\n '\\\\u008D',\n '\\\\u008E',\n '\\\\u008F',\n '\\\\u0090',\n '\\\\u0091',\n '\\\\u0092',\n '\\\\u0093',\n '\\\\u0094',\n '\\\\u0095',\n '\\\\u0096',\n '\\\\u0097',\n '\\\\u0098',\n '\\\\u0099',\n '\\\\u009A',\n '\\\\u009B',\n '\\\\u009C',\n '\\\\u009D',\n '\\\\u009E',\n '\\\\u009F',\n];\n","import { printBlockString } from './blockString.mjs';\nimport { printString } from './printString.mjs';\nimport { visit } from './visitor.mjs';\n/**\n * Converts an AST into a string, using one set of reasonable\n * formatting rules.\n */\n\nexport function print(ast) {\n return visit(ast, printDocASTReducer);\n}\nconst MAX_LINE_LENGTH = 80;\nconst printDocASTReducer = {\n Name: {\n leave: (node) => node.value,\n },\n Variable: {\n leave: (node) => '$' + node.name,\n },\n // Document\n Document: {\n leave: (node) => join(node.definitions, '\\n\\n'),\n },\n OperationDefinition: {\n leave(node) {\n const varDefs = wrap('(', join(node.variableDefinitions, ', '), ')');\n const prefix = join(\n [\n node.operation,\n join([node.name, varDefs]),\n join(node.directives, ' '),\n ],\n ' ',\n ); // Anonymous queries with no directives or variable definitions can use\n // the query short form.\n\n return (prefix === 'query' ? '' : prefix + ' ') + node.selectionSet;\n },\n },\n VariableDefinition: {\n leave: ({ variable, type, defaultValue, directives }) =>\n variable +\n ': ' +\n type +\n wrap(' = ', defaultValue) +\n wrap(' ', join(directives, ' ')),\n },\n SelectionSet: {\n leave: ({ selections }) => block(selections),\n },\n Field: {\n leave({ alias, name, arguments: args, directives, selectionSet }) {\n const prefix = wrap('', alias, ': ') + name;\n let argsLine = prefix + wrap('(', join(args, ', '), ')');\n\n if (argsLine.length > MAX_LINE_LENGTH) {\n argsLine = prefix + wrap('(\\n', indent(join(args, '\\n')), '\\n)');\n }\n\n return join([argsLine, join(directives, ' '), selectionSet], ' ');\n },\n },\n Argument: {\n leave: ({ name, value }) => name + ': ' + value,\n },\n // Fragments\n FragmentSpread: {\n leave: ({ name, directives }) =>\n '...' + name + wrap(' ', join(directives, ' ')),\n },\n InlineFragment: {\n leave: ({ typeCondition, directives, selectionSet }) =>\n join(\n [\n '...',\n wrap('on ', typeCondition),\n join(directives, ' '),\n selectionSet,\n ],\n ' ',\n ),\n },\n FragmentDefinition: {\n leave: (\n { name, typeCondition, variableDefinitions, directives, selectionSet }, // Note: fragment variable definitions are experimental and may be changed\n ) =>\n // or removed in the future.\n `fragment ${name}${wrap('(', join(variableDefinitions, ', '), ')')} ` +\n `on ${typeCondition} ${wrap('', join(directives, ' '), ' ')}` +\n selectionSet,\n },\n // Value\n IntValue: {\n leave: ({ value }) => value,\n },\n FloatValue: {\n leave: ({ value }) => value,\n },\n StringValue: {\n leave: ({ value, block: isBlockString }) =>\n isBlockString ? printBlockString(value) : printString(value),\n },\n BooleanValue: {\n leave: ({ value }) => (value ? 'true' : 'false'),\n },\n NullValue: {\n leave: () => 'null',\n },\n EnumValue: {\n leave: ({ value }) => value,\n },\n ListValue: {\n leave: ({ values }) => '[' + join(values, ', ') + ']',\n },\n ObjectValue: {\n leave: ({ fields }) => '{' + join(fields, ', ') + '}',\n },\n ObjectField: {\n leave: ({ name, value }) => name + ': ' + value,\n },\n // Directive\n Directive: {\n leave: ({ name, arguments: args }) =>\n '@' + name + wrap('(', join(args, ', '), ')'),\n },\n // Type\n NamedType: {\n leave: ({ name }) => name,\n },\n ListType: {\n leave: ({ type }) => '[' + type + ']',\n },\n NonNullType: {\n leave: ({ type }) => type + '!',\n },\n // Type System Definitions\n SchemaDefinition: {\n leave: ({ description, directives, operationTypes }) =>\n wrap('', description, '\\n') +\n join(['schema', join(directives, ' '), block(operationTypes)], ' '),\n },\n OperationTypeDefinition: {\n leave: ({ operation, type }) => operation + ': ' + type,\n },\n ScalarTypeDefinition: {\n leave: ({ description, name, directives }) =>\n wrap('', description, '\\n') +\n join(['scalar', name, join(directives, ' ')], ' '),\n },\n ObjectTypeDefinition: {\n leave: ({ description, name, interfaces, directives, fields }) =>\n wrap('', description, '\\n') +\n join(\n [\n 'type',\n name,\n wrap('implements ', join(interfaces, ' & ')),\n join(directives, ' '),\n block(fields),\n ],\n ' ',\n ),\n },\n FieldDefinition: {\n leave: ({ description, name, arguments: args, type, directives }) =>\n wrap('', description, '\\n') +\n name +\n (hasMultilineItems(args)\n ? wrap('(\\n', indent(join(args, '\\n')), '\\n)')\n : wrap('(', join(args, ', '), ')')) +\n ': ' +\n type +\n wrap(' ', join(directives, ' ')),\n },\n InputValueDefinition: {\n leave: ({ description, name, type, defaultValue, directives }) =>\n wrap('', description, '\\n') +\n join(\n [name + ': ' + type, wrap('= ', defaultValue), join(directives, ' ')],\n ' ',\n ),\n },\n InterfaceTypeDefinition: {\n leave: ({ description, name, interfaces, directives, fields }) =>\n wrap('', description, '\\n') +\n join(\n [\n 'interface',\n name,\n wrap('implements ', join(interfaces, ' & ')),\n join(directives, ' '),\n block(fields),\n ],\n ' ',\n ),\n },\n UnionTypeDefinition: {\n leave: ({ description, name, directives, types }) =>\n wrap('', description, '\\n') +\n join(\n ['union', name, join(directives, ' '), wrap('= ', join(types, ' | '))],\n ' ',\n ),\n },\n EnumTypeDefinition: {\n leave: ({ description, name, directives, values }) =>\n wrap('', description, '\\n') +\n join(['enum', name, join(directives, ' '), block(values)], ' '),\n },\n EnumValueDefinition: {\n leave: ({ description, name, directives }) =>\n wrap('', description, '\\n') + join([name, join(directives, ' ')], ' '),\n },\n InputObjectTypeDefinition: {\n leave: ({ description, name, directives, fields }) =>\n wrap('', description, '\\n') +\n join(['input', name, join(directives, ' '), block(fields)], ' '),\n },\n DirectiveDefinition: {\n leave: ({ description, name, arguments: args, repeatable, locations }) =>\n wrap('', description, '\\n') +\n 'directive @' +\n name +\n (hasMultilineItems(args)\n ? wrap('(\\n', indent(join(args, '\\n')), '\\n)')\n : wrap('(', join(args, ', '), ')')) +\n (repeatable ? ' repeatable' : '') +\n ' on ' +\n join(locations, ' | '),\n },\n SchemaExtension: {\n leave: ({ directives, operationTypes }) =>\n join(\n ['extend schema', join(directives, ' '), block(operationTypes)],\n ' ',\n ),\n },\n ScalarTypeExtension: {\n leave: ({ name, directives }) =>\n join(['extend scalar', name, join(directives, ' ')], ' '),\n },\n ObjectTypeExtension: {\n leave: ({ name, interfaces, directives, fields }) =>\n join(\n [\n 'extend type',\n name,\n wrap('implements ', join(interfaces, ' & ')),\n join(directives, ' '),\n block(fields),\n ],\n ' ',\n ),\n },\n InterfaceTypeExtension: {\n leave: ({ name, interfaces, directives, fields }) =>\n join(\n [\n 'extend interface',\n name,\n wrap('implements ', join(interfaces, ' & ')),\n join(directives, ' '),\n block(fields),\n ],\n ' ',\n ),\n },\n UnionTypeExtension: {\n leave: ({ name, directives, types }) =>\n join(\n [\n 'extend union',\n name,\n join(directives, ' '),\n wrap('= ', join(types, ' | ')),\n ],\n ' ',\n ),\n },\n EnumTypeExtension: {\n leave: ({ name, directives, values }) =>\n join(['extend enum', name, join(directives, ' '), block(values)], ' '),\n },\n InputObjectTypeExtension: {\n leave: ({ name, directives, fields }) =>\n join(['extend input', name, join(directives, ' '), block(fields)], ' '),\n },\n};\n/**\n * Given maybeArray, print an empty string if it is null or empty, otherwise\n * print all items together separated by separator if provided\n */\n\nfunction join(maybeArray, separator = '') {\n var _maybeArray$filter$jo;\n\n return (_maybeArray$filter$jo =\n maybeArray === null || maybeArray === void 0\n ? void 0\n : maybeArray.filter((x) => x).join(separator)) !== null &&\n _maybeArray$filter$jo !== void 0\n ? _maybeArray$filter$jo\n : '';\n}\n/**\n * Given array, print each item on its own line, wrapped in an indented `{ }` block.\n */\n\nfunction block(array) {\n return wrap('{\\n', indent(join(array, '\\n')), '\\n}');\n}\n/**\n * If maybeString is not null or empty, then wrap with start and end, otherwise print an empty string.\n */\n\nfunction wrap(start, maybeString, end = '') {\n return maybeString != null && maybeString !== ''\n ? start + maybeString + end\n : '';\n}\n\nfunction indent(str) {\n return wrap(' ', str.replace(/\\n/g, '\\n '));\n}\n\nfunction hasMultilineItems(maybeArray) {\n var _maybeArray$some;\n\n // FIXME: https://github.com/graphql/graphql-js/issues/2203\n\n /* c8 ignore next */\n return (_maybeArray$some =\n maybeArray === null || maybeArray === void 0\n ? void 0\n : maybeArray.some((str) => str.includes('\\n'))) !== null &&\n _maybeArray$some !== void 0\n ? _maybeArray$some\n : false;\n}\n","import type { ASTNode } from \"graphql\";\nimport { print as origPrint } from \"graphql\";\nimport {\n AutoCleanedWeakCache,\n cacheSizes,\n defaultCacheSizes,\n} from \"../caching/index.js\";\nimport { registerGlobalCache } from \"../caching/getMemoryInternals.js\";\n\nlet printCache!: AutoCleanedWeakCache;\nexport const print = Object.assign(\n (ast: ASTNode) => {\n let result = printCache.get(ast);\n\n if (!result) {\n result = origPrint(ast);\n printCache.set(ast, result);\n }\n return result;\n },\n {\n reset() {\n printCache = new AutoCleanedWeakCache(\n cacheSizes.print || defaultCacheSizes.print\n );\n },\n }\n);\nprint.reset();\n\nif (__DEV__) {\n registerGlobalCache(\"print\", () => (printCache ? printCache.size : 0));\n}\n","import { isWhiteSpace } from './characterClasses.mjs';\n/**\n * Produces the value of a block string from its parsed raw value, similar to\n * CoffeeScript's block string, Python's docstring trim or Ruby's strip_heredoc.\n *\n * This implements the GraphQL spec's BlockStringValue() static algorithm.\n *\n * @internal\n */\n\nexport function dedentBlockStringLines(lines) {\n var _firstNonEmptyLine2;\n\n let commonIndent = Number.MAX_SAFE_INTEGER;\n let firstNonEmptyLine = null;\n let lastNonEmptyLine = -1;\n\n for (let i = 0; i < lines.length; ++i) {\n var _firstNonEmptyLine;\n\n const line = lines[i];\n const indent = leadingWhitespace(line);\n\n if (indent === line.length) {\n continue; // skip empty lines\n }\n\n firstNonEmptyLine =\n (_firstNonEmptyLine = firstNonEmptyLine) !== null &&\n _firstNonEmptyLine !== void 0\n ? _firstNonEmptyLine\n : i;\n lastNonEmptyLine = i;\n\n if (i !== 0 && indent < commonIndent) {\n commonIndent = indent;\n }\n }\n\n return lines // Remove common indentation from all lines but first.\n .map((line, i) => (i === 0 ? line : line.slice(commonIndent))) // Remove leading and trailing blank lines.\n .slice(\n (_firstNonEmptyLine2 = firstNonEmptyLine) !== null &&\n _firstNonEmptyLine2 !== void 0\n ? _firstNonEmptyLine2\n : 0,\n lastNonEmptyLine + 1,\n );\n}\n\nfunction leadingWhitespace(str) {\n let i = 0;\n\n while (i < str.length && isWhiteSpace(str.charCodeAt(i))) {\n ++i;\n }\n\n return i;\n}\n/**\n * @internal\n */\n\nexport function isPrintableAsBlockString(value) {\n if (value === '') {\n return true; // empty string is printable\n }\n\n let isEmptyLine = true;\n let hasIndent = false;\n let hasCommonIndent = true;\n let seenNonEmptyLine = false;\n\n for (let i = 0; i < value.length; ++i) {\n switch (value.codePointAt(i)) {\n case 0x0000:\n case 0x0001:\n case 0x0002:\n case 0x0003:\n case 0x0004:\n case 0x0005:\n case 0x0006:\n case 0x0007:\n case 0x0008:\n case 0x000b:\n case 0x000c:\n case 0x000e:\n case 0x000f:\n return false;\n // Has non-printable characters\n\n case 0x000d:\n // \\r\n return false;\n // Has \\r or \\r\\n which will be replaced as \\n\n\n case 10:\n // \\n\n if (isEmptyLine && !seenNonEmptyLine) {\n return false; // Has leading new line\n }\n\n seenNonEmptyLine = true;\n isEmptyLine = true;\n hasIndent = false;\n break;\n\n case 9: // \\t\n\n case 32:\n // \n hasIndent || (hasIndent = isEmptyLine);\n break;\n\n default:\n hasCommonIndent && (hasCommonIndent = hasIndent);\n isEmptyLine = false;\n }\n }\n\n if (isEmptyLine) {\n return false; // Has trailing empty lines\n }\n\n if (hasCommonIndent && seenNonEmptyLine) {\n return false; // Has internal indent\n }\n\n return true;\n}\n/**\n * Print a block string in the indented block form by adding a leading and\n * trailing blank line. However, if a block string starts with whitespace and is\n * a single-line, adding a leading blank line would strip that whitespace.\n *\n * @internal\n */\n\nexport function printBlockString(value, options) {\n const escapedValue = value.replace(/\"\"\"/g, '\\\\\"\"\"'); // Expand a block string's raw value into independent lines.\n\n const lines = escapedValue.split(/\\r\\n|[\\n\\r]/g);\n const isSingleLine = lines.length === 1; // If common indentation is found we can fix some of those cases by adding leading new line\n\n const forceLeadingNewLine =\n lines.length > 1 &&\n lines\n .slice(1)\n .every((line) => line.length === 0 || isWhiteSpace(line.charCodeAt(0))); // Trailing triple quotes just looks confusing but doesn't force trailing new line\n\n const hasTrailingTripleQuotes = escapedValue.endsWith('\\\\\"\"\"'); // Trailing quote (single or double) or slash forces trailing new line\n\n const hasTrailingQuote = value.endsWith('\"') && !hasTrailingTripleQuotes;\n const hasTrailingSlash = value.endsWith('\\\\');\n const forceTrailingNewline = hasTrailingQuote || hasTrailingSlash;\n const printAsMultipleLines =\n !(options !== null && options !== void 0 && options.minimize) && // add leading and trailing new lines only if it improves readability\n (!isSingleLine ||\n value.length > 70 ||\n forceTrailingNewline ||\n forceLeadingNewLine ||\n hasTrailingTripleQuotes);\n let result = ''; // Format a multi-line block quote to account for leading space.\n\n const skipLeadingNewLine = isSingleLine && isWhiteSpace(value.charCodeAt(0));\n\n if ((printAsMultipleLines && !skipLeadingNewLine) || forceLeadingNewLine) {\n result += '\\n';\n }\n\n result += escapedValue;\n\n if (printAsMultipleLines || forceTrailingNewline) {\n result += '\\n';\n }\n\n return '\"\"\"' + result + '\"\"\"';\n}\n","import type { ASTNode } from \"graphql\";\nimport { print } from \"../../utilities/index.js\";\n\nimport type { Operation } from \"../core/index.js\";\n\nexport interface Printer {\n (node: ASTNode, originalPrint: typeof print): string;\n}\n\nexport interface UriFunction {\n (operation: Operation): string;\n}\n\nexport interface Body {\n query?: string;\n operationName?: string;\n variables?: Record;\n extensions?: Record;\n}\n\nexport interface HttpOptions {\n /**\n * The URI to use when fetching operations.\n *\n * Defaults to '/graphql'.\n */\n uri?: string | UriFunction;\n\n /**\n * Passes the extensions field to your graphql server.\n *\n * Defaults to false.\n */\n includeExtensions?: boolean;\n\n /**\n * A `fetch`-compatible API to use when making requests.\n */\n fetch?: typeof fetch;\n\n /**\n * An object representing values to be sent as headers on the request.\n */\n headers?: Record;\n\n /**\n * If set to true, header names won't be automatically normalized to\n * lowercase. This allows for non-http-spec-compliant servers that might\n * expect capitalized header names.\n */\n preserveHeaderCase?: boolean;\n\n /**\n * The credentials policy you want to use for the fetch call.\n */\n credentials?: string;\n\n /**\n * Any overrides of the fetch options argument to pass to the fetch call.\n */\n fetchOptions?: any;\n\n /**\n * If set to true, use the HTTP GET method for query operations. Mutations\n * will still use the method specified in fetchOptions.method (which defaults\n * to POST).\n */\n useGETForQueries?: boolean;\n\n /**\n * If set to true, the default behavior of stripping unused variables\n * from the request will be disabled.\n *\n * Unused variables are likely to trigger server-side validation errors,\n * per https://spec.graphql.org/draft/#sec-All-Variables-Used, but this\n * includeUnusedVariables option can be useful if your server deviates\n * from the GraphQL specification by not strictly enforcing that rule.\n */\n includeUnusedVariables?: boolean;\n /**\n * A function to substitute for the default query print function. Can be\n * used to apply changes to the results of the print function.\n */\n print?: Printer;\n}\n\nexport interface HttpQueryOptions {\n includeQuery?: boolean;\n includeExtensions?: boolean;\n preserveHeaderCase?: boolean;\n}\n\nexport interface HttpConfig {\n http?: HttpQueryOptions;\n options?: any;\n headers?: Record;\n credentials?: any;\n}\n\nconst defaultHttpOptions: HttpQueryOptions = {\n includeQuery: true,\n includeExtensions: false,\n preserveHeaderCase: false,\n};\n\nconst defaultHeaders = {\n // headers are case insensitive (https://stackoverflow.com/a/5259004)\n accept: \"*/*\",\n // The content-type header describes the type of the body of the request, and\n // so it typically only is sent with requests that actually have bodies. One\n // could imagine that Apollo Client would remove this header when constructing\n // a GET request (which has no body), but we historically have not done that.\n // This means that browsers will preflight all Apollo Client requests (even\n // GET requests). Apollo Server's CSRF prevention feature (introduced in\n // AS3.7) takes advantage of this fact and does not block requests with this\n // header. If you want to drop this header from GET requests, then you should\n // probably replace it with a `apollo-require-preflight` header, or servers\n // with CSRF prevention enabled might block your GET request. See\n // https://www.apollographql.com/docs/apollo-server/security/cors/#preventing-cross-site-request-forgery-csrf\n // for more details.\n \"content-type\": \"application/json\",\n};\n\nconst defaultOptions = {\n method: \"POST\",\n};\n\nexport const fallbackHttpConfig = {\n http: defaultHttpOptions,\n headers: defaultHeaders,\n options: defaultOptions,\n};\n\nexport const defaultPrinter: Printer = (ast, printer) => printer(ast);\n\nexport function selectHttpOptionsAndBody(\n operation: Operation,\n fallbackConfig: HttpConfig,\n ...configs: Array\n) {\n configs.unshift(fallbackConfig);\n return selectHttpOptionsAndBodyInternal(\n operation,\n defaultPrinter,\n ...configs\n );\n}\n\nexport function selectHttpOptionsAndBodyInternal(\n operation: Operation,\n printer: Printer,\n ...configs: HttpConfig[]\n) {\n let options = {} as HttpConfig & Record;\n let http = {} as HttpQueryOptions;\n\n configs.forEach((config) => {\n options = {\n ...options,\n ...config.options,\n headers: {\n ...options.headers,\n ...config.headers,\n },\n };\n\n if (config.credentials) {\n options.credentials = config.credentials;\n }\n\n http = {\n ...http,\n ...config.http,\n };\n });\n\n if (options.headers) {\n options.headers = removeDuplicateHeaders(\n options.headers,\n http.preserveHeaderCase\n );\n }\n\n //The body depends on the http options\n const { operationName, extensions, variables, query } = operation;\n const body: Body = { operationName, variables };\n\n if (http.includeExtensions) (body as any).extensions = extensions;\n\n // not sending the query (i.e persisted queries)\n if (http.includeQuery) (body as any).query = printer(query, print);\n\n return {\n options,\n body,\n };\n}\n\n// Remove potential duplicate header names, preserving last (by insertion order).\n// This is done to prevent unintentionally duplicating a header instead of\n// overwriting it (See #8447 and #8449).\nfunction removeDuplicateHeaders(\n headers: Record,\n preserveHeaderCase: boolean | undefined\n): typeof headers {\n // If we're not preserving the case, just remove duplicates w/ normalization.\n if (!preserveHeaderCase) {\n const normalizedHeaders = Object.create(null);\n Object.keys(Object(headers)).forEach((name) => {\n normalizedHeaders[name.toLowerCase()] = headers[name];\n });\n return normalizedHeaders;\n }\n\n // If we are preserving the case, remove duplicates w/ normalization,\n // preserving the original name.\n // This allows for non-http-spec-compliant servers that expect intentionally\n // capitalized header names (See #6741).\n const headerData = Object.create(null);\n Object.keys(Object(headers)).forEach((name) => {\n headerData[name.toLowerCase()] = {\n originalName: name,\n value: headers[name],\n };\n });\n\n const normalizedHeaders = Object.create(null);\n Object.keys(headerData).forEach((name) => {\n normalizedHeaders[headerData[name].originalName] = headerData[name].value;\n });\n return normalizedHeaders;\n}\n","import { Observable } from \"../../utilities/index.js\";\n\nexport function fromError(errorValue: any): Observable {\n return new Observable((observer) => {\n observer.error(errorValue);\n });\n}\n","import { invariant } from \"../globals/index.js\";\n\nimport type {\n DocumentNode,\n SelectionNode,\n SelectionSetNode,\n OperationDefinitionNode,\n FieldNode,\n DirectiveNode,\n FragmentDefinitionNode,\n ArgumentNode,\n FragmentSpreadNode,\n VariableDefinitionNode,\n ASTNode,\n ASTVisitFn,\n InlineFragmentNode,\n} from \"graphql\";\nimport { visit, Kind } from \"graphql\";\n\nimport {\n checkDocument,\n getOperationDefinition,\n getFragmentDefinition,\n getFragmentDefinitions,\n getMainDefinition,\n} from \"./getFromAST.js\";\nimport { isField } from \"./storeUtils.js\";\nimport type { FragmentMap } from \"./fragments.js\";\nimport { createFragmentMap } from \"./fragments.js\";\nimport { isArray, isNonEmptyArray } from \"../common/arrays.js\";\n\n// https://github.com/graphql/graphql-js/blob/8d7c8fccf5a9846a50785de04abda58a7eb13fc0/src/language/visitor.ts#L20-L23\ninterface EnterLeaveVisitor {\n readonly enter?: ASTVisitFn;\n readonly leave?: ASTVisitFn;\n}\n\nexport type RemoveNodeConfig = {\n name?: string;\n test?: (node: N) => boolean;\n remove?: boolean;\n};\n\nexport type GetNodeConfig = {\n name?: string;\n test?: (node: N) => boolean;\n};\n\nexport type RemoveDirectiveConfig = RemoveNodeConfig;\nexport type GetDirectiveConfig = GetNodeConfig;\nexport type RemoveArgumentsConfig = RemoveNodeConfig;\nexport type GetFragmentSpreadConfig = GetNodeConfig;\nexport type RemoveFragmentSpreadConfig = RemoveNodeConfig;\nexport type RemoveFragmentDefinitionConfig =\n RemoveNodeConfig;\nexport type RemoveVariableDefinitionConfig =\n RemoveNodeConfig;\n\nconst TYPENAME_FIELD: FieldNode = {\n kind: Kind.FIELD,\n name: {\n kind: Kind.NAME,\n value: \"__typename\",\n },\n};\n\nfunction isEmpty(\n op: OperationDefinitionNode | FragmentDefinitionNode,\n fragmentMap: FragmentMap\n): boolean {\n return (\n !op ||\n op.selectionSet.selections.every(\n (selection) =>\n selection.kind === Kind.FRAGMENT_SPREAD &&\n isEmpty(fragmentMap[selection.name.value], fragmentMap)\n )\n );\n}\n\nfunction nullIfDocIsEmpty(doc: DocumentNode) {\n return (\n isEmpty(\n getOperationDefinition(doc) || getFragmentDefinition(doc),\n createFragmentMap(getFragmentDefinitions(doc))\n )\n ) ?\n null\n : doc;\n}\n\nfunction getDirectiveMatcher(\n configs: (RemoveDirectiveConfig | GetDirectiveConfig)[]\n) {\n const names = new Map();\n\n const tests = new Map<\n (directive: DirectiveNode) => boolean,\n RemoveDirectiveConfig | GetDirectiveConfig\n >();\n\n configs.forEach((directive) => {\n if (directive) {\n if (directive.name) {\n names.set(directive.name, directive);\n } else if (directive.test) {\n tests.set(directive.test, directive);\n }\n }\n });\n\n return (directive: DirectiveNode) => {\n let config = names.get(directive.name.value);\n if (!config && tests.size) {\n tests.forEach((testConfig, test) => {\n if (test(directive)) {\n config = testConfig;\n }\n });\n }\n return config;\n };\n}\n\n// Helper interface and function used by removeDirectivesFromDocument to keep\n// track of variable references and fragments spreads found within a given\n// operation or fragment definition.\ninterface InternalInUseInfo {\n variables: Set;\n fragmentSpreads: Set;\n // Set to true when we deliberately remove a fragment definition, so we can\n // make sure also to remove dangling ...spreads that refer to it.\n removed?: boolean;\n // Populated by the populateTransitiveVars helper function below.\n transitiveVars?: Set;\n}\nfunction makeInUseGetterFunction(defaultKey: TKey) {\n const map = new Map();\n\n return function inUseGetterFunction(\n key: TKey = defaultKey\n ): InternalInUseInfo {\n let inUse = map.get(key);\n if (!inUse) {\n map.set(\n key,\n (inUse = {\n // Variable and fragment spread names used directly within this\n // operation or fragment definition, as identified by key. These sets\n // will be populated during the first traversal of the document in\n // removeDirectivesFromDocument below.\n variables: new Set(),\n fragmentSpreads: new Set(),\n })\n );\n }\n return inUse;\n };\n}\n\nexport function removeDirectivesFromDocument(\n directives: RemoveDirectiveConfig[],\n doc: DocumentNode\n): DocumentNode | null {\n checkDocument(doc);\n\n // Passing empty strings to makeInUseGetterFunction means we handle anonymous\n // operations as if their names were \"\". Anonymous fragment definitions are\n // not supposed to be possible, but the same default naming strategy seems\n // appropriate for that case as well.\n const getInUseByOperationName = makeInUseGetterFunction(\"\");\n const getInUseByFragmentName = makeInUseGetterFunction(\"\");\n const getInUse = (\n ancestors: readonly (ASTNode | readonly ASTNode[])[]\n ): InternalInUseInfo | null => {\n for (\n let p = 0, ancestor: ASTNode | readonly ASTNode[];\n p < ancestors.length && (ancestor = ancestors[p]);\n ++p\n ) {\n if (isArray(ancestor)) continue;\n if (ancestor.kind === Kind.OPERATION_DEFINITION) {\n // If an operation is anonymous, we use the empty string as its key.\n return getInUseByOperationName(ancestor.name && ancestor.name.value);\n }\n if (ancestor.kind === Kind.FRAGMENT_DEFINITION) {\n return getInUseByFragmentName(ancestor.name.value);\n }\n }\n invariant.error(`Could not find operation or fragment`);\n return null;\n };\n\n let operationCount = 0;\n for (let i = doc.definitions.length - 1; i >= 0; --i) {\n if (doc.definitions[i].kind === Kind.OPERATION_DEFINITION) {\n ++operationCount;\n }\n }\n\n const directiveMatcher = getDirectiveMatcher(directives);\n const shouldRemoveField = (nodeDirectives: FieldNode[\"directives\"]) =>\n isNonEmptyArray(nodeDirectives) &&\n nodeDirectives\n .map(directiveMatcher)\n .some(\n (config: RemoveDirectiveConfig | undefined) => config && config.remove\n );\n\n const originalFragmentDefsByPath = new Map();\n\n // Any time the first traversal of the document below makes a change like\n // removing a fragment (by returning null), this variable should be set to\n // true. Once it becomes true, it should never be set to false again. If this\n // variable remains false throughout the traversal, then we can return the\n // original doc immediately without any modifications.\n let firstVisitMadeChanges = false;\n\n const fieldOrInlineFragmentVisitor: EnterLeaveVisitor<\n FieldNode | InlineFragmentNode\n > = {\n enter(node) {\n if (shouldRemoveField(node.directives)) {\n firstVisitMadeChanges = true;\n return null;\n }\n },\n };\n\n const docWithoutDirectiveSubtrees = visit(doc, {\n // These two AST node types share the same implementation, defined above.\n Field: fieldOrInlineFragmentVisitor,\n InlineFragment: fieldOrInlineFragmentVisitor,\n\n VariableDefinition: {\n enter() {\n // VariableDefinition nodes do not count as variables in use, though\n // they do contain Variable nodes that might be visited below. To avoid\n // counting variable declarations as usages, we skip visiting the\n // contents of this VariableDefinition node by returning false.\n return false;\n },\n },\n\n Variable: {\n enter(node, _key, _parent, _path, ancestors) {\n const inUse = getInUse(ancestors);\n if (inUse) {\n inUse.variables.add(node.name.value);\n }\n },\n },\n\n FragmentSpread: {\n enter(node, _key, _parent, _path, ancestors) {\n if (shouldRemoveField(node.directives)) {\n firstVisitMadeChanges = true;\n return null;\n }\n const inUse = getInUse(ancestors);\n if (inUse) {\n inUse.fragmentSpreads.add(node.name.value);\n }\n // We might like to remove this FragmentSpread by returning null here if\n // the corresponding FragmentDefinition node is also going to be removed\n // by the logic below, but we can't control the relative order of those\n // events, so we have to postpone the removal of dangling FragmentSpread\n // nodes until after the current visit of the document has finished.\n },\n },\n\n FragmentDefinition: {\n enter(node, _key, _parent, path) {\n originalFragmentDefsByPath.set(JSON.stringify(path), node);\n },\n leave(node, _key, _parent, path) {\n const originalNode = originalFragmentDefsByPath.get(\n JSON.stringify(path)\n );\n if (node === originalNode) {\n // If the FragmentNode received by this leave function is identical to\n // the one received by the corresponding enter function (above), then\n // the visitor must not have made any changes within this\n // FragmentDefinition node. This fragment definition may still be\n // removed if there are no ...spread references to it, but it won't be\n // removed just because it has only a __typename field.\n return node;\n }\n\n if (\n // This logic applies only if the document contains one or more\n // operations, since removing all fragments from a document containing\n // only fragments makes the document useless.\n operationCount > 0 &&\n node.selectionSet.selections.every(\n (selection) =>\n selection.kind === Kind.FIELD &&\n selection.name.value === \"__typename\"\n )\n ) {\n // This is a somewhat opinionated choice: if a FragmentDefinition ends\n // up having no fields other than __typename, we remove the whole\n // fragment definition, and later prune ...spread references to it.\n getInUseByFragmentName(node.name.value).removed = true;\n firstVisitMadeChanges = true;\n return null;\n }\n },\n },\n\n Directive: {\n leave(node) {\n // If a matching directive is found, remove the directive itself. Note\n // that this does not remove the target (field, argument, etc) of the\n // directive, but only the directive itself.\n if (directiveMatcher(node)) {\n firstVisitMadeChanges = true;\n return null;\n }\n },\n },\n });\n\n if (!firstVisitMadeChanges) {\n // If our first pass did not change anything about the document, then there\n // is no cleanup we need to do, and we can return the original doc.\n return doc;\n }\n\n // Utility for making sure inUse.transitiveVars is recursively populated.\n // Because this logic assumes inUse.fragmentSpreads has been completely\n // populated and inUse.removed has been set if appropriate,\n // populateTransitiveVars must be called after that information has been\n // collected by the first traversal of the document.\n const populateTransitiveVars = (inUse: InternalInUseInfo) => {\n if (!inUse.transitiveVars) {\n inUse.transitiveVars = new Set(inUse.variables);\n if (!inUse.removed) {\n inUse.fragmentSpreads.forEach((childFragmentName) => {\n populateTransitiveVars(\n getInUseByFragmentName(childFragmentName)\n ).transitiveVars!.forEach((varName) => {\n inUse.transitiveVars!.add(varName);\n });\n });\n }\n }\n return inUse;\n };\n\n // Since we've been keeping track of fragment spreads used by particular\n // operations and fragment definitions, we now need to compute the set of all\n // spreads used (transitively) by any operations in the document.\n const allFragmentNamesUsed = new Set();\n docWithoutDirectiveSubtrees.definitions.forEach((def) => {\n if (def.kind === Kind.OPERATION_DEFINITION) {\n populateTransitiveVars(\n getInUseByOperationName(def.name && def.name.value)\n ).fragmentSpreads.forEach((childFragmentName) => {\n allFragmentNamesUsed.add(childFragmentName);\n });\n } else if (\n def.kind === Kind.FRAGMENT_DEFINITION &&\n // If there are no operations in the document, then all fragment\n // definitions count as usages of their own fragment names. This heuristic\n // prevents accidentally removing all fragment definitions from the\n // document just because it contains no operations that use the fragments.\n operationCount === 0 &&\n !getInUseByFragmentName(def.name.value).removed\n ) {\n allFragmentNamesUsed.add(def.name.value);\n }\n });\n // Now that we have added all fragment spreads used by operations to the\n // allFragmentNamesUsed set, we can complete the set by transitively adding\n // all fragment spreads used by those fragments, and so on.\n allFragmentNamesUsed.forEach((fragmentName) => {\n // Once all the childFragmentName strings added here have been seen already,\n // the top-level allFragmentNamesUsed.forEach loop will terminate.\n populateTransitiveVars(\n getInUseByFragmentName(fragmentName)\n ).fragmentSpreads.forEach((childFragmentName) => {\n allFragmentNamesUsed.add(childFragmentName);\n });\n });\n\n const fragmentWillBeRemoved = (fragmentName: string) =>\n !!(\n // A fragment definition will be removed if there are no spreads that refer\n // to it, or the fragment was explicitly removed because it had no fields\n // other than __typename.\n (\n !allFragmentNamesUsed.has(fragmentName) ||\n getInUseByFragmentName(fragmentName).removed\n )\n );\n\n const enterVisitor: EnterLeaveVisitor<\n FragmentSpreadNode | FragmentDefinitionNode\n > = {\n enter(node) {\n if (fragmentWillBeRemoved(node.name.value)) {\n return null;\n }\n },\n };\n\n return nullIfDocIsEmpty(\n visit(docWithoutDirectiveSubtrees, {\n // If the fragment is going to be removed, then leaving any dangling\n // FragmentSpread nodes with the same name would be a mistake.\n FragmentSpread: enterVisitor,\n\n // This is where the fragment definition is actually removed.\n FragmentDefinition: enterVisitor,\n\n OperationDefinition: {\n leave(node) {\n // Upon leaving each operation in the depth-first AST traversal, prune\n // any variables that are declared by the operation but unused within.\n if (node.variableDefinitions) {\n const usedVariableNames = populateTransitiveVars(\n // If an operation is anonymous, we use the empty string as its key.\n getInUseByOperationName(node.name && node.name.value)\n ).transitiveVars!;\n\n // According to the GraphQL spec, all variables declared by an\n // operation must either be used by that operation or used by some\n // fragment included transitively into that operation:\n // https://spec.graphql.org/draft/#sec-All-Variables-Used\n //\n // To stay on the right side of this validation rule, if/when we\n // remove the last $var references from an operation or its fragments,\n // we must also remove the corresponding $var declaration from the\n // enclosing operation. This pruning applies only to operations and\n // not fragment definitions, at the moment. Fragments may be able to\n // declare variables eventually, but today they can only consume them.\n if (usedVariableNames.size < node.variableDefinitions.length) {\n return {\n ...node,\n variableDefinitions: node.variableDefinitions.filter((varDef) =>\n usedVariableNames.has(varDef.variable.name.value)\n ),\n };\n }\n }\n },\n },\n })\n );\n}\n\nexport const addTypenameToDocument = Object.assign(\n function (doc: TNode): TNode {\n return visit(doc, {\n SelectionSet: {\n enter(node, _key, parent) {\n // Don't add __typename to OperationDefinitions.\n if (\n parent &&\n (parent as OperationDefinitionNode).kind ===\n Kind.OPERATION_DEFINITION\n ) {\n return;\n }\n\n // No changes if no selections.\n const { selections } = node;\n if (!selections) {\n return;\n }\n\n // If selections already have a __typename, or are part of an\n // introspection query, do nothing.\n const skip = selections.some((selection) => {\n return (\n isField(selection) &&\n (selection.name.value === \"__typename\" ||\n selection.name.value.lastIndexOf(\"__\", 0) === 0)\n );\n });\n if (skip) {\n return;\n }\n\n // If this SelectionSet is @export-ed as an input variable, it should\n // not have a __typename field (see issue #4691).\n const field = parent as FieldNode;\n if (\n isField(field) &&\n field.directives &&\n field.directives.some((d) => d.name.value === \"export\")\n ) {\n return;\n }\n\n // Create and return a new SelectionSet with a __typename Field.\n return {\n ...node,\n selections: [...selections, TYPENAME_FIELD],\n };\n },\n },\n });\n },\n {\n added(field: FieldNode): boolean {\n return field === TYPENAME_FIELD;\n },\n }\n);\n\nconst connectionRemoveConfig = {\n test: (directive: DirectiveNode) => {\n const willRemove = directive.name.value === \"connection\";\n if (willRemove) {\n if (\n !directive.arguments ||\n !directive.arguments.some((arg) => arg.name.value === \"key\")\n ) {\n invariant.warn(\n \"Removing an @connection directive even though it does not have a key. \" +\n \"You may want to use the key parameter to specify a store key.\"\n );\n }\n }\n\n return willRemove;\n },\n};\n\nexport function removeConnectionDirectiveFromDocument(doc: DocumentNode) {\n return removeDirectivesFromDocument(\n [connectionRemoveConfig],\n checkDocument(doc)\n );\n}\n\nfunction hasDirectivesInSelectionSet(\n directives: GetDirectiveConfig[],\n selectionSet: SelectionSetNode | undefined,\n nestedCheck = true\n): boolean {\n return (\n !!selectionSet &&\n selectionSet.selections &&\n selectionSet.selections.some((selection) =>\n hasDirectivesInSelection(directives, selection, nestedCheck)\n )\n );\n}\n\nfunction hasDirectivesInSelection(\n directives: GetDirectiveConfig[],\n selection: SelectionNode,\n nestedCheck = true\n): boolean {\n if (!isField(selection)) {\n return true;\n }\n\n if (!selection.directives) {\n return false;\n }\n\n return (\n selection.directives.some(getDirectiveMatcher(directives)) ||\n (nestedCheck &&\n hasDirectivesInSelectionSet(\n directives,\n selection.selectionSet,\n nestedCheck\n ))\n );\n}\n\nfunction getArgumentMatcher(config: RemoveArgumentsConfig[]) {\n return function argumentMatcher(argument: ArgumentNode) {\n return config.some(\n (aConfig: RemoveArgumentsConfig) =>\n argument.value &&\n argument.value.kind === Kind.VARIABLE &&\n argument.value.name &&\n (aConfig.name === argument.value.name.value ||\n (aConfig.test && aConfig.test(argument)))\n );\n };\n}\n\nexport function removeArgumentsFromDocument(\n config: RemoveArgumentsConfig[],\n doc: DocumentNode\n): DocumentNode | null {\n const argMatcher = getArgumentMatcher(config);\n\n return nullIfDocIsEmpty(\n visit(doc, {\n OperationDefinition: {\n enter(node) {\n return {\n ...node,\n // Remove matching top level variables definitions.\n variableDefinitions:\n node.variableDefinitions ?\n node.variableDefinitions.filter(\n (varDef) =>\n !config.some(\n (arg) => arg.name === varDef.variable.name.value\n )\n )\n : [],\n };\n },\n },\n\n Field: {\n enter(node) {\n // If `remove` is set to true for an argument, and an argument match\n // is found for a field, remove the field as well.\n const shouldRemoveField = config.some(\n (argConfig) => argConfig.remove\n );\n\n if (shouldRemoveField) {\n let argMatchCount = 0;\n if (node.arguments) {\n node.arguments.forEach((arg) => {\n if (argMatcher(arg)) {\n argMatchCount += 1;\n }\n });\n }\n\n if (argMatchCount === 1) {\n return null;\n }\n }\n },\n },\n\n Argument: {\n enter(node) {\n // Remove all matching arguments.\n if (argMatcher(node)) {\n return null;\n }\n },\n },\n })\n );\n}\n\nexport function removeFragmentSpreadFromDocument(\n config: RemoveFragmentSpreadConfig[],\n doc: DocumentNode\n): DocumentNode | null {\n function enter(\n node: FragmentSpreadNode | FragmentDefinitionNode\n ): null | void {\n if (config.some((def) => def.name === node.name.value)) {\n return null;\n }\n }\n\n return nullIfDocIsEmpty(\n visit(doc, {\n FragmentSpread: { enter },\n FragmentDefinition: { enter },\n })\n );\n}\n\n// If the incoming document is a query, return it as is. Otherwise, build a\n// new document containing a query operation based on the selection set\n// of the previous main operation.\nexport function buildQueryFromSelectionSet(\n document: DocumentNode\n): DocumentNode {\n const definition = getMainDefinition(document);\n const definitionOperation = (definition).operation;\n\n if (definitionOperation === \"query\") {\n // Already a query, so return the existing document.\n return document;\n }\n\n // Build a new query using the selection set of the main operation.\n const modifiedDoc = visit(document, {\n OperationDefinition: {\n enter(node) {\n return {\n ...node,\n operation: \"query\",\n };\n },\n },\n });\n return modifiedDoc;\n}\n\n// Remove fields / selection sets that include an @client directive.\nexport function removeClientSetsFromDocument(\n document: DocumentNode\n): DocumentNode | null {\n checkDocument(document);\n\n let modifiedDoc = removeDirectivesFromDocument(\n [\n {\n test: (directive: DirectiveNode) => directive.name.value === \"client\",\n remove: true,\n },\n ],\n document\n );\n\n return modifiedDoc;\n}\n","import { invariant } from \"../../utilities/globals/index.js\";\n\nimport type { DefinitionNode } from \"graphql\";\n\nimport { ApolloLink } from \"../core/index.js\";\nimport { Observable, hasDirectives } from \"../../utilities/index.js\";\nimport { serializeFetchParameter } from \"./serializeFetchParameter.js\";\nimport { selectURI } from \"./selectURI.js\";\nimport {\n handleError,\n readMultipartBody,\n parseAndCheckHttpResponse,\n} from \"./parseAndCheckHttpResponse.js\";\nimport { checkFetcher } from \"./checkFetcher.js\";\nimport type { HttpOptions } from \"./selectHttpOptionsAndBody.js\";\nimport {\n selectHttpOptionsAndBodyInternal,\n defaultPrinter,\n fallbackHttpConfig,\n} from \"./selectHttpOptionsAndBody.js\";\nimport { rewriteURIForGET } from \"./rewriteURIForGET.js\";\nimport { fromError, filterOperationVariables } from \"../utils/index.js\";\nimport {\n maybe,\n getMainDefinition,\n removeClientSetsFromDocument,\n} from \"../../utilities/index.js\";\n\nconst backupFetch = maybe(() => fetch);\n\nexport const createHttpLink = (linkOptions: HttpOptions = {}) => {\n let {\n uri = \"/graphql\",\n // use default global fetch if nothing passed in\n fetch: preferredFetch,\n print = defaultPrinter,\n includeExtensions,\n preserveHeaderCase,\n useGETForQueries,\n includeUnusedVariables = false,\n ...requestOptions\n } = linkOptions;\n\n if (__DEV__) {\n // Make sure at least one of preferredFetch, window.fetch, or backupFetch is\n // defined, so requests won't fail at runtime.\n checkFetcher(preferredFetch || backupFetch);\n }\n\n const linkConfig = {\n http: { includeExtensions, preserveHeaderCase },\n options: requestOptions.fetchOptions,\n credentials: requestOptions.credentials,\n headers: requestOptions.headers,\n };\n\n return new ApolloLink((operation) => {\n let chosenURI = selectURI(operation, uri);\n\n const context = operation.getContext();\n\n // `apollographql-client-*` headers are automatically set if a\n // `clientAwareness` object is found in the context. These headers are\n // set first, followed by the rest of the headers pulled from\n // `context.headers`. If desired, `apollographql-client-*` headers set by\n // the `clientAwareness` object can be overridden by\n // `apollographql-client-*` headers set in `context.headers`.\n const clientAwarenessHeaders: {\n \"apollographql-client-name\"?: string;\n \"apollographql-client-version\"?: string;\n } = {};\n\n if (context.clientAwareness) {\n const { name, version } = context.clientAwareness;\n if (name) {\n clientAwarenessHeaders[\"apollographql-client-name\"] = name;\n }\n if (version) {\n clientAwarenessHeaders[\"apollographql-client-version\"] = version;\n }\n }\n\n const contextHeaders = { ...clientAwarenessHeaders, ...context.headers };\n\n const contextConfig = {\n http: context.http,\n options: context.fetchOptions,\n credentials: context.credentials,\n headers: contextHeaders,\n };\n\n if (hasDirectives([\"client\"], operation.query)) {\n const transformedQuery = removeClientSetsFromDocument(operation.query);\n\n if (!transformedQuery) {\n return fromError(\n new Error(\n \"HttpLink: Trying to send a client-only query to the server. To send to the server, ensure a non-client field is added to the query or set the `transformOptions.removeClientFields` option to `true`.\"\n )\n );\n }\n\n operation.query = transformedQuery;\n }\n\n //uses fallback, link, and then context to build options\n const { options, body } = selectHttpOptionsAndBodyInternal(\n operation,\n print,\n fallbackHttpConfig,\n linkConfig,\n contextConfig\n );\n\n if (body.variables && !includeUnusedVariables) {\n body.variables = filterOperationVariables(\n body.variables,\n operation.query\n );\n }\n\n let controller: AbortController | undefined;\n if (!options.signal && typeof AbortController !== \"undefined\") {\n controller = new AbortController();\n options.signal = controller.signal;\n }\n\n // If requested, set method to GET if there are no mutations.\n const definitionIsMutation = (d: DefinitionNode) => {\n return d.kind === \"OperationDefinition\" && d.operation === \"mutation\";\n };\n const definitionIsSubscription = (d: DefinitionNode) => {\n return d.kind === \"OperationDefinition\" && d.operation === \"subscription\";\n };\n const isSubscription = definitionIsSubscription(\n getMainDefinition(operation.query)\n );\n // does not match custom directives beginning with @defer\n const hasDefer = hasDirectives([\"defer\"], operation.query);\n if (\n useGETForQueries &&\n !operation.query.definitions.some(definitionIsMutation)\n ) {\n options.method = \"GET\";\n }\n\n if (hasDefer || isSubscription) {\n options.headers = options.headers || {};\n let acceptHeader = \"multipart/mixed;\";\n // Omit defer-specific headers if the user attempts to defer a selection\n // set on a subscription and log a warning.\n if (isSubscription && hasDefer) {\n invariant.warn(\"Multipart-subscriptions do not support @defer\");\n }\n\n if (isSubscription) {\n acceptHeader +=\n \"boundary=graphql;subscriptionSpec=1.0,application/json\";\n } else if (hasDefer) {\n acceptHeader += \"deferSpec=20220824,application/json\";\n }\n options.headers.accept = acceptHeader;\n }\n\n if (options.method === \"GET\") {\n const { newURI, parseError } = rewriteURIForGET(chosenURI, body);\n if (parseError) {\n return fromError(parseError);\n }\n chosenURI = newURI;\n } else {\n try {\n (options as any).body = serializeFetchParameter(body, \"Payload\");\n } catch (parseError) {\n return fromError(parseError);\n }\n }\n\n return new Observable((observer) => {\n // Prefer linkOptions.fetch (preferredFetch) if provided, and otherwise\n // fall back to the *current* global window.fetch function (see issue\n // #7832), or (if all else fails) the backupFetch function we saved when\n // this module was first evaluated. This last option protects against the\n // removal of window.fetch, which is unlikely but not impossible.\n const currentFetch = preferredFetch || maybe(() => fetch) || backupFetch;\n\n const observerNext = observer.next.bind(observer);\n currentFetch!(chosenURI, options)\n .then((response) => {\n operation.setContext({ response });\n const ctype = response.headers?.get(\"content-type\");\n\n if (ctype !== null && /^multipart\\/mixed/i.test(ctype)) {\n return readMultipartBody(response, observerNext);\n } else {\n return parseAndCheckHttpResponse(operation)(response).then(\n observerNext\n );\n }\n })\n .then(() => {\n controller = undefined;\n observer.complete();\n })\n .catch((err) => {\n controller = undefined;\n handleError(err, observer);\n });\n\n return () => {\n // XXX support canceling this request\n // https://developers.google.com/web/updates/2017/09/abortable-fetch\n if (controller) controller.abort();\n };\n });\n });\n};\n","import { newInvariantError } from \"../../utilities/globals/index.js\";\n\nexport const checkFetcher = (fetcher: typeof fetch | undefined) => {\n if (!fetcher && typeof fetch === \"undefined\") {\n throw newInvariantError(`\n\"fetch\" has not been found globally and no fetcher has been \\\nconfigured. To fix this, install a fetch package (like \\\nhttps://www.npmjs.com/package/cross-fetch), instantiate the \\\nfetcher, and pass it into your HttpLink constructor. For example:\n\nimport fetch from 'cross-fetch';\nimport { ApolloClient, HttpLink } from '@apollo/client';\nconst client = new ApolloClient({\n link: new HttpLink({ uri: '/graphql', fetch })\n});\n `);\n }\n};\n","import type { Operation } from \"../core/index.js\";\n\nexport const selectURI = (\n operation: Operation,\n fallbackURI?: string | ((operation: Operation) => string)\n) => {\n const context = operation.getContext();\n const contextURI = context.uri;\n\n if (contextURI) {\n return contextURI;\n } else if (typeof fallbackURI === \"function\") {\n return fallbackURI(operation);\n } else {\n return (fallbackURI as string) || \"/graphql\";\n }\n};\n","import type { VariableDefinitionNode, DocumentNode } from \"graphql\";\nimport { visit } from \"graphql\";\n\nexport function filterOperationVariables(\n variables: Record,\n query: DocumentNode\n) {\n const result = { ...variables };\n const unusedNames = new Set(Object.keys(variables));\n visit(query, {\n Variable(node, _key, parent) {\n // A variable type definition at the top level of a query is not\n // enough to silence server-side errors about the variable being\n // unused, so variable definitions do not count as usage.\n // https://spec.graphql.org/draft/#sec-All-Variables-Used\n if (\n parent &&\n (parent as VariableDefinitionNode).kind !== \"VariableDefinition\"\n ) {\n unusedNames.delete(node.name.value);\n }\n },\n });\n unusedNames.forEach((name) => {\n delete result![name];\n });\n return result;\n}\n","import { serializeFetchParameter } from \"./serializeFetchParameter.js\";\nimport type { Body } from \"./selectHttpOptionsAndBody.js\";\n\n// For GET operations, returns the given URI rewritten with parameters, or a\n// parse error.\nexport function rewriteURIForGET(chosenURI: string, body: Body) {\n // Implement the standard HTTP GET serialization, plus 'extensions'. Note\n // the extra level of JSON serialization!\n const queryParams: string[] = [];\n const addQueryParam = (key: string, value: string) => {\n queryParams.push(`${key}=${encodeURIComponent(value)}`);\n };\n\n if (\"query\" in body) {\n addQueryParam(\"query\", body.query!);\n }\n if (body.operationName) {\n addQueryParam(\"operationName\", body.operationName);\n }\n if (body.variables) {\n let serializedVariables;\n try {\n serializedVariables = serializeFetchParameter(\n body.variables,\n \"Variables map\"\n );\n } catch (parseError) {\n return { parseError };\n }\n addQueryParam(\"variables\", serializedVariables);\n }\n if (body.extensions) {\n let serializedExtensions;\n try {\n serializedExtensions = serializeFetchParameter(\n body.extensions,\n \"Extensions map\"\n );\n } catch (parseError) {\n return { parseError };\n }\n addQueryParam(\"extensions\", serializedExtensions);\n }\n\n // Reconstruct the URI with added query params.\n // XXX This assumes that the URI is well-formed and that it doesn't\n // already contain any of these query params. We could instead use the\n // URL API and take a polyfill (whatwg-url@6) for older browsers that\n // don't support URLSearchParams. Note that some browsers (and\n // versions of whatwg-url) support URL but not URLSearchParams!\n let fragment = \"\",\n preFragment = chosenURI;\n const fragmentStart = chosenURI.indexOf(\"#\");\n if (fragmentStart !== -1) {\n fragment = chosenURI.substr(fragmentStart);\n preFragment = chosenURI.substr(0, fragmentStart);\n }\n const queryParamsPrefix = preFragment.indexOf(\"?\") === -1 ? \"?\" : \"&\";\n const newURI =\n preFragment + queryParamsPrefix + queryParams.join(\"&\") + fragment;\n return { newURI };\n}\n","import { ApolloLink } from \"../core/index.js\";\nimport type { HttpOptions } from \"./selectHttpOptionsAndBody.js\";\nimport { createHttpLink } from \"./createHttpLink.js\";\n\nexport class HttpLink extends ApolloLink {\n constructor(public options: HttpOptions = {}) {\n super(createHttpLink(options).request);\n }\n}\n","import { ApolloLink } from \"./ApolloLink.js\";\n\nexport const execute = ApolloLink.execute;\n",null,null,null,null,null,null,"import { Trie } from \"@wry/trie\";\nimport { canUseWeakMap, canUseWeakSet } from \"../common/canUse.js\";\nimport { checkDocument } from \"./getFromAST.js\";\nimport { invariant } from \"../globals/index.js\";\nimport type { DocumentNode } from \"graphql\";\nimport { WeakCache } from \"@wry/caches\";\nimport { wrap } from \"optimism\";\nimport { cacheSizes } from \"../caching/index.js\";\n\nexport type DocumentTransformCacheKey = ReadonlyArray;\n\ntype TransformFn = (document: DocumentNode) => DocumentNode;\n\ninterface DocumentTransformOptions {\n /**\n * Determines whether to cache the transformed GraphQL document. Caching can speed up repeated calls to the document transform for the same input document. Set to `false` to completely disable caching for the document transform. When disabled, this option takes precedence over the [`getCacheKey`](#getcachekey) option.\n *\n * The default value is `true`.\n */\n cache?: boolean;\n /**\n * Defines a custom cache key for a GraphQL document that will determine whether to re-run the document transform when given the same input GraphQL document. Returns an array that defines the cache key. Return `undefined` to disable caching for that GraphQL document.\n *\n * > **Note:** The items in the array may be any type, but also need to be referentially stable to guarantee a stable cache key.\n *\n * The default implementation of this function returns the `document` as the cache key.\n */\n getCacheKey?: (\n document: DocumentNode\n ) => DocumentTransformCacheKey | undefined;\n}\n\nfunction identity(document: DocumentNode) {\n return document;\n}\n\nexport class DocumentTransform {\n private readonly transform: TransformFn;\n private cached: boolean;\n\n private readonly resultCache =\n canUseWeakSet ? new WeakSet() : new Set();\n\n // This default implementation of getCacheKey can be overridden by providing\n // options.getCacheKey to the DocumentTransform constructor. In general, a\n // getCacheKey function may either return an array of keys (often including\n // the document) to be used as a cache key, or undefined to indicate the\n // transform for this document should not be cached.\n private getCacheKey(\n document: DocumentNode\n ): DocumentTransformCacheKey | undefined {\n return [document];\n }\n\n static identity() {\n // No need to cache this transform since it just returns the document\n // unchanged. This should save a bit of memory that would otherwise be\n // needed to populate the `documentCache` of this transform.\n return new DocumentTransform(identity, { cache: false });\n }\n\n static split(\n predicate: (document: DocumentNode) => boolean,\n left: DocumentTransform,\n right: DocumentTransform = DocumentTransform.identity()\n ) {\n return Object.assign(\n new DocumentTransform(\n (document) => {\n const documentTransform = predicate(document) ? left : right;\n\n return documentTransform.transformDocument(document);\n },\n // Reasonably assume both `left` and `right` transforms handle their own caching\n { cache: false }\n ),\n { left, right }\n );\n }\n\n constructor(\n transform: TransformFn,\n options: DocumentTransformOptions = Object.create(null)\n ) {\n this.transform = transform;\n\n if (options.getCacheKey) {\n // Override default `getCacheKey` function, which returns [document].\n this.getCacheKey = options.getCacheKey;\n }\n this.cached = options.cache !== false;\n\n this.resetCache();\n }\n\n /**\n * Resets the internal cache of this transform, if it has one.\n */\n resetCache() {\n if (this.cached) {\n const stableCacheKeys = new Trie(canUseWeakMap);\n this.performWork = wrap(\n DocumentTransform.prototype.performWork.bind(this),\n {\n makeCacheKey: (document) => {\n const cacheKeys = this.getCacheKey(document);\n if (cacheKeys) {\n invariant(\n Array.isArray(cacheKeys),\n \"`getCacheKey` must return an array or undefined\"\n );\n return stableCacheKeys.lookupArray(cacheKeys);\n }\n },\n max: cacheSizes[\"documentTransform.cache\"],\n cache: WeakCache,\n }\n );\n }\n }\n\n private performWork(document: DocumentNode) {\n checkDocument(document);\n return this.transform(document);\n }\n\n transformDocument(document: DocumentNode) {\n // If a user passes an already transformed result back to this function,\n // immediately return it.\n if (this.resultCache.has(document)) {\n return document;\n }\n\n const transformedDocument = this.performWork(document);\n\n this.resultCache.add(transformedDocument);\n\n return transformedDocument;\n }\n\n concat(otherTransform: DocumentTransform): DocumentTransform {\n return Object.assign(\n new DocumentTransform(\n (document) => {\n return otherTransform.transformDocument(\n this.transformDocument(document)\n );\n },\n // Reasonably assume both transforms handle their own caching\n { cache: false }\n ),\n {\n left: this,\n right: otherTransform,\n }\n );\n }\n\n /**\n * @internal\n * Used to iterate through all transforms that are concatenations or `split` links.\n */\n readonly left?: DocumentTransform;\n /**\n * @internal\n * Used to iterate through all transforms that are concatenations or `split` links.\n */\n readonly right?: DocumentTransform;\n}\n","import type { Observer } from \"./Observable.js\";\nimport { Observable } from \"./Observable.js\";\n\n// Like Observable.prototype.map, except that the mapping function can\n// optionally return a Promise (or be async).\nexport function asyncMap(\n observable: Observable,\n mapFn: (value: V) => R | PromiseLike,\n catchFn?: (error: any) => R | PromiseLike\n): Observable {\n return new Observable((observer) => {\n let promiseQueue = {\n // Normally we would initialize promiseQueue to Promise.resolve(), but\n // in this case, for backwards compatibility, we need to be careful to\n // invoke the first callback synchronously.\n then(callback: () => any) {\n return new Promise((resolve) => resolve(callback()));\n },\n } as Promise;\n\n function makeCallback(\n examiner: typeof mapFn | typeof catchFn,\n key: \"next\" | \"error\"\n ): (arg: any) => void {\n return (arg) => {\n if (examiner) {\n const both = () =>\n // If the observer is closed, we don't want to continue calling the\n // mapping function - it's result will be swallowed anyways.\n observer.closed ?\n /* will be swallowed */ (0 as any)\n : examiner(arg);\n\n promiseQueue = promiseQueue.then(both, both).then(\n (result) => observer.next(result),\n (error) => observer.error(error)\n );\n } else {\n observer[key](arg);\n }\n };\n }\n\n const handler: Observer = {\n next: makeCallback(mapFn, \"next\"),\n error: makeCallback(catchFn, \"error\"),\n complete() {\n // no need to reassign `promiseQueue`, after `observer.complete`,\n // the observer will be closed and short-circuit everything anyways\n /*promiseQueue = */ promiseQueue.then(() => observer.complete());\n },\n };\n\n const sub = observable.subscribe(handler);\n return () => sub.unsubscribe();\n });\n}\n","import type { FetchResult } from \"../../link/core/index.js\";\nimport { isNonEmptyArray } from \"./arrays.js\";\nimport { isExecutionPatchIncrementalResult } from \"./incrementalResult.js\";\n\nexport function graphQLResultHasError(result: FetchResult): boolean {\n const errors = getGraphQLErrorsFromResult(result);\n return isNonEmptyArray(errors);\n}\n\nexport function getGraphQLErrorsFromResult(result: FetchResult) {\n const graphQLErrors =\n isNonEmptyArray(result.errors) ? result.errors.slice(0) : [];\n\n if (\n isExecutionPatchIncrementalResult(result) &&\n isNonEmptyArray(result.incremental)\n ) {\n result.incremental.forEach((incrementalResult) => {\n if (incrementalResult.errors) {\n graphQLErrors.push(...incrementalResult.errors);\n }\n });\n }\n return graphQLErrors;\n}\n","import type { Observer } from \"./Observable.js\";\n\nexport function iterateObserversSafely(\n observers: Set>,\n method: keyof Observer,\n argument?: A\n) {\n // In case observers is modified during iteration, we need to commit to the\n // original elements, which also provides an opportunity to filter them down\n // to just the observers with the given method.\n const observersWithMethod: Observer[] = [];\n observers.forEach((obs) => obs[method] && observersWithMethod.push(obs));\n observersWithMethod.forEach((obs) => (obs as any)[method](argument));\n}\n","import { Observable } from \"./Observable.js\";\nimport { canUseSymbol } from \"../common/canUse.js\";\n\n// Generic implementations of Observable.prototype methods like map and\n// filter need to know how to create a new Observable from an Observable\n// subclass (like Concast or ObservableQuery). Those methods assume\n// (perhaps unwisely?) that they can call the subtype's constructor with a\n// Subscriber function, even though the subclass constructor might expect\n// different parameters. Defining this static Symbol.species property on\n// the subclass is a hint to generic Observable code to use the default\n// constructor instead of trying to do `new Subclass(observer => ...)`.\nexport function fixObservableSubclass<\n S extends new (...args: any[]) => Observable,\n>(subclass: S): S {\n function set(key: symbol | string) {\n // Object.defineProperty is necessary because the Symbol.species\n // property is a getter by default in modern JS environments, so we\n // can't assign to it with a normal assignment expression.\n Object.defineProperty(subclass, key, { value: Observable });\n }\n if (canUseSymbol && Symbol.species) {\n set(Symbol.species);\n }\n // The \"@@species\" string is used as a fake Symbol.species value in some\n // polyfill systems (including the SymbolSpecies variable used by\n // zen-observable), so we should set it as well, to be safe.\n set(\"@@species\");\n return subclass;\n}\n","import type {\n Observer,\n ObservableSubscription,\n Subscriber,\n} from \"./Observable.js\";\nimport { Observable } from \"./Observable.js\";\nimport { iterateObserversSafely } from \"./iteration.js\";\nimport { fixObservableSubclass } from \"./subclassing.js\";\n\ntype MaybeAsync = T | PromiseLike;\n\nfunction isPromiseLike(value: MaybeAsync): value is PromiseLike {\n return value && typeof (value as any).then === \"function\";\n}\n\n// Any individual Source can be an Observable or a promise for one.\ntype Source = MaybeAsync>;\n\nexport type ConcastSourcesIterable = Iterable>;\nexport type ConcastSourcesArray = Array>;\n\n// A Concast observable concatenates the given sources into a single\n// non-overlapping sequence of Ts, automatically unwrapping any promises,\n// and broadcasts the T elements of that sequence to any number of\n// subscribers, all without creating a bunch of intermediary Observable\n// wrapper objects.\n//\n// Even though any number of observers can subscribe to the Concast, each\n// source observable is guaranteed to receive at most one subscribe call,\n// and the results are multicast to all observers.\n//\n// In addition to broadcasting every next/error message to this.observers,\n// the Concast stores the most recent message using this.latest, so any\n// new observers can immediately receive the latest message, even if it\n// was originally delivered in the past. This behavior means we can assume\n// every active observer in this.observers has received the same most\n// recent message.\n//\n// With the exception of this.latest replay, a Concast is a \"hot\"\n// observable in the sense that it does not replay past results from the\n// beginning of time for each new observer.\n//\n// Could we have used some existing RxJS class instead? Concast is\n// similar to a BehaviorSubject, because it is multicast and redelivers\n// the latest next/error message to new subscribers. Unlike Subject,\n// Concast does not expose an Observer interface (this.handlers is\n// intentionally private), since Concast gets its inputs from the\n// concatenated sources. If we ever switch to RxJS, there may be some\n// value in reusing their code, but for now we use zen-observable, which\n// does not contain any Subject implementations.\nexport class Concast extends Observable {\n // Active observers receiving broadcast messages. Thanks to this.latest,\n // we can assume all observers in this Set have received the same most\n // recent message, though possibly at different times in the past.\n private observers = new Set>();\n\n // This property starts off undefined to indicate the initial\n // subscription has not yet begun, then points to each source\n // subscription in turn, and finally becomes null after the sources have\n // been exhausted. After that, it stays null.\n private sub?: ObservableSubscription | null;\n\n // Not only can the individual elements of the iterable be promises, but\n // also the iterable itself can be wrapped in a promise.\n constructor(sources: MaybeAsync> | Subscriber) {\n super((observer) => {\n this.addObserver(observer);\n return () => this.removeObserver(observer);\n });\n\n // Suppress rejection warnings for this.promise, since it's perfectly\n // acceptable to pay no attention to this.promise if you're consuming\n // the results through the normal observable API.\n this.promise.catch((_) => {});\n\n // If someone accidentally tries to create a Concast using a subscriber\n // function, recover by creating an Observable from that subscriber and\n // using it as the source.\n if (typeof sources === \"function\") {\n sources = [new Observable(sources)];\n }\n\n if (isPromiseLike(sources)) {\n sources.then((iterable) => this.start(iterable), this.handlers.error);\n } else {\n this.start(sources);\n }\n }\n\n // A consumable array of source observables, incrementally consumed each time\n // this.handlers.complete is called. This private field is not initialized\n // until the concast.start method is called, which can happen asynchronously\n // if a Promise is passed to the Concast constructor, so undefined is a\n // possible value for this.sources before concast.start is called.\n private sources: Source[] | undefined;\n\n private start(sources: ConcastSourcesIterable) {\n if (this.sub !== void 0) return;\n\n // In practice, sources is most often simply an Array of observables.\n // TODO Consider using sources[Symbol.iterator]() to take advantage\n // of the laziness of non-Array iterables.\n this.sources = Array.from(sources);\n\n // Calling this.handlers.complete() kicks off consumption of the first\n // source observable. It's tempting to do this step lazily in\n // addObserver, but this.promise can be accessed without calling\n // addObserver, so consumption needs to begin eagerly.\n this.handlers.complete();\n }\n\n private deliverLastMessage(observer: Observer) {\n if (this.latest) {\n const nextOrError = this.latest[0];\n const method = observer[nextOrError];\n if (method) {\n method.call(observer, this.latest[1]);\n }\n // If the subscription is already closed, and the last message was\n // a 'next' message, simulate delivery of the final 'complete'\n // message again.\n if (this.sub === null && nextOrError === \"next\" && observer.complete) {\n observer.complete();\n }\n }\n }\n\n public addObserver(observer: Observer) {\n if (!this.observers.has(observer)) {\n // Immediately deliver the most recent message, so we can always\n // be sure all observers have the latest information.\n this.deliverLastMessage(observer);\n this.observers.add(observer);\n }\n }\n\n public removeObserver(observer: Observer) {\n if (this.observers.delete(observer) && this.observers.size < 1) {\n // In case there are still any listeners in this.nextResultListeners, and\n // no error or completion has been broadcast yet, make sure those\n // observers have a chance to run and then remove themselves from\n // this.observers.\n this.handlers.complete();\n }\n }\n\n // Any Concast object can be trivially converted to a Promise, without\n // having to create a new wrapper Observable. This promise provides an\n // easy way to observe the final state of the Concast.\n private resolve!: (result?: T | PromiseLike) => void;\n private reject!: (reason: any) => void;\n public readonly promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n\n // Name and argument of the most recently invoked observer method, used\n // to deliver latest results immediately to new observers.\n private latest?: [\"next\", T] | [\"error\", any];\n\n // Bound handler functions that can be reused for every internal\n // subscription.\n private handlers = {\n next: (result: T) => {\n if (this.sub !== null) {\n this.latest = [\"next\", result];\n this.notify(\"next\", result);\n iterateObserversSafely(this.observers, \"next\", result);\n }\n },\n\n error: (error: any) => {\n const { sub } = this;\n if (sub !== null) {\n // Delay unsubscribing from the underlying subscription slightly,\n // so that immediately subscribing another observer can keep the\n // subscription active.\n if (sub) setTimeout(() => sub.unsubscribe());\n this.sub = null;\n this.latest = [\"error\", error];\n this.reject(error);\n this.notify(\"error\", error);\n iterateObserversSafely(this.observers, \"error\", error);\n }\n },\n\n complete: () => {\n const { sub, sources = [] } = this;\n if (sub !== null) {\n // If complete is called before concast.start, this.sources may be\n // undefined, so we use a default value of [] for sources. That works\n // here because it falls into the if (!value) {...} block, which\n // appropriately terminates the Concast, even if this.sources might\n // eventually have been initialized to a non-empty array.\n const value = sources.shift();\n if (!value) {\n if (sub) setTimeout(() => sub.unsubscribe());\n this.sub = null;\n if (this.latest && this.latest[0] === \"next\") {\n this.resolve(this.latest[1]);\n } else {\n this.resolve();\n }\n this.notify(\"complete\");\n // We do not store this.latest = [\"complete\"], because doing so\n // discards useful information about the previous next (or\n // error) message. Instead, if new observers subscribe after\n // this Concast has completed, they will receive the final\n // 'next' message (unless there was an error) immediately\n // followed by a 'complete' message (see addObserver).\n iterateObserversSafely(this.observers, \"complete\");\n } else if (isPromiseLike(value)) {\n value.then(\n (obs) => (this.sub = obs.subscribe(this.handlers)),\n this.handlers.error\n );\n } else {\n this.sub = value.subscribe(this.handlers);\n }\n }\n },\n };\n\n private nextResultListeners = new Set();\n\n private notify(\n method: Parameters[0],\n arg?: Parameters[1]\n ) {\n const { nextResultListeners } = this;\n if (nextResultListeners.size) {\n // Replacing this.nextResultListeners first ensures it does not grow while\n // we are iterating over it, potentially leading to infinite loops.\n this.nextResultListeners = new Set();\n nextResultListeners.forEach((listener) => listener(method, arg));\n }\n }\n\n // We need a way to run callbacks just *before* the next result (or error or\n // completion) is delivered by this Concast, so we can be sure any code that\n // runs as a result of delivering that result/error observes the effects of\n // running the callback(s). It was tempting to reuse the Observer type instead\n // of introducing NextResultListener, but that messes with the sizing and\n // maintenance of this.observers, and ends up being more code overall.\n beforeNext(callback: NextResultListener) {\n let called = false;\n this.nextResultListeners.add((method, arg) => {\n if (!called) {\n called = true;\n callback(method, arg);\n }\n });\n }\n\n // A public way to abort observation and broadcast.\n public cancel = (reason: any) => {\n this.reject(reason);\n this.sources = [];\n this.handlers.complete();\n };\n}\n\ntype NextResultListener = (\n method: \"next\" | \"error\" | \"complete\",\n arg?: any\n) => any;\n\n// Necessary because the Concast constructor has a different signature\n// than the Observable constructor.\nfixObservableSubclass(Concast);\n","/**\n * The current status of a query’s execution in our system.\n */\nexport enum NetworkStatus {\n /**\n * The query has never been run before and the query is now currently running. A query will still\n * have this network status even if a partial data result was returned from the cache, but a\n * query was dispatched anyway.\n */\n loading = 1,\n\n /**\n * If `setVariables` was called and a query was fired because of that then the network status\n * will be `setVariables` until the result of that query comes back.\n */\n setVariables = 2,\n\n /**\n * Indicates that `fetchMore` was called on this query and that the query created is currently in\n * flight.\n */\n fetchMore = 3,\n\n /**\n * Similar to the `setVariables` network status. It means that `refetch` was called on a query\n * and the refetch request is currently in flight.\n */\n refetch = 4,\n\n /**\n * Indicates that a polling query is currently in flight. So for example if you are polling a\n * query every 10 seconds then the network status will switch to `poll` every 10 seconds whenever\n * a poll request has been sent but not resolved.\n */\n poll = 6,\n\n /**\n * No request is in flight for this query, and no errors happened. Everything is OK.\n */\n ready = 7,\n\n /**\n * No request is in flight for this query, but one or more errors were detected.\n */\n error = 8,\n}\n\n/**\n * Returns true if there is currently a network request in flight according to a given network\n * status.\n */\nexport function isNetworkRequestInFlight(\n networkStatus?: NetworkStatus\n): boolean {\n return networkStatus ? networkStatus < 7 : false;\n}\n\n/**\n * Returns true if the network request is in ready or error state according to a given network\n * status.\n */\nexport function isNetworkRequestSettled(\n networkStatus?: NetworkStatus\n): boolean {\n return networkStatus === 7 || networkStatus === 8;\n}\n","import type { TupleToIntersection } from \"./mergeDeep.js\";\n\n/**\n * Merges the provided objects shallowly and removes\n * all properties with an `undefined` value\n */\nexport function compact(\n ...objects: TArgs\n): TupleToIntersection {\n const result = Object.create(null);\n\n objects.forEach((obj) => {\n if (!obj) return;\n Object.keys(obj).forEach((key) => {\n const value = (obj as any)[key];\n if (value !== void 0) {\n result[key] = value;\n }\n });\n });\n\n return result;\n}\n","const { toString } = Object.prototype;\n\n/**\n * Deeply clones a value to create a new instance.\n */\nexport function cloneDeep(value: T): T {\n return cloneDeepHelper(value);\n}\n\nfunction cloneDeepHelper(val: T, seen?: Map): T {\n switch (toString.call(val)) {\n case \"[object Array]\": {\n seen = seen || new Map();\n if (seen.has(val)) return seen.get(val);\n const copy: T & any[] = (val as any).slice(0);\n seen.set(val, copy);\n copy.forEach(function (child, i) {\n copy[i] = cloneDeepHelper(child, seen);\n });\n return copy;\n }\n\n case \"[object Object]\": {\n seen = seen || new Map();\n if (seen.has(val)) return seen.get(val);\n // High fidelity polyfills of Object.create and Object.getPrototypeOf are\n // possible in all JS environments, so we will assume they exist/work.\n const copy = Object.create(Object.getPrototypeOf(val));\n seen.set(val, copy);\n Object.keys(val as T & Record).forEach((key) => {\n copy[key] = cloneDeepHelper((val as any)[key], seen);\n });\n return copy;\n }\n\n default:\n return val;\n }\n}\n","import equal from \"@wry/equality\";\n\nimport type {\n DirectiveNode,\n DocumentNode,\n FieldNode,\n FragmentDefinitionNode,\n FragmentSpreadNode,\n InlineFragmentNode,\n SelectionNode,\n SelectionSetNode,\n} from \"graphql\";\n\nimport type { ApolloQueryResult, OperationVariables } from \"./types.js\";\n\nimport type { FragmentMap } from \"../utilities/index.js\";\nimport {\n createFragmentMap,\n getFragmentDefinitions,\n getFragmentFromSelection,\n getMainDefinition,\n isField,\n resultKeyNameFromField,\n shouldInclude,\n} from \"../utilities/index.js\";\n\n// Returns true if aResult and bResult are deeply equal according to the fields\n// selected by the given query, ignoring any fields marked as @nonreactive.\nexport function equalByQuery(\n query: DocumentNode,\n { data: aData, ...aRest }: Partial>,\n { data: bData, ...bRest }: Partial>,\n variables?: OperationVariables\n): boolean {\n return (\n equal(aRest, bRest) &&\n equalBySelectionSet(getMainDefinition(query).selectionSet, aData, bData, {\n fragmentMap: createFragmentMap(getFragmentDefinitions(query)),\n variables,\n })\n );\n}\n\n// Encapsulates the information used by equalBySelectionSet that does not change\n// during the recursion.\ninterface CompareContext {\n fragmentMap: FragmentMap;\n variables: TVariables | undefined;\n}\n\nfunction equalBySelectionSet(\n selectionSet: SelectionSetNode,\n aResult: any,\n bResult: any,\n context: CompareContext\n): boolean {\n if (aResult === bResult) {\n return true;\n }\n\n const seenSelections = new Set();\n\n // Returning true from this Array.prototype.every callback function skips the\n // current field/subtree. Returning false aborts the entire traversal\n // immediately, causing equalBySelectionSet to return false.\n return selectionSet.selections.every((selection) => {\n // Avoid re-processing the same selection at the same level of recursion, in\n // case the same field gets included via multiple indirect fragment spreads.\n if (seenSelections.has(selection)) return true;\n seenSelections.add(selection);\n\n // Ignore @skip(if: true) and @include(if: false) fields.\n if (!shouldInclude(selection, context.variables)) return true;\n\n // If the field or (named) fragment spread has a @nonreactive directive on\n // it, we don't care if it's different, so we pretend it's the same.\n if (selectionHasNonreactiveDirective(selection)) return true;\n\n if (isField(selection)) {\n const resultKey = resultKeyNameFromField(selection);\n const aResultChild = aResult && aResult[resultKey];\n const bResultChild = bResult && bResult[resultKey];\n const childSelectionSet = selection.selectionSet;\n\n if (!childSelectionSet) {\n // These are scalar values, so we can compare them with deep equal\n // without redoing the main recursive work.\n return equal(aResultChild, bResultChild);\n }\n\n const aChildIsArray = Array.isArray(aResultChild);\n const bChildIsArray = Array.isArray(bResultChild);\n if (aChildIsArray !== bChildIsArray) return false;\n if (aChildIsArray && bChildIsArray) {\n const length = aResultChild.length;\n if (bResultChild.length !== length) {\n return false;\n }\n for (let i = 0; i < length; ++i) {\n if (\n !equalBySelectionSet(\n childSelectionSet,\n aResultChild[i],\n bResultChild[i],\n context\n )\n ) {\n return false;\n }\n }\n return true;\n }\n\n return equalBySelectionSet(\n childSelectionSet,\n aResultChild,\n bResultChild,\n context\n );\n } else {\n const fragment = getFragmentFromSelection(selection, context.fragmentMap);\n if (fragment) {\n // The fragment might === selection if it's an inline fragment, but\n // could be !== if it's a named fragment ...spread.\n if (selectionHasNonreactiveDirective(fragment)) return true;\n\n return equalBySelectionSet(\n fragment.selectionSet,\n // Notice that we reuse the same aResult and bResult values here,\n // since the fragment ...spread does not specify a field name, but\n // consists of multiple fields (within the fragment's selection set)\n // that should be applied to the current result value(s).\n aResult,\n bResult,\n context\n );\n }\n }\n });\n}\n\nfunction selectionHasNonreactiveDirective(\n selection:\n | FieldNode\n | InlineFragmentNode\n | FragmentSpreadNode\n | FragmentDefinitionNode\n): boolean {\n return (\n !!selection.directives && selection.directives.some(directiveIsNonreactive)\n );\n}\n\nfunction directiveIsNonreactive(dir: DirectiveNode): boolean {\n return dir.name.value === \"nonreactive\";\n}\n","import { invariant } from \"../utilities/globals/index.js\";\nimport type { DocumentNode } from \"graphql\";\nimport { equal } from \"@wry/equality\";\n\nimport { NetworkStatus, isNetworkRequestInFlight } from \"./networkStatus.js\";\nimport type {\n Concast,\n Observer,\n ObservableSubscription,\n} from \"../utilities/index.js\";\nimport {\n cloneDeep,\n compact,\n getOperationDefinition,\n Observable,\n iterateObserversSafely,\n fixObservableSubclass,\n getQueryDefinition,\n} from \"../utilities/index.js\";\nimport type { ApolloError } from \"../errors/index.js\";\nimport type { QueryManager } from \"./QueryManager.js\";\nimport type {\n ApolloQueryResult,\n OperationVariables,\n TypedDocumentNode,\n} from \"./types.js\";\nimport type {\n WatchQueryOptions,\n FetchMoreQueryOptions,\n SubscribeToMoreOptions,\n NextFetchPolicyContext,\n WatchQueryFetchPolicy,\n} from \"./watchQueryOptions.js\";\nimport type { QueryInfo } from \"./QueryInfo.js\";\nimport type { MissingFieldError } from \"../cache/index.js\";\nimport type { MissingTree } from \"../cache/core/types/common.js\";\nimport { equalByQuery } from \"./equalByQuery.js\";\nimport type { TODO } from \"../utilities/types/TODO.js\";\n\nconst { assign, hasOwnProperty } = Object;\n\nexport interface FetchMoreOptions<\n TData = any,\n TVariables = OperationVariables,\n> {\n updateQuery?: (\n previousQueryResult: TData,\n options: {\n fetchMoreResult?: TData;\n variables?: TVariables;\n }\n ) => TData;\n}\n\nexport interface UpdateQueryOptions {\n variables?: TVariables;\n}\n\ninterface Last {\n result: ApolloQueryResult;\n variables?: TVariables;\n error?: ApolloError;\n}\n\nexport class ObservableQuery<\n TData = any,\n TVariables extends OperationVariables = OperationVariables,\n> extends Observable> {\n public readonly options: WatchQueryOptions;\n public readonly queryId: string;\n public readonly queryName?: string;\n\n // The `query` computed property will always reflect the document transformed\n // by the last run query. `this.options.query` will always reflect the raw\n // untransformed query to ensure document transforms with runtime conditionals\n // are run on the original document.\n public get query(): TypedDocumentNode {\n return this.lastQuery || this.options.query;\n }\n\n // Computed shorthand for this.options.variables, preserved for\n // backwards compatibility.\n /**\n * An object containing the variables that were provided for the query.\n */\n public get variables(): TVariables | undefined {\n return this.options.variables;\n }\n\n private isTornDown: boolean;\n private queryManager: QueryManager;\n private observers = new Set>>();\n private subscriptions = new Set();\n\n private waitForOwnResult: boolean;\n private last?: Last;\n private lastQuery?: DocumentNode;\n\n private queryInfo: QueryInfo;\n\n // When this.concast is defined, this.observer is the Observer currently\n // subscribed to that Concast.\n private concast?: Concast>;\n private observer?: Observer>;\n\n private pollingInfo?: {\n interval: number;\n timeout: ReturnType;\n };\n\n constructor({\n queryManager,\n queryInfo,\n options,\n }: {\n queryManager: QueryManager;\n queryInfo: QueryInfo;\n options: WatchQueryOptions;\n }) {\n super((observer: Observer>) => {\n // Zen Observable has its own error function, so in order to log correctly\n // we need to provide a custom error callback.\n try {\n var subObserver = (observer as any)._subscription._observer;\n if (subObserver && !subObserver.error) {\n subObserver.error = defaultSubscriptionObserverErrorCallback;\n }\n } catch {}\n\n const first = !this.observers.size;\n this.observers.add(observer);\n\n // Deliver most recent error or result.\n const last = this.last;\n if (last && last.error) {\n observer.error && observer.error(last.error);\n } else if (last && last.result) {\n observer.next && observer.next(last.result);\n }\n\n // Initiate observation of this query if it hasn't been reported to\n // the QueryManager yet.\n if (first) {\n // Blindly catching here prevents unhandled promise rejections,\n // and is safe because the ObservableQuery handles this error with\n // this.observer.error, so we're not just swallowing the error by\n // ignoring it here.\n this.reobserve().catch(() => {});\n }\n\n return () => {\n if (this.observers.delete(observer) && !this.observers.size) {\n this.tearDownQuery();\n }\n };\n });\n\n // related classes\n this.queryInfo = queryInfo;\n this.queryManager = queryManager;\n\n // active state\n this.waitForOwnResult = skipCacheDataFor(options.fetchPolicy);\n this.isTornDown = false;\n\n const {\n watchQuery: { fetchPolicy: defaultFetchPolicy = \"cache-first\" } = {},\n } = queryManager.defaultOptions;\n\n const {\n fetchPolicy = defaultFetchPolicy,\n // Make sure we don't store \"standby\" as the initialFetchPolicy.\n initialFetchPolicy = fetchPolicy === \"standby\" ? defaultFetchPolicy : (\n fetchPolicy\n ),\n } = options;\n\n this.options = {\n ...options,\n\n // Remember the initial options.fetchPolicy so we can revert back to this\n // policy when variables change. This information can also be specified\n // (or overridden) by providing options.initialFetchPolicy explicitly.\n initialFetchPolicy,\n\n // This ensures this.options.fetchPolicy always has a string value, in\n // case options.fetchPolicy was not provided.\n fetchPolicy,\n };\n\n this.queryId = queryInfo.queryId || queryManager.generateQueryId();\n\n const opDef = getOperationDefinition(this.query);\n this.queryName = opDef && opDef.name && opDef.name.value;\n }\n\n public result(): Promise> {\n return new Promise((resolve, reject) => {\n // TODO: this code doesn’t actually make sense insofar as the observer\n // will never exist in this.observers due how zen-observable wraps observables.\n // https://github.com/zenparsing/zen-observable/blob/master/src/Observable.js#L169\n const observer: Observer> = {\n next: (result: ApolloQueryResult) => {\n resolve(result);\n\n // Stop the query within the QueryManager if we can before\n // this function returns.\n //\n // We do this in order to prevent observers piling up within\n // the QueryManager. Notice that we only fully unsubscribe\n // from the subscription in a setTimeout(..., 0) call. This call can\n // actually be handled by the browser at a much later time. If queries\n // are fired in the meantime, observers that should have been removed\n // from the QueryManager will continue to fire, causing an unnecessary\n // performance hit.\n this.observers.delete(observer);\n if (!this.observers.size) {\n this.queryManager.removeQuery(this.queryId);\n }\n\n setTimeout(() => {\n subscription.unsubscribe();\n }, 0);\n },\n error: reject,\n };\n const subscription = this.subscribe(observer);\n });\n }\n\n /** @internal */\n public resetDiff() {\n this.queryInfo.resetDiff();\n }\n\n public getCurrentResult(saveAsLastResult = true): ApolloQueryResult {\n // Use the last result as long as the variables match this.variables.\n const lastResult = this.getLastResult(true);\n\n const networkStatus =\n this.queryInfo.networkStatus ||\n (lastResult && lastResult.networkStatus) ||\n NetworkStatus.ready;\n\n const result = {\n ...lastResult,\n loading: isNetworkRequestInFlight(networkStatus),\n networkStatus,\n } as ApolloQueryResult;\n\n const { fetchPolicy = \"cache-first\" } = this.options;\n if (\n // These fetch policies should never deliver data from the cache, unless\n // redelivering a previously delivered result.\n skipCacheDataFor(fetchPolicy) ||\n // If this.options.query has @client(always: true) fields, we cannot\n // trust diff.result, since it was read from the cache without running\n // local resolvers (and it's too late to run resolvers now, since we must\n // return a result synchronously).\n this.queryManager.getDocumentInfo(this.query).hasForcedResolvers\n ) {\n // Fall through.\n } else if (this.waitForOwnResult) {\n // This would usually be a part of `QueryInfo.getDiff()`.\n // which we skip in the waitForOwnResult case since we are not\n // interested in the diff.\n this.queryInfo[\"updateWatch\"]();\n } else {\n const diff = this.queryInfo.getDiff();\n\n if (diff.complete || this.options.returnPartialData) {\n result.data = diff.result;\n }\n\n if (equal(result.data, {})) {\n result.data = void 0 as any;\n }\n\n if (diff.complete) {\n // Similar to setting result.partial to false, but taking advantage of the\n // falsiness of missing fields.\n delete result.partial;\n\n // If the diff is complete, and we're using a FetchPolicy that\n // terminates after a complete cache read, we can assume the next result\n // we receive will have NetworkStatus.ready and !loading.\n if (\n diff.complete &&\n result.networkStatus === NetworkStatus.loading &&\n (fetchPolicy === \"cache-first\" || fetchPolicy === \"cache-only\")\n ) {\n result.networkStatus = NetworkStatus.ready;\n result.loading = false;\n }\n } else {\n result.partial = true;\n }\n\n if (\n __DEV__ &&\n !diff.complete &&\n !this.options.partialRefetch &&\n !result.loading &&\n !result.data &&\n !result.error\n ) {\n logMissingFieldErrors(diff.missing);\n }\n }\n\n if (saveAsLastResult) {\n this.updateLastResult(result);\n }\n\n return result;\n }\n\n // Compares newResult to the snapshot we took of this.lastResult when it was\n // first received.\n public isDifferentFromLastResult(\n newResult: ApolloQueryResult,\n variables?: TVariables\n ) {\n if (!this.last) {\n return true;\n }\n\n const resultIsDifferent =\n this.queryManager.getDocumentInfo(this.query).hasNonreactiveDirective ?\n !equalByQuery(this.query, this.last.result, newResult, this.variables)\n : !equal(this.last.result, newResult);\n\n return (\n resultIsDifferent || (variables && !equal(this.last.variables, variables))\n );\n }\n\n private getLast>(\n key: K,\n variablesMustMatch?: boolean\n ) {\n const last = this.last;\n if (\n last &&\n last[key] &&\n (!variablesMustMatch || equal(last.variables, this.variables))\n ) {\n return last[key];\n }\n }\n\n public getLastResult(\n variablesMustMatch?: boolean\n ): ApolloQueryResult | undefined {\n return this.getLast(\"result\", variablesMustMatch);\n }\n\n public getLastError(variablesMustMatch?: boolean): ApolloError | undefined {\n return this.getLast(\"error\", variablesMustMatch);\n }\n\n public resetLastResults(): void {\n delete this.last;\n this.isTornDown = false;\n }\n\n public resetQueryStoreErrors() {\n this.queryManager.resetErrors(this.queryId);\n }\n\n /**\n * Update the variables of this observable query, and fetch the new results.\n * This method should be preferred over `setVariables` in most use cases.\n *\n * @param variables - The new set of variables. If there are missing variables,\n * the previous values of those variables will be used.\n */\n public refetch(\n variables?: Partial\n ): Promise> {\n const reobserveOptions: Partial> = {\n // Always disable polling for refetches.\n pollInterval: 0,\n };\n\n // Unless the provided fetchPolicy always consults the network\n // (no-cache, network-only, or cache-and-network), override it with\n // network-only to force the refetch for this fetchQuery call.\n const { fetchPolicy } = this.options;\n if (fetchPolicy === \"cache-and-network\") {\n reobserveOptions.fetchPolicy = fetchPolicy;\n } else if (fetchPolicy === \"no-cache\") {\n reobserveOptions.fetchPolicy = \"no-cache\";\n } else {\n reobserveOptions.fetchPolicy = \"network-only\";\n }\n\n if (__DEV__ && variables && hasOwnProperty.call(variables, \"variables\")) {\n const queryDef = getQueryDefinition(this.query);\n const vars = queryDef.variableDefinitions;\n if (!vars || !vars.some((v) => v.variable.name.value === \"variables\")) {\n invariant.warn(\n `Called refetch(%o) for query %o, which does not declare a $variables variable.\nDid you mean to call refetch(variables) instead of refetch({ variables })?`,\n variables,\n queryDef.name?.value || queryDef\n );\n }\n }\n\n if (variables && !equal(this.options.variables, variables)) {\n // Update the existing options with new variables\n reobserveOptions.variables = this.options.variables = {\n ...this.options.variables,\n ...variables,\n } as TVariables;\n }\n\n this.queryInfo.resetLastWrite();\n return this.reobserve(reobserveOptions, NetworkStatus.refetch);\n }\n\n /**\n * A function that helps you fetch the next set of results for a [paginated list field](https://www.apollographql.com/docs/react/pagination/core-api/).\n */\n public fetchMore<\n TFetchData = TData,\n TFetchVars extends OperationVariables = TVariables,\n >(\n fetchMoreOptions: FetchMoreQueryOptions & {\n updateQuery?: (\n previousQueryResult: TData,\n options: {\n fetchMoreResult: TFetchData;\n variables: TFetchVars;\n }\n ) => TData;\n }\n ): Promise> {\n const combinedOptions = {\n ...(fetchMoreOptions.query ? fetchMoreOptions : (\n {\n ...this.options,\n query: this.options.query,\n ...fetchMoreOptions,\n variables: {\n ...this.options.variables,\n ...fetchMoreOptions.variables,\n },\n }\n )),\n // The fetchMore request goes immediately to the network and does\n // not automatically write its result to the cache (hence no-cache\n // instead of network-only), because we allow the caller of\n // fetchMore to provide an updateQuery callback that determines how\n // the data gets written to the cache.\n fetchPolicy: \"no-cache\",\n } as WatchQueryOptions;\n\n combinedOptions.query = this.transformDocument(combinedOptions.query);\n\n const qid = this.queryManager.generateQueryId();\n\n // If a temporary query is passed to `fetchMore`, we don't want to store\n // it as the last query result since it may be an optimized query for\n // pagination. We will however run the transforms on the original document\n // as well as the document passed in `fetchMoreOptions` to ensure the cache\n // uses the most up-to-date document which may rely on runtime conditionals.\n this.lastQuery =\n fetchMoreOptions.query ?\n this.transformDocument(this.options.query)\n : combinedOptions.query;\n\n // Simulate a loading result for the original query with\n // result.networkStatus === NetworkStatus.fetchMore.\n const { queryInfo } = this;\n const originalNetworkStatus = queryInfo.networkStatus;\n queryInfo.networkStatus = NetworkStatus.fetchMore;\n if (combinedOptions.notifyOnNetworkStatusChange) {\n this.observe();\n }\n\n const updatedQuerySet = new Set();\n\n return this.queryManager\n .fetchQuery(qid, combinedOptions, NetworkStatus.fetchMore)\n .then((fetchMoreResult) => {\n this.queryManager.removeQuery(qid);\n\n if (queryInfo.networkStatus === NetworkStatus.fetchMore) {\n queryInfo.networkStatus = originalNetworkStatus;\n }\n\n // Performing this cache update inside a cache.batch transaction ensures\n // any affected cache.watch watchers are notified at most once about any\n // updates. Most watchers will be using the QueryInfo class, which\n // responds to notifications by calling reobserveCacheFirst to deliver\n // fetchMore cache results back to this ObservableQuery.\n this.queryManager.cache.batch({\n update: (cache) => {\n const { updateQuery } = fetchMoreOptions;\n if (updateQuery) {\n cache.updateQuery(\n {\n query: this.query,\n variables: this.variables,\n returnPartialData: true,\n optimistic: false,\n },\n (previous) =>\n updateQuery(previous!, {\n fetchMoreResult: fetchMoreResult.data,\n variables: combinedOptions.variables as TFetchVars,\n })\n );\n } else {\n // If we're using a field policy instead of updateQuery, the only\n // thing we need to do is write the new data to the cache using\n // combinedOptions.variables (instead of this.variables, which is\n // what this.updateQuery uses, because it works by abusing the\n // original field value, keyed by the original variables).\n cache.writeQuery({\n query: combinedOptions.query,\n variables: combinedOptions.variables,\n data: fetchMoreResult.data,\n });\n }\n },\n\n onWatchUpdated: (watch) => {\n // Record the DocumentNode associated with any watched query whose\n // data were updated by the cache writes above.\n updatedQuerySet.add(watch.query);\n },\n });\n\n return fetchMoreResult;\n })\n .finally(() => {\n // In case the cache writes above did not generate a broadcast\n // notification (which would have been intercepted by onWatchUpdated),\n // likely because the written data were the same as what was already in\n // the cache, we still want fetchMore to deliver its final loading:false\n // result with the unchanged data.\n if (!updatedQuerySet.has(this.query)) {\n reobserveCacheFirst(this);\n }\n });\n }\n\n // XXX the subscription variables are separate from the query variables.\n // if you want to update subscription variables, right now you have to do that separately,\n // and you can only do it by stopping the subscription and then subscribing again with new variables.\n /**\n * A function that enables you to execute a [subscription](https://www.apollographql.com/docs/react/data/subscriptions/), usually to subscribe to specific fields that were included in the query.\n *\n * This function returns _another_ function that you can call to terminate the subscription.\n */\n public subscribeToMore<\n TSubscriptionData = TData,\n TSubscriptionVariables extends OperationVariables = TVariables,\n >(\n options: SubscribeToMoreOptions<\n TData,\n TSubscriptionVariables,\n TSubscriptionData\n >\n ) {\n const subscription = this.queryManager\n .startGraphQLSubscription({\n query: options.document,\n variables: options.variables,\n context: options.context,\n })\n .subscribe({\n next: (subscriptionData: { data: TSubscriptionData }) => {\n const { updateQuery } = options;\n if (updateQuery) {\n this.updateQuery(\n (previous, { variables }) =>\n updateQuery(previous, {\n subscriptionData,\n variables,\n })\n );\n }\n },\n error: (err: any) => {\n if (options.onError) {\n options.onError(err);\n return;\n }\n invariant.error(\"Unhandled GraphQL subscription error\", err);\n },\n });\n\n this.subscriptions.add(subscription);\n\n return () => {\n if (this.subscriptions.delete(subscription)) {\n subscription.unsubscribe();\n }\n };\n }\n\n public setOptions(\n newOptions: Partial>\n ): Promise> {\n return this.reobserve(newOptions);\n }\n\n public silentSetOptions(\n newOptions: Partial>\n ) {\n const mergedOptions = compact(this.options, newOptions || {});\n assign(this.options, mergedOptions);\n }\n\n /**\n * Update the variables of this observable query, and fetch the new results\n * if they've changed. Most users should prefer `refetch` instead of\n * `setVariables` in order to to be properly notified of results even when\n * they come from the cache.\n *\n * Note: the `next` callback will *not* fire if the variables have not changed\n * or if the result is coming from cache.\n *\n * Note: the promise will return the old results immediately if the variables\n * have not changed.\n *\n * Note: the promise will return null immediately if the query is not active\n * (there are no subscribers).\n *\n * @param variables - The new set of variables. If there are missing variables,\n * the previous values of those variables will be used.\n */\n public setVariables(\n variables: TVariables\n ): Promise | void> {\n if (equal(this.variables, variables)) {\n // If we have no observers, then we don't actually want to make a network\n // request. As soon as someone observes the query, the request will kick\n // off. For now, we just store any changes. (See #1077)\n return this.observers.size ? this.result() : Promise.resolve();\n }\n\n this.options.variables = variables;\n\n // See comment above\n if (!this.observers.size) {\n return Promise.resolve();\n }\n\n return this.reobserve(\n {\n // Reset options.fetchPolicy to its original value.\n fetchPolicy: this.options.initialFetchPolicy,\n variables,\n },\n NetworkStatus.setVariables\n );\n }\n\n /**\n * A function that enables you to update the query's cached result without executing a followup GraphQL operation.\n *\n * See [using updateQuery and updateFragment](https://www.apollographql.com/docs/react/caching/cache-interaction/#using-updatequery-and-updatefragment) for additional information.\n */\n public updateQuery(\n mapFn: (\n previousQueryResult: TData,\n options: Pick, \"variables\">\n ) => TData\n ): void {\n const { queryManager } = this;\n const { result } = queryManager.cache.diff({\n query: this.options.query,\n variables: this.variables,\n returnPartialData: true,\n optimistic: false,\n });\n\n const newResult = mapFn(result!, {\n variables: (this as any).variables,\n });\n\n if (newResult) {\n queryManager.cache.writeQuery({\n query: this.options.query,\n data: newResult,\n variables: this.variables,\n });\n\n queryManager.broadcastQueries();\n }\n }\n\n /**\n * A function that instructs the query to begin re-executing at a specified interval (in milliseconds).\n */\n public startPolling(pollInterval: number) {\n this.options.pollInterval = pollInterval;\n this.updatePolling();\n }\n\n /**\n * A function that instructs the query to stop polling after a previous call to `startPolling`.\n */\n public stopPolling() {\n this.options.pollInterval = 0;\n this.updatePolling();\n }\n\n // Update options.fetchPolicy according to options.nextFetchPolicy.\n private applyNextFetchPolicy(\n reason: NextFetchPolicyContext[\"reason\"],\n // It's possible to use this method to apply options.nextFetchPolicy to\n // options.fetchPolicy even if options !== this.options, though that happens\n // most often when the options are temporary, used for only one request and\n // then thrown away, so nextFetchPolicy may not end up mattering.\n options: WatchQueryOptions\n ) {\n if (options.nextFetchPolicy) {\n const { fetchPolicy = \"cache-first\", initialFetchPolicy = fetchPolicy } =\n options;\n\n if (fetchPolicy === \"standby\") {\n // Do nothing, leaving options.fetchPolicy unchanged.\n } else if (typeof options.nextFetchPolicy === \"function\") {\n // When someone chooses \"cache-and-network\" or \"network-only\" as their\n // initial FetchPolicy, they often do not want future cache updates to\n // trigger unconditional network requests, which is what repeatedly\n // applying the \"cache-and-network\" or \"network-only\" policies would\n // seem to imply. Instead, when the cache reports an update after the\n // initial network request, it may be desirable for subsequent network\n // requests to be triggered only if the cache result is incomplete. To\n // that end, the options.nextFetchPolicy option provides an easy way to\n // update options.fetchPolicy after the initial network request, without\n // having to call observableQuery.setOptions.\n options.fetchPolicy = options.nextFetchPolicy(fetchPolicy, {\n reason,\n options,\n observable: this,\n initialFetchPolicy,\n });\n } else if (reason === \"variables-changed\") {\n options.fetchPolicy = initialFetchPolicy;\n } else {\n options.fetchPolicy = options.nextFetchPolicy;\n }\n }\n\n return options.fetchPolicy;\n }\n\n private fetch(\n options: WatchQueryOptions,\n newNetworkStatus?: NetworkStatus,\n query?: DocumentNode\n ) {\n // TODO Make sure we update the networkStatus (and infer fetchVariables)\n // before actually committing to the fetch.\n this.queryManager.setObservableQuery(this);\n return this.queryManager[\"fetchConcastWithInfo\"](\n this.queryId,\n options,\n newNetworkStatus,\n query\n );\n }\n\n // Turns polling on or off based on this.options.pollInterval.\n private updatePolling() {\n // Avoid polling in SSR mode\n if (this.queryManager.ssrMode) {\n return;\n }\n\n const {\n pollingInfo,\n options: { pollInterval },\n } = this;\n\n if (!pollInterval || !this.hasObservers()) {\n if (pollingInfo) {\n clearTimeout(pollingInfo.timeout);\n delete this.pollingInfo;\n }\n return;\n }\n\n if (pollingInfo && pollingInfo.interval === pollInterval) {\n return;\n }\n\n invariant(\n pollInterval,\n \"Attempted to start a polling query without a polling interval.\"\n );\n\n const info = pollingInfo || (this.pollingInfo = {} as any);\n info.interval = pollInterval;\n\n const maybeFetch = () => {\n if (this.pollingInfo) {\n if (\n !isNetworkRequestInFlight(this.queryInfo.networkStatus) &&\n !this.options.skipPollAttempt?.()\n ) {\n this.reobserve(\n {\n // Most fetchPolicy options don't make sense to use in a polling context, as\n // users wouldn't want to be polling the cache directly. However, network-only and\n // no-cache are both useful for when the user wants to control whether or not the\n // polled results are written to the cache.\n fetchPolicy:\n this.options.initialFetchPolicy === \"no-cache\" ?\n \"no-cache\"\n : \"network-only\",\n },\n NetworkStatus.poll\n ).then(poll, poll);\n } else {\n poll();\n }\n }\n };\n\n const poll = () => {\n const info = this.pollingInfo;\n if (info) {\n clearTimeout(info.timeout);\n info.timeout = setTimeout(maybeFetch, info.interval);\n }\n };\n\n poll();\n }\n\n private updateLastResult(\n newResult: ApolloQueryResult,\n variables = this.variables\n ) {\n let error: ApolloError | undefined = this.getLastError();\n // Preserve this.last.error unless the variables have changed.\n if (error && this.last && !equal(variables, this.last.variables)) {\n error = void 0;\n }\n return (this.last = {\n result:\n this.queryManager.assumeImmutableResults ?\n newResult\n : cloneDeep(newResult),\n variables,\n ...(error ? { error } : null),\n });\n }\n\n public reobserveAsConcast(\n newOptions?: Partial>,\n newNetworkStatus?: NetworkStatus\n ): Concast> {\n this.isTornDown = false;\n\n const useDisposableConcast =\n // Refetching uses a disposable Concast to allow refetches using different\n // options/variables, without permanently altering the options of the\n // original ObservableQuery.\n newNetworkStatus === NetworkStatus.refetch ||\n // The fetchMore method does not actually call the reobserve method, but,\n // if it did, it would definitely use a disposable Concast.\n newNetworkStatus === NetworkStatus.fetchMore ||\n // Polling uses a disposable Concast so the polling options (which force\n // fetchPolicy to be \"network-only\" or \"no-cache\") won't override the original options.\n newNetworkStatus === NetworkStatus.poll;\n\n // Save the old variables, since Object.assign may modify them below.\n const oldVariables = this.options.variables;\n const oldFetchPolicy = this.options.fetchPolicy;\n\n const mergedOptions = compact(this.options, newOptions || {});\n const options =\n useDisposableConcast ?\n // Disposable Concast fetches receive a shallow copy of this.options\n // (merged with newOptions), leaving this.options unmodified.\n mergedOptions\n : assign(this.options, mergedOptions);\n\n // Don't update options.query with the transformed query to avoid\n // overwriting this.options.query when we aren't using a disposable concast.\n // We want to ensure we can re-run the custom document transforms the next\n // time a request is made against the original query.\n const query = this.transformDocument(options.query);\n\n this.lastQuery = query;\n\n if (!useDisposableConcast) {\n // We can skip calling updatePolling if we're not changing this.options.\n this.updatePolling();\n\n // Reset options.fetchPolicy to its original value when variables change,\n // unless a new fetchPolicy was provided by newOptions.\n if (\n newOptions &&\n newOptions.variables &&\n !equal(newOptions.variables, oldVariables) &&\n // Don't mess with the fetchPolicy if it's currently \"standby\".\n options.fetchPolicy !== \"standby\" &&\n // If we're changing the fetchPolicy anyway, don't try to change it here\n // using applyNextFetchPolicy. The explicit options.fetchPolicy wins.\n options.fetchPolicy === oldFetchPolicy\n ) {\n this.applyNextFetchPolicy(\"variables-changed\", options);\n if (newNetworkStatus === void 0) {\n newNetworkStatus = NetworkStatus.setVariables;\n }\n }\n }\n\n this.waitForOwnResult &&= skipCacheDataFor(options.fetchPolicy);\n const finishWaitingForOwnResult = () => {\n if (this.concast === concast) {\n this.waitForOwnResult = false;\n }\n };\n\n const variables = options.variables && { ...options.variables };\n const { concast, fromLink } = this.fetch(options, newNetworkStatus, query);\n const observer: Observer> = {\n next: (result) => {\n if (equal(this.variables, variables)) {\n finishWaitingForOwnResult();\n this.reportResult(result, variables);\n }\n },\n error: (error) => {\n if (equal(this.variables, variables)) {\n finishWaitingForOwnResult();\n this.reportError(error, variables);\n }\n },\n };\n\n if (!useDisposableConcast && (fromLink || !this.concast)) {\n // We use the {add,remove}Observer methods directly to avoid wrapping\n // observer with an unnecessary SubscriptionObserver object.\n if (this.concast && this.observer) {\n this.concast.removeObserver(this.observer);\n }\n\n this.concast = concast;\n this.observer = observer;\n }\n\n concast.addObserver(observer);\n\n return concast;\n }\n\n public reobserve(\n newOptions?: Partial>,\n newNetworkStatus?: NetworkStatus\n ): Promise> {\n return this.reobserveAsConcast(newOptions, newNetworkStatus)\n .promise as TODO;\n }\n\n public resubscribeAfterError(\n onNext: (value: ApolloQueryResult) => void,\n onError?: (error: any) => void,\n onComplete?: () => void\n ): ObservableSubscription;\n\n public resubscribeAfterError(\n observer: Observer>\n ): ObservableSubscription;\n\n public resubscribeAfterError(...args: [any, any?, any?]) {\n // If `lastError` is set in the current when the subscription is re-created,\n // the subscription will immediately receive the error, which will\n // cause it to terminate again. To avoid this, we first clear\n // the last error/result from the `observableQuery` before re-starting\n // the subscription, and restore the last value afterwards so that the\n // subscription has a chance to stay open.\n const last = this.last;\n this.resetLastResults();\n\n const subscription = this.subscribe(...args);\n this.last = last;\n\n return subscription;\n }\n\n // (Re)deliver the current result to this.observers without applying fetch\n // policies or making network requests.\n private observe() {\n this.reportResult(\n // Passing false is important so that this.getCurrentResult doesn't\n // save the fetchMore result as this.lastResult, causing it to be\n // ignored due to the this.isDifferentFromLastResult check in\n // this.reportResult.\n this.getCurrentResult(false),\n this.variables\n );\n }\n\n private reportResult(\n result: ApolloQueryResult,\n variables: TVariables | undefined\n ) {\n const lastError = this.getLastError();\n const isDifferent = this.isDifferentFromLastResult(result, variables);\n // Update the last result even when isDifferentFromLastResult returns false,\n // because the query may be using the @nonreactive directive, and we want to\n // save the the latest version of any nonreactive subtrees (in case\n // getCurrentResult is called), even though we skip broadcasting changes.\n if (lastError || !result.partial || this.options.returnPartialData) {\n this.updateLastResult(result, variables);\n }\n if (lastError || isDifferent) {\n iterateObserversSafely(this.observers, \"next\", result);\n }\n }\n\n private reportError(error: ApolloError, variables: TVariables | undefined) {\n // Since we don't get the current result on errors, only the error, we\n // must mirror the updates that occur in QueryStore.markQueryError here\n const errorResult = {\n ...this.getLastResult(),\n error,\n errors: error.graphQLErrors,\n networkStatus: NetworkStatus.error,\n loading: false,\n } as ApolloQueryResult;\n\n this.updateLastResult(errorResult, variables);\n\n iterateObserversSafely(this.observers, \"error\", (this.last!.error = error));\n }\n\n public hasObservers() {\n return this.observers.size > 0;\n }\n\n private tearDownQuery() {\n if (this.isTornDown) return;\n if (this.concast && this.observer) {\n this.concast.removeObserver(this.observer);\n delete this.concast;\n delete this.observer;\n }\n\n this.stopPolling();\n // stop all active GraphQL subscriptions\n this.subscriptions.forEach((sub) => sub.unsubscribe());\n this.subscriptions.clear();\n this.queryManager.stopQuery(this.queryId);\n this.observers.clear();\n this.isTornDown = true;\n }\n\n private transformDocument(document: DocumentNode) {\n return this.queryManager.transform(document);\n }\n}\n\n// Necessary because the ObservableQuery constructor has a different\n// signature than the Observable constructor.\nfixObservableSubclass(ObservableQuery);\n\n// Reobserve with fetchPolicy effectively set to \"cache-first\", triggering\n// delivery of any new data from the cache, possibly falling back to the network\n// if any cache data are missing. This allows _complete_ cache results to be\n// delivered without also kicking off unnecessary network requests when\n// this.options.fetchPolicy is \"cache-and-network\" or \"network-only\". When\n// this.options.fetchPolicy is any other policy (\"cache-first\", \"cache-only\",\n// \"standby\", or \"no-cache\"), we call this.reobserve() as usual.\nexport function reobserveCacheFirst(\n obsQuery: ObservableQuery\n) {\n const { fetchPolicy, nextFetchPolicy } = obsQuery.options;\n\n if (fetchPolicy === \"cache-and-network\" || fetchPolicy === \"network-only\") {\n return obsQuery.reobserve({\n fetchPolicy: \"cache-first\",\n // Use a temporary nextFetchPolicy function that replaces itself with the\n // previous nextFetchPolicy value and returns the original fetchPolicy.\n nextFetchPolicy(\n this: WatchQueryOptions,\n currentFetchPolicy: WatchQueryFetchPolicy,\n context: NextFetchPolicyContext\n ) {\n // Replace this nextFetchPolicy function in the options object with the\n // original this.options.nextFetchPolicy value.\n this.nextFetchPolicy = nextFetchPolicy;\n // If the original nextFetchPolicy value was a function, give it a\n // chance to decide what happens here.\n if (typeof this.nextFetchPolicy === \"function\") {\n return this.nextFetchPolicy(currentFetchPolicy, context);\n }\n // Otherwise go back to the original this.options.fetchPolicy.\n return fetchPolicy!;\n },\n });\n }\n\n return obsQuery.reobserve();\n}\n\nfunction defaultSubscriptionObserverErrorCallback(error: ApolloError) {\n invariant.error(\"Unhandled error\", error.message, error.stack);\n}\n\nexport function logMissingFieldErrors(\n missing: MissingFieldError[] | MissingTree | undefined\n) {\n if (__DEV__ && missing) {\n invariant.debug(`Missing cache result fields: %o`, missing);\n }\n}\n\nfunction skipCacheDataFor(\n fetchPolicy?: WatchQueryFetchPolicy /* `undefined` would mean `\"cache-first\"` */\n) {\n return (\n fetchPolicy === \"network-only\" ||\n fetchPolicy === \"no-cache\" ||\n fetchPolicy === \"standby\"\n );\n}\n","import { Kind } from './kinds.mjs';\nexport function isDefinitionNode(node) {\n return (\n isExecutableDefinitionNode(node) ||\n isTypeSystemDefinitionNode(node) ||\n isTypeSystemExtensionNode(node)\n );\n}\nexport function isExecutableDefinitionNode(node) {\n return (\n node.kind === Kind.OPERATION_DEFINITION ||\n node.kind === Kind.FRAGMENT_DEFINITION\n );\n}\nexport function isSelectionNode(node) {\n return (\n node.kind === Kind.FIELD ||\n node.kind === Kind.FRAGMENT_SPREAD ||\n node.kind === Kind.INLINE_FRAGMENT\n );\n}\nexport function isValueNode(node) {\n return (\n node.kind === Kind.VARIABLE ||\n node.kind === Kind.INT ||\n node.kind === Kind.FLOAT ||\n node.kind === Kind.STRING ||\n node.kind === Kind.BOOLEAN ||\n node.kind === Kind.NULL ||\n node.kind === Kind.ENUM ||\n node.kind === Kind.LIST ||\n node.kind === Kind.OBJECT\n );\n}\nexport function isConstValueNode(node) {\n return (\n isValueNode(node) &&\n (node.kind === Kind.LIST\n ? node.values.some(isConstValueNode)\n : node.kind === Kind.OBJECT\n ? node.fields.some((field) => isConstValueNode(field.value))\n : node.kind !== Kind.VARIABLE)\n );\n}\nexport function isTypeNode(node) {\n return (\n node.kind === Kind.NAMED_TYPE ||\n node.kind === Kind.LIST_TYPE ||\n node.kind === Kind.NON_NULL_TYPE\n );\n}\nexport function isTypeSystemDefinitionNode(node) {\n return (\n node.kind === Kind.SCHEMA_DEFINITION ||\n isTypeDefinitionNode(node) ||\n node.kind === Kind.DIRECTIVE_DEFINITION\n );\n}\nexport function isTypeDefinitionNode(node) {\n return (\n node.kind === Kind.SCALAR_TYPE_DEFINITION ||\n node.kind === Kind.OBJECT_TYPE_DEFINITION ||\n node.kind === Kind.INTERFACE_TYPE_DEFINITION ||\n node.kind === Kind.UNION_TYPE_DEFINITION ||\n node.kind === Kind.ENUM_TYPE_DEFINITION ||\n node.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION\n );\n}\nexport function isTypeSystemExtensionNode(node) {\n return node.kind === Kind.SCHEMA_EXTENSION || isTypeExtensionNode(node);\n}\nexport function isTypeExtensionNode(node) {\n return (\n node.kind === Kind.SCALAR_TYPE_EXTENSION ||\n node.kind === Kind.OBJECT_TYPE_EXTENSION ||\n node.kind === Kind.INTERFACE_TYPE_EXTENSION ||\n node.kind === Kind.UNION_TYPE_EXTENSION ||\n node.kind === Kind.ENUM_TYPE_EXTENSION ||\n node.kind === Kind.INPUT_OBJECT_TYPE_EXTENSION\n );\n}\n","import type { OptimisticDependencyFunction } from \"optimism\";\nimport { dep, Slot } from \"optimism\";\nimport type { InMemoryCache } from \"./inMemoryCache.js\";\nimport type { ApolloCache } from \"../../core/index.js\";\n\nexport interface ReactiveVar {\n (newValue?: T): T;\n onNextChange(listener: ReactiveListener): () => void;\n attachCache(cache: ApolloCache): this;\n forgetCache(cache: ApolloCache): boolean;\n}\n\nexport type ReactiveListener = (value: T) => any;\n\n// Contextual Slot that acquires its value when custom read functions are\n// called in Policies#readField.\nexport const cacheSlot = new Slot>();\n\nconst cacheInfoMap = new WeakMap<\n ApolloCache,\n {\n vars: Set>;\n dep: OptimisticDependencyFunction>;\n }\n>();\n\nfunction getCacheInfo(cache: ApolloCache) {\n let info = cacheInfoMap.get(cache)!;\n if (!info) {\n cacheInfoMap.set(\n cache,\n (info = {\n vars: new Set(),\n dep: dep(),\n })\n );\n }\n return info;\n}\n\nexport function forgetCache(cache: ApolloCache) {\n getCacheInfo(cache).vars.forEach((rv) => rv.forgetCache(cache));\n}\n\n// Calling forgetCache(cache) serves to silence broadcasts and allows the\n// cache to be garbage collected. However, the varsByCache WeakMap\n// preserves the set of reactive variables that were previously associated\n// with this cache, which makes it possible to \"recall\" the cache at a\n// later time, by reattaching it to those variables. If the cache has been\n// garbage collected in the meantime, because it is no longer reachable,\n// you won't be able to call recallCache(cache), and the cache will\n// automatically disappear from the varsByCache WeakMap.\nexport function recallCache(cache: ApolloCache) {\n getCacheInfo(cache).vars.forEach((rv) => rv.attachCache(cache));\n}\n\nexport function makeVar(value: T): ReactiveVar {\n const caches = new Set>();\n const listeners = new Set>();\n\n const rv: ReactiveVar = function (newValue) {\n if (arguments.length > 0) {\n if (value !== newValue) {\n value = newValue!;\n caches.forEach((cache) => {\n // Invalidate any fields with custom read functions that\n // consumed this variable, so query results involving those\n // fields will be recomputed the next time we read them.\n getCacheInfo(cache).dep.dirty(rv);\n // Broadcast changes to any caches that have previously read\n // from this variable.\n broadcast(cache);\n });\n // Finally, notify any listeners added via rv.onNextChange.\n const oldListeners = Array.from(listeners);\n listeners.clear();\n oldListeners.forEach((listener) => listener(value));\n }\n } else {\n // When reading from the variable, obtain the current cache from\n // context via cacheSlot. This isn't entirely foolproof, but it's\n // the same system that powers varDep.\n const cache = cacheSlot.getValue();\n if (cache) {\n attach(cache);\n getCacheInfo(cache).dep(rv);\n }\n }\n\n return value;\n };\n\n rv.onNextChange = (listener) => {\n listeners.add(listener);\n return () => {\n listeners.delete(listener);\n };\n };\n\n const attach = (rv.attachCache = (cache) => {\n caches.add(cache);\n getCacheInfo(cache).vars.add(rv);\n return rv;\n });\n\n rv.forgetCache = (cache) => caches.delete(cache);\n\n return rv;\n}\n\ntype Broadcastable = ApolloCache & {\n // This method is protected in InMemoryCache, which we are ignoring, but\n // we still want some semblance of type safety when we call it.\n broadcastWatches?: InMemoryCache[\"broadcastWatches\"];\n};\n\nfunction broadcast(cache: Broadcastable) {\n if (cache.broadcastWatches) {\n cache.broadcastWatches();\n }\n}\n","import { invariant } from \"../utilities/globals/index.js\";\n\nimport type {\n DocumentNode,\n OperationDefinitionNode,\n SelectionSetNode,\n SelectionNode,\n InlineFragmentNode,\n FragmentDefinitionNode,\n FieldNode,\n ASTNode,\n DirectiveNode,\n FragmentSpreadNode,\n ExecutableDefinitionNode,\n} from \"graphql\";\nimport { visit, BREAK, isSelectionNode } from \"graphql\";\n\nimport type { ApolloCache } from \"../cache/index.js\";\nimport type { FragmentMap, StoreObject } from \"../utilities/index.js\";\nimport {\n argumentsObjectFromField,\n buildQueryFromSelectionSet,\n createFragmentMap,\n getFragmentDefinitions,\n getMainDefinition,\n hasDirectives,\n isField,\n isInlineFragment,\n mergeDeep,\n mergeDeepArray,\n removeClientSetsFromDocument,\n resultKeyNameFromField,\n shouldInclude,\n} from \"../utilities/index.js\";\nimport type { ApolloClient } from \"./ApolloClient.js\";\nimport type { Resolvers, OperationVariables } from \"./types.js\";\nimport type { FetchResult } from \"../link/core/index.js\";\nimport { cacheSlot } from \"../cache/index.js\";\n\nexport type Resolver = (\n rootValue?: any,\n args?: any,\n context?: any,\n info?: {\n field: FieldNode;\n fragmentMap: FragmentMap;\n }\n) => any;\n\nexport type VariableMap = { [name: string]: any };\n\nexport type FragmentMatcher = (\n rootValue: any,\n typeCondition: string,\n context: any\n) => boolean;\n\nexport type ExecContext = {\n fragmentMap: FragmentMap;\n context: any;\n variables: VariableMap;\n fragmentMatcher: FragmentMatcher;\n defaultOperationType: string;\n exportedVariables: Record;\n onlyRunForcedResolvers: boolean;\n selectionsToResolve: Set;\n};\n\nexport type LocalStateOptions = {\n cache: ApolloCache;\n client?: ApolloClient;\n resolvers?: Resolvers | Resolvers[];\n fragmentMatcher?: FragmentMatcher;\n};\n\nexport class LocalState {\n private cache: ApolloCache;\n private client?: ApolloClient;\n private resolvers?: Resolvers;\n private fragmentMatcher?: FragmentMatcher;\n private selectionsToResolveCache = new WeakMap<\n ExecutableDefinitionNode,\n Set\n >();\n\n constructor({\n cache,\n client,\n resolvers,\n fragmentMatcher,\n }: LocalStateOptions) {\n this.cache = cache;\n\n if (client) {\n this.client = client;\n }\n\n if (resolvers) {\n this.addResolvers(resolvers);\n }\n\n if (fragmentMatcher) {\n this.setFragmentMatcher(fragmentMatcher);\n }\n }\n\n public addResolvers(resolvers: Resolvers | Resolvers[]) {\n this.resolvers = this.resolvers || {};\n if (Array.isArray(resolvers)) {\n resolvers.forEach((resolverGroup) => {\n this.resolvers = mergeDeep(this.resolvers, resolverGroup);\n });\n } else {\n this.resolvers = mergeDeep(this.resolvers, resolvers);\n }\n }\n\n public setResolvers(resolvers: Resolvers | Resolvers[]) {\n this.resolvers = {};\n this.addResolvers(resolvers);\n }\n\n public getResolvers() {\n return this.resolvers || {};\n }\n\n // Run local client resolvers against the incoming query and remote data.\n // Locally resolved field values are merged with the incoming remote data,\n // and returned. Note that locally resolved fields will overwrite\n // remote data using the same field name.\n public async runResolvers({\n document,\n remoteResult,\n context,\n variables,\n onlyRunForcedResolvers = false,\n }: {\n document: DocumentNode | null;\n remoteResult: FetchResult;\n context?: Record;\n variables?: Record;\n onlyRunForcedResolvers?: boolean;\n }): Promise> {\n if (document) {\n return this.resolveDocument(\n document,\n remoteResult.data,\n context,\n variables,\n this.fragmentMatcher,\n onlyRunForcedResolvers\n ).then((localResult) => ({\n ...remoteResult,\n data: localResult.result,\n }));\n }\n\n return remoteResult;\n }\n\n public setFragmentMatcher(fragmentMatcher: FragmentMatcher) {\n this.fragmentMatcher = fragmentMatcher;\n }\n\n public getFragmentMatcher(): FragmentMatcher | undefined {\n return this.fragmentMatcher;\n }\n\n // Client queries contain everything in the incoming document (if a @client\n // directive is found).\n public clientQuery(document: DocumentNode) {\n if (hasDirectives([\"client\"], document)) {\n if (this.resolvers) {\n return document;\n }\n }\n return null;\n }\n\n // Server queries are stripped of all @client based selection sets.\n public serverQuery(document: DocumentNode) {\n return removeClientSetsFromDocument(document);\n }\n\n public prepareContext(context?: Record) {\n const { cache } = this;\n return {\n ...context,\n cache,\n // Getting an entry's cache key is useful for local state resolvers.\n getCacheKey(obj: StoreObject) {\n return cache.identify(obj);\n },\n };\n }\n\n // To support `@client @export(as: \"someVar\")` syntax, we'll first resolve\n // @client @export fields locally, then pass the resolved values back to be\n // used alongside the original operation variables.\n public async addExportedVariables(\n document: DocumentNode,\n variables: TVars = {} as TVars,\n context = {}\n ): /* returns at least the variables that were passed in */ Promise {\n if (document) {\n return this.resolveDocument(\n document,\n this.buildRootValueFromCache(document, variables) || {},\n this.prepareContext(context),\n variables\n ).then((data) => ({\n ...variables,\n ...data.exportedVariables,\n }));\n }\n\n return {\n ...variables,\n };\n }\n\n public shouldForceResolvers(document: ASTNode) {\n let forceResolvers = false;\n visit(document, {\n Directive: {\n enter(node) {\n if (node.name.value === \"client\" && node.arguments) {\n forceResolvers = node.arguments.some(\n (arg) =>\n arg.name.value === \"always\" &&\n arg.value.kind === \"BooleanValue\" &&\n arg.value.value === true\n );\n if (forceResolvers) {\n return BREAK;\n }\n }\n },\n },\n });\n return forceResolvers;\n }\n\n // Query the cache and return matching data.\n private buildRootValueFromCache(\n document: DocumentNode,\n variables?: Record\n ) {\n return this.cache.diff({\n query: buildQueryFromSelectionSet(document),\n variables,\n returnPartialData: true,\n optimistic: false,\n }).result;\n }\n\n private async resolveDocument(\n document: DocumentNode,\n rootValue: TData,\n context: any = {},\n variables: VariableMap = {},\n fragmentMatcher: FragmentMatcher = () => true,\n onlyRunForcedResolvers: boolean = false\n ) {\n const mainDefinition = getMainDefinition(\n document\n ) as OperationDefinitionNode;\n const fragments = getFragmentDefinitions(document);\n const fragmentMap = createFragmentMap(fragments);\n const selectionsToResolve = this.collectSelectionsToResolve(\n mainDefinition,\n fragmentMap\n );\n\n const definitionOperation = mainDefinition.operation;\n\n const defaultOperationType =\n definitionOperation ?\n definitionOperation.charAt(0).toUpperCase() +\n definitionOperation.slice(1)\n : \"Query\";\n\n const { cache, client } = this;\n const execContext: ExecContext = {\n fragmentMap,\n context: {\n ...context,\n cache,\n client,\n },\n variables,\n fragmentMatcher,\n defaultOperationType,\n exportedVariables: {},\n selectionsToResolve,\n onlyRunForcedResolvers,\n };\n const isClientFieldDescendant = false;\n\n return this.resolveSelectionSet(\n mainDefinition.selectionSet,\n isClientFieldDescendant,\n rootValue,\n execContext\n ).then((result) => ({\n result,\n exportedVariables: execContext.exportedVariables,\n }));\n }\n\n private async resolveSelectionSet(\n selectionSet: SelectionSetNode,\n isClientFieldDescendant: boolean,\n rootValue: TData,\n execContext: ExecContext\n ) {\n const { fragmentMap, context, variables } = execContext;\n const resultsToMerge: TData[] = [rootValue];\n\n const execute = async (selection: SelectionNode): Promise => {\n if (\n !isClientFieldDescendant &&\n !execContext.selectionsToResolve.has(selection)\n ) {\n // Skip selections without @client directives\n // (still processing if one of the ancestors or one of the child fields has @client directive)\n return;\n }\n if (!shouldInclude(selection, variables)) {\n // Skip this entirely.\n return;\n }\n\n if (isField(selection)) {\n return this.resolveField(\n selection,\n isClientFieldDescendant,\n rootValue,\n execContext\n ).then((fieldResult) => {\n if (typeof fieldResult !== \"undefined\") {\n resultsToMerge.push({\n [resultKeyNameFromField(selection)]: fieldResult,\n } as TData);\n }\n });\n }\n\n let fragment: InlineFragmentNode | FragmentDefinitionNode;\n\n if (isInlineFragment(selection)) {\n fragment = selection;\n } else {\n // This is a named fragment.\n fragment = fragmentMap[selection.name.value];\n invariant(fragment, `No fragment named %s`, selection.name.value);\n }\n\n if (fragment && fragment.typeCondition) {\n const typeCondition = fragment.typeCondition.name.value;\n if (execContext.fragmentMatcher(rootValue, typeCondition, context)) {\n return this.resolveSelectionSet(\n fragment.selectionSet,\n isClientFieldDescendant,\n rootValue,\n execContext\n ).then((fragmentResult) => {\n resultsToMerge.push(fragmentResult);\n });\n }\n }\n };\n\n return Promise.all(selectionSet.selections.map(execute)).then(function () {\n return mergeDeepArray(resultsToMerge);\n });\n }\n\n private async resolveField(\n field: FieldNode,\n isClientFieldDescendant: boolean,\n rootValue: any,\n execContext: ExecContext\n ): Promise {\n if (!rootValue) {\n return null;\n }\n\n const { variables } = execContext;\n const fieldName = field.name.value;\n const aliasedFieldName = resultKeyNameFromField(field);\n const aliasUsed = fieldName !== aliasedFieldName;\n const defaultResult = rootValue[aliasedFieldName] || rootValue[fieldName];\n let resultPromise = Promise.resolve(defaultResult);\n\n // Usually all local resolvers are run when passing through here, but\n // if we've specifically identified that we only want to run forced\n // resolvers (that is, resolvers for fields marked with\n // `@client(always: true)`), then we'll skip running non-forced resolvers.\n if (\n !execContext.onlyRunForcedResolvers ||\n this.shouldForceResolvers(field)\n ) {\n const resolverType =\n rootValue.__typename || execContext.defaultOperationType;\n const resolverMap = this.resolvers && this.resolvers[resolverType];\n if (resolverMap) {\n const resolve = resolverMap[aliasUsed ? fieldName : aliasedFieldName];\n if (resolve) {\n resultPromise = Promise.resolve(\n // In case the resolve function accesses reactive variables,\n // set cacheSlot to the current cache instance.\n cacheSlot.withValue(this.cache, resolve, [\n rootValue,\n argumentsObjectFromField(field, variables),\n execContext.context,\n { field, fragmentMap: execContext.fragmentMap },\n ])\n );\n }\n }\n }\n\n return resultPromise.then((result = defaultResult) => {\n // If an @export directive is associated with the current field, store\n // the `as` export variable name and current result for later use.\n if (field.directives) {\n field.directives.forEach((directive) => {\n if (directive.name.value === \"export\" && directive.arguments) {\n directive.arguments.forEach((arg) => {\n if (arg.name.value === \"as\" && arg.value.kind === \"StringValue\") {\n execContext.exportedVariables[arg.value.value] = result;\n }\n });\n }\n });\n }\n\n // Handle all scalar types here.\n if (!field.selectionSet) {\n return result;\n }\n\n // From here down, the field has a selection set, which means it's trying\n // to query a GraphQLObjectType.\n if (result == null) {\n // Basically any field in a GraphQL response can be null, or missing\n return result;\n }\n\n const isClientField =\n field.directives?.some((d) => d.name.value === \"client\") ?? false;\n\n if (Array.isArray(result)) {\n return this.resolveSubSelectedArray(\n field,\n isClientFieldDescendant || isClientField,\n result,\n execContext\n );\n }\n\n // Returned value is an object, and the query has a sub-selection. Recurse.\n if (field.selectionSet) {\n return this.resolveSelectionSet(\n field.selectionSet,\n isClientFieldDescendant || isClientField,\n result,\n execContext\n );\n }\n });\n }\n\n private resolveSubSelectedArray(\n field: FieldNode,\n isClientFieldDescendant: boolean,\n result: any[],\n execContext: ExecContext\n ): any {\n return Promise.all(\n result.map((item) => {\n if (item === null) {\n return null;\n }\n\n // This is a nested array, recurse.\n if (Array.isArray(item)) {\n return this.resolveSubSelectedArray(\n field,\n isClientFieldDescendant,\n item,\n execContext\n );\n }\n\n // This is an object, run the selection set on it.\n if (field.selectionSet) {\n return this.resolveSelectionSet(\n field.selectionSet,\n isClientFieldDescendant,\n item,\n execContext\n );\n }\n })\n );\n }\n\n // Collect selection nodes on paths from document root down to all @client directives.\n // This function takes into account transitive fragment spreads.\n // Complexity equals to a single `visit` over the full document.\n private collectSelectionsToResolve(\n mainDefinition: OperationDefinitionNode,\n fragmentMap: FragmentMap\n ): Set {\n const isSingleASTNode = (\n node: ASTNode | readonly ASTNode[]\n ): node is ASTNode => !Array.isArray(node);\n const selectionsToResolveCache = this.selectionsToResolveCache;\n\n function collectByDefinition(\n definitionNode: ExecutableDefinitionNode\n ): Set {\n if (!selectionsToResolveCache.has(definitionNode)) {\n const matches = new Set();\n selectionsToResolveCache.set(definitionNode, matches);\n\n visit(definitionNode, {\n Directive(node: DirectiveNode, _, __, ___, ancestors) {\n if (node.name.value === \"client\") {\n ancestors.forEach((node) => {\n if (isSingleASTNode(node) && isSelectionNode(node)) {\n matches.add(node);\n }\n });\n }\n },\n FragmentSpread(spread: FragmentSpreadNode, _, __, ___, ancestors) {\n const fragment = fragmentMap[spread.name.value];\n invariant(fragment, `No fragment named %s`, spread.name.value);\n\n const fragmentSelections = collectByDefinition(fragment);\n if (fragmentSelections.size > 0) {\n // Fragment for this spread contains @client directive (either directly or transitively)\n // Collect selection nodes on paths from the root down to fields with the @client directive\n ancestors.forEach((node) => {\n if (isSingleASTNode(node) && isSelectionNode(node)) {\n matches.add(node);\n }\n });\n matches.add(spread);\n fragmentSelections.forEach((selection) => {\n matches.add(selection);\n });\n }\n },\n });\n }\n return selectionsToResolveCache.get(definitionNode)!;\n }\n return collectByDefinition(mainDefinition);\n }\n}\n","import type { DocumentNode, GraphQLError } from \"graphql\";\nimport { equal } from \"@wry/equality\";\n\nimport type { Cache, ApolloCache } from \"../cache/index.js\";\nimport { DeepMerger } from \"../utilities/index.js\";\nimport { mergeIncrementalData } from \"../utilities/index.js\";\nimport type { WatchQueryOptions, ErrorPolicy } from \"./watchQueryOptions.js\";\nimport type { ObservableQuery } from \"./ObservableQuery.js\";\nimport { reobserveCacheFirst } from \"./ObservableQuery.js\";\nimport type { QueryListener } from \"./types.js\";\nimport type { FetchResult } from \"../link/core/index.js\";\nimport {\n isNonEmptyArray,\n graphQLResultHasError,\n canUseWeakMap,\n} from \"../utilities/index.js\";\nimport { NetworkStatus, isNetworkRequestInFlight } from \"./networkStatus.js\";\nimport type { ApolloError } from \"../errors/index.js\";\nimport type { QueryManager } from \"./QueryManager.js\";\n\nexport type QueryStoreValue = Pick<\n QueryInfo,\n \"variables\" | \"networkStatus\" | \"networkError\" | \"graphQLErrors\"\n>;\n\nexport const enum CacheWriteBehavior {\n FORBID,\n OVERWRITE,\n MERGE,\n}\n\nconst destructiveMethodCounts = new (canUseWeakMap ? WeakMap : Map)<\n ApolloCache,\n number\n>();\n\nfunction wrapDestructiveCacheMethod(\n cache: ApolloCache,\n methodName: \"evict\" | \"modify\" | \"reset\"\n) {\n const original = cache[methodName];\n if (typeof original === \"function\") {\n // @ts-expect-error this is just too generic to be typed correctly\n cache[methodName] = function () {\n destructiveMethodCounts.set(\n cache,\n // The %1e15 allows the count to wrap around to 0 safely every\n // quadrillion evictions, so there's no risk of overflow. To be\n // clear, this is more of a pedantic principle than something\n // that matters in any conceivable practical scenario.\n (destructiveMethodCounts.get(cache)! + 1) % 1e15\n );\n // @ts-expect-error this is just too generic to be typed correctly\n return original.apply(this, arguments);\n };\n }\n}\n\nfunction cancelNotifyTimeout(info: QueryInfo) {\n if (info[\"notifyTimeout\"]) {\n clearTimeout(info[\"notifyTimeout\"]);\n info[\"notifyTimeout\"] = void 0;\n }\n}\n\n// A QueryInfo object represents a single query managed by the\n// QueryManager, which tracks all QueryInfo objects by queryId in its\n// this.queries Map. QueryInfo objects store the latest results and errors\n// for the given query, and are responsible for reporting those results to\n// the corresponding ObservableQuery, via the QueryInfo.notify method.\n// Results are reported asynchronously whenever setDiff marks the\n// QueryInfo object as dirty, though a call to the QueryManager's\n// broadcastQueries method may trigger the notification before it happens\n// automatically. This class used to be a simple interface type without\n// any field privacy or meaningful methods, which is why it still has so\n// many public fields. The effort to lock down and simplify the QueryInfo\n// interface is ongoing, and further improvements are welcome.\nexport class QueryInfo {\n listeners = new Set();\n document: DocumentNode | null = null;\n lastRequestId = 1;\n variables?: Record;\n networkStatus?: NetworkStatus;\n networkError?: Error | null;\n graphQLErrors?: ReadonlyArray;\n stopped = false;\n\n private cache: ApolloCache;\n\n constructor(\n queryManager: QueryManager,\n public readonly queryId = queryManager.generateQueryId()\n ) {\n const cache = (this.cache = queryManager.cache);\n\n // Track how often cache.evict is called, since we want eviction to\n // override the feud-stopping logic in the markResult method, by\n // causing shouldWrite to return true. Wrapping the cache.evict method\n // is a bit of a hack, but it saves us from having to make eviction\n // counting an official part of the ApolloCache API.\n if (!destructiveMethodCounts.has(cache)) {\n destructiveMethodCounts.set(cache, 0);\n wrapDestructiveCacheMethod(cache, \"evict\");\n wrapDestructiveCacheMethod(cache, \"modify\");\n wrapDestructiveCacheMethod(cache, \"reset\");\n }\n }\n\n public init(query: {\n document: DocumentNode;\n variables: Record | undefined;\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus?: NetworkStatus;\n observableQuery?: ObservableQuery;\n lastRequestId?: number;\n }): this {\n let networkStatus = query.networkStatus || NetworkStatus.loading;\n if (\n this.variables &&\n this.networkStatus !== NetworkStatus.loading &&\n !equal(this.variables, query.variables)\n ) {\n networkStatus = NetworkStatus.setVariables;\n }\n\n if (!equal(query.variables, this.variables)) {\n this.lastDiff = void 0;\n }\n\n Object.assign(this, {\n document: query.document,\n variables: query.variables,\n networkError: null,\n graphQLErrors: this.graphQLErrors || [],\n networkStatus,\n });\n\n if (query.observableQuery) {\n this.setObservableQuery(query.observableQuery);\n }\n\n if (query.lastRequestId) {\n this.lastRequestId = query.lastRequestId;\n }\n\n return this;\n }\n\n private dirty: boolean = false;\n\n private notifyTimeout?: ReturnType;\n\n reset() {\n cancelNotifyTimeout(this);\n this.dirty = false;\n }\n\n resetDiff() {\n this.lastDiff = void 0;\n }\n\n getDiff(): Cache.DiffResult {\n const options = this.getDiffOptions();\n\n if (this.lastDiff && equal(options, this.lastDiff.options)) {\n return this.lastDiff.diff;\n }\n\n this.updateWatch(this.variables);\n\n const oq = this.observableQuery;\n if (oq && oq.options.fetchPolicy === \"no-cache\") {\n return { complete: false };\n }\n\n const diff = this.cache.diff(options);\n this.updateLastDiff(diff, options);\n return diff;\n }\n\n private lastDiff?: {\n diff: Cache.DiffResult;\n options: Cache.DiffOptions;\n };\n\n private updateLastDiff(\n diff: Cache.DiffResult | null,\n options?: Cache.DiffOptions\n ) {\n this.lastDiff =\n diff ?\n {\n diff,\n options: options || this.getDiffOptions(),\n }\n : void 0;\n }\n\n private getDiffOptions(variables = this.variables): Cache.DiffOptions {\n return {\n query: this.document!,\n variables,\n returnPartialData: true,\n optimistic: true,\n canonizeResults: this.observableQuery?.options.canonizeResults,\n };\n }\n\n setDiff(diff: Cache.DiffResult | null) {\n const oldDiff = this.lastDiff && this.lastDiff.diff;\n\n // If we are trying to deliver an incomplete cache result, we avoid\n // reporting it if the query has errored, otherwise we let the broadcast try\n // and repair the partial result by refetching the query. This check avoids\n // a situation where a query that errors and another succeeds with\n // overlapping data does not report the partial data result to the errored\n // query.\n //\n // See https://github.com/apollographql/apollo-client/issues/11400 for more\n // information on this issue.\n if (diff && !diff.complete && this.observableQuery?.getLastError()) {\n return;\n }\n\n this.updateLastDiff(diff);\n\n if (!this.dirty && !equal(oldDiff && oldDiff.result, diff && diff.result)) {\n this.dirty = true;\n if (!this.notifyTimeout) {\n this.notifyTimeout = setTimeout(() => this.notify(), 0);\n }\n }\n }\n\n public readonly observableQuery: ObservableQuery | null = null;\n private oqListener?: QueryListener;\n\n setObservableQuery(oq: ObservableQuery | null) {\n if (oq === this.observableQuery) return;\n\n if (this.oqListener) {\n this.listeners.delete(this.oqListener);\n }\n\n (this as any).observableQuery = oq;\n\n if (oq) {\n oq[\"queryInfo\"] = this;\n this.listeners.add(\n (this.oqListener = () => {\n const diff = this.getDiff();\n if (diff.fromOptimisticTransaction) {\n // If this diff came from an optimistic transaction, deliver the\n // current cache data to the ObservableQuery, but don't perform a\n // reobservation, since oq.reobserveCacheFirst might make a network\n // request, and we never want to trigger network requests in the\n // middle of optimistic updates.\n oq[\"observe\"]();\n } else {\n // Otherwise, make the ObservableQuery \"reobserve\" the latest data\n // using a temporary fetch policy of \"cache-first\", so complete cache\n // results have a chance to be delivered without triggering additional\n // network requests, even when options.fetchPolicy is \"network-only\"\n // or \"cache-and-network\". All other fetch policies are preserved by\n // this method, and are handled by calling oq.reobserve(). If this\n // reobservation is spurious, isDifferentFromLastResult still has a\n // chance to catch it before delivery to ObservableQuery subscribers.\n reobserveCacheFirst(oq);\n }\n })\n );\n } else {\n delete this.oqListener;\n }\n }\n\n notify() {\n cancelNotifyTimeout(this);\n\n if (this.shouldNotify()) {\n this.listeners.forEach((listener) => listener(this));\n }\n\n this.dirty = false;\n }\n\n private shouldNotify() {\n if (!this.dirty || !this.listeners.size) {\n return false;\n }\n\n if (isNetworkRequestInFlight(this.networkStatus) && this.observableQuery) {\n const { fetchPolicy } = this.observableQuery.options;\n if (fetchPolicy !== \"cache-only\" && fetchPolicy !== \"cache-and-network\") {\n return false;\n }\n }\n\n return true;\n }\n\n public stop() {\n if (!this.stopped) {\n this.stopped = true;\n\n // Cancel the pending notify timeout\n this.reset();\n\n this.cancel();\n // Revert back to the no-op version of cancel inherited from\n // QueryInfo.prototype.\n this.cancel = QueryInfo.prototype.cancel;\n\n const oq = this.observableQuery;\n if (oq) oq.stopPolling();\n }\n }\n\n // This method is a no-op by default, until/unless overridden by the\n // updateWatch method.\n private cancel() {}\n\n private lastWatch?: Cache.WatchOptions;\n\n private updateWatch(variables = this.variables) {\n const oq = this.observableQuery;\n if (oq && oq.options.fetchPolicy === \"no-cache\") {\n return;\n }\n\n const watchOptions: Cache.WatchOptions = {\n // Although this.getDiffOptions returns Cache.DiffOptions instead of\n // Cache.WatchOptions, all the overlapping options should be the same, so\n // we can reuse getDiffOptions here, for consistency.\n ...this.getDiffOptions(variables),\n watcher: this,\n callback: (diff) => this.setDiff(diff),\n };\n\n if (!this.lastWatch || !equal(watchOptions, this.lastWatch)) {\n this.cancel();\n this.cancel = this.cache.watch((this.lastWatch = watchOptions));\n }\n }\n\n private lastWrite?: {\n result: FetchResult;\n variables: WatchQueryOptions[\"variables\"];\n dmCount: number | undefined;\n };\n\n public resetLastWrite() {\n this.lastWrite = void 0;\n }\n\n private shouldWrite(\n result: FetchResult,\n variables: WatchQueryOptions[\"variables\"]\n ) {\n const { lastWrite } = this;\n return !(\n lastWrite &&\n // If cache.evict has been called since the last time we wrote this\n // data into the cache, there's a chance writing this result into\n // the cache will repair what was evicted.\n lastWrite.dmCount === destructiveMethodCounts.get(this.cache) &&\n equal(variables, lastWrite.variables) &&\n equal(result.data, lastWrite.result.data)\n );\n }\n\n public markResult(\n result: FetchResult,\n document: DocumentNode,\n options: Pick<\n WatchQueryOptions,\n \"variables\" | \"fetchPolicy\" | \"errorPolicy\"\n >,\n cacheWriteBehavior: CacheWriteBehavior\n ) {\n const merger = new DeepMerger();\n const graphQLErrors =\n isNonEmptyArray(result.errors) ? result.errors.slice(0) : [];\n\n // Cancel the pending notify timeout (if it exists) to prevent extraneous network\n // requests. To allow future notify timeouts, diff and dirty are reset as well.\n this.reset();\n\n if (\"incremental\" in result && isNonEmptyArray(result.incremental)) {\n const mergedData = mergeIncrementalData(this.getDiff().result, result);\n result.data = mergedData;\n\n // Detect the first chunk of a deferred query and merge it with existing\n // cache data. This ensures a `cache-first` fetch policy that returns\n // partial cache data or a `cache-and-network` fetch policy that already\n // has full data in the cache does not complain when trying to merge the\n // initial deferred server data with existing cache data.\n } else if (\"hasNext\" in result && result.hasNext) {\n const diff = this.getDiff();\n result.data = merger.merge(diff.result, result.data);\n }\n\n this.graphQLErrors = graphQLErrors;\n\n if (options.fetchPolicy === \"no-cache\") {\n this.updateLastDiff(\n { result: result.data, complete: true },\n this.getDiffOptions(options.variables)\n );\n } else if (cacheWriteBehavior !== CacheWriteBehavior.FORBID) {\n if (shouldWriteResult(result, options.errorPolicy)) {\n // Using a transaction here so we have a chance to read the result\n // back from the cache before the watch callback fires as a result\n // of writeQuery, so we can store the new diff quietly and ignore\n // it when we receive it redundantly from the watch callback.\n this.cache.performTransaction((cache) => {\n if (this.shouldWrite(result, options.variables)) {\n cache.writeQuery({\n query: document,\n data: result.data as T,\n variables: options.variables,\n overwrite: cacheWriteBehavior === CacheWriteBehavior.OVERWRITE,\n });\n\n this.lastWrite = {\n result,\n variables: options.variables,\n dmCount: destructiveMethodCounts.get(this.cache),\n };\n } else {\n // If result is the same as the last result we received from\n // the network (and the variables match too), avoid writing\n // result into the cache again. The wisdom of skipping this\n // cache write is far from obvious, since any cache write\n // could be the one that puts the cache back into a desired\n // state, fixing corruption or missing data. However, if we\n // always write every network result into the cache, we enable\n // feuds between queries competing to update the same data in\n // incompatible ways, which can lead to an endless cycle of\n // cache broadcasts and useless network requests. As with any\n // feud, eventually one side must step back from the brink,\n // letting the other side(s) have the last word(s). There may\n // be other points where we could break this cycle, such as\n // silencing the broadcast for cache.writeQuery (not a good\n // idea, since it just delays the feud a bit) or somehow\n // avoiding the network request that just happened (also bad,\n // because the server could return useful new data). All\n // options considered, skipping this cache write seems to be\n // the least damaging place to break the cycle, because it\n // reflects the intuition that we recently wrote this exact\n // result into the cache, so the cache *should* already/still\n // contain this data. If some other query has clobbered that\n // data in the meantime, that's too bad, but there will be no\n // winners if every query blindly reverts to its own version\n // of the data. This approach also gives the network a chance\n // to return new data, which will be written into the cache as\n // usual, notifying only those queries that are directly\n // affected by the cache updates, as usual. In the future, an\n // even more sophisticated cache could perhaps prevent or\n // mitigate the clobbering somehow, but that would make this\n // particular cache write even less important, and thus\n // skipping it would be even safer than it is today.\n if (this.lastDiff && this.lastDiff.diff.complete) {\n // Reuse data from the last good (complete) diff that we\n // received, when possible.\n result.data = this.lastDiff.diff.result;\n return;\n }\n // If the previous this.diff was incomplete, fall through to\n // re-reading the latest data with cache.diff, below.\n }\n\n const diffOptions = this.getDiffOptions(options.variables);\n const diff = cache.diff(diffOptions);\n\n // In case the QueryManager stops this QueryInfo before its\n // results are delivered, it's important to avoid restarting the\n // cache watch when markResult is called. We also avoid updating\n // the watch if we are writing a result that doesn't match the current\n // variables to avoid race conditions from broadcasting the wrong\n // result.\n if (!this.stopped && equal(this.variables, options.variables)) {\n // Any time we're about to update this.diff, we need to make\n // sure we've started watching the cache.\n this.updateWatch(options.variables);\n }\n\n // If we're allowed to write to the cache, and we can read a\n // complete result from the cache, update result.data to be the\n // result from the cache, rather than the raw network result.\n // Set without setDiff to avoid triggering a notify call, since\n // we have other ways of notifying for this result.\n this.updateLastDiff(diff, diffOptions);\n if (diff.complete) {\n result.data = diff.result;\n }\n });\n } else {\n this.lastWrite = void 0;\n }\n }\n }\n\n public markReady() {\n this.networkError = null;\n return (this.networkStatus = NetworkStatus.ready);\n }\n\n public markError(error: ApolloError) {\n this.networkStatus = NetworkStatus.error;\n this.lastWrite = void 0;\n\n this.reset();\n\n if (error.graphQLErrors) {\n this.graphQLErrors = error.graphQLErrors;\n }\n\n if (error.networkError) {\n this.networkError = error.networkError;\n }\n\n return error;\n }\n}\n\nexport function shouldWriteResult(\n result: FetchResult,\n errorPolicy: ErrorPolicy = \"none\"\n) {\n const ignoreErrors = errorPolicy === \"ignore\" || errorPolicy === \"all\";\n let writeWithErrors = !graphQLResultHasError(result);\n if (!writeWithErrors && ignoreErrors && result.data) {\n writeWithErrors = true;\n }\n return writeWithErrors;\n}\n","import { invariant, newInvariantError } from \"../utilities/globals/index.js\";\n\nimport type { DocumentNode } from \"graphql\";\n// TODO(brian): A hack until this issue is resolved (https://github.com/graphql/graphql-js/issues/3356)\ntype OperationTypeNode = any;\nimport { equal } from \"@wry/equality\";\n\nimport type { ApolloLink, FetchResult } from \"../link/core/index.js\";\nimport { execute } from \"../link/core/index.js\";\nimport {\n defaultCacheSizes,\n hasDirectives,\n isExecutionPatchIncrementalResult,\n isExecutionPatchResult,\n removeDirectivesFromDocument,\n} from \"../utilities/index.js\";\nimport type { Cache, ApolloCache } from \"../cache/index.js\";\nimport { canonicalStringify } from \"../cache/index.js\";\n\nimport type {\n ObservableSubscription,\n ConcastSourcesArray,\n} from \"../utilities/index.js\";\nimport {\n getDefaultValues,\n getOperationDefinition,\n getOperationName,\n hasClientExports,\n graphQLResultHasError,\n getGraphQLErrorsFromResult,\n Observable,\n asyncMap,\n isNonEmptyArray,\n Concast,\n makeUniqueId,\n isDocumentNode,\n isNonNullObject,\n DocumentTransform,\n} from \"../utilities/index.js\";\nimport { mergeIncrementalData } from \"../utilities/common/incrementalResult.js\";\nimport {\n ApolloError,\n isApolloError,\n graphQLResultHasProtocolErrors,\n} from \"../errors/index.js\";\nimport type {\n QueryOptions,\n WatchQueryOptions,\n SubscriptionOptions,\n MutationOptions,\n ErrorPolicy,\n MutationFetchPolicy,\n} from \"./watchQueryOptions.js\";\nimport { ObservableQuery, logMissingFieldErrors } from \"./ObservableQuery.js\";\nimport { NetworkStatus, isNetworkRequestInFlight } from \"./networkStatus.js\";\nimport type {\n ApolloQueryResult,\n OperationVariables,\n MutationUpdaterFunction,\n OnQueryUpdated,\n InternalRefetchQueriesInclude,\n InternalRefetchQueriesOptions,\n InternalRefetchQueriesResult,\n InternalRefetchQueriesMap,\n DefaultContext,\n} from \"./types.js\";\nimport { LocalState } from \"./LocalState.js\";\n\nimport type { QueryStoreValue } from \"./QueryInfo.js\";\nimport {\n QueryInfo,\n shouldWriteResult,\n CacheWriteBehavior,\n} from \"./QueryInfo.js\";\nimport type { ApolloErrorOptions } from \"../errors/index.js\";\nimport { PROTOCOL_ERRORS_SYMBOL } from \"../errors/index.js\";\nimport { print } from \"../utilities/index.js\";\nimport type { IgnoreModifier } from \"../cache/core/types/common.js\";\nimport type { TODO } from \"../utilities/types/TODO.js\";\n\nconst { hasOwnProperty } = Object.prototype;\n\nconst IGNORE: IgnoreModifier = Object.create(null);\n\ninterface MutationStoreValue {\n mutation: DocumentNode;\n variables: Record;\n loading: boolean;\n error: Error | null;\n}\n\ntype UpdateQueries = MutationOptions[\"updateQueries\"];\n\ninterface TransformCacheEntry {\n hasClientExports: boolean;\n hasForcedResolvers: boolean;\n hasNonreactiveDirective: boolean;\n clientQuery: DocumentNode | null;\n serverQuery: DocumentNode | null;\n defaultVars: OperationVariables;\n asQuery: DocumentNode;\n}\n\nimport type { DefaultOptions } from \"./ApolloClient.js\";\nimport { Trie } from \"@wry/trie\";\nimport { AutoCleanedWeakCache, cacheSizes } from \"../utilities/index.js\";\n\nexport class QueryManager {\n public cache: ApolloCache;\n public link: ApolloLink;\n public defaultOptions: DefaultOptions;\n\n public readonly assumeImmutableResults: boolean;\n public readonly documentTransform: DocumentTransform;\n public readonly ssrMode: boolean;\n public readonly defaultContext: Partial;\n\n private queryDeduplication: boolean;\n private clientAwareness: Record = {};\n private localState: LocalState;\n\n private onBroadcast?: () => void;\n public mutationStore?: {\n [mutationId: string]: MutationStoreValue;\n };\n\n // All the queries that the QueryManager is currently managing (not\n // including mutations and subscriptions).\n private queries = new Map();\n\n // Maps from queryId strings to Promise rejection functions for\n // currently active queries and fetches.\n // Use protected instead of private field so\n // @apollo/experimental-nextjs-app-support can access type info.\n protected fetchCancelFns = new Map any>();\n\n constructor({\n cache,\n link,\n defaultOptions,\n documentTransform,\n queryDeduplication = false,\n onBroadcast,\n ssrMode = false,\n clientAwareness = {},\n localState,\n assumeImmutableResults = !!cache.assumeImmutableResults,\n defaultContext,\n }: {\n cache: ApolloCache;\n link: ApolloLink;\n defaultOptions?: DefaultOptions;\n documentTransform?: DocumentTransform;\n queryDeduplication?: boolean;\n onBroadcast?: () => void;\n ssrMode?: boolean;\n clientAwareness?: Record;\n localState?: LocalState;\n assumeImmutableResults?: boolean;\n defaultContext?: Partial;\n }) {\n const defaultDocumentTransform = new DocumentTransform(\n (document) => this.cache.transformDocument(document),\n // Allow the apollo cache to manage its own transform caches\n { cache: false }\n );\n\n this.cache = cache;\n this.link = link;\n this.defaultOptions = defaultOptions || Object.create(null);\n this.queryDeduplication = queryDeduplication;\n this.clientAwareness = clientAwareness;\n this.localState = localState || new LocalState({ cache });\n this.ssrMode = ssrMode;\n this.assumeImmutableResults = assumeImmutableResults;\n this.documentTransform =\n documentTransform ?\n defaultDocumentTransform\n .concat(documentTransform)\n // The custom document transform may add new fragment spreads or new\n // field selections, so we want to give the cache a chance to run\n // again. For example, the InMemoryCache adds __typename to field\n // selections and fragments from the fragment registry.\n .concat(defaultDocumentTransform)\n : defaultDocumentTransform;\n this.defaultContext = defaultContext || Object.create(null);\n\n if ((this.onBroadcast = onBroadcast)) {\n this.mutationStore = Object.create(null);\n }\n }\n\n /**\n * Call this method to terminate any active query processes, making it safe\n * to dispose of this QueryManager instance.\n */\n public stop() {\n this.queries.forEach((_info, queryId) => {\n this.stopQueryNoBroadcast(queryId);\n });\n\n this.cancelPendingFetches(\n newInvariantError(\"QueryManager stopped while query was in flight\")\n );\n }\n\n private cancelPendingFetches(error: Error) {\n this.fetchCancelFns.forEach((cancel) => cancel(error));\n this.fetchCancelFns.clear();\n }\n\n public async mutate<\n TData,\n TVariables extends OperationVariables,\n TContext extends Record,\n TCache extends ApolloCache,\n >({\n mutation,\n variables,\n optimisticResponse,\n updateQueries,\n refetchQueries = [],\n awaitRefetchQueries = false,\n update: updateWithProxyFn,\n onQueryUpdated,\n fetchPolicy = this.defaultOptions.mutate?.fetchPolicy || \"network-only\",\n errorPolicy = this.defaultOptions.mutate?.errorPolicy || \"none\",\n keepRootFields,\n context,\n }: MutationOptions): Promise<\n FetchResult\n > {\n invariant(\n mutation,\n \"mutation option is required. You must specify your GraphQL document in the mutation option.\"\n );\n\n invariant(\n fetchPolicy === \"network-only\" || fetchPolicy === \"no-cache\",\n \"Mutations support only 'network-only' or 'no-cache' fetchPolicy strings. The default `network-only` behavior automatically writes mutation results to the cache. Passing `no-cache` skips the cache write.\"\n );\n\n const mutationId = this.generateMutationId();\n\n mutation = this.cache.transformForLink(this.transform(mutation));\n const { hasClientExports } = this.getDocumentInfo(mutation);\n\n variables = this.getVariables(mutation, variables) as TVariables;\n if (hasClientExports) {\n variables = (await this.localState.addExportedVariables(\n mutation,\n variables,\n context\n )) as TVariables;\n }\n\n const mutationStoreValue =\n this.mutationStore &&\n (this.mutationStore[mutationId] = {\n mutation,\n variables,\n loading: true,\n error: null,\n } as MutationStoreValue);\n\n const isOptimistic =\n optimisticResponse &&\n this.markMutationOptimistic(\n optimisticResponse,\n {\n mutationId,\n document: mutation,\n variables,\n fetchPolicy,\n errorPolicy,\n context,\n updateQueries,\n update: updateWithProxyFn,\n keepRootFields,\n }\n );\n\n this.broadcastQueries();\n\n const self = this;\n\n return new Promise((resolve, reject) => {\n return asyncMap(\n self.getObservableFromLink(\n mutation,\n {\n ...context,\n optimisticResponse: isOptimistic ? optimisticResponse : void 0,\n },\n variables,\n false\n ),\n\n (result: FetchResult) => {\n if (graphQLResultHasError(result) && errorPolicy === \"none\") {\n throw new ApolloError({\n graphQLErrors: getGraphQLErrorsFromResult(result),\n });\n }\n\n if (mutationStoreValue) {\n mutationStoreValue.loading = false;\n mutationStoreValue.error = null;\n }\n\n const storeResult: typeof result = { ...result };\n\n if (typeof refetchQueries === \"function\") {\n refetchQueries = refetchQueries(storeResult);\n }\n\n if (errorPolicy === \"ignore\" && graphQLResultHasError(storeResult)) {\n delete storeResult.errors;\n }\n\n return self.markMutationResult({\n mutationId,\n result: storeResult,\n document: mutation,\n variables,\n fetchPolicy,\n errorPolicy,\n context,\n update: updateWithProxyFn,\n updateQueries,\n awaitRefetchQueries,\n refetchQueries,\n removeOptimistic: isOptimistic ? mutationId : void 0,\n onQueryUpdated,\n keepRootFields,\n });\n }\n ).subscribe({\n next(storeResult) {\n self.broadcastQueries();\n\n // Since mutations might receive multiple payloads from the\n // ApolloLink chain (e.g. when used with @defer),\n // we resolve with a SingleExecutionResult or after the final\n // ExecutionPatchResult has arrived and we have assembled the\n // multipart response into a single result.\n if (!(\"hasNext\" in storeResult) || storeResult.hasNext === false) {\n resolve(storeResult);\n }\n },\n\n error(err: Error) {\n if (mutationStoreValue) {\n mutationStoreValue.loading = false;\n mutationStoreValue.error = err;\n }\n\n if (isOptimistic) {\n self.cache.removeOptimistic(mutationId);\n }\n\n self.broadcastQueries();\n\n reject(\n err instanceof ApolloError ? err : (\n new ApolloError({\n networkError: err,\n })\n )\n );\n },\n });\n });\n }\n\n public markMutationResult<\n TData,\n TVariables,\n TContext,\n TCache extends ApolloCache,\n >(\n mutation: {\n mutationId: string;\n result: FetchResult;\n document: DocumentNode;\n variables?: TVariables;\n fetchPolicy?: MutationFetchPolicy;\n errorPolicy: ErrorPolicy;\n context?: TContext;\n updateQueries: UpdateQueries;\n update?: MutationUpdaterFunction;\n awaitRefetchQueries?: boolean;\n refetchQueries?: InternalRefetchQueriesInclude;\n removeOptimistic?: string;\n onQueryUpdated?: OnQueryUpdated;\n keepRootFields?: boolean;\n },\n cache = this.cache\n ): Promise> {\n let { result } = mutation;\n const cacheWrites: Cache.WriteOptions[] = [];\n const skipCache = mutation.fetchPolicy === \"no-cache\";\n\n if (!skipCache && shouldWriteResult(result, mutation.errorPolicy)) {\n if (!isExecutionPatchIncrementalResult(result)) {\n cacheWrites.push({\n result: result.data,\n dataId: \"ROOT_MUTATION\",\n query: mutation.document,\n variables: mutation.variables,\n });\n }\n if (\n isExecutionPatchIncrementalResult(result) &&\n isNonEmptyArray(result.incremental)\n ) {\n const diff = cache.diff({\n id: \"ROOT_MUTATION\",\n // The cache complains if passed a mutation where it expects a\n // query, so we transform mutations and subscriptions to queries\n // (only once, thanks to this.transformCache).\n query: this.getDocumentInfo(mutation.document).asQuery,\n variables: mutation.variables,\n optimistic: false,\n returnPartialData: true,\n });\n let mergedData;\n if (diff.result) {\n mergedData = mergeIncrementalData(diff.result, result);\n }\n if (typeof mergedData !== \"undefined\") {\n // cast the ExecutionPatchResult to FetchResult here since\n // ExecutionPatchResult never has `data` when returned from the server\n (result as FetchResult).data = mergedData;\n cacheWrites.push({\n result: mergedData,\n dataId: \"ROOT_MUTATION\",\n query: mutation.document,\n variables: mutation.variables,\n });\n }\n }\n\n const { updateQueries } = mutation;\n if (updateQueries) {\n this.queries.forEach(({ observableQuery }, queryId) => {\n const queryName = observableQuery && observableQuery.queryName;\n if (!queryName || !hasOwnProperty.call(updateQueries, queryName)) {\n return;\n }\n const updater = updateQueries[queryName];\n const { document, variables } = this.queries.get(queryId)!;\n\n // Read the current query result from the store.\n const { result: currentQueryResult, complete } = cache.diff({\n query: document!,\n variables,\n returnPartialData: true,\n optimistic: false,\n });\n\n if (complete && currentQueryResult) {\n // Run our reducer using the current query result and the mutation result.\n const nextQueryResult = updater(currentQueryResult, {\n mutationResult: result,\n queryName: (document && getOperationName(document)) || void 0,\n queryVariables: variables!,\n });\n\n // Write the modified result back into the store if we got a new result.\n if (nextQueryResult) {\n cacheWrites.push({\n result: nextQueryResult,\n dataId: \"ROOT_QUERY\",\n query: document!,\n variables,\n });\n }\n }\n });\n }\n }\n\n if (\n cacheWrites.length > 0 ||\n (mutation.refetchQueries || \"\").length > 0 ||\n mutation.update ||\n mutation.onQueryUpdated ||\n mutation.removeOptimistic\n ) {\n const results: any[] = [];\n\n this.refetchQueries({\n updateCache: (cache) => {\n if (!skipCache) {\n cacheWrites.forEach((write) => cache.write(write));\n }\n\n // If the mutation has some writes associated with it then we need to\n // apply those writes to the store by running this reducer again with\n // a write action.\n const { update } = mutation;\n // Determine whether result is a SingleExecutionResult,\n // or the final ExecutionPatchResult.\n const isFinalResult =\n !isExecutionPatchResult(result) ||\n (isExecutionPatchIncrementalResult(result) && !result.hasNext);\n\n if (update) {\n if (!skipCache) {\n // Re-read the ROOT_MUTATION data we just wrote into the cache\n // (the first cache.write call in the cacheWrites.forEach loop\n // above), so field read functions have a chance to run for\n // fields within mutation result objects.\n const diff = cache.diff({\n id: \"ROOT_MUTATION\",\n // The cache complains if passed a mutation where it expects a\n // query, so we transform mutations and subscriptions to queries\n // (only once, thanks to this.transformCache).\n query: this.getDocumentInfo(mutation.document).asQuery,\n variables: mutation.variables,\n optimistic: false,\n returnPartialData: true,\n });\n\n if (diff.complete) {\n result = { ...(result as FetchResult), data: diff.result };\n if (\"incremental\" in result) {\n delete result.incremental;\n }\n if (\"hasNext\" in result) {\n delete result.hasNext;\n }\n }\n }\n\n // If we've received the whole response,\n // either a SingleExecutionResult or the final ExecutionPatchResult,\n // call the update function.\n if (isFinalResult) {\n update(cache as TCache, result, {\n context: mutation.context,\n variables: mutation.variables,\n });\n }\n }\n\n // TODO Do this with cache.evict({ id: 'ROOT_MUTATION' }) but make it\n // shallow to allow rolling back optimistic evictions.\n if (!skipCache && !mutation.keepRootFields && isFinalResult) {\n cache.modify({\n id: \"ROOT_MUTATION\",\n fields(value, { fieldName, DELETE }) {\n return fieldName === \"__typename\" ? value : DELETE;\n },\n });\n }\n },\n\n include: mutation.refetchQueries,\n\n // Write the final mutation.result to the root layer of the cache.\n optimistic: false,\n\n // Remove the corresponding optimistic layer at the same time as we\n // write the final non-optimistic result.\n removeOptimistic: mutation.removeOptimistic,\n\n // Let the caller of client.mutate optionally determine the refetching\n // behavior for watched queries after the mutation.update function runs.\n // If no onQueryUpdated function was provided for this mutation, pass\n // null instead of undefined to disable the default refetching behavior.\n onQueryUpdated: mutation.onQueryUpdated || null,\n }).forEach((result) => results.push(result));\n\n if (mutation.awaitRefetchQueries || mutation.onQueryUpdated) {\n // Returning a promise here makes the mutation await that promise, so we\n // include results in that promise's work if awaitRefetchQueries or an\n // onQueryUpdated function was specified.\n return Promise.all(results).then(() => result);\n }\n }\n\n return Promise.resolve(result);\n }\n\n public markMutationOptimistic<\n TData,\n TVariables,\n TContext,\n TCache extends ApolloCache,\n >(\n optimisticResponse: any,\n mutation: {\n mutationId: string;\n document: DocumentNode;\n variables?: TVariables;\n fetchPolicy?: MutationFetchPolicy;\n errorPolicy: ErrorPolicy;\n context?: TContext;\n updateQueries: UpdateQueries;\n update?: MutationUpdaterFunction;\n keepRootFields?: boolean;\n }\n ) {\n const data =\n typeof optimisticResponse === \"function\" ?\n optimisticResponse(mutation.variables, { IGNORE })\n : optimisticResponse;\n\n if (data === IGNORE) {\n return false;\n }\n\n this.cache.recordOptimisticTransaction((cache) => {\n try {\n this.markMutationResult(\n {\n ...mutation,\n result: { data },\n },\n cache\n );\n } catch (error) {\n invariant.error(error);\n }\n }, mutation.mutationId);\n\n return true;\n }\n\n public fetchQuery(\n queryId: string,\n options: WatchQueryOptions,\n networkStatus?: NetworkStatus\n ): Promise> {\n return this.fetchConcastWithInfo(queryId, options, networkStatus).concast\n .promise as TODO;\n }\n\n public getQueryStore() {\n const store: Record = Object.create(null);\n this.queries.forEach((info, queryId) => {\n store[queryId] = {\n variables: info.variables,\n networkStatus: info.networkStatus,\n networkError: info.networkError,\n graphQLErrors: info.graphQLErrors,\n };\n });\n return store;\n }\n\n public resetErrors(queryId: string) {\n const queryInfo = this.queries.get(queryId);\n if (queryInfo) {\n queryInfo.networkError = undefined;\n queryInfo.graphQLErrors = [];\n }\n }\n\n public transform(document: DocumentNode) {\n return this.documentTransform.transformDocument(document);\n }\n\n private transformCache = new AutoCleanedWeakCache<\n DocumentNode,\n TransformCacheEntry\n >(\n cacheSizes[\"queryManager.getDocumentInfo\"] ||\n defaultCacheSizes[\"queryManager.getDocumentInfo\"]\n );\n\n public getDocumentInfo(document: DocumentNode) {\n const { transformCache } = this;\n\n if (!transformCache.has(document)) {\n const cacheEntry: TransformCacheEntry = {\n // TODO These three calls (hasClientExports, shouldForceResolvers, and\n // usesNonreactiveDirective) are performing independent full traversals\n // of the transformed document. We should consider merging these\n // traversals into a single pass in the future, though the work is\n // cached after the first time.\n hasClientExports: hasClientExports(document),\n hasForcedResolvers: this.localState.shouldForceResolvers(document),\n hasNonreactiveDirective: hasDirectives([\"nonreactive\"], document),\n clientQuery: this.localState.clientQuery(document),\n serverQuery: removeDirectivesFromDocument(\n [\n { name: \"client\", remove: true },\n { name: \"connection\" },\n { name: \"nonreactive\" },\n ],\n document\n ),\n defaultVars: getDefaultValues(\n getOperationDefinition(document)\n ) as OperationVariables,\n // Transform any mutation or subscription operations to query operations\n // so we can read/write them from/to the cache.\n asQuery: {\n ...document,\n definitions: document.definitions.map((def) => {\n if (\n def.kind === \"OperationDefinition\" &&\n def.operation !== \"query\"\n ) {\n return { ...def, operation: \"query\" as OperationTypeNode };\n }\n return def;\n }),\n },\n };\n\n transformCache.set(document, cacheEntry);\n }\n\n return transformCache.get(document)!;\n }\n\n private getVariables(\n document: DocumentNode,\n variables?: TVariables\n ): OperationVariables {\n return {\n ...this.getDocumentInfo(document).defaultVars,\n ...variables,\n };\n }\n\n public watchQuery<\n T,\n TVariables extends OperationVariables = OperationVariables,\n >(options: WatchQueryOptions): ObservableQuery {\n const query = this.transform(options.query);\n\n // assign variable default values if supplied\n // NOTE: We don't modify options.query here with the transformed query to\n // ensure observable.options.query is set to the raw untransformed query.\n options = {\n ...options,\n variables: this.getVariables(query, options.variables) as TVariables,\n };\n\n if (typeof options.notifyOnNetworkStatusChange === \"undefined\") {\n options.notifyOnNetworkStatusChange = false;\n }\n\n const queryInfo = new QueryInfo(this);\n const observable = new ObservableQuery({\n queryManager: this,\n queryInfo,\n options,\n });\n observable[\"lastQuery\"] = query;\n\n this.queries.set(observable.queryId, queryInfo);\n\n // We give queryInfo the transformed query to ensure the first cache diff\n // uses the transformed query instead of the raw query\n queryInfo.init({\n document: query,\n observableQuery: observable,\n variables: observable.variables,\n });\n\n return observable;\n }\n\n public query(\n options: QueryOptions,\n queryId = this.generateQueryId()\n ): Promise> {\n invariant(\n options.query,\n \"query option is required. You must specify your GraphQL document \" +\n \"in the query option.\"\n );\n\n invariant(\n options.query.kind === \"Document\",\n 'You must wrap the query string in a \"gql\" tag.'\n );\n\n invariant(\n !(options as any).returnPartialData,\n \"returnPartialData option only supported on watchQuery.\"\n );\n\n invariant(\n !(options as any).pollInterval,\n \"pollInterval option only supported on watchQuery.\"\n );\n\n return this.fetchQuery(queryId, {\n ...options,\n query: this.transform(options.query),\n }).finally(() => this.stopQuery(queryId));\n }\n\n private queryIdCounter = 1;\n public generateQueryId() {\n return String(this.queryIdCounter++);\n }\n\n private requestIdCounter = 1;\n public generateRequestId() {\n return this.requestIdCounter++;\n }\n\n private mutationIdCounter = 1;\n public generateMutationId() {\n return String(this.mutationIdCounter++);\n }\n\n public stopQueryInStore(queryId: string) {\n this.stopQueryInStoreNoBroadcast(queryId);\n this.broadcastQueries();\n }\n\n private stopQueryInStoreNoBroadcast(queryId: string) {\n const queryInfo = this.queries.get(queryId);\n if (queryInfo) queryInfo.stop();\n }\n\n public clearStore(\n options: Cache.ResetOptions = {\n discardWatches: true,\n }\n ): Promise {\n // Before we have sent the reset action to the store, we can no longer\n // rely on the results returned by in-flight requests since these may\n // depend on values that previously existed in the data portion of the\n // store. So, we cancel the promises and observers that we have issued\n // so far and not yet resolved (in the case of queries).\n this.cancelPendingFetches(\n newInvariantError(\n \"Store reset while query was in flight (not completed in link chain)\"\n )\n );\n\n this.queries.forEach((queryInfo) => {\n if (queryInfo.observableQuery) {\n // Set loading to true so listeners don't trigger unless they want\n // results with partial data.\n queryInfo.networkStatus = NetworkStatus.loading;\n } else {\n queryInfo.stop();\n }\n });\n\n if (this.mutationStore) {\n this.mutationStore = Object.create(null);\n }\n\n // begin removing data from the store\n return this.cache.reset(options);\n }\n\n public getObservableQueries(\n include: InternalRefetchQueriesInclude = \"active\"\n ) {\n const queries = new Map>();\n const queryNamesAndDocs = new Map();\n const legacyQueryOptions = new Set();\n\n if (Array.isArray(include)) {\n include.forEach((desc) => {\n if (typeof desc === \"string\") {\n queryNamesAndDocs.set(desc, false);\n } else if (isDocumentNode(desc)) {\n queryNamesAndDocs.set(this.transform(desc), false);\n } else if (isNonNullObject(desc) && desc.query) {\n legacyQueryOptions.add(desc);\n }\n });\n }\n\n this.queries.forEach(({ observableQuery: oq, document }, queryId) => {\n if (oq) {\n if (include === \"all\") {\n queries.set(queryId, oq);\n return;\n }\n\n const {\n queryName,\n options: { fetchPolicy },\n } = oq;\n\n if (\n fetchPolicy === \"standby\" ||\n (include === \"active\" && !oq.hasObservers())\n ) {\n return;\n }\n\n if (\n include === \"active\" ||\n (queryName && queryNamesAndDocs.has(queryName)) ||\n (document && queryNamesAndDocs.has(document))\n ) {\n queries.set(queryId, oq);\n if (queryName) queryNamesAndDocs.set(queryName, true);\n if (document) queryNamesAndDocs.set(document, true);\n }\n }\n });\n\n if (legacyQueryOptions.size) {\n legacyQueryOptions.forEach((options: QueryOptions) => {\n // We will be issuing a fresh network request for this query, so we\n // pre-allocate a new query ID here, using a special prefix to enable\n // cleaning up these temporary queries later, after fetching.\n const queryId = makeUniqueId(\"legacyOneTimeQuery\");\n const queryInfo = this.getQuery(queryId).init({\n document: options.query,\n variables: options.variables,\n });\n const oq = new ObservableQuery({\n queryManager: this,\n queryInfo,\n options: {\n ...options,\n fetchPolicy: \"network-only\",\n },\n });\n invariant(oq.queryId === queryId);\n queryInfo.setObservableQuery(oq);\n queries.set(queryId, oq);\n });\n }\n\n if (__DEV__ && queryNamesAndDocs.size) {\n queryNamesAndDocs.forEach((included, nameOrDoc) => {\n if (!included) {\n invariant.warn(\n typeof nameOrDoc === \"string\" ?\n `Unknown query named \"%s\" requested in refetchQueries options.include array`\n : `Unknown query %o requested in refetchQueries options.include array`,\n nameOrDoc\n );\n }\n });\n }\n\n return queries;\n }\n\n public reFetchObservableQueries(\n includeStandby: boolean = false\n ): Promise[]> {\n const observableQueryPromises: Promise>[] = [];\n\n this.getObservableQueries(includeStandby ? \"all\" : \"active\").forEach(\n (observableQuery, queryId) => {\n const { fetchPolicy } = observableQuery.options;\n observableQuery.resetLastResults();\n if (\n includeStandby ||\n (fetchPolicy !== \"standby\" && fetchPolicy !== \"cache-only\")\n ) {\n observableQueryPromises.push(observableQuery.refetch());\n }\n this.getQuery(queryId).setDiff(null);\n }\n );\n\n this.broadcastQueries();\n\n return Promise.all(observableQueryPromises);\n }\n\n public setObservableQuery(observableQuery: ObservableQuery) {\n this.getQuery(observableQuery.queryId).setObservableQuery(observableQuery);\n }\n\n public startGraphQLSubscription({\n query,\n fetchPolicy,\n errorPolicy = \"none\",\n variables,\n context = {},\n }: SubscriptionOptions): Observable> {\n query = this.transform(query);\n variables = this.getVariables(query, variables);\n\n const makeObservable = (variables: OperationVariables) =>\n this.getObservableFromLink(query, context, variables).map((result) => {\n if (fetchPolicy !== \"no-cache\") {\n // the subscription interface should handle not sending us results we no longer subscribe to.\n // XXX I don't think we ever send in an object with errors, but we might in the future...\n if (shouldWriteResult(result, errorPolicy)) {\n this.cache.write({\n query,\n result: result.data,\n dataId: \"ROOT_SUBSCRIPTION\",\n variables: variables,\n });\n }\n\n this.broadcastQueries();\n }\n\n const hasErrors = graphQLResultHasError(result);\n const hasProtocolErrors = graphQLResultHasProtocolErrors(result);\n if (hasErrors || hasProtocolErrors) {\n const errors: ApolloErrorOptions = {};\n if (hasErrors) {\n errors.graphQLErrors = result.errors;\n }\n if (hasProtocolErrors) {\n errors.protocolErrors = result.extensions[PROTOCOL_ERRORS_SYMBOL];\n }\n\n // `errorPolicy` is a mechanism for handling GraphQL errors, according\n // to our documentation, so we throw protocol errors regardless of the\n // set error policy.\n if (errorPolicy === \"none\" || hasProtocolErrors) {\n throw new ApolloError(errors);\n }\n }\n\n if (errorPolicy === \"ignore\") {\n delete result.errors;\n }\n\n return result;\n });\n\n if (this.getDocumentInfo(query).hasClientExports) {\n const observablePromise = this.localState\n .addExportedVariables(query, variables, context)\n .then(makeObservable);\n\n return new Observable>((observer) => {\n let sub: ObservableSubscription | null = null;\n observablePromise.then(\n (observable) => (sub = observable.subscribe(observer)),\n observer.error\n );\n return () => sub && sub.unsubscribe();\n });\n }\n\n return makeObservable(variables);\n }\n\n public stopQuery(queryId: string) {\n this.stopQueryNoBroadcast(queryId);\n this.broadcastQueries();\n }\n\n private stopQueryNoBroadcast(queryId: string) {\n this.stopQueryInStoreNoBroadcast(queryId);\n this.removeQuery(queryId);\n }\n\n public removeQuery(queryId: string) {\n // teardown all links\n // Both `QueryManager.fetchRequest` and `QueryManager.query` create separate promises\n // that each add their reject functions to fetchCancelFns.\n // A query created with `QueryManager.query()` could trigger a `QueryManager.fetchRequest`.\n // The same queryId could have two rejection fns for two promises\n this.fetchCancelFns.delete(queryId);\n if (this.queries.has(queryId)) {\n this.getQuery(queryId).stop();\n this.queries.delete(queryId);\n }\n }\n\n public broadcastQueries() {\n if (this.onBroadcast) this.onBroadcast();\n this.queries.forEach((info) => info.notify());\n }\n\n public getLocalState(): LocalState {\n return this.localState;\n }\n\n // Use protected instead of private field so\n // @apollo/experimental-nextjs-app-support can access type info.\n protected inFlightLinkObservables = new Trie<{\n observable?: Observable>;\n }>(false);\n\n private getObservableFromLink(\n query: DocumentNode,\n context: any,\n variables?: OperationVariables,\n // Prefer context.queryDeduplication if specified.\n deduplication: boolean = context?.queryDeduplication ??\n this.queryDeduplication\n ): Observable> {\n let observable: Observable> | undefined;\n\n const { serverQuery, clientQuery } = this.getDocumentInfo(query);\n if (serverQuery) {\n const { inFlightLinkObservables, link } = this;\n\n const operation = {\n query: serverQuery,\n variables,\n operationName: getOperationName(serverQuery) || void 0,\n context: this.prepareContext({\n ...context,\n forceFetch: !deduplication,\n }),\n };\n\n context = operation.context;\n\n if (deduplication) {\n const printedServerQuery = print(serverQuery);\n const varJson = canonicalStringify(variables);\n\n const entry = inFlightLinkObservables.lookup(\n printedServerQuery,\n varJson\n );\n\n observable = entry.observable;\n if (!observable) {\n const concast = new Concast([\n execute(link, operation) as Observable>,\n ]);\n observable = entry.observable = concast;\n\n concast.beforeNext(() => {\n inFlightLinkObservables.remove(printedServerQuery, varJson);\n });\n }\n } else {\n observable = new Concast([\n execute(link, operation) as Observable>,\n ]);\n }\n } else {\n observable = new Concast([Observable.of({ data: {} } as FetchResult)]);\n context = this.prepareContext(context);\n }\n\n if (clientQuery) {\n observable = asyncMap(observable, (result) => {\n return this.localState.runResolvers({\n document: clientQuery,\n remoteResult: result,\n context,\n variables,\n });\n });\n }\n\n return observable;\n }\n\n private getResultsFromLink(\n queryInfo: QueryInfo,\n cacheWriteBehavior: CacheWriteBehavior,\n options: Pick<\n WatchQueryOptions,\n \"query\" | \"variables\" | \"context\" | \"fetchPolicy\" | \"errorPolicy\"\n >\n ): Observable> {\n const requestId = (queryInfo.lastRequestId = this.generateRequestId());\n\n // Performing transformForLink here gives this.cache a chance to fill in\n // missing fragment definitions (for example) before sending this document\n // through the link chain.\n const linkDocument = this.cache.transformForLink(options.query);\n\n return asyncMap(\n this.getObservableFromLink(\n linkDocument,\n options.context,\n options.variables\n ),\n\n (result) => {\n const graphQLErrors = getGraphQLErrorsFromResult(result);\n const hasErrors = graphQLErrors.length > 0;\n\n // If we interrupted this request by calling getResultsFromLink again\n // with the same QueryInfo object, we ignore the old results.\n if (requestId >= queryInfo.lastRequestId) {\n if (hasErrors && options.errorPolicy === \"none\") {\n // Throwing here effectively calls observer.error.\n throw queryInfo.markError(\n new ApolloError({\n graphQLErrors,\n })\n );\n }\n // Use linkDocument rather than queryInfo.document so the\n // operation/fragments used to write the result are the same as the\n // ones used to obtain it from the link.\n queryInfo.markResult(\n result,\n linkDocument,\n options,\n cacheWriteBehavior\n );\n queryInfo.markReady();\n }\n\n const aqr: ApolloQueryResult = {\n data: result.data,\n loading: false,\n networkStatus: NetworkStatus.ready,\n };\n\n if (hasErrors && options.errorPolicy !== \"ignore\") {\n aqr.errors = graphQLErrors;\n aqr.networkStatus = NetworkStatus.error;\n }\n\n return aqr;\n },\n\n (networkError) => {\n const error =\n isApolloError(networkError) ? networkError : (\n new ApolloError({ networkError })\n );\n\n // Avoid storing errors from older interrupted queries.\n if (requestId >= queryInfo.lastRequestId) {\n queryInfo.markError(error);\n }\n\n throw error;\n }\n );\n }\n\n private fetchConcastWithInfo(\n queryId: string,\n options: WatchQueryOptions,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus = NetworkStatus.loading,\n query = options.query\n ): ConcastAndInfo {\n const variables = this.getVariables(query, options.variables) as TVars;\n const queryInfo = this.getQuery(queryId);\n\n const defaults = this.defaultOptions.watchQuery;\n let {\n fetchPolicy = (defaults && defaults.fetchPolicy) || \"cache-first\",\n errorPolicy = (defaults && defaults.errorPolicy) || \"none\",\n returnPartialData = false,\n notifyOnNetworkStatusChange = false,\n context = {},\n } = options;\n\n const normalized = Object.assign({}, options, {\n query,\n variables,\n fetchPolicy,\n errorPolicy,\n returnPartialData,\n notifyOnNetworkStatusChange,\n context,\n });\n\n const fromVariables = (variables: TVars) => {\n // Since normalized is always a fresh copy of options, it's safe to\n // modify its properties here, rather than creating yet another new\n // WatchQueryOptions object.\n normalized.variables = variables;\n\n const sourcesWithInfo = this.fetchQueryByPolicy(\n queryInfo,\n normalized,\n networkStatus\n );\n\n if (\n // If we're in standby, postpone advancing options.fetchPolicy using\n // applyNextFetchPolicy.\n normalized.fetchPolicy !== \"standby\" &&\n // The \"standby\" policy currently returns [] from fetchQueryByPolicy, so\n // this is another way to detect when nothing was done/fetched.\n sourcesWithInfo.sources.length > 0 &&\n queryInfo.observableQuery\n ) {\n queryInfo.observableQuery[\"applyNextFetchPolicy\"](\n \"after-fetch\",\n options\n );\n }\n\n return sourcesWithInfo;\n };\n\n // This cancel function needs to be set before the concast is created,\n // in case concast creation synchronously cancels the request.\n const cleanupCancelFn = () => this.fetchCancelFns.delete(queryId);\n this.fetchCancelFns.set(queryId, (reason) => {\n cleanupCancelFn();\n // This delay ensures the concast variable has been initialized.\n setTimeout(() => concast.cancel(reason));\n });\n\n let concast: Concast>,\n containsDataFromLink: boolean;\n // If the query has @export(as: ...) directives, then we need to\n // process those directives asynchronously. When there are no\n // @export directives (the common case), we deliberately avoid\n // wrapping the result of this.fetchQueryByPolicy in a Promise,\n // since the timing of result delivery is (unfortunately) important\n // for backwards compatibility. TODO This code could be simpler if\n // we deprecated and removed LocalState.\n if (this.getDocumentInfo(normalized.query).hasClientExports) {\n concast = new Concast(\n this.localState\n .addExportedVariables(\n normalized.query,\n normalized.variables,\n normalized.context\n )\n .then(fromVariables)\n .then((sourcesWithInfo) => sourcesWithInfo.sources)\n );\n // there is just no way we can synchronously get the *right* value here,\n // so we will assume `true`, which is the behaviour before the bug fix in\n // #10597. This means that bug is not fixed in that case, and is probably\n // un-fixable with reasonable effort for the edge case of @export as\n // directives.\n containsDataFromLink = true;\n } else {\n const sourcesWithInfo = fromVariables(normalized.variables);\n containsDataFromLink = sourcesWithInfo.fromLink;\n concast = new Concast(sourcesWithInfo.sources);\n }\n\n concast.promise.then(cleanupCancelFn, cleanupCancelFn);\n\n return {\n concast,\n fromLink: containsDataFromLink,\n };\n }\n\n public refetchQueries({\n updateCache,\n include,\n optimistic = false,\n removeOptimistic = optimistic ? makeUniqueId(\"refetchQueries\") : void 0,\n onQueryUpdated,\n }: InternalRefetchQueriesOptions<\n ApolloCache,\n TResult\n >): InternalRefetchQueriesMap {\n const includedQueriesById = new Map<\n string,\n {\n oq: ObservableQuery;\n lastDiff?: Cache.DiffResult;\n diff?: Cache.DiffResult;\n }\n >();\n\n if (include) {\n this.getObservableQueries(include).forEach((oq, queryId) => {\n includedQueriesById.set(queryId, {\n oq,\n lastDiff: this.getQuery(queryId).getDiff(),\n });\n });\n }\n\n const results: InternalRefetchQueriesMap = new Map();\n\n if (updateCache) {\n this.cache.batch({\n update: updateCache,\n\n // Since you can perform any combination of cache reads and/or writes in\n // the cache.batch update function, its optimistic option can be either\n // a boolean or a string, representing three distinct modes of\n // operation:\n //\n // * false: read/write only the root layer\n // * true: read/write the topmost layer\n // * string: read/write a fresh optimistic layer with that ID string\n //\n // When typeof optimistic === \"string\", a new optimistic layer will be\n // temporarily created within cache.batch with that string as its ID. If\n // we then pass that same string as the removeOptimistic option, we can\n // make cache.batch immediately remove the optimistic layer after\n // running the updateCache function, triggering only one broadcast.\n //\n // However, the refetchQueries method accepts only true or false for its\n // optimistic option (not string). We interpret true to mean a temporary\n // optimistic layer should be created, to allow efficiently rolling back\n // the effect of the updateCache function, which involves passing a\n // string instead of true as the optimistic option to cache.batch, when\n // refetchQueries receives optimistic: true.\n //\n // In other words, we are deliberately not supporting the use case of\n // writing to an *existing* optimistic layer (using the refetchQueries\n // updateCache function), since that would potentially interfere with\n // other optimistic updates in progress. Instead, you can read/write\n // only the root layer by passing optimistic: false to refetchQueries,\n // or you can read/write a brand new optimistic layer that will be\n // automatically removed by passing optimistic: true.\n optimistic: (optimistic && removeOptimistic) || false,\n\n // The removeOptimistic option can also be provided by itself, even if\n // optimistic === false, to remove some previously-added optimistic\n // layer safely and efficiently, like we do in markMutationResult.\n //\n // If an explicit removeOptimistic string is provided with optimistic:\n // true, the removeOptimistic string will determine the ID of the\n // temporary optimistic layer, in case that ever matters.\n removeOptimistic,\n\n onWatchUpdated(watch, diff, lastDiff) {\n const oq =\n watch.watcher instanceof QueryInfo && watch.watcher.observableQuery;\n\n if (oq) {\n if (onQueryUpdated) {\n // Since we're about to handle this query now, remove it from\n // includedQueriesById, in case it was added earlier because of\n // options.include.\n includedQueriesById.delete(oq.queryId);\n\n let result: TResult | boolean | Promise> =\n onQueryUpdated(oq, diff, lastDiff);\n\n if (result === true) {\n // The onQueryUpdated function requested the default refetching\n // behavior by returning true.\n result = oq.refetch();\n }\n\n // Record the result in the results Map, as long as onQueryUpdated\n // did not return false to skip/ignore this result.\n if (result !== false) {\n results.set(\n oq,\n result as InternalRefetchQueriesResult\n );\n }\n\n // Allow the default cache broadcast to happen, except when\n // onQueryUpdated returns false.\n return result;\n }\n\n if (onQueryUpdated !== null) {\n // If we don't have an onQueryUpdated function, and onQueryUpdated\n // was not disabled by passing null, make sure this query is\n // \"included\" like any other options.include-specified query.\n includedQueriesById.set(oq.queryId, { oq, lastDiff, diff });\n }\n }\n },\n });\n }\n\n if (includedQueriesById.size) {\n includedQueriesById.forEach(({ oq, lastDiff, diff }, queryId) => {\n let result:\n | TResult\n | boolean\n | Promise>\n | undefined;\n\n // If onQueryUpdated is provided, we want to use it for all included\n // queries, even the QueryOptions ones.\n if (onQueryUpdated) {\n if (!diff) {\n const info = oq[\"queryInfo\"];\n info.reset(); // Force info.getDiff() to read from cache.\n diff = info.getDiff();\n }\n result = onQueryUpdated(oq, diff, lastDiff);\n }\n\n // Otherwise, we fall back to refetching.\n if (!onQueryUpdated || result === true) {\n result = oq.refetch();\n }\n\n if (result !== false) {\n results.set(oq, result as InternalRefetchQueriesResult);\n }\n\n if (queryId.indexOf(\"legacyOneTimeQuery\") >= 0) {\n this.stopQueryNoBroadcast(queryId);\n }\n });\n }\n\n if (removeOptimistic) {\n // In case no updateCache callback was provided (so cache.batch was not\n // called above, and thus did not already remove the optimistic layer),\n // remove it here. Since this is a no-op when the layer has already been\n // removed, we do it even if we called cache.batch above, since it's\n // possible this.cache is an instance of some ApolloCache subclass other\n // than InMemoryCache, and does not fully support the removeOptimistic\n // option for cache.batch.\n this.cache.removeOptimistic(removeOptimistic);\n }\n\n return results;\n }\n\n private fetchQueryByPolicy(\n queryInfo: QueryInfo,\n {\n query,\n variables,\n fetchPolicy,\n refetchWritePolicy,\n errorPolicy,\n returnPartialData,\n context,\n notifyOnNetworkStatusChange,\n }: WatchQueryOptions,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus: NetworkStatus\n ): SourcesAndInfo {\n const oldNetworkStatus = queryInfo.networkStatus;\n\n queryInfo.init({\n document: query,\n variables,\n networkStatus,\n });\n\n const readCache = () => queryInfo.getDiff();\n\n const resultsFromCache = (\n diff: Cache.DiffResult,\n networkStatus = queryInfo.networkStatus || NetworkStatus.loading\n ) => {\n const data = diff.result;\n\n if (__DEV__ && !returnPartialData && !equal(data, {})) {\n logMissingFieldErrors(diff.missing);\n }\n\n const fromData = (data: TData | undefined) =>\n Observable.of({\n data,\n loading: isNetworkRequestInFlight(networkStatus),\n networkStatus,\n ...(diff.complete ? null : { partial: true }),\n } as ApolloQueryResult);\n\n if (data && this.getDocumentInfo(query).hasForcedResolvers) {\n return this.localState\n .runResolvers({\n document: query,\n remoteResult: { data },\n context,\n variables,\n onlyRunForcedResolvers: true,\n })\n .then((resolved) => fromData(resolved.data || void 0));\n }\n\n // Resolves https://github.com/apollographql/apollo-client/issues/10317.\n // If errorPolicy is 'none' and notifyOnNetworkStatusChange is true,\n // data was incorrectly returned from the cache on refetch:\n // if diff.missing exists, we should not return cache data.\n if (\n errorPolicy === \"none\" &&\n networkStatus === NetworkStatus.refetch &&\n Array.isArray(diff.missing)\n ) {\n return fromData(void 0);\n }\n\n return fromData(data);\n };\n\n const cacheWriteBehavior =\n fetchPolicy === \"no-cache\" ? CacheWriteBehavior.FORBID\n // Watched queries must opt into overwriting existing data on refetch,\n // by passing refetchWritePolicy: \"overwrite\" in their WatchQueryOptions.\n : (\n networkStatus === NetworkStatus.refetch &&\n refetchWritePolicy !== \"merge\"\n ) ?\n CacheWriteBehavior.OVERWRITE\n : CacheWriteBehavior.MERGE;\n\n const resultsFromLink = () =>\n this.getResultsFromLink(queryInfo, cacheWriteBehavior, {\n query,\n variables,\n context,\n fetchPolicy,\n errorPolicy,\n });\n\n const shouldNotify =\n notifyOnNetworkStatusChange &&\n typeof oldNetworkStatus === \"number\" &&\n oldNetworkStatus !== networkStatus &&\n isNetworkRequestInFlight(networkStatus);\n\n switch (fetchPolicy) {\n default:\n case \"cache-first\": {\n const diff = readCache();\n\n if (diff.complete) {\n return {\n fromLink: false,\n sources: [resultsFromCache(diff, queryInfo.markReady())],\n };\n }\n\n if (returnPartialData || shouldNotify) {\n return {\n fromLink: true,\n sources: [resultsFromCache(diff), resultsFromLink()],\n };\n }\n\n return { fromLink: true, sources: [resultsFromLink()] };\n }\n\n case \"cache-and-network\": {\n const diff = readCache();\n\n if (diff.complete || returnPartialData || shouldNotify) {\n return {\n fromLink: true,\n sources: [resultsFromCache(diff), resultsFromLink()],\n };\n }\n\n return { fromLink: true, sources: [resultsFromLink()] };\n }\n\n case \"cache-only\":\n return {\n fromLink: false,\n sources: [resultsFromCache(readCache(), queryInfo.markReady())],\n };\n\n case \"network-only\":\n if (shouldNotify) {\n return {\n fromLink: true,\n sources: [resultsFromCache(readCache()), resultsFromLink()],\n };\n }\n\n return { fromLink: true, sources: [resultsFromLink()] };\n\n case \"no-cache\":\n if (shouldNotify) {\n return {\n fromLink: true,\n // Note that queryInfo.getDiff() for no-cache queries does not call\n // cache.diff, but instead returns a { complete: false } stub result\n // when there is no queryInfo.diff already defined.\n sources: [resultsFromCache(queryInfo.getDiff()), resultsFromLink()],\n };\n }\n\n return { fromLink: true, sources: [resultsFromLink()] };\n\n case \"standby\":\n return { fromLink: false, sources: [] };\n }\n }\n\n private getQuery(queryId: string): QueryInfo {\n if (queryId && !this.queries.has(queryId)) {\n this.queries.set(queryId, new QueryInfo(this, queryId));\n }\n return this.queries.get(queryId)!;\n }\n\n private prepareContext(context = {}) {\n const newContext = this.localState.prepareContext(context);\n return {\n ...this.defaultContext,\n ...newContext,\n clientAwareness: this.clientAwareness,\n };\n }\n}\n\n// Return types used by fetchQueryByPolicy and other private methods above.\ninterface FetchConcastInfo {\n // Metadata properties that can be returned in addition to the Concast.\n fromLink: boolean;\n}\ninterface SourcesAndInfo extends FetchConcastInfo {\n sources: ConcastSourcesArray>;\n}\ninterface ConcastAndInfo extends FetchConcastInfo {\n concast: Concast>;\n}\n","import type {\n QueryOptions,\n WatchQueryOptions,\n MutationOptions,\n OperationVariables,\n} from \"../../core/index.js\";\n\nimport { compact } from \"./compact.js\";\n\ntype OptionsUnion =\n | WatchQueryOptions\n | QueryOptions\n | MutationOptions;\n\nexport function mergeOptions<\n TDefaultOptions extends Partial>,\n TOptions extends TDefaultOptions,\n>(\n defaults: TDefaultOptions | Partial | undefined,\n options: TOptions | Partial\n): TOptions & TDefaultOptions {\n return compact(\n defaults,\n options,\n options.variables && {\n variables: compact({\n ...(defaults && defaults.variables),\n ...options.variables,\n }),\n }\n );\n}\n","import { invariant, newInvariantError } from \"../utilities/globals/index.js\";\n\nimport type { ExecutionResult, DocumentNode } from \"graphql\";\n\nimport type { FetchResult, GraphQLRequest } from \"../link/core/index.js\";\nimport { ApolloLink, execute } from \"../link/core/index.js\";\nimport type { ApolloCache, DataProxy, Reference } from \"../cache/index.js\";\nimport type { DocumentTransform, Observable } from \"../utilities/index.js\";\nimport { version } from \"../version.js\";\nimport type { UriFunction } from \"../link/http/index.js\";\nimport { HttpLink } from \"../link/http/index.js\";\n\nimport { QueryManager } from \"./QueryManager.js\";\nimport type { ObservableQuery } from \"./ObservableQuery.js\";\n\nimport type {\n ApolloQueryResult,\n DefaultContext,\n OperationVariables,\n Resolvers,\n RefetchQueriesOptions,\n RefetchQueriesResult,\n InternalRefetchQueriesResult,\n RefetchQueriesInclude,\n} from \"./types.js\";\n\nimport type {\n QueryOptions,\n WatchQueryOptions,\n MutationOptions,\n SubscriptionOptions,\n WatchQueryFetchPolicy,\n} from \"./watchQueryOptions.js\";\n\nimport type { FragmentMatcher } from \"./LocalState.js\";\nimport { LocalState } from \"./LocalState.js\";\n\nexport interface DefaultOptions {\n watchQuery?: Partial>;\n query?: Partial>;\n mutate?: Partial>;\n}\n\nlet hasSuggestedDevtools = false;\n\nexport interface ApolloClientOptions {\n /**\n * The URI of the GraphQL endpoint that Apollo Client will communicate with.\n *\n * One of `uri` or `link` is **required**. If you provide both, `link` takes precedence.\n */\n uri?: string | UriFunction;\n credentials?: string;\n /**\n * An object representing headers to include in every HTTP request, such as `{Authorization: 'Bearer 1234'}`\n *\n * This value will be ignored when using the `link` option.\n */\n headers?: Record;\n /**\n * You can provide an `ApolloLink` instance to serve as Apollo Client's network layer. For more information, see [Advanced HTTP networking](https://www.apollographql.com/docs/react/networking/advanced-http-networking/).\n *\n * One of `uri` or `link` is **required**. If you provide both, `link` takes precedence.\n */\n link?: ApolloLink;\n /**\n * The cache that Apollo Client should use to store query results locally. The recommended cache is `InMemoryCache`, which is provided by the `@apollo/client` package.\n *\n * For more information, see [Configuring the cache](https://www.apollographql.com/docs/react/caching/cache-configuration/).\n */\n cache: ApolloCache;\n /**\n * The time interval (in milliseconds) before Apollo Client force-fetches queries after a server-side render.\n *\n * @defaultValue `0` (no delay)\n */\n ssrForceFetchDelay?: number;\n /**\n * When using Apollo Client for [server-side rendering](https://www.apollographql.com/docs/react/performance/server-side-rendering/), set this to `true` so that the [`getDataFromTree` function](../react/ssr/#getdatafromtree) can work effectively.\n *\n * @defaultValue `false`\n */\n ssrMode?: boolean;\n /**\n * If `true`, the [Apollo Client Devtools](https://www.apollographql.com/docs/react/development-testing/developer-tooling/#apollo-client-devtools) browser extension can connect to Apollo Client.\n *\n * The default value is `false` in production and `true` in development (if there is a `window` object).\n */\n connectToDevTools?: boolean;\n /**\n * If `false`, Apollo Client sends every created query to the server, even if a _completely_ identical query (identical in terms of query string, variable values, and operationName) is already in flight.\n *\n * @defaultValue `true`\n */\n queryDeduplication?: boolean;\n /**\n * Provide this object to set application-wide default values for options you can provide to the `watchQuery`, `query`, and `mutate` functions. See below for an example object.\n *\n * See this [example object](https://www.apollographql.com/docs/react/api/core/ApolloClient#example-defaultoptions-object).\n */\n defaultOptions?: DefaultOptions;\n defaultContext?: Partial;\n /**\n * If `true`, Apollo Client will assume results read from the cache are never mutated by application code, which enables substantial performance optimizations.\n *\n * @defaultValue `false`\n */\n assumeImmutableResults?: boolean;\n resolvers?: Resolvers | Resolvers[];\n typeDefs?: string | string[] | DocumentNode | DocumentNode[];\n fragmentMatcher?: FragmentMatcher;\n /**\n * A custom name (e.g., `iOS`) that identifies this particular client among your set of clients. Apollo Server and Apollo Studio use this property as part of the [client awareness](https://www.apollographql.com/docs/apollo-server/monitoring/metrics#identifying-distinct-clients) feature.\n */\n name?: string;\n /**\n * A custom version that identifies the current version of this particular client (e.g., `1.2`). Apollo Server and Apollo Studio use this property as part of the [client awareness](https://www.apollographql.com/docs/apollo-server/monitoring/metrics#identifying-distinct-clients) feature.\n *\n * This is **not** the version of Apollo Client that you are using, but rather any version string that helps you differentiate between versions of your client.\n */\n version?: string;\n documentTransform?: DocumentTransform;\n}\n\n// Though mergeOptions now resides in @apollo/client/utilities, it was\n// previously declared and exported from this module, and then reexported from\n// @apollo/client/core. Since we need to preserve that API anyway, the easiest\n// solution is to reexport mergeOptions where it was previously declared (here).\nimport { mergeOptions } from \"../utilities/index.js\";\nimport { getApolloClientMemoryInternals } from \"../utilities/caching/getMemoryInternals.js\";\nimport type {\n WatchFragmentOptions,\n WatchFragmentResult,\n} from \"../cache/core/cache.js\";\nexport { mergeOptions };\n\n/**\n * This is the primary Apollo Client class. It is used to send GraphQL documents (i.e. queries\n * and mutations) to a GraphQL spec-compliant server over an `ApolloLink` instance,\n * receive results from the server and cache the results in a store. It also delivers updates\n * to GraphQL queries through `Observable` instances.\n */\nexport class ApolloClient implements DataProxy {\n public link: ApolloLink;\n public cache: ApolloCache;\n public disableNetworkFetches: boolean;\n public version: string;\n public queryDeduplication: boolean;\n public defaultOptions: DefaultOptions;\n public readonly typeDefs: ApolloClientOptions[\"typeDefs\"];\n\n private queryManager: QueryManager;\n private devToolsHookCb?: Function;\n private resetStoreCallbacks: Array<() => Promise> = [];\n private clearStoreCallbacks: Array<() => Promise> = [];\n private localState: LocalState;\n\n /**\n * Constructs an instance of `ApolloClient`.\n *\n * @example\n * ```js\n * import { ApolloClient, InMemoryCache } from '@apollo/client';\n *\n * const cache = new InMemoryCache();\n *\n * const client = new ApolloClient({\n * // Provide required constructor fields\n * cache: cache,\n * uri: 'http://localhost:4000/',\n *\n * // Provide some optional constructor fields\n * name: 'react-web-client',\n * version: '1.3',\n * queryDeduplication: false,\n * defaultOptions: {\n * watchQuery: {\n * fetchPolicy: 'cache-and-network',\n * },\n * },\n * });\n * ```\n */\n constructor(options: ApolloClientOptions) {\n if (!options.cache) {\n throw newInvariantError(\n \"To initialize Apollo Client, you must specify a 'cache' property \" +\n \"in the options object. \\n\" +\n \"For more information, please visit: https://go.apollo.dev/c/docs\"\n );\n }\n\n const {\n uri,\n credentials,\n headers,\n cache,\n documentTransform,\n ssrMode = false,\n ssrForceFetchDelay = 0,\n // Expose the client instance as window.__APOLLO_CLIENT__ and call\n // onBroadcast in queryManager.broadcastQueries to enable browser\n // devtools, but disable them by default in production.\n connectToDevTools = typeof window === \"object\" &&\n !(window as any).__APOLLO_CLIENT__ &&\n __DEV__,\n queryDeduplication = true,\n defaultOptions,\n defaultContext,\n assumeImmutableResults = cache.assumeImmutableResults,\n resolvers,\n typeDefs,\n fragmentMatcher,\n name: clientAwarenessName,\n version: clientAwarenessVersion,\n } = options;\n\n let { link } = options;\n\n if (!link) {\n link =\n uri ? new HttpLink({ uri, credentials, headers }) : ApolloLink.empty();\n }\n\n this.link = link;\n this.cache = cache;\n this.disableNetworkFetches = ssrMode || ssrForceFetchDelay > 0;\n this.queryDeduplication = queryDeduplication;\n this.defaultOptions = defaultOptions || Object.create(null);\n this.typeDefs = typeDefs;\n\n if (ssrForceFetchDelay) {\n setTimeout(\n () => (this.disableNetworkFetches = false),\n ssrForceFetchDelay\n );\n }\n\n this.watchQuery = this.watchQuery.bind(this);\n this.query = this.query.bind(this);\n this.mutate = this.mutate.bind(this);\n this.watchFragment = this.watchFragment.bind(this);\n this.resetStore = this.resetStore.bind(this);\n this.reFetchObservableQueries = this.reFetchObservableQueries.bind(this);\n\n this.version = version;\n\n this.localState = new LocalState({\n cache,\n client: this,\n resolvers,\n fragmentMatcher,\n });\n\n this.queryManager = new QueryManager({\n cache: this.cache,\n link: this.link,\n defaultOptions: this.defaultOptions,\n defaultContext,\n documentTransform,\n queryDeduplication,\n ssrMode,\n clientAwareness: {\n name: clientAwarenessName!,\n version: clientAwarenessVersion!,\n },\n localState: this.localState,\n assumeImmutableResults,\n onBroadcast:\n connectToDevTools ?\n () => {\n if (this.devToolsHookCb) {\n this.devToolsHookCb({\n action: {},\n state: {\n queries: this.queryManager.getQueryStore(),\n mutations: this.queryManager.mutationStore || {},\n },\n dataWithOptimisticResults: this.cache.extract(true),\n });\n }\n }\n : void 0,\n });\n\n if (connectToDevTools) this.connectToDevTools();\n }\n\n private connectToDevTools() {\n if (typeof window === \"object\") {\n type DevToolsConnector = {\n push(client: ApolloClient): void;\n };\n const windowWithDevTools = window as Window & {\n [devtoolsSymbol]?: DevToolsConnector;\n __APOLLO_CLIENT__?: ApolloClient;\n };\n const devtoolsSymbol = Symbol.for(\"apollo.devtools\");\n (windowWithDevTools[devtoolsSymbol] =\n windowWithDevTools[devtoolsSymbol] || ([] as DevToolsConnector)).push(\n this\n );\n windowWithDevTools.__APOLLO_CLIENT__ = this;\n }\n\n /**\n * Suggest installing the devtools for developers who don't have them\n */\n if (!hasSuggestedDevtools && __DEV__) {\n hasSuggestedDevtools = true;\n setTimeout(() => {\n if (\n typeof window !== \"undefined\" &&\n window.document &&\n window.top === window.self &&\n !(window as any).__APOLLO_DEVTOOLS_GLOBAL_HOOK__ &&\n /^(https?|file):$/.test(window.location.protocol)\n ) {\n const nav = window.navigator;\n const ua = nav && nav.userAgent;\n let url: string | undefined;\n if (typeof ua === \"string\") {\n if (ua.indexOf(\"Chrome/\") > -1) {\n url =\n \"https://chrome.google.com/webstore/detail/\" +\n \"apollo-client-developer-t/jdkknkkbebbapilgoeccciglkfbmbnfm\";\n } else if (ua.indexOf(\"Firefox/\") > -1) {\n url =\n \"https://addons.mozilla.org/en-US/firefox/addon/apollo-developer-tools/\";\n }\n }\n if (url) {\n invariant.log(\n \"Download the Apollo DevTools for a better development \" +\n \"experience: %s\",\n url\n );\n }\n }\n }, 10000);\n }\n }\n\n /**\n * The `DocumentTransform` used to modify GraphQL documents before a request\n * is made. If a custom `DocumentTransform` is not provided, this will be the\n * default document transform.\n */\n get documentTransform() {\n return this.queryManager.documentTransform;\n }\n\n /**\n * Call this method to terminate any active client processes, making it safe\n * to dispose of this `ApolloClient` instance.\n */\n public stop() {\n this.queryManager.stop();\n }\n\n /**\n * This watches the cache store of the query according to the options specified and\n * returns an `ObservableQuery`. We can subscribe to this `ObservableQuery` and\n * receive updated results through an observer when the cache store changes.\n *\n * Note that this method is not an implementation of GraphQL subscriptions. Rather,\n * it uses Apollo's store in order to reactively deliver updates to your query results.\n *\n * For example, suppose you call watchQuery on a GraphQL query that fetches a person's\n * first and last name and this person has a particular object identifier, provided by\n * dataIdFromObject. Later, a different query fetches that same person's\n * first and last name and the first name has now changed. Then, any observers associated\n * with the results of the first query will be updated with a new result object.\n *\n * Note that if the cache does not change, the subscriber will *not* be notified.\n *\n * See [here](https://medium.com/apollo-stack/the-concepts-of-graphql-bc68bd819be3#.3mb0cbcmc) for\n * a description of store reactivity.\n */\n public watchQuery<\n T = any,\n TVariables extends OperationVariables = OperationVariables,\n >(options: WatchQueryOptions): ObservableQuery {\n if (this.defaultOptions.watchQuery) {\n options = mergeOptions(this.defaultOptions.watchQuery, options);\n }\n\n // XXX Overwriting options is probably not the best way to do this long term...\n if (\n this.disableNetworkFetches &&\n (options.fetchPolicy === \"network-only\" ||\n options.fetchPolicy === \"cache-and-network\")\n ) {\n options = { ...options, fetchPolicy: \"cache-first\" };\n }\n\n return this.queryManager.watchQuery(options);\n }\n\n /**\n * This resolves a single query according to the options specified and\n * returns a `Promise` which is either resolved with the resulting data\n * or rejected with an error.\n *\n * @param options - An object of type `QueryOptions` that allows us to\n * describe how this query should be treated e.g. whether it should hit the\n * server at all or just resolve from the cache, etc.\n */\n public query<\n T = any,\n TVariables extends OperationVariables = OperationVariables,\n >(options: QueryOptions): Promise> {\n if (this.defaultOptions.query) {\n options = mergeOptions(this.defaultOptions.query, options);\n }\n\n invariant(\n (options.fetchPolicy as WatchQueryFetchPolicy) !== \"cache-and-network\",\n \"The cache-and-network fetchPolicy does not work with client.query, because \" +\n \"client.query can only return a single result. Please use client.watchQuery \" +\n \"to receive multiple results from the cache and the network, or consider \" +\n \"using a different fetchPolicy, such as cache-first or network-only.\"\n );\n\n if (this.disableNetworkFetches && options.fetchPolicy === \"network-only\") {\n options = { ...options, fetchPolicy: \"cache-first\" };\n }\n\n return this.queryManager.query(options);\n }\n\n /**\n * This resolves a single mutation according to the options specified and returns a\n * Promise which is either resolved with the resulting data or rejected with an\n * error. In some cases both `data` and `errors` might be undefined, for example\n * when `errorPolicy` is set to `'ignore'`.\n *\n * It takes options as an object with the following keys and values:\n */\n public mutate<\n TData = any,\n TVariables extends OperationVariables = OperationVariables,\n TContext extends Record = DefaultContext,\n TCache extends ApolloCache = ApolloCache,\n >(\n options: MutationOptions\n ): Promise> {\n if (this.defaultOptions.mutate) {\n options = mergeOptions(this.defaultOptions.mutate, options);\n }\n return this.queryManager.mutate(\n options\n );\n }\n\n /**\n * This subscribes to a graphql subscription according to the options specified and returns an\n * `Observable` which either emits received data or an error.\n */\n public subscribe<\n T = any,\n TVariables extends OperationVariables = OperationVariables,\n >(options: SubscriptionOptions): Observable> {\n return this.queryManager.startGraphQLSubscription(options);\n }\n\n /**\n * Tries to read some data from the store in the shape of the provided\n * GraphQL query without making a network request. This method will start at\n * the root query. To start at a specific id returned by `dataIdFromObject`\n * use `readFragment`.\n *\n * @param optimistic - Set to `true` to allow `readQuery` to return\n * optimistic results. Is `false` by default.\n */\n public readQuery(\n options: DataProxy.Query,\n optimistic: boolean = false\n ): T | null {\n return this.cache.readQuery(options, optimistic);\n }\n\n /**\n * Watches the cache store of the fragment according to the options specified\n * and returns an `Observable`. We can subscribe to this\n * `Observable` and receive updated results through an\n * observer when the cache store changes.\n *\n * You must pass in a GraphQL document with a single fragment or a document\n * with multiple fragments that represent what you are reading. If you pass\n * in a document with multiple fragments then you must also specify a\n * `fragmentName`.\n *\n * @since 3.10.0\n * @param options - An object of type `WatchFragmentOptions` that allows\n * the cache to identify the fragment and optionally specify whether to react\n * to optimistic updates.\n */\n\n public watchFragment<\n TFragmentData = unknown,\n TVariables = OperationVariables,\n >(\n options: WatchFragmentOptions\n ): Observable> {\n return this.cache.watchFragment(options);\n }\n\n /**\n * Tries to read some data from the store in the shape of the provided\n * GraphQL fragment without making a network request. This method will read a\n * GraphQL fragment from any arbitrary id that is currently cached, unlike\n * `readQuery` which will only read from the root query.\n *\n * You must pass in a GraphQL document with a single fragment or a document\n * with multiple fragments that represent what you are reading. If you pass\n * in a document with multiple fragments then you must also specify a\n * `fragmentName`.\n *\n * @param optimistic - Set to `true` to allow `readFragment` to return\n * optimistic results. Is `false` by default.\n */\n public readFragment(\n options: DataProxy.Fragment,\n optimistic: boolean = false\n ): T | null {\n return this.cache.readFragment(options, optimistic);\n }\n\n /**\n * Writes some data in the shape of the provided GraphQL query directly to\n * the store. This method will start at the root query. To start at a\n * specific id returned by `dataIdFromObject` then use `writeFragment`.\n */\n public writeQuery(\n options: DataProxy.WriteQueryOptions\n ): Reference | undefined {\n const ref = this.cache.writeQuery(options);\n\n if (options.broadcast !== false) {\n this.queryManager.broadcastQueries();\n }\n\n return ref;\n }\n\n /**\n * Writes some data in the shape of the provided GraphQL fragment directly to\n * the store. This method will write to a GraphQL fragment from any arbitrary\n * id that is currently cached, unlike `writeQuery` which will only write\n * from the root query.\n *\n * You must pass in a GraphQL document with a single fragment or a document\n * with multiple fragments that represent what you are writing. If you pass\n * in a document with multiple fragments then you must also specify a\n * `fragmentName`.\n */\n public writeFragment(\n options: DataProxy.WriteFragmentOptions\n ): Reference | undefined {\n const ref = this.cache.writeFragment(options);\n\n if (options.broadcast !== false) {\n this.queryManager.broadcastQueries();\n }\n\n return ref;\n }\n\n public __actionHookForDevTools(cb: () => any) {\n this.devToolsHookCb = cb;\n }\n\n public __requestRaw(payload: GraphQLRequest): Observable {\n return execute(this.link, payload);\n }\n\n /**\n * Resets your entire store by clearing out your cache and then re-executing\n * all of your active queries. This makes it so that you may guarantee that\n * there is no data left in your store from a time before you called this\n * method.\n *\n * `resetStore()` is useful when your user just logged out. You’ve removed the\n * user session, and you now want to make sure that any references to data you\n * might have fetched while the user session was active is gone.\n *\n * It is important to remember that `resetStore()` *will* refetch any active\n * queries. This means that any components that might be mounted will execute\n * their queries again using your network interface. If you do not want to\n * re-execute any queries then you should make sure to stop watching any\n * active queries.\n */\n public resetStore(): Promise[] | null> {\n return Promise.resolve()\n .then(() =>\n this.queryManager.clearStore({\n discardWatches: false,\n })\n )\n .then(() => Promise.all(this.resetStoreCallbacks.map((fn) => fn())))\n .then(() => this.reFetchObservableQueries());\n }\n\n /**\n * Remove all data from the store. Unlike `resetStore`, `clearStore` will\n * not refetch any active queries.\n */\n public clearStore(): Promise {\n return Promise.resolve()\n .then(() =>\n this.queryManager.clearStore({\n discardWatches: true,\n })\n )\n .then(() => Promise.all(this.clearStoreCallbacks.map((fn) => fn())));\n }\n\n /**\n * Allows callbacks to be registered that are executed when the store is\n * reset. `onResetStore` returns an unsubscribe function that can be used\n * to remove registered callbacks.\n */\n public onResetStore(cb: () => Promise): () => void {\n this.resetStoreCallbacks.push(cb);\n return () => {\n this.resetStoreCallbacks = this.resetStoreCallbacks.filter(\n (c) => c !== cb\n );\n };\n }\n\n /**\n * Allows callbacks to be registered that are executed when the store is\n * cleared. `onClearStore` returns an unsubscribe function that can be used\n * to remove registered callbacks.\n */\n public onClearStore(cb: () => Promise): () => void {\n this.clearStoreCallbacks.push(cb);\n return () => {\n this.clearStoreCallbacks = this.clearStoreCallbacks.filter(\n (c) => c !== cb\n );\n };\n }\n\n /**\n * Refetches all of your active queries.\n *\n * `reFetchObservableQueries()` is useful if you want to bring the client back to proper state in case of a network outage\n *\n * It is important to remember that `reFetchObservableQueries()` *will* refetch any active\n * queries. This means that any components that might be mounted will execute\n * their queries again using your network interface. If you do not want to\n * re-execute any queries then you should make sure to stop watching any\n * active queries.\n * Takes optional parameter `includeStandby` which will include queries in standby-mode when refetching.\n */\n public reFetchObservableQueries(\n includeStandby?: boolean\n ): Promise[]> {\n return this.queryManager.reFetchObservableQueries(includeStandby);\n }\n\n /**\n * Refetches specified active queries. Similar to \"reFetchObservableQueries()\" but with a specific list of queries.\n *\n * `refetchQueries()` is useful for use cases to imperatively refresh a selection of queries.\n *\n * It is important to remember that `refetchQueries()` *will* refetch specified active\n * queries. This means that any components that might be mounted will execute\n * their queries again using your network interface. If you do not want to\n * re-execute any queries then you should make sure to stop watching any\n * active queries.\n */\n public refetchQueries<\n TCache extends ApolloCache = ApolloCache,\n TResult = Promise>,\n >(\n options: RefetchQueriesOptions\n ): RefetchQueriesResult {\n const map = this.queryManager.refetchQueries(\n options as RefetchQueriesOptions, TResult>\n );\n const queries: ObservableQuery[] = [];\n const results: InternalRefetchQueriesResult[] = [];\n\n map.forEach((result, obsQuery) => {\n queries.push(obsQuery);\n results.push(result);\n });\n\n const result = Promise.all(\n results as TResult[]\n ) as RefetchQueriesResult;\n\n // In case you need the raw results immediately, without awaiting\n // Promise.all(results):\n result.queries = queries;\n result.results = results;\n\n // If you decide to ignore the result Promise because you're using\n // result.queries and result.results instead, you shouldn't have to worry\n // about preventing uncaught rejections for the Promise.all result.\n result.catch((error) => {\n invariant.debug(\n `In client.refetchQueries, Promise.all promise rejected with error %o`,\n error\n );\n });\n\n return result;\n }\n\n /**\n * Get all currently active `ObservableQuery` objects, in a `Map` keyed by\n * query ID strings.\n *\n * An \"active\" query is one that has observers and a `fetchPolicy` other than\n * \"standby\" or \"cache-only\".\n *\n * You can include all `ObservableQuery` objects (including the inactive ones)\n * by passing \"all\" instead of \"active\", or you can include just a subset of\n * active queries by passing an array of query names or DocumentNode objects.\n */\n public getObservableQueries(\n include: RefetchQueriesInclude = \"active\"\n ): Map> {\n return this.queryManager.getObservableQueries(include);\n }\n\n /**\n * Exposes the cache's complete state, in a serializable format for later restoration.\n */\n public extract(optimistic?: boolean): TCacheShape {\n return this.cache.extract(optimistic);\n }\n\n /**\n * Replaces existing state in the cache (if any) with the values expressed by\n * `serializedState`.\n *\n * Called when hydrating a cache (server side rendering, or offline storage),\n * and also (potentially) during hot reloads.\n */\n public restore(serializedState: TCacheShape): ApolloCache {\n return this.cache.restore(serializedState);\n }\n\n /**\n * Add additional local resolvers.\n */\n public addResolvers(resolvers: Resolvers | Resolvers[]) {\n this.localState.addResolvers(resolvers);\n }\n\n /**\n * Set (override existing) local resolvers.\n */\n public setResolvers(resolvers: Resolvers | Resolvers[]) {\n this.localState.setResolvers(resolvers);\n }\n\n /**\n * Get all registered local resolvers.\n */\n public getResolvers() {\n return this.localState.getResolvers();\n }\n\n /**\n * Set a custom local state fragment matcher.\n */\n public setLocalStateFragmentMatcher(fragmentMatcher: FragmentMatcher) {\n this.localState.setFragmentMatcher(fragmentMatcher);\n }\n\n /**\n * Define a new ApolloLink (or link chain) that Apollo Client will use.\n */\n public setLink(newLink: ApolloLink) {\n this.link = this.queryManager.link = newLink;\n }\n\n public get defaultContext() {\n return this.queryManager.defaultContext;\n }\n\n /**\n * @experimental\n * This is not a stable API - it is used in development builds to expose\n * information to the DevTools.\n * Use at your own risk!\n * For more details, see [Memory Management](https://www.apollographql.com/docs/react/caching/memory-management/#measuring-cache-usage)\n *\n * @example\n * ```ts\n * console.log(client.getMemoryInternals())\n * ```\n * Logs output in the following JSON format:\n * @example\n * ```json\n *{\n * limits: {\n * parser: 1000,\n * canonicalStringify: 1000,\n * print: 2000,\n * 'documentTransform.cache': 2000,\n * 'queryManager.getDocumentInfo': 2000,\n * 'PersistedQueryLink.persistedQueryHashes': 2000,\n * 'fragmentRegistry.transform': 2000,\n * 'fragmentRegistry.lookup': 1000,\n * 'fragmentRegistry.findFragmentSpreads': 4000,\n * 'cache.fragmentQueryDocuments': 1000,\n * 'removeTypenameFromVariables.getVariableDefinitions': 2000,\n * 'inMemoryCache.maybeBroadcastWatch': 5000,\n * 'inMemoryCache.executeSelectionSet': 10000,\n * 'inMemoryCache.executeSubSelectedArray': 5000\n * },\n * sizes: {\n * parser: 26,\n * canonicalStringify: 4,\n * print: 14,\n * addTypenameDocumentTransform: [\n * {\n * cache: 14,\n * },\n * ],\n * queryManager: {\n * getDocumentInfo: 14,\n * documentTransforms: [\n * {\n * cache: 14,\n * },\n * {\n * cache: 14,\n * },\n * ],\n * },\n * fragmentRegistry: {\n * findFragmentSpreads: 34,\n * lookup: 20,\n * transform: 14,\n * },\n * cache: {\n * fragmentQueryDocuments: 22,\n * },\n * inMemoryCache: {\n * executeSelectionSet: 4345,\n * executeSubSelectedArray: 1206,\n * maybeBroadcastWatch: 32,\n * },\n * links: [\n * {\n * PersistedQueryLink: {\n * persistedQueryHashes: 14,\n * },\n * },\n * {\n * removeTypenameFromVariables: {\n * getVariableDefinitions: 14,\n * },\n * },\n * ],\n * },\n * }\n *```\n */\n public getMemoryInternals?: typeof getApolloClientMemoryInternals;\n}\n\nif (__DEV__) {\n ApolloClient.prototype.getMemoryInternals = getApolloClientMemoryInternals;\n}\n","import type { DocumentNode } from \"graphql\";\nimport { wrap } from \"optimism\";\n\nimport type {\n StoreObject,\n Reference,\n DeepPartial,\n} from \"../../utilities/index.js\";\nimport {\n Observable,\n cacheSizes,\n defaultCacheSizes,\n getFragmentQueryDocument,\n mergeDeepArray,\n} from \"../../utilities/index.js\";\nimport type { DataProxy } from \"./types/DataProxy.js\";\nimport type { Cache } from \"./types/Cache.js\";\nimport { WeakCache } from \"@wry/caches\";\nimport { getApolloCacheMemoryInternals } from \"../../utilities/caching/getMemoryInternals.js\";\nimport type {\n OperationVariables,\n TypedDocumentNode,\n} from \"../../core/types.js\";\nimport type { MissingTree } from \"./types/common.js\";\nimport { equalByQuery } from \"../../core/equalByQuery.js\";\n\nexport type Transaction = (c: ApolloCache) => void;\n\n/**\n * Watched fragment options.\n */\nexport interface WatchFragmentOptions {\n /**\n * A GraphQL fragment document parsed into an AST with the `gql`\n * template literal.\n *\n * @docGroup 1. Required options\n */\n fragment: DocumentNode | TypedDocumentNode;\n /**\n * An object containing a `__typename` and primary key fields\n * (such as `id`) identifying the entity object from which the fragment will\n * be retrieved, or a `{ __ref: \"...\" }` reference, or a `string` ID\n * (uncommon).\n *\n * @docGroup 1. Required options\n */\n from: StoreObject | Reference | string;\n /**\n * Any variables that the GraphQL fragment may depend on.\n *\n * @docGroup 2. Cache options\n */\n variables?: TVars;\n /**\n * The name of the fragment defined in the fragment document.\n *\n * Required if the fragment document includes more than one fragment,\n * optional otherwise.\n *\n * @docGroup 2. Cache options\n */\n fragmentName?: string;\n /**\n * If `true`, `watchFragment` returns optimistic results.\n *\n * The default value is `true`.\n *\n * @docGroup 2. Cache options\n */\n optimistic?: boolean;\n /**\n * @deprecated\n * Using `canonizeResults` can result in memory leaks so we generally do not\n * recommend using this option anymore.\n * A future version of Apollo Client will contain a similar feature.\n *\n * Whether to canonize cache results before returning them. Canonization\n * takes some extra time, but it speeds up future deep equality comparisons.\n * Defaults to false.\n */\n canonizeResults?: boolean;\n}\n\n/**\n * Watched fragment results.\n */\nexport type WatchFragmentResult =\n | {\n data: TData;\n complete: true;\n missing?: never;\n }\n | {\n data: DeepPartial;\n complete: false;\n missing: MissingTree;\n };\n\nexport abstract class ApolloCache implements DataProxy {\n public readonly assumeImmutableResults: boolean = false;\n\n // required to implement\n // core API\n public abstract read(\n query: Cache.ReadOptions\n ): TData | null;\n public abstract write(\n write: Cache.WriteOptions\n ): Reference | undefined;\n public abstract diff(query: Cache.DiffOptions): Cache.DiffResult;\n public abstract watch(\n watch: Cache.WatchOptions\n ): () => void;\n\n // Empty the cache and restart all current watches (unless\n // options.discardWatches is true).\n public abstract reset(options?: Cache.ResetOptions): Promise;\n\n // Remove whole objects from the cache by passing just options.id, or\n // specific fields by passing options.field and/or options.args. If no\n // options.args are provided, all fields matching options.field (even\n // those with arguments) will be removed. Returns true iff any data was\n // removed from the cache.\n public abstract evict(options: Cache.EvictOptions): boolean;\n\n // initializer / offline / ssr API\n /**\n * Replaces existing state in the cache (if any) with the values expressed by\n * `serializedState`.\n *\n * Called when hydrating a cache (server side rendering, or offline storage),\n * and also (potentially) during hot reloads.\n */\n public abstract restore(\n serializedState: TSerialized\n ): ApolloCache;\n\n /**\n * Exposes the cache's complete state, in a serializable format for later restoration.\n */\n public abstract extract(optimistic?: boolean): TSerialized;\n\n // Optimistic API\n\n public abstract removeOptimistic(id: string): void;\n\n // Transactional API\n\n // The batch method is intended to replace/subsume both performTransaction\n // and recordOptimisticTransaction, but performTransaction came first, so we\n // provide a default batch implementation that's just another way of calling\n // performTransaction. Subclasses of ApolloCache (such as InMemoryCache) can\n // override the batch method to do more interesting things with its options.\n public batch(options: Cache.BatchOptions): U {\n const optimisticId =\n typeof options.optimistic === \"string\" ? options.optimistic\n : options.optimistic === false ? null\n : void 0;\n let updateResult: U;\n this.performTransaction(\n () => (updateResult = options.update(this)),\n optimisticId\n );\n return updateResult!;\n }\n\n public abstract performTransaction(\n transaction: Transaction,\n // Although subclasses may implement recordOptimisticTransaction\n // however they choose, the default implementation simply calls\n // performTransaction with a string as the second argument, allowing\n // performTransaction to handle both optimistic and non-optimistic\n // (broadcast-batching) transactions. Passing null for optimisticId is\n // also allowed, and indicates that performTransaction should apply\n // the transaction non-optimistically (ignoring optimistic data).\n optimisticId?: string | null\n ): void;\n\n public recordOptimisticTransaction(\n transaction: Transaction,\n optimisticId: string\n ) {\n this.performTransaction(transaction, optimisticId);\n }\n\n // Optional API\n\n // Called once per input document, allowing the cache to make static changes\n // to the query, such as adding __typename fields.\n public transformDocument(document: DocumentNode): DocumentNode {\n return document;\n }\n\n // Called before each ApolloLink request, allowing the cache to make dynamic\n // changes to the query, such as filling in missing fragment definitions.\n public transformForLink(document: DocumentNode): DocumentNode {\n return document;\n }\n\n public identify(object: StoreObject | Reference): string | undefined {\n return;\n }\n\n public gc(): string[] {\n return [];\n }\n\n public modify = Record>(\n options: Cache.ModifyOptions\n ): boolean {\n return false;\n }\n\n // DataProxy API\n public readQuery(\n options: Cache.ReadQueryOptions,\n optimistic = !!options.optimistic\n ): QueryType | null {\n return this.read({\n ...options,\n rootId: options.id || \"ROOT_QUERY\",\n optimistic,\n });\n }\n\n /** {@inheritDoc @apollo/client!ApolloClient#watchFragment:member(1)} */\n public watchFragment(\n options: WatchFragmentOptions\n ): Observable> {\n const { fragment, fragmentName, from, optimistic = true } = options;\n const query = this.getFragmentDoc(fragment, fragmentName);\n\n const diffOptions: Cache.DiffOptions = {\n returnPartialData: true,\n id: typeof from === \"string\" ? from : this.identify(from),\n query,\n optimistic,\n };\n\n let latestDiff: DataProxy.DiffResult | undefined;\n\n return new Observable((observer) => {\n return this.watch({\n ...diffOptions,\n immediate: true,\n callback(diff) {\n if (\n // Always ensure we deliver the first result\n latestDiff &&\n equalByQuery(\n query,\n { data: latestDiff?.result },\n { data: diff.result }\n )\n ) {\n return;\n }\n\n const result = {\n data: diff.result as DeepPartial,\n complete: !!diff.complete,\n } as WatchFragmentResult;\n\n if (diff.missing) {\n result.missing = mergeDeepArray(\n diff.missing.map((error) => error.missing)\n );\n }\n\n latestDiff = diff;\n observer.next(result);\n },\n });\n });\n }\n\n // Make sure we compute the same (===) fragment query document every\n // time we receive the same fragment in readFragment.\n private getFragmentDoc = wrap(getFragmentQueryDocument, {\n max:\n cacheSizes[\"cache.fragmentQueryDocuments\"] ||\n defaultCacheSizes[\"cache.fragmentQueryDocuments\"],\n cache: WeakCache,\n });\n\n public readFragment(\n options: Cache.ReadFragmentOptions,\n optimistic = !!options.optimistic\n ): FragmentType | null {\n return this.read({\n ...options,\n query: this.getFragmentDoc(options.fragment, options.fragmentName),\n rootId: options.id,\n optimistic,\n });\n }\n\n public writeQuery({\n id,\n data,\n ...options\n }: Cache.WriteQueryOptions): Reference | undefined {\n return this.write(\n Object.assign(options, {\n dataId: id || \"ROOT_QUERY\",\n result: data,\n })\n );\n }\n\n public writeFragment({\n id,\n data,\n fragment,\n fragmentName,\n ...options\n }: Cache.WriteFragmentOptions): Reference | undefined {\n return this.write(\n Object.assign(options, {\n query: this.getFragmentDoc(fragment, fragmentName),\n dataId: id,\n result: data,\n })\n );\n }\n\n public updateQuery(\n options: Cache.UpdateQueryOptions,\n update: (data: TData | null) => TData | null | void\n ): TData | null {\n return this.batch({\n update(cache) {\n const value = cache.readQuery(options);\n const data = update(value);\n if (data === void 0 || data === null) return value;\n cache.writeQuery({ ...options, data });\n return data;\n },\n });\n }\n\n public updateFragment(\n options: Cache.UpdateFragmentOptions,\n update: (data: TData | null) => TData | null | void\n ): TData | null {\n return this.batch({\n update(cache) {\n const value = cache.readFragment(options);\n const data = update(value);\n if (data === void 0 || data === null) return value;\n cache.writeFragment({ ...options, data });\n return data;\n },\n });\n }\n\n /**\n * @experimental\n * @internal\n * This is not a stable API - it is used in development builds to expose\n * information to the DevTools.\n * Use at your own risk!\n */\n public getMemoryInternals?: typeof getApolloCacheMemoryInternals;\n}\n\nif (__DEV__) {\n ApolloCache.prototype.getMemoryInternals = getApolloCacheMemoryInternals;\n}\n","import type { DocumentNode, FieldNode } from \"graphql\";\n\nimport type {\n Reference,\n StoreObject,\n StoreValue,\n isReference,\n AsStoreObject,\n} from \"../../../utilities/index.js\";\n\nimport type { StorageType } from \"../../inmemory/policies.js\";\n\n// The Readonly type only really works for object types, since it marks\n// all of the object's properties as readonly, but there are many cases when\n// a generic type parameter like TExisting might be a string or some other\n// primitive type, in which case we need to avoid wrapping it with Readonly.\n// SafeReadonly collapses to just string, which makes string\n// assignable to SafeReadonly, whereas string is not assignable to\n// Readonly, somewhat surprisingly.\nexport type SafeReadonly = T extends object ? Readonly : T;\n\nexport type MissingTree =\n | string\n | {\n readonly [key: string]: MissingTree;\n };\n\nexport class MissingFieldError extends Error {\n constructor(\n public readonly message: string,\n public readonly path: MissingTree | Array,\n public readonly query: DocumentNode,\n public readonly variables?: Record\n ) {\n // 'Error' breaks prototype chain here\n super(message);\n\n if (Array.isArray(this.path)) {\n this.missing = this.message;\n for (let i = this.path.length - 1; i >= 0; --i) {\n this.missing = { [this.path[i]]: this.missing };\n }\n } else {\n this.missing = this.path;\n }\n\n // We're not using `Object.setPrototypeOf` here as it isn't fully supported\n // on Android (see issue #3236).\n (this as any).__proto__ = MissingFieldError.prototype;\n }\n\n public readonly missing: MissingTree;\n}\n\nexport interface FieldSpecifier {\n typename?: string;\n fieldName: string;\n field?: FieldNode;\n args?: Record;\n variables?: Record;\n}\n\nexport interface ReadFieldOptions extends FieldSpecifier {\n from?: StoreObject | Reference;\n}\n\nexport interface ReadFieldFunction {\n (options: ReadFieldOptions): SafeReadonly | undefined;\n (\n fieldName: string,\n from?: StoreObject | Reference\n ): SafeReadonly | undefined;\n}\n\nexport type ToReferenceFunction = (\n objOrIdOrRef: StoreObject | string | Reference,\n mergeIntoStore?: boolean\n) => Reference | undefined;\n\nexport type CanReadFunction = (value: StoreValue) => boolean;\n\ndeclare const _deleteModifier: unique symbol;\nexport interface DeleteModifier {\n [_deleteModifier]: true;\n}\ndeclare const _invalidateModifier: unique symbol;\nexport interface InvalidateModifier {\n [_invalidateModifier]: true;\n}\ndeclare const _ignoreModifier: unique symbol;\nexport interface IgnoreModifier {\n [_ignoreModifier]: true;\n}\n\nexport type ModifierDetails = {\n DELETE: DeleteModifier;\n INVALIDATE: InvalidateModifier;\n fieldName: string;\n storeFieldName: string;\n readField: ReadFieldFunction;\n canRead: CanReadFunction;\n isReference: typeof isReference;\n toReference: ToReferenceFunction;\n storage: StorageType;\n};\n\nexport type Modifier = (\n value: T,\n details: ModifierDetails\n) => T | DeleteModifier | InvalidateModifier;\n\ntype StoreObjectValueMaybeReference =\n StoreVal extends Array> ?\n StoreVal extends Array ?\n Item extends Record ?\n ReadonlyArray | Reference>\n : never\n : never\n : StoreVal extends Record ? AsStoreObject | Reference\n : StoreVal;\n\nexport type AllFieldsModifier> = Modifier<\n Entity[keyof Entity] extends infer Value ?\n StoreObjectValueMaybeReference>\n : never\n>;\n\nexport type Modifiers = Record> =\n Partial<{\n [FieldName in keyof T]: Modifier<\n StoreObjectValueMaybeReference>\n >;\n }>;\n","import { isNonNullObject } from \"./objects.js\";\n\nfunction deepFreeze(value: any) {\n const workSet = new Set([value]);\n workSet.forEach((obj) => {\n if (isNonNullObject(obj) && shallowFreeze(obj) === obj) {\n Object.getOwnPropertyNames(obj).forEach((name) => {\n if (isNonNullObject(obj[name])) workSet.add(obj[name]);\n });\n }\n });\n return value;\n}\n\nfunction shallowFreeze(obj: T): T | null {\n if (__DEV__ && !Object.isFrozen(obj)) {\n try {\n Object.freeze(obj);\n } catch (e) {\n // Some types like Uint8Array and Node.js's Buffer cannot be frozen, but\n // they all throw a TypeError when you try, so we re-throw any exceptions\n // that are not TypeErrors, since that would be unexpected.\n if (e instanceof TypeError) return null;\n throw e;\n }\n }\n return obj;\n}\n\nexport function maybeDeepFreeze(obj: T): T {\n if (__DEV__) {\n deepFreeze(obj);\n }\n return obj;\n}\n","import type {\n DocumentNode,\n FragmentDefinitionNode,\n SelectionSetNode,\n} from \"graphql\";\n\nimport type { NormalizedCache, InMemoryCacheConfig } from \"./types.js\";\n\nimport type { KeyFieldsContext } from \"./policies.js\";\nimport type { FragmentRegistryAPI } from \"./fragmentRegistry.js\";\n\nimport type {\n Reference,\n StoreValue,\n StoreObject,\n FragmentMap,\n FragmentMapFunction,\n} from \"../../utilities/index.js\";\nimport {\n isReference,\n isField,\n DeepMerger,\n resultKeyNameFromField,\n shouldInclude,\n isNonNullObject,\n compact,\n createFragmentMap,\n getFragmentDefinitions,\n isArray,\n} from \"../../utilities/index.js\";\n\nexport const { hasOwnProperty: hasOwn } = Object.prototype;\n\nexport function isNullish(value: any): value is null | undefined {\n return value === null || value === void 0;\n}\n\nexport { isArray };\n\nexport function defaultDataIdFromObject(\n { __typename, id, _id }: Readonly,\n context?: KeyFieldsContext\n): string | undefined {\n if (typeof __typename === \"string\") {\n if (context) {\n context.keyObject =\n !isNullish(id) ? { id }\n : !isNullish(_id) ? { _id }\n : void 0;\n }\n\n // If there is no object.id, fall back to object._id.\n if (isNullish(id) && !isNullish(_id)) {\n id = _id;\n }\n\n if (!isNullish(id)) {\n return `${__typename}:${\n typeof id === \"number\" || typeof id === \"string\" ?\n id\n : JSON.stringify(id)\n }`;\n }\n }\n}\n\nconst defaultConfig = {\n dataIdFromObject: defaultDataIdFromObject,\n addTypename: true,\n resultCaching: true,\n // Thanks to the shouldCanonizeResults helper, this should be the only line\n // you have to change to reenable canonization by default in the future.\n canonizeResults: false,\n};\n\nexport function normalizeConfig(config: InMemoryCacheConfig) {\n return compact(defaultConfig, config);\n}\n\nexport function shouldCanonizeResults(\n config: Pick\n): boolean {\n const value = config.canonizeResults;\n return value === void 0 ? defaultConfig.canonizeResults : value;\n}\n\nexport function getTypenameFromStoreObject(\n store: NormalizedCache,\n objectOrReference: StoreObject | Reference\n): string | undefined {\n return isReference(objectOrReference) ?\n (store.get(objectOrReference.__ref, \"__typename\") as string)\n : objectOrReference && objectOrReference.__typename;\n}\n\nexport const TypeOrFieldNameRegExp = /^[_a-z][_0-9a-z]*/i;\n\nexport function fieldNameFromStoreName(storeFieldName: string): string {\n const match = storeFieldName.match(TypeOrFieldNameRegExp);\n return match ? match[0] : storeFieldName;\n}\n\nexport function selectionSetMatchesResult(\n selectionSet: SelectionSetNode,\n result: Record,\n variables?: Record\n): boolean {\n if (isNonNullObject(result)) {\n return isArray(result) ?\n result.every((item) =>\n selectionSetMatchesResult(selectionSet, item, variables)\n )\n : selectionSet.selections.every((field) => {\n if (isField(field) && shouldInclude(field, variables)) {\n const key = resultKeyNameFromField(field);\n return (\n hasOwn.call(result, key) &&\n (!field.selectionSet ||\n selectionSetMatchesResult(\n field.selectionSet,\n result[key],\n variables\n ))\n );\n }\n // If the selection has been skipped with @skip(true) or\n // @include(false), it should not count against the matching. If\n // the selection is not a field, it must be a fragment (inline or\n // named). We will determine if selectionSetMatchesResult for that\n // fragment when we get to it, so for now we return true.\n return true;\n });\n }\n return false;\n}\n\nexport function storeValueIsStoreObject(\n value: StoreValue\n): value is StoreObject {\n return isNonNullObject(value) && !isReference(value) && !isArray(value);\n}\n\nexport function makeProcessedFieldsMerger() {\n return new DeepMerger();\n}\n\nexport function extractFragmentContext(\n document: DocumentNode,\n fragments?: FragmentRegistryAPI\n): {\n fragmentMap: FragmentMap;\n lookupFragment: FragmentMapFunction;\n} {\n // FragmentMap consisting only of fragments defined directly in document, not\n // including other fragments registered in the FragmentRegistry.\n const fragmentMap = createFragmentMap(getFragmentDefinitions(document));\n return {\n fragmentMap,\n lookupFragment(name) {\n let def: FragmentDefinitionNode | null = fragmentMap[name];\n if (!def && fragments) {\n def = fragments.lookup(name);\n }\n return def || null;\n },\n };\n}\n","import { invariant } from \"../../utilities/globals/index.js\";\nimport type { OptimisticDependencyFunction } from \"optimism\";\nimport { dep } from \"optimism\";\nimport { equal } from \"@wry/equality\";\nimport { Trie } from \"@wry/trie\";\n\nimport type {\n StoreValue,\n StoreObject,\n Reference,\n} from \"../../utilities/index.js\";\nimport {\n isReference,\n makeReference,\n DeepMerger,\n maybeDeepFreeze,\n canUseWeakMap,\n isNonNullObject,\n} from \"../../utilities/index.js\";\nimport type { NormalizedCache, NormalizedCacheObject } from \"./types.js\";\nimport { hasOwn, fieldNameFromStoreName } from \"./helpers.js\";\nimport type { Policies, StorageType } from \"./policies.js\";\nimport type { Cache } from \"../core/types/Cache.js\";\nimport type {\n SafeReadonly,\n Modifier,\n Modifiers,\n ReadFieldOptions,\n ToReferenceFunction,\n CanReadFunction,\n InvalidateModifier,\n DeleteModifier,\n ModifierDetails,\n} from \"../core/types/common.js\";\nimport type { DocumentNode, FieldNode, SelectionSetNode } from \"graphql\";\n\nconst DELETE: DeleteModifier = Object.create(null);\nconst delModifier: Modifier = () => DELETE;\nconst INVALIDATE: InvalidateModifier = Object.create(null);\n\nexport abstract class EntityStore implements NormalizedCache {\n protected data: NormalizedCacheObject = Object.create(null);\n\n constructor(\n public readonly policies: Policies,\n public readonly group: CacheGroup\n ) {}\n\n public abstract addLayer(\n layerId: string,\n replay: (layer: EntityStore) => any\n ): Layer;\n\n public abstract removeLayer(layerId: string): EntityStore;\n\n // Although the EntityStore class is abstract, it contains concrete\n // implementations of the various NormalizedCache interface methods that\n // are inherited by the Root and Layer subclasses.\n\n public toObject(): NormalizedCacheObject {\n return { ...this.data };\n }\n\n public has(dataId: string): boolean {\n return this.lookup(dataId, true) !== void 0;\n }\n\n public get(dataId: string, fieldName: string): StoreValue {\n this.group.depend(dataId, fieldName);\n if (hasOwn.call(this.data, dataId)) {\n const storeObject = this.data[dataId];\n if (storeObject && hasOwn.call(storeObject, fieldName)) {\n return storeObject[fieldName];\n }\n }\n if (\n fieldName === \"__typename\" &&\n hasOwn.call(this.policies.rootTypenamesById, dataId)\n ) {\n return this.policies.rootTypenamesById[dataId];\n }\n if (this instanceof Layer) {\n return this.parent.get(dataId, fieldName);\n }\n }\n\n protected lookup(\n dataId: string,\n dependOnExistence?: boolean\n ): StoreObject | undefined {\n // The has method (above) calls lookup with dependOnExistence = true, so\n // that it can later be invalidated when we add or remove a StoreObject for\n // this dataId. Any consumer who cares about the contents of the StoreObject\n // should not rely on this dependency, since the contents could change\n // without the object being added or removed.\n if (dependOnExistence) this.group.depend(dataId, \"__exists\");\n\n if (hasOwn.call(this.data, dataId)) {\n return this.data[dataId];\n }\n\n if (this instanceof Layer) {\n return this.parent.lookup(dataId, dependOnExistence);\n }\n\n if (this.policies.rootTypenamesById[dataId]) {\n return Object.create(null);\n }\n }\n\n public merge(older: string | StoreObject, newer: StoreObject | string): void {\n let dataId: string | undefined;\n\n // Convert unexpected references to ID strings.\n if (isReference(older)) older = older.__ref;\n if (isReference(newer)) newer = newer.__ref;\n\n const existing: StoreObject | undefined =\n typeof older === \"string\" ? this.lookup((dataId = older)) : older;\n\n const incoming: StoreObject | undefined =\n typeof newer === \"string\" ? this.lookup((dataId = newer)) : newer;\n\n // If newer was a string ID, but that ID was not defined in this store,\n // then there are no fields to be merged, so we're done.\n if (!incoming) return;\n\n invariant(typeof dataId === \"string\", \"store.merge expects a string ID\");\n\n const merged: StoreObject = new DeepMerger(storeObjectReconciler).merge(\n existing,\n incoming\n );\n\n // Even if merged === existing, existing may have come from a lower\n // layer, so we always need to set this.data[dataId] on this level.\n this.data[dataId] = merged;\n\n if (merged !== existing) {\n delete this.refs[dataId];\n if (this.group.caching) {\n const fieldsToDirty: Record = Object.create(null);\n\n // If we added a new StoreObject where there was previously none, dirty\n // anything that depended on the existence of this dataId, such as the\n // EntityStore#has method.\n if (!existing) fieldsToDirty.__exists = 1;\n\n // Now invalidate dependents who called getFieldValue for any fields\n // that are changing as a result of this merge.\n Object.keys(incoming).forEach((storeFieldName) => {\n if (\n !existing ||\n existing[storeFieldName] !== merged[storeFieldName]\n ) {\n // Always dirty the full storeFieldName, which may include\n // serialized arguments following the fieldName prefix.\n fieldsToDirty[storeFieldName] = 1;\n\n // Also dirty fieldNameFromStoreName(storeFieldName) if it's\n // different from storeFieldName and this field does not have\n // keyArgs configured, because that means the cache can't make\n // any assumptions about how field values with the same field\n // name but different arguments might be interrelated, so it\n // must err on the side of invalidating all field values that\n // share the same short fieldName, regardless of arguments.\n const fieldName = fieldNameFromStoreName(storeFieldName);\n if (\n fieldName !== storeFieldName &&\n !this.policies.hasKeyArgs(merged.__typename, fieldName)\n ) {\n fieldsToDirty[fieldName] = 1;\n }\n\n // If merged[storeFieldName] has become undefined, and this is the\n // Root layer, actually delete the property from the merged object,\n // which is guaranteed to have been created fresh in this method.\n if (merged[storeFieldName] === void 0 && !(this instanceof Layer)) {\n delete merged[storeFieldName];\n }\n }\n });\n\n if (\n fieldsToDirty.__typename &&\n !(existing && existing.__typename) &&\n // Since we return default root __typename strings\n // automatically from store.get, we don't need to dirty the\n // ROOT_QUERY.__typename field if merged.__typename is equal\n // to the default string (usually \"Query\").\n this.policies.rootTypenamesById[dataId] === merged.__typename\n ) {\n delete fieldsToDirty.__typename;\n }\n\n Object.keys(fieldsToDirty).forEach((fieldName) =>\n this.group.dirty(dataId as string, fieldName)\n );\n }\n }\n }\n\n public modify(\n dataId: string,\n fields: Modifier | Modifiers>\n ): boolean {\n const storeObject = this.lookup(dataId);\n\n if (storeObject) {\n const changedFields: Record = Object.create(null);\n let needToMerge = false;\n let allDeleted = true;\n\n const sharedDetails = {\n DELETE,\n INVALIDATE,\n isReference,\n toReference: this.toReference,\n canRead: this.canRead,\n readField: (\n fieldNameOrOptions: string | ReadFieldOptions,\n from?: StoreObject | Reference\n ) =>\n this.policies.readField(\n typeof fieldNameOrOptions === \"string\" ?\n {\n fieldName: fieldNameOrOptions,\n from: from || makeReference(dataId),\n }\n : fieldNameOrOptions,\n { store: this }\n ),\n } satisfies Partial;\n\n Object.keys(storeObject).forEach((storeFieldName) => {\n const fieldName = fieldNameFromStoreName(storeFieldName);\n let fieldValue = storeObject[storeFieldName];\n if (fieldValue === void 0) return;\n const modify: Modifier | undefined =\n typeof fields === \"function\" ? fields : (\n fields[storeFieldName] || fields[fieldName]\n );\n if (modify) {\n let newValue =\n modify === delModifier ? DELETE : (\n modify(maybeDeepFreeze(fieldValue), {\n ...sharedDetails,\n fieldName,\n storeFieldName,\n storage: this.getStorage(dataId, storeFieldName),\n })\n );\n if (newValue === INVALIDATE) {\n this.group.dirty(dataId, storeFieldName);\n } else {\n if (newValue === DELETE) newValue = void 0;\n if (newValue !== fieldValue) {\n changedFields[storeFieldName] = newValue;\n needToMerge = true;\n fieldValue = newValue;\n\n if (__DEV__) {\n const checkReference = (ref: Reference) => {\n if (this.lookup(ref.__ref) === undefined) {\n invariant.warn(\n \"cache.modify: You are trying to write a Reference that is not part of the store: %o\\n\" +\n \"Please make sure to set the `mergeIntoStore` parameter to `true` when creating a Reference that is not part of the store yet:\\n\" +\n \"`toReference(object, true)`\",\n ref\n );\n return true;\n }\n };\n if (isReference(newValue)) {\n checkReference(newValue);\n } else if (Array.isArray(newValue)) {\n // Warn about writing \"mixed\" arrays of Reference and non-Reference objects\n let seenReference: boolean = false;\n let someNonReference: unknown;\n for (const value of newValue) {\n if (isReference(value)) {\n seenReference = true;\n if (checkReference(value)) break;\n } else {\n // Do not warn on primitive values, since those could never be represented\n // by a reference. This is a valid (albeit uncommon) use case.\n if (typeof value === \"object\" && !!value) {\n const [id] = this.policies.identify(value);\n // check if object could even be referenced, otherwise we are not interested in it for this warning\n if (id) {\n someNonReference = value;\n }\n }\n }\n if (seenReference && someNonReference !== undefined) {\n invariant.warn(\n \"cache.modify: Writing an array with a mix of both References and Objects will not result in the Objects being normalized correctly.\\n\" +\n \"Please convert the object instance %o to a Reference before writing it to the cache by calling `toReference(object, true)`.\",\n someNonReference\n );\n break;\n }\n }\n }\n }\n }\n }\n }\n if (fieldValue !== void 0) {\n allDeleted = false;\n }\n });\n\n if (needToMerge) {\n this.merge(dataId, changedFields);\n\n if (allDeleted) {\n if (this instanceof Layer) {\n this.data[dataId] = void 0;\n } else {\n delete this.data[dataId];\n }\n this.group.dirty(dataId, \"__exists\");\n }\n\n return true;\n }\n }\n\n return false;\n }\n\n // If called with only one argument, removes the entire entity\n // identified by dataId. If called with a fieldName as well, removes all\n // fields of that entity whose names match fieldName according to the\n // fieldNameFromStoreName helper function. If called with a fieldName\n // and variables, removes all fields of that entity whose names match fieldName\n // and whose arguments when cached exactly match the variables passed.\n public delete(\n dataId: string,\n fieldName?: string,\n args?: Record\n ) {\n const storeObject = this.lookup(dataId);\n if (storeObject) {\n const typename = this.getFieldValue(storeObject, \"__typename\");\n const storeFieldName =\n fieldName && args ?\n this.policies.getStoreFieldName({ typename, fieldName, args })\n : fieldName;\n return this.modify(\n dataId,\n storeFieldName ?\n {\n [storeFieldName]: delModifier,\n }\n : delModifier\n );\n }\n return false;\n }\n\n public evict(options: Cache.EvictOptions, limit: EntityStore): boolean {\n let evicted = false;\n if (options.id) {\n if (hasOwn.call(this.data, options.id)) {\n evicted = this.delete(options.id, options.fieldName, options.args);\n }\n if (this instanceof Layer && this !== limit) {\n evicted = this.parent.evict(options, limit) || evicted;\n }\n // Always invalidate the field to trigger rereading of watched\n // queries, even if no cache data was modified by the eviction,\n // because queries may depend on computed fields with custom read\n // functions, whose values are not stored in the EntityStore.\n if (options.fieldName || evicted) {\n this.group.dirty(options.id, options.fieldName || \"__exists\");\n }\n }\n return evicted;\n }\n\n public clear(): void {\n this.replace(null);\n }\n\n public extract(): NormalizedCacheObject {\n const obj = this.toObject();\n const extraRootIds: string[] = [];\n this.getRootIdSet().forEach((id) => {\n if (!hasOwn.call(this.policies.rootTypenamesById, id)) {\n extraRootIds.push(id);\n }\n });\n if (extraRootIds.length) {\n obj.__META = { extraRootIds: extraRootIds.sort() };\n }\n return obj;\n }\n\n public replace(newData: NormalizedCacheObject | null): void {\n Object.keys(this.data).forEach((dataId) => {\n if (!(newData && hasOwn.call(newData, dataId))) {\n this.delete(dataId);\n }\n });\n if (newData) {\n const { __META, ...rest } = newData;\n Object.keys(rest).forEach((dataId) => {\n this.merge(dataId, rest[dataId] as StoreObject);\n });\n if (__META) {\n __META.extraRootIds.forEach(this.retain, this);\n }\n }\n }\n\n public abstract getStorage(\n idOrObj: string | StoreObject,\n ...storeFieldNames: (string | number)[]\n ): StorageType;\n\n // Maps root entity IDs to the number of times they have been retained, minus\n // the number of times they have been released. Retained entities keep other\n // entities they reference (even indirectly) from being garbage collected.\n private rootIds: {\n [rootId: string]: number;\n } = Object.create(null);\n\n public retain(rootId: string): number {\n return (this.rootIds[rootId] = (this.rootIds[rootId] || 0) + 1);\n }\n\n public release(rootId: string): number {\n if (this.rootIds[rootId] > 0) {\n const count = --this.rootIds[rootId];\n if (!count) delete this.rootIds[rootId];\n return count;\n }\n return 0;\n }\n\n // Return a Set of all the ID strings that have been retained by\n // this layer/root *and* any layers/roots beneath it.\n public getRootIdSet(ids = new Set()) {\n Object.keys(this.rootIds).forEach(ids.add, ids);\n if (this instanceof Layer) {\n this.parent.getRootIdSet(ids);\n } else {\n // Official singleton IDs like ROOT_QUERY and ROOT_MUTATION are\n // always considered roots for garbage collection, regardless of\n // their retainment counts in this.rootIds.\n Object.keys(this.policies.rootTypenamesById).forEach(ids.add, ids);\n }\n return ids;\n }\n\n // The goal of garbage collection is to remove IDs from the Root layer of the\n // store that are no longer reachable starting from any IDs that have been\n // explicitly retained (see retain and release, above). Returns an array of\n // dataId strings that were removed from the store.\n public gc() {\n const ids = this.getRootIdSet();\n const snapshot = this.toObject();\n ids.forEach((id) => {\n if (hasOwn.call(snapshot, id)) {\n // Because we are iterating over an ECMAScript Set, the IDs we add here\n // will be visited in later iterations of the forEach loop only if they\n // were not previously contained by the Set.\n Object.keys(this.findChildRefIds(id)).forEach(ids.add, ids);\n // By removing IDs from the snapshot object here, we protect them from\n // getting removed from the root store layer below.\n delete snapshot[id];\n }\n });\n const idsToRemove = Object.keys(snapshot);\n if (idsToRemove.length) {\n let root: EntityStore = this;\n while (root instanceof Layer) root = root.parent;\n idsToRemove.forEach((id) => root.delete(id));\n }\n return idsToRemove;\n }\n\n // Lazily tracks { __ref: } strings contained by this.data[dataId].\n private refs: {\n [dataId: string]: Record;\n } = Object.create(null);\n\n public findChildRefIds(dataId: string): Record {\n if (!hasOwn.call(this.refs, dataId)) {\n const found = (this.refs[dataId] = Object.create(null));\n const root = this.data[dataId];\n if (!root) return found;\n\n const workSet = new Set>([root]);\n // Within the store, only arrays and objects can contain child entity\n // references, so we can prune the traversal using this predicate:\n workSet.forEach((obj) => {\n if (isReference(obj)) {\n found[obj.__ref] = true;\n // In rare cases, a { __ref } Reference object may have other fields.\n // This often indicates a mismerging of References with StoreObjects,\n // but garbage collection should not be fooled by a stray __ref\n // property in a StoreObject (ignoring all the other fields just\n // because the StoreObject looks like a Reference). To avoid this\n // premature termination of findChildRefIds recursion, we fall through\n // to the code below, which will handle any other properties of obj.\n }\n if (isNonNullObject(obj)) {\n Object.keys(obj).forEach((key) => {\n const child = obj[key];\n // No need to add primitive values to the workSet, since they cannot\n // contain reference objects.\n if (isNonNullObject(child)) {\n workSet.add(child);\n }\n });\n }\n });\n }\n return this.refs[dataId];\n }\n\n // Used to compute cache keys specific to this.group.\n /** overload for `InMemoryCache.maybeBroadcastWatch` */\n public makeCacheKey(\n document: DocumentNode,\n callback: Cache.WatchCallback,\n details: string\n ): object;\n /** overload for `StoreReader.executeSelectionSet` */\n public makeCacheKey(\n selectionSet: SelectionSetNode,\n parent: string /* = ( Reference.__ref ) */ | StoreObject,\n varString: string | undefined,\n canonizeResults: boolean\n ): object;\n /** overload for `StoreReader.executeSubSelectedArray` */\n public makeCacheKey(\n field: FieldNode,\n array: readonly any[],\n varString: string | undefined\n ): object;\n /** @deprecated This is only meant for internal usage,\n * in your own code please use a `Trie` instance instead. */\n public makeCacheKey(...args: any[]): object;\n public makeCacheKey() {\n return this.group.keyMaker.lookupArray(arguments);\n }\n\n // Bound function that can be passed around to provide easy access to fields\n // of Reference objects as well as ordinary objects.\n public getFieldValue = (\n objectOrReference: StoreObject | Reference | undefined,\n storeFieldName: string\n ) =>\n maybeDeepFreeze(\n isReference(objectOrReference) ?\n this.get(objectOrReference.__ref, storeFieldName)\n : objectOrReference && objectOrReference[storeFieldName]\n ) as SafeReadonly;\n\n // Returns true for non-normalized StoreObjects and non-dangling\n // References, indicating that readField(name, objOrRef) has a chance of\n // working. Useful for filtering out dangling references from lists.\n public canRead: CanReadFunction = (objOrRef) => {\n return isReference(objOrRef) ?\n this.has(objOrRef.__ref)\n : typeof objOrRef === \"object\";\n };\n\n // Bound function that converts an id or an object with a __typename and\n // primary key fields to a Reference object. If called with a Reference object,\n // that same Reference object is returned. Pass true for mergeIntoStore to persist\n // an object into the store.\n public toReference: ToReferenceFunction = (objOrIdOrRef, mergeIntoStore) => {\n if (typeof objOrIdOrRef === \"string\") {\n return makeReference(objOrIdOrRef);\n }\n\n if (isReference(objOrIdOrRef)) {\n return objOrIdOrRef;\n }\n\n const [id] = this.policies.identify(objOrIdOrRef);\n\n if (id) {\n const ref = makeReference(id);\n if (mergeIntoStore) {\n this.merge(id, objOrIdOrRef);\n }\n return ref;\n }\n };\n}\n\nexport type FieldValueGetter = EntityStore[\"getFieldValue\"];\n\n// A single CacheGroup represents a set of one or more EntityStore objects,\n// typically the Root store in a CacheGroup by itself, and all active Layer\n// stores in a group together. A single EntityStore object belongs to only\n// one CacheGroup, store.group. The CacheGroup is responsible for tracking\n// dependencies, so store.group is helpful for generating unique keys for\n// cached results that need to be invalidated when/if those dependencies\n// change. If we used the EntityStore objects themselves as cache keys (that\n// is, store rather than store.group), the cache would become unnecessarily\n// fragmented by all the different Layer objects. Instead, the CacheGroup\n// approach allows all optimistic Layer objects in the same linked list to\n// belong to one CacheGroup, with the non-optimistic Root object belonging\n// to another CacheGroup, allowing resultCaching dependencies to be tracked\n// separately for optimistic and non-optimistic entity data.\nclass CacheGroup {\n private d: OptimisticDependencyFunction | null = null;\n\n // Used by the EntityStore#makeCacheKey method to compute cache keys\n // specific to this CacheGroup.\n public keyMaker!: Trie;\n\n constructor(\n public readonly caching: boolean,\n private parent: CacheGroup | null = null\n ) {\n this.resetCaching();\n }\n\n public resetCaching() {\n this.d = this.caching ? dep() : null;\n this.keyMaker = new Trie(canUseWeakMap);\n }\n\n public depend(dataId: string, storeFieldName: string) {\n if (this.d) {\n this.d(makeDepKey(dataId, storeFieldName));\n const fieldName = fieldNameFromStoreName(storeFieldName);\n if (fieldName !== storeFieldName) {\n // Fields with arguments that contribute extra identifying\n // information to the fieldName (thus forming the storeFieldName)\n // depend not only on the full storeFieldName but also on the\n // short fieldName, so the field can be invalidated using either\n // level of specificity.\n this.d(makeDepKey(dataId, fieldName));\n }\n if (this.parent) {\n this.parent.depend(dataId, storeFieldName);\n }\n }\n }\n\n public dirty(dataId: string, storeFieldName: string) {\n if (this.d) {\n this.d.dirty(\n makeDepKey(dataId, storeFieldName),\n // When storeFieldName === \"__exists\", that means the entity identified\n // by dataId has either disappeared from the cache or was newly added,\n // so the result caching system would do well to \"forget everything it\n // knows\" about that object. To achieve that kind of invalidation, we\n // not only dirty the associated result cache entry, but also remove it\n // completely from the dependency graph. For the optimism implementation\n // details, see https://github.com/benjamn/optimism/pull/195.\n storeFieldName === \"__exists\" ? \"forget\" : \"setDirty\"\n );\n }\n }\n}\n\nfunction makeDepKey(dataId: string, storeFieldName: string) {\n // Since field names cannot have '#' characters in them, this method\n // of joining the field name and the ID should be unambiguous, and much\n // cheaper than JSON.stringify([dataId, fieldName]).\n return storeFieldName + \"#\" + dataId;\n}\n\nexport function maybeDependOnExistenceOfEntity(\n store: NormalizedCache,\n entityId: string\n) {\n if (supportsResultCaching(store)) {\n // We use this pseudo-field __exists elsewhere in the EntityStore code to\n // represent changes in the existence of the entity object identified by\n // entityId. This dependency gets reliably dirtied whenever an object with\n // this ID is deleted (or newly created) within this group, so any result\n // cache entries (for example, StoreReader#executeSelectionSet results) that\n // depend on __exists for this entityId will get dirtied as well, leading to\n // the eventual recomputation (instead of reuse) of those result objects the\n // next time someone reads them from the cache.\n store.group.depend(entityId, \"__exists\");\n }\n}\n\nexport namespace EntityStore {\n // Refer to this class as EntityStore.Root outside this namespace.\n export class Root extends EntityStore {\n constructor({\n policies,\n resultCaching = true,\n seed,\n }: {\n policies: Policies;\n resultCaching?: boolean;\n seed?: NormalizedCacheObject;\n }) {\n super(policies, new CacheGroup(resultCaching));\n if (seed) this.replace(seed);\n }\n\n public readonly stump = new Stump(this);\n\n public addLayer(\n layerId: string,\n replay: (layer: EntityStore) => any\n ): Layer {\n // Adding an optimistic Layer on top of the Root actually adds the Layer\n // on top of the Stump, so the Stump always comes between the Root and\n // any Layer objects that we've added.\n return this.stump.addLayer(layerId, replay);\n }\n\n public removeLayer(): Root {\n // Never remove the root layer.\n return this;\n }\n\n public readonly storageTrie = new Trie(canUseWeakMap);\n public getStorage(): StorageType {\n return this.storageTrie.lookupArray(arguments);\n }\n }\n}\n\n// Not exported, since all Layer instances are created by the addLayer method\n// of the EntityStore.Root class.\nclass Layer extends EntityStore {\n constructor(\n public readonly id: string,\n public readonly parent: EntityStore,\n public readonly replay: (layer: EntityStore) => any,\n public readonly group: CacheGroup\n ) {\n super(parent.policies, group);\n replay(this);\n }\n\n public addLayer(layerId: string, replay: (layer: EntityStore) => any): Layer {\n return new Layer(layerId, this, replay, this.group);\n }\n\n public removeLayer(layerId: string): EntityStore {\n // Remove all instances of the given id, not just the first one.\n const parent = this.parent.removeLayer(layerId);\n\n if (layerId === this.id) {\n if (this.group.caching) {\n // Dirty every ID we're removing. Technically we might be able to avoid\n // dirtying fields that have values in higher layers, but we don't have\n // easy access to higher layers here, and we're about to recreate those\n // layers anyway (see parent.addLayer below).\n Object.keys(this.data).forEach((dataId) => {\n const ownStoreObject = this.data[dataId];\n const parentStoreObject = parent[\"lookup\"](dataId);\n if (!parentStoreObject) {\n // The StoreObject identified by dataId was defined in this layer\n // but will be undefined in the parent layer, so we can delete the\n // whole entity using this.delete(dataId). Since we're about to\n // throw this layer away, the only goal of this deletion is to dirty\n // the removed fields.\n this.delete(dataId);\n } else if (!ownStoreObject) {\n // This layer had an entry for dataId but it was undefined, which\n // means the entity was deleted in this layer, and it's about to\n // become undeleted when we remove this layer, so we need to dirty\n // all fields that are about to be reexposed.\n this.group.dirty(dataId, \"__exists\");\n Object.keys(parentStoreObject).forEach((storeFieldName) => {\n this.group.dirty(dataId, storeFieldName);\n });\n } else if (ownStoreObject !== parentStoreObject) {\n // If ownStoreObject is not exactly the same as parentStoreObject,\n // dirty any fields whose values will change as a result of this\n // removal.\n Object.keys(ownStoreObject).forEach((storeFieldName) => {\n if (\n !equal(\n ownStoreObject[storeFieldName],\n parentStoreObject[storeFieldName]\n )\n ) {\n this.group.dirty(dataId, storeFieldName);\n }\n });\n }\n });\n }\n\n return parent;\n }\n\n // No changes are necessary if the parent chain remains identical.\n if (parent === this.parent) return this;\n\n // Recreate this layer on top of the new parent.\n return parent.addLayer(this.id, this.replay);\n }\n\n public toObject(): NormalizedCacheObject {\n return {\n ...this.parent.toObject(),\n ...this.data,\n };\n }\n\n public findChildRefIds(dataId: string): Record {\n const fromParent = this.parent.findChildRefIds(dataId);\n return hasOwn.call(this.data, dataId) ?\n {\n ...fromParent,\n ...super.findChildRefIds(dataId),\n }\n : fromParent;\n }\n\n public getStorage(): StorageType {\n let p: EntityStore = this.parent;\n while ((p as Layer).parent) p = (p as Layer).parent;\n return p.getStorage.apply(\n p,\n // @ts-expect-error\n arguments\n );\n }\n}\n\n// Represents a Layer permanently installed just above the Root, which allows\n// reading optimistically (and registering optimistic dependencies) even when\n// no optimistic layers are currently active. The stump.group CacheGroup object\n// is shared by any/all Layer objects added on top of the Stump.\nclass Stump extends Layer {\n constructor(root: EntityStore.Root) {\n super(\n \"EntityStore.Stump\",\n root,\n () => {},\n new CacheGroup(root.group.caching, root.group)\n );\n }\n\n public removeLayer() {\n // Never remove the Stump layer.\n return this;\n }\n\n public merge(older: string | StoreObject, newer: string | StoreObject) {\n // We never want to write any data into the Stump, so we forward any merge\n // calls to the Root instead. Another option here would be to throw an\n // exception, but the toReference(object, true) function can sometimes\n // trigger Stump writes (which used to be Root writes, before the Stump\n // concept was introduced).\n return this.parent.merge(older, newer);\n }\n}\n\nfunction storeObjectReconciler(\n existingObject: StoreObject,\n incomingObject: StoreObject,\n property: string | number\n): StoreValue {\n const existingValue = existingObject[property];\n const incomingValue = incomingObject[property];\n // Wherever there is a key collision, prefer the incoming value, unless\n // it is deeply equal to the existing value. It's worth checking deep\n // equality here (even though blindly returning incoming would be\n // logically correct) because preserving the referential identity of\n // existing data can prevent needless rereading and rerendering.\n return equal(existingValue, incomingValue) ? existingValue : incomingValue;\n}\n\nexport function supportsResultCaching(store: any): store is EntityStore {\n // When result caching is disabled, store.depend will be null.\n return !!(store instanceof EntityStore && store.group.caching);\n}\n","import { Trie } from \"@wry/trie\";\nimport {\n canUseWeakMap,\n canUseWeakSet,\n isNonNullObject as isObjectOrArray,\n} from \"../../utilities/index.js\";\nimport { isArray } from \"./helpers.js\";\n\nfunction shallowCopy(value: T): T {\n if (isObjectOrArray(value)) {\n return isArray(value) ?\n (value.slice(0) as any as T)\n : { __proto__: Object.getPrototypeOf(value), ...value };\n }\n return value;\n}\n\n// When programmers talk about the \"canonical form\" of an object, they\n// usually have the following meaning in mind, which I've copied from\n// https://en.wiktionary.org/wiki/canonical_form:\n//\n// 1. A standard or normal presentation of a mathematical entity [or\n// object]. A canonical form is an element of a set of representatives\n// of equivalence classes of forms such that there is a function or\n// procedure which projects every element of each equivalence class\n// onto that one element, the canonical form of that equivalence\n// class. The canonical form is expected to be simpler than the rest of\n// the forms in some way.\n//\n// That's a long-winded way of saying any two objects that have the same\n// canonical form may be considered equivalent, even if they are !==,\n// which usually means the objects are structurally equivalent (deeply\n// equal), but don't necessarily use the same memory.\n//\n// Like a literary or musical canon, this ObjectCanon class represents a\n// collection of unique canonical items (JavaScript objects), with the\n// important property that canon.admit(a) === canon.admit(b) if a and b\n// are deeply equal to each other. In terms of the definition above, the\n// canon.admit method is the \"function or procedure which projects every\"\n// object \"onto that one element, the canonical form.\"\n//\n// In the worst case, the canonicalization process may involve looking at\n// every property in the provided object tree, so it takes the same order\n// of time as deep equality checking. Fortunately, already-canonicalized\n// objects are returned immediately from canon.admit, so the presence of\n// canonical subtrees tends to speed up canonicalization.\n//\n// Since consumers of canonical objects can check for deep equality in\n// constant time, canonicalizing cache results can massively improve the\n// performance of application code that skips re-rendering unchanged\n// results, such as \"pure\" UI components in a framework like React.\n//\n// Of course, since canonical objects may be shared widely between\n// unrelated consumers, it's important to think of them as immutable, even\n// though they are not actually frozen with Object.freeze in production,\n// due to the extra performance overhead that comes with frozen objects.\n//\n// Custom scalar objects whose internal class name is neither Array nor\n// Object can be included safely in the admitted tree, but they will not\n// be replaced with a canonical version (to put it another way, they are\n// assumed to be canonical already).\n//\n// If we ignore custom objects, no detection of cycles or repeated object\n// references is currently required by the StoreReader class, since\n// GraphQL result objects are JSON-serializable trees (and thus contain\n// neither cycles nor repeated subtrees), so we can avoid the complexity\n// of keeping track of objects we've already seen during the recursion of\n// the admit method.\n//\n// In the future, we may consider adding additional cases to the switch\n// statement to handle other common object types, such as \"[object Date]\"\n// objects, as needed.\nexport class ObjectCanon {\n // Set of all canonical objects this ObjectCanon has admitted, allowing\n // canon.admit to return previously-canonicalized objects immediately.\n private known = new (canUseWeakSet ? WeakSet : Set)();\n\n // Efficient storage/lookup structure for canonical objects.\n private pool = new Trie<{\n array?: any[];\n object?: Record;\n keys?: SortedKeysInfo;\n }>(canUseWeakMap);\n\n public isKnown(value: any): boolean {\n return isObjectOrArray(value) && this.known.has(value);\n }\n\n // Make the ObjectCanon assume this value has already been\n // canonicalized.\n private passes = new WeakMap();\n public pass(value: T): T;\n public pass(value: any) {\n if (isObjectOrArray(value)) {\n const copy = shallowCopy(value);\n this.passes.set(copy, value);\n return copy;\n }\n return value;\n }\n\n // Returns the canonical version of value.\n public admit(value: T): T;\n public admit(value: any) {\n if (isObjectOrArray(value)) {\n const original = this.passes.get(value);\n if (original) return original;\n\n const proto = Object.getPrototypeOf(value);\n switch (proto) {\n case Array.prototype: {\n if (this.known.has(value)) return value;\n const array: any[] = (value as any[]).map(this.admit, this);\n // Arrays are looked up in the Trie using their recursively\n // canonicalized elements, and the known version of the array is\n // preserved as node.array.\n const node = this.pool.lookupArray(array);\n if (!node.array) {\n this.known.add((node.array = array));\n // Since canonical arrays may be shared widely between\n // unrelated consumers, it's important to regard them as\n // immutable, even if they are not frozen in production.\n if (__DEV__) {\n Object.freeze(array);\n }\n }\n return node.array;\n }\n\n case null:\n case Object.prototype: {\n if (this.known.has(value)) return value;\n const proto = Object.getPrototypeOf(value);\n const array = [proto];\n const keys = this.sortedKeys(value);\n array.push(keys.json);\n const firstValueIndex = array.length;\n keys.sorted.forEach((key) => {\n array.push(this.admit((value as any)[key]));\n });\n // Objects are looked up in the Trie by their prototype (which\n // is *not* recursively canonicalized), followed by a JSON\n // representation of their (sorted) keys, followed by the\n // sequence of recursively canonicalized values corresponding to\n // those keys. To keep the final results unambiguous with other\n // sequences (such as arrays that just happen to contain [proto,\n // keys.json, value1, value2, ...]), the known version of the\n // object is stored as node.object.\n const node = this.pool.lookupArray(array);\n if (!node.object) {\n const obj = (node.object = Object.create(proto));\n this.known.add(obj);\n keys.sorted.forEach((key, i) => {\n obj[key] = array[firstValueIndex + i];\n });\n // Since canonical objects may be shared widely between\n // unrelated consumers, it's important to regard them as\n // immutable, even if they are not frozen in production.\n if (__DEV__) {\n Object.freeze(obj);\n }\n }\n return node.object;\n }\n }\n }\n return value;\n }\n\n // It's worthwhile to cache the sorting of arrays of strings, since the\n // same initial unsorted arrays tend to be encountered many times.\n // Fortunately, we can reuse the Trie machinery to look up the sorted\n // arrays in linear time (which is faster than sorting large arrays).\n private sortedKeys(obj: object) {\n const keys = Object.keys(obj);\n const node = this.pool.lookupArray(keys);\n if (!node.keys) {\n keys.sort();\n const json = JSON.stringify(keys);\n if (!(node.keys = this.keysByJSON.get(json))) {\n this.keysByJSON.set(json, (node.keys = { sorted: keys, json }));\n }\n }\n return node.keys;\n }\n // Arrays that contain the same elements in a different order can share\n // the same SortedKeysInfo object, to save memory.\n private keysByJSON = new Map();\n\n // This has to come last because it depends on keysByJSON.\n public readonly empty = this.admit({});\n}\n\ntype SortedKeysInfo = {\n sorted: string[];\n json: string;\n};\n","import { invariant, newInvariantError } from \"../../utilities/globals/index.js\";\n\nimport type { DocumentNode, FieldNode, SelectionSetNode } from \"graphql\";\nimport { Kind } from \"graphql\";\nimport type { OptimisticWrapperFunction } from \"optimism\";\nimport { wrap } from \"optimism\";\n\nimport type {\n Reference,\n StoreObject,\n FragmentMap,\n FragmentMapFunction,\n} from \"../../utilities/index.js\";\nimport {\n isField,\n resultKeyNameFromField,\n isReference,\n makeReference,\n shouldInclude,\n addTypenameToDocument,\n getDefaultValues,\n getMainDefinition,\n getQueryDefinition,\n getFragmentFromSelection,\n maybeDeepFreeze,\n mergeDeepArray,\n DeepMerger,\n isNonNullObject,\n canUseWeakMap,\n compact,\n canonicalStringify,\n cacheSizes,\n defaultCacheSizes,\n} from \"../../utilities/index.js\";\nimport type { Cache } from \"../core/types/Cache.js\";\nimport type {\n DiffQueryAgainstStoreOptions,\n InMemoryCacheConfig,\n NormalizedCache,\n ReadMergeModifyContext,\n} from \"./types.js\";\nimport {\n maybeDependOnExistenceOfEntity,\n supportsResultCaching,\n} from \"./entityStore.js\";\nimport {\n isArray,\n extractFragmentContext,\n getTypenameFromStoreObject,\n shouldCanonizeResults,\n} from \"./helpers.js\";\nimport type { Policies } from \"./policies.js\";\nimport type { InMemoryCache } from \"./inMemoryCache.js\";\nimport type { MissingTree } from \"../core/types/common.js\";\nimport { MissingFieldError } from \"../core/types/common.js\";\nimport { ObjectCanon } from \"./object-canon.js\";\n\nexport type VariableMap = { [name: string]: any };\n\ninterface ReadContext extends ReadMergeModifyContext {\n query: DocumentNode;\n policies: Policies;\n canonizeResults: boolean;\n fragmentMap: FragmentMap;\n lookupFragment: FragmentMapFunction;\n}\n\nexport type ExecResult = {\n result: R;\n missing?: MissingTree;\n};\n\ntype ExecSelectionSetOptions = {\n selectionSet: SelectionSetNode;\n objectOrReference: StoreObject | Reference;\n enclosingRef: Reference;\n context: ReadContext;\n};\n\ntype ExecSubSelectedArrayOptions = {\n field: FieldNode;\n array: readonly any[];\n enclosingRef: Reference;\n context: ReadContext;\n};\n\nexport interface StoreReaderConfig {\n cache: InMemoryCache;\n addTypename?: boolean;\n resultCacheMaxSize?: number;\n canonizeResults?: boolean;\n canon?: ObjectCanon;\n fragments?: InMemoryCacheConfig[\"fragments\"];\n}\n\n// Arguments type after keyArgs translation.\ntype ExecSelectionSetKeyArgs = [\n SelectionSetNode,\n StoreObject | Reference,\n ReadMergeModifyContext,\n boolean,\n];\n\nfunction execSelectionSetKeyArgs(\n options: ExecSelectionSetOptions\n): ExecSelectionSetKeyArgs {\n return [\n options.selectionSet,\n options.objectOrReference,\n options.context,\n // We split out this property so we can pass different values\n // independently without modifying options.context itself.\n options.context.canonizeResults,\n ];\n}\n\nexport class StoreReader {\n // cached version of executeSelectionSet\n private executeSelectionSet: OptimisticWrapperFunction<\n [ExecSelectionSetOptions], // Actual arguments tuple type.\n ExecResult, // Actual return type.\n ExecSelectionSetKeyArgs\n >;\n\n // cached version of executeSubSelectedArray\n private executeSubSelectedArray: OptimisticWrapperFunction<\n [ExecSubSelectedArrayOptions],\n ExecResult,\n [ExecSubSelectedArrayOptions]\n >;\n\n private config: {\n cache: InMemoryCache;\n addTypename: boolean;\n resultCacheMaxSize?: number;\n canonizeResults: boolean;\n fragments?: InMemoryCacheConfig[\"fragments\"];\n };\n\n private knownResults = new (canUseWeakMap ? WeakMap : Map)<\n Record,\n SelectionSetNode\n >();\n\n public canon: ObjectCanon;\n public resetCanon() {\n this.canon = new ObjectCanon();\n }\n\n constructor(config: StoreReaderConfig) {\n this.config = compact(config, {\n addTypename: config.addTypename !== false,\n canonizeResults: shouldCanonizeResults(config),\n });\n\n this.canon = config.canon || new ObjectCanon();\n\n // memoized functions in this class will be \"garbage-collected\"\n // by recreating the whole `StoreReader` in\n // `InMemoryCache.resetResultsCache`\n // (triggered from `InMemoryCache.gc` with `resetResultCache: true`)\n this.executeSelectionSet = wrap(\n (options) => {\n const { canonizeResults } = options.context;\n\n const peekArgs = execSelectionSetKeyArgs(options);\n\n // Negate this boolean option so we can find out if we've already read\n // this result using the other boolean value.\n peekArgs[3] = !canonizeResults;\n\n const other = this.executeSelectionSet.peek(...peekArgs);\n\n if (other) {\n if (canonizeResults) {\n return {\n ...other,\n // If we previously read this result without canonizing it, we can\n // reuse that result simply by canonizing it now.\n result: this.canon.admit(other.result),\n };\n }\n // If we previously read this result with canonization enabled, we can\n // return that canonized result as-is.\n return other;\n }\n\n maybeDependOnExistenceOfEntity(\n options.context.store,\n options.enclosingRef.__ref\n );\n\n // Finally, if we didn't find any useful previous results, run the real\n // execSelectionSetImpl method with the given options.\n return this.execSelectionSetImpl(options);\n },\n {\n max:\n this.config.resultCacheMaxSize ||\n cacheSizes[\"inMemoryCache.executeSelectionSet\"] ||\n defaultCacheSizes[\"inMemoryCache.executeSelectionSet\"],\n keyArgs: execSelectionSetKeyArgs,\n // Note that the parameters of makeCacheKey are determined by the\n // array returned by keyArgs.\n makeCacheKey(selectionSet, parent, context, canonizeResults) {\n if (supportsResultCaching(context.store)) {\n return context.store.makeCacheKey(\n selectionSet,\n isReference(parent) ? parent.__ref : parent,\n context.varString,\n canonizeResults\n );\n }\n },\n }\n );\n\n this.executeSubSelectedArray = wrap(\n (options: ExecSubSelectedArrayOptions) => {\n maybeDependOnExistenceOfEntity(\n options.context.store,\n options.enclosingRef.__ref\n );\n return this.execSubSelectedArrayImpl(options);\n },\n {\n max:\n this.config.resultCacheMaxSize ||\n cacheSizes[\"inMemoryCache.executeSubSelectedArray\"] ||\n defaultCacheSizes[\"inMemoryCache.executeSubSelectedArray\"],\n makeCacheKey({ field, array, context }) {\n if (supportsResultCaching(context.store)) {\n return context.store.makeCacheKey(field, array, context.varString);\n }\n },\n }\n );\n }\n\n /**\n * Given a store and a query, return as much of the result as possible and\n * identify if any data was missing from the store.\n */\n public diffQueryAgainstStore({\n store,\n query,\n rootId = \"ROOT_QUERY\",\n variables,\n returnPartialData = true,\n canonizeResults = this.config.canonizeResults,\n }: DiffQueryAgainstStoreOptions): Cache.DiffResult {\n const policies = this.config.cache.policies;\n\n variables = {\n ...getDefaultValues(getQueryDefinition(query)),\n ...variables!,\n };\n\n const rootRef = makeReference(rootId);\n const execResult = this.executeSelectionSet({\n selectionSet: getMainDefinition(query).selectionSet,\n objectOrReference: rootRef,\n enclosingRef: rootRef,\n context: {\n store,\n query,\n policies,\n variables,\n varString: canonicalStringify(variables),\n canonizeResults,\n ...extractFragmentContext(query, this.config.fragments),\n },\n });\n\n let missing: MissingFieldError[] | undefined;\n if (execResult.missing) {\n // For backwards compatibility we still report an array of\n // MissingFieldError objects, even though there will only ever be at most\n // one of them, now that all missing field error messages are grouped\n // together in the execResult.missing tree.\n missing = [\n new MissingFieldError(\n firstMissing(execResult.missing)!,\n execResult.missing,\n query,\n variables\n ),\n ];\n if (!returnPartialData) {\n throw missing[0];\n }\n }\n\n return {\n result: execResult.result,\n complete: !missing,\n missing,\n };\n }\n\n public isFresh(\n result: Record,\n parent: StoreObject | Reference,\n selectionSet: SelectionSetNode,\n context: ReadMergeModifyContext\n ): boolean {\n if (\n supportsResultCaching(context.store) &&\n this.knownResults.get(result) === selectionSet\n ) {\n const latest = this.executeSelectionSet.peek(\n selectionSet,\n parent,\n context,\n // If result is canonical, then it could only have been previously\n // cached by the canonizing version of executeSelectionSet, so we can\n // avoid checking both possibilities here.\n this.canon.isKnown(result)\n );\n if (latest && result === latest.result) {\n return true;\n }\n }\n return false;\n }\n\n // Uncached version of executeSelectionSet.\n private execSelectionSetImpl({\n selectionSet,\n objectOrReference,\n enclosingRef,\n context,\n }: ExecSelectionSetOptions): ExecResult {\n if (\n isReference(objectOrReference) &&\n !context.policies.rootTypenamesById[objectOrReference.__ref] &&\n !context.store.has(objectOrReference.__ref)\n ) {\n return {\n result: this.canon.empty,\n missing: `Dangling reference to missing ${objectOrReference.__ref} object`,\n };\n }\n\n const { variables, policies, store } = context;\n const typename = store.getFieldValue(\n objectOrReference,\n \"__typename\"\n );\n\n const objectsToMerge: Record[] = [];\n let missing: MissingTree | undefined;\n const missingMerger = new DeepMerger();\n\n if (\n this.config.addTypename &&\n typeof typename === \"string\" &&\n !policies.rootIdsByTypename[typename]\n ) {\n // Ensure we always include a default value for the __typename\n // field, if we have one, and this.config.addTypename is true. Note\n // that this field can be overridden by other merged objects.\n objectsToMerge.push({ __typename: typename });\n }\n\n function handleMissing(result: ExecResult, resultName: string): T {\n if (result.missing) {\n missing = missingMerger.merge(missing, {\n [resultName]: result.missing,\n });\n }\n return result.result;\n }\n\n const workSet = new Set(selectionSet.selections);\n\n workSet.forEach((selection) => {\n // Omit fields with directives @skip(if: ) or\n // @include(if: ).\n if (!shouldInclude(selection, variables)) return;\n\n if (isField(selection)) {\n let fieldValue = policies.readField(\n {\n fieldName: selection.name.value,\n field: selection,\n variables: context.variables,\n from: objectOrReference,\n },\n context\n );\n\n const resultName = resultKeyNameFromField(selection);\n\n if (fieldValue === void 0) {\n if (!addTypenameToDocument.added(selection)) {\n missing = missingMerger.merge(missing, {\n [resultName]: `Can't find field '${selection.name.value}' on ${\n isReference(objectOrReference) ?\n objectOrReference.__ref + \" object\"\n : \"object \" + JSON.stringify(objectOrReference, null, 2)\n }`,\n });\n }\n } else if (isArray(fieldValue)) {\n if (fieldValue.length > 0) {\n fieldValue = handleMissing(\n this.executeSubSelectedArray({\n field: selection,\n array: fieldValue,\n enclosingRef,\n context,\n }),\n resultName\n );\n }\n } else if (!selection.selectionSet) {\n // If the field does not have a selection set, then we handle it\n // as a scalar value. To keep this.canon from canonicalizing\n // this value, we use this.canon.pass to wrap fieldValue in a\n // Pass object that this.canon.admit will later unwrap as-is.\n if (context.canonizeResults) {\n fieldValue = this.canon.pass(fieldValue);\n }\n } else if (fieldValue != null) {\n // In this case, because we know the field has a selection set,\n // it must be trying to query a GraphQLObjectType, which is why\n // fieldValue must be != null.\n fieldValue = handleMissing(\n this.executeSelectionSet({\n selectionSet: selection.selectionSet,\n objectOrReference: fieldValue as StoreObject | Reference,\n enclosingRef: isReference(fieldValue) ? fieldValue : enclosingRef,\n context,\n }),\n resultName\n );\n }\n\n if (fieldValue !== void 0) {\n objectsToMerge.push({ [resultName]: fieldValue });\n }\n } else {\n const fragment = getFragmentFromSelection(\n selection,\n context.lookupFragment\n );\n\n if (!fragment && selection.kind === Kind.FRAGMENT_SPREAD) {\n throw newInvariantError(`No fragment named %s`, selection.name.value);\n }\n\n if (fragment && policies.fragmentMatches(fragment, typename)) {\n fragment.selectionSet.selections.forEach(workSet.add, workSet);\n }\n }\n });\n\n const result = mergeDeepArray(objectsToMerge);\n const finalResult: ExecResult = { result, missing };\n const frozen =\n context.canonizeResults ?\n this.canon.admit(finalResult)\n // Since this.canon is normally responsible for freezing results (only in\n // development), freeze them manually if canonization is disabled.\n : maybeDeepFreeze(finalResult);\n\n // Store this result with its selection set so that we can quickly\n // recognize it again in the StoreReader#isFresh method.\n if (frozen.result) {\n this.knownResults.set(frozen.result, selectionSet);\n }\n\n return frozen;\n }\n\n // Uncached version of executeSubSelectedArray.\n private execSubSelectedArrayImpl({\n field,\n array,\n enclosingRef,\n context,\n }: ExecSubSelectedArrayOptions): ExecResult {\n let missing: MissingTree | undefined;\n let missingMerger = new DeepMerger();\n\n function handleMissing(childResult: ExecResult, i: number): T {\n if (childResult.missing) {\n missing = missingMerger.merge(missing, { [i]: childResult.missing });\n }\n return childResult.result;\n }\n\n if (field.selectionSet) {\n array = array.filter(context.store.canRead);\n }\n\n array = array.map((item, i) => {\n // null value in array\n if (item === null) {\n return null;\n }\n\n // This is a nested array, recurse\n if (isArray(item)) {\n return handleMissing(\n this.executeSubSelectedArray({\n field,\n array: item,\n enclosingRef,\n context,\n }),\n i\n );\n }\n\n // This is an object, run the selection set on it\n if (field.selectionSet) {\n return handleMissing(\n this.executeSelectionSet({\n selectionSet: field.selectionSet,\n objectOrReference: item,\n enclosingRef: isReference(item) ? item : enclosingRef,\n context,\n }),\n i\n );\n }\n\n if (__DEV__) {\n assertSelectionSetForIdValue(context.store, field, item);\n }\n\n return item;\n });\n\n return {\n result: context.canonizeResults ? this.canon.admit(array) : array,\n missing,\n };\n }\n}\n\nfunction firstMissing(tree: MissingTree): string | undefined {\n try {\n JSON.stringify(tree, (_, value) => {\n if (typeof value === \"string\") throw value;\n return value;\n });\n } catch (result) {\n return result as string;\n }\n}\n\nfunction assertSelectionSetForIdValue(\n store: NormalizedCache,\n field: FieldNode,\n fieldValue: any\n) {\n if (!field.selectionSet) {\n const workSet = new Set([fieldValue]);\n workSet.forEach((value) => {\n if (isNonNullObject(value)) {\n invariant(\n !isReference(value),\n `Missing selection set for object of type %s returned for query field %s`,\n getTypenameFromStoreObject(store, value),\n field.name.value\n );\n Object.values(value).forEach(workSet.add, workSet);\n }\n });\n }\n}\n","import { invariant } from \"../../utilities/globals/index.js\";\n\nimport {\n argumentsObjectFromField,\n DeepMerger,\n isNonEmptyArray,\n isNonNullObject,\n} from \"../../utilities/index.js\";\n\nimport { hasOwn, isArray } from \"./helpers.js\";\nimport type {\n KeySpecifier,\n KeyFieldsFunction,\n KeyArgsFunction,\n} from \"./policies.js\";\n\n// Mapping from JSON-encoded KeySpecifier strings to associated information.\nconst specifierInfoCache: Record<\n string,\n {\n paths?: string[][];\n keyFieldsFn?: KeyFieldsFunction;\n keyArgsFn?: KeyArgsFunction;\n }\n> = Object.create(null);\n\nfunction lookupSpecifierInfo(spec: KeySpecifier) {\n // It's safe to encode KeySpecifier arrays with JSON.stringify, since they're\n // just arrays of strings or nested KeySpecifier arrays, and the order of the\n // array elements is important (and suitably preserved by JSON.stringify).\n const cacheKey = JSON.stringify(spec);\n return (\n specifierInfoCache[cacheKey] ||\n (specifierInfoCache[cacheKey] = Object.create(null))\n );\n}\n\nexport function keyFieldsFnFromSpecifier(\n specifier: KeySpecifier\n): KeyFieldsFunction {\n const info = lookupSpecifierInfo(specifier);\n\n return (\n info.keyFieldsFn ||\n (info.keyFieldsFn = (object, context) => {\n const extract: typeof extractKey = (from, key) =>\n context.readField(key, from);\n\n const keyObject = (context.keyObject = collectSpecifierPaths(\n specifier,\n (schemaKeyPath) => {\n let extracted = extractKeyPath(\n context.storeObject,\n schemaKeyPath,\n // Using context.readField to extract paths from context.storeObject\n // allows the extraction to see through Reference objects and respect\n // custom read functions.\n extract\n );\n\n if (\n extracted === void 0 &&\n object !== context.storeObject &&\n hasOwn.call(object, schemaKeyPath[0])\n ) {\n // If context.storeObject fails to provide a value for the requested\n // path, fall back to the raw result object, if it has a top-level key\n // matching the first key in the path (schemaKeyPath[0]). This allows\n // key fields included in the written data to be saved in the cache\n // even if they are not selected explicitly in context.selectionSet.\n // Not being mentioned by context.selectionSet is convenient here,\n // since it means these extra fields cannot be affected by field\n // aliasing, which is why we can use extractKey instead of\n // context.readField for this extraction.\n extracted = extractKeyPath(object, schemaKeyPath, extractKey);\n }\n\n invariant(\n extracted !== void 0,\n `Missing field '%s' while extracting keyFields from %s`,\n schemaKeyPath.join(\".\"),\n object\n );\n\n return extracted;\n }\n ));\n\n return `${context.typename}:${JSON.stringify(keyObject)}`;\n })\n );\n}\n\n// The keyArgs extraction process is roughly analogous to keyFields extraction,\n// but there are no aliases involved, missing fields are tolerated (by merely\n// omitting them from the key), and drawing from field.directives or variables\n// is allowed (in addition to drawing from the field's arguments object).\n// Concretely, these differences mean passing a different key path extractor\n// function to collectSpecifierPaths, reusing the shared extractKeyPath helper\n// wherever possible.\nexport function keyArgsFnFromSpecifier(\n specifier: KeySpecifier\n): KeyArgsFunction {\n const info = lookupSpecifierInfo(specifier);\n\n return (\n info.keyArgsFn ||\n (info.keyArgsFn = (args, { field, variables, fieldName }) => {\n const collected = collectSpecifierPaths(specifier, (keyPath) => {\n const firstKey = keyPath[0];\n const firstChar = firstKey.charAt(0);\n\n if (firstChar === \"@\") {\n if (field && isNonEmptyArray(field.directives)) {\n const directiveName = firstKey.slice(1);\n // If the directive appears multiple times, only the first\n // occurrence's arguments will be used. TODO Allow repetition?\n // TODO Cache this work somehow, a la aliasMap?\n const d = field.directives.find(\n (d) => d.name.value === directiveName\n );\n // Fortunately argumentsObjectFromField works for DirectiveNode!\n const directiveArgs = d && argumentsObjectFromField(d, variables);\n // For directives without arguments (d defined, but directiveArgs ===\n // null), the presence or absence of the directive still counts as\n // part of the field key, so we return null in those cases. If no\n // directive with this name was found for this field (d undefined and\n // thus directiveArgs undefined), we return undefined, which causes\n // this value to be omitted from the key object returned by\n // collectSpecifierPaths.\n return (\n directiveArgs &&\n extractKeyPath(\n directiveArgs,\n // If keyPath.length === 1, this code calls extractKeyPath with an\n // empty path, which works because it uses directiveArgs as the\n // extracted value.\n keyPath.slice(1)\n )\n );\n }\n // If the key started with @ but there was no corresponding directive,\n // we want to omit this value from the key object, not fall through to\n // treating @whatever as a normal argument name.\n return;\n }\n\n if (firstChar === \"$\") {\n const variableName = firstKey.slice(1);\n if (variables && hasOwn.call(variables, variableName)) {\n const varKeyPath = keyPath.slice(0);\n varKeyPath[0] = variableName;\n return extractKeyPath(variables, varKeyPath);\n }\n // If the key started with $ but there was no corresponding variable, we\n // want to omit this value from the key object, not fall through to\n // treating $whatever as a normal argument name.\n return;\n }\n\n if (args) {\n return extractKeyPath(args, keyPath);\n }\n });\n\n const suffix = JSON.stringify(collected);\n\n // If no arguments were passed to this field, and it didn't have any other\n // field key contributions from directives or variables, hide the empty\n // :{} suffix from the field key. However, a field passed no arguments can\n // still end up with a non-empty :{...} suffix if its key configuration\n // refers to directives or variables.\n if (args || suffix !== \"{}\") {\n fieldName += \":\" + suffix;\n }\n\n return fieldName;\n })\n );\n}\n\nexport function collectSpecifierPaths(\n specifier: KeySpecifier,\n extractor: (path: string[]) => any\n): Record {\n // For each path specified by specifier, invoke the extractor, and repeatedly\n // merge the results together, with appropriate ancestor context.\n const merger = new DeepMerger();\n return getSpecifierPaths(specifier).reduce((collected, path) => {\n let toMerge = extractor(path);\n if (toMerge !== void 0) {\n // This path is not expected to contain array indexes, so the toMerge\n // reconstruction will not contain arrays. TODO Fix this?\n for (let i = path.length - 1; i >= 0; --i) {\n toMerge = { [path[i]]: toMerge };\n }\n collected = merger.merge(collected, toMerge);\n }\n return collected;\n }, Object.create(null));\n}\n\nexport function getSpecifierPaths(spec: KeySpecifier): string[][] {\n const info = lookupSpecifierInfo(spec);\n\n if (!info.paths) {\n const paths: string[][] = (info.paths = []);\n const currentPath: string[] = [];\n\n spec.forEach((s, i) => {\n if (isArray(s)) {\n getSpecifierPaths(s).forEach((p) => paths.push(currentPath.concat(p)));\n currentPath.length = 0;\n } else {\n currentPath.push(s);\n if (!isArray(spec[i + 1])) {\n paths.push(currentPath.slice(0));\n currentPath.length = 0;\n }\n }\n });\n }\n\n return info.paths!;\n}\n\nfunction extractKey, TKey extends string>(\n object: TObj,\n key: TKey\n): TObj[TKey] | undefined {\n return object[key];\n}\n\nexport function extractKeyPath(\n object: Record,\n path: string[],\n extract?: typeof extractKey\n): any {\n // For each key in path, extract the corresponding child property from obj,\n // flattening arrays if encountered (uncommon for keyFields and keyArgs, but\n // possible). The final result of path.reduce is normalized so unexpected leaf\n // objects have their keys safely sorted. That final result is difficult to\n // type as anything other than any. You're welcome to try to improve the\n // return type, but keep in mind extractKeyPath is not a public function\n // (exported only for testing), so the effort may not be worthwhile unless the\n // limited set of actual callers (see above) pass arguments that TypeScript\n // can statically type. If we know only that path is some array of strings\n // (and not, say, a specific tuple of statically known strings), any (or\n // possibly unknown) is the honest answer.\n extract = extract || extractKey;\n return normalize(\n path.reduce(function reducer(obj, key): any {\n return isArray(obj) ?\n obj.map((child) => reducer(child, key))\n : obj && extract!(obj, key);\n }, object)\n );\n}\n\nfunction normalize(value: T): T {\n // Usually the extracted value will be a scalar value, since most primary\n // key fields are scalar, but just in case we get an object or an array, we\n // need to do some normalization of the order of (nested) keys.\n if (isNonNullObject(value)) {\n if (isArray(value)) {\n return value.map(normalize) as any;\n }\n return collectSpecifierPaths(Object.keys(value).sort(), (path) =>\n extractKeyPath(value, path)\n ) as T;\n }\n return value;\n}\n","import { invariant, newInvariantError } from \"../../utilities/globals/index.js\";\n\nimport type {\n InlineFragmentNode,\n FragmentDefinitionNode,\n SelectionSetNode,\n FieldNode,\n} from \"graphql\";\n\nimport type {\n FragmentMap,\n StoreValue,\n StoreObject,\n Reference,\n} from \"../../utilities/index.js\";\nimport {\n storeKeyNameFromField,\n argumentsObjectFromField,\n isReference,\n getStoreKeyName,\n isNonNullObject,\n stringifyForDisplay,\n} from \"../../utilities/index.js\";\nimport type {\n IdGetter,\n MergeInfo,\n NormalizedCache,\n ReadMergeModifyContext,\n} from \"./types.js\";\nimport {\n hasOwn,\n fieldNameFromStoreName,\n storeValueIsStoreObject,\n selectionSetMatchesResult,\n TypeOrFieldNameRegExp,\n defaultDataIdFromObject,\n isArray,\n} from \"./helpers.js\";\nimport { cacheSlot } from \"./reactiveVars.js\";\nimport type { InMemoryCache } from \"./inMemoryCache.js\";\nimport type {\n SafeReadonly,\n FieldSpecifier,\n ToReferenceFunction,\n ReadFieldFunction,\n ReadFieldOptions,\n CanReadFunction,\n} from \"../core/types/common.js\";\nimport type { WriteContext } from \"./writeToStore.js\";\n\nimport {\n keyArgsFnFromSpecifier,\n keyFieldsFnFromSpecifier,\n} from \"./key-extractor.js\";\n\nexport type TypePolicies = {\n [__typename: string]: TypePolicy;\n};\n\n// TypeScript 3.7 will allow recursive type aliases, so this should work:\n// type KeySpecifier = (string | KeySpecifier)[]\nexport type KeySpecifier = ReadonlyArray;\n\nexport type KeyFieldsContext = {\n // The __typename of the incoming object, even if the __typename field was\n // aliased to another name in the raw result object. May be undefined when\n // dataIdFromObject is called for objects without __typename fields.\n typename: string | undefined;\n\n // The object to be identified, after processing to remove aliases and\n // normalize identifiable child objects with references.\n storeObject: StoreObject;\n\n // Handy tool for reading additional fields from context.storeObject, either\n // readField(\"fieldName\") to read storeObject[fieldName], or readField(\"name\",\n // objectOrReference) to read from another object or Reference. If you read a\n // field with a read function, that function will be invoked.\n readField: ReadFieldFunction;\n\n // If you are writing a custom keyFields function, and you plan to use the raw\n // result object passed as the first argument, you may also need access to the\n // selection set and available fragments for this object, just in case any\n // fields have aliases. Since this logic is tricky to get right, and these\n // context properties are not even always provided (for example, they are\n // omitted when calling cache.identify(object), where object is assumed to be\n // a StoreObject), we recommend you use context.storeObject (which has already\n // been de-aliased) and context.readField (which can read from references as\n // well as objects) instead of the raw result object in your keyFields\n // functions, or just rely on the internal implementation of keyFields:[...]\n // syntax to get these details right for you.\n selectionSet?: SelectionSetNode;\n fragmentMap?: FragmentMap;\n\n // Internal. May be set by the KeyFieldsFunction to report fields that were\n // involved in computing the ID. Never passed in by the caller.\n keyObject?: Record;\n};\n\nexport type KeyFieldsFunction = (\n object: Readonly,\n context: KeyFieldsContext\n) => KeySpecifier | false | ReturnType;\n\ntype KeyFieldsResult = Exclude, KeySpecifier>;\n\n// TODO Should TypePolicy be a generic type, with a TObject or TEntity\n// type parameter?\nexport type TypePolicy = {\n // Allows defining the primary key fields for this type, either using an\n // array of field names or a function that returns an arbitrary string.\n keyFields?: KeySpecifier | KeyFieldsFunction | false;\n\n // Allows defining a merge function (or merge:true/false shorthand) to\n // be used for merging objects of this type wherever they appear, unless\n // the parent field also defines a merge function/boolean (that is,\n // parent field merge functions take precedence over type policy merge\n // functions). In many cases, defining merge:true for a given type\n // policy can save you from specifying merge:true for all the field\n // policies where that type might be encountered.\n merge?: FieldMergeFunction | boolean;\n\n // In the rare event that your schema happens to use a different\n // __typename for the root Query, Mutation, and/or Schema types, you can\n // express your deviant preferences by enabling one of these options.\n queryType?: true;\n mutationType?: true;\n subscriptionType?: true;\n\n fields?: {\n [fieldName: string]: FieldPolicy | FieldReadFunction;\n };\n};\n\nexport type KeyArgsFunction = (\n args: Record | null,\n context: {\n typename: string;\n fieldName: string;\n field: FieldNode | null;\n variables?: Record;\n }\n) => KeySpecifier | false | ReturnType;\n\nexport type FieldPolicy<\n // The internal representation used to store the field's data in the\n // cache. Must be JSON-serializable if you plan to serialize the result\n // of cache.extract() using JSON.\n TExisting = any,\n // The type of the incoming parameter passed to the merge function,\n // typically matching the GraphQL response format, but with Reference\n // objects substituted for any identifiable child objects. Often the\n // same as TExisting, but not necessarily.\n TIncoming = TExisting,\n // The type that the read function actually returns, using TExisting\n // data and options.args as input. Usually the same as TIncoming.\n TReadResult = TIncoming,\n // Allows FieldFunctionOptions definition to be overwritten by the\n // developer\n TOptions extends FieldFunctionOptions = FieldFunctionOptions,\n> = {\n keyArgs?: KeySpecifier | KeyArgsFunction | false;\n read?: FieldReadFunction;\n merge?: FieldMergeFunction | boolean;\n};\n\nexport type StorageType = Record;\n\nfunction argsFromFieldSpecifier(spec: FieldSpecifier) {\n return (\n spec.args !== void 0 ? spec.args\n : spec.field ? argumentsObjectFromField(spec.field, spec.variables)\n : null\n );\n}\n\nexport interface FieldFunctionOptions<\n TArgs = Record,\n TVars = Record,\n> {\n args: TArgs | null;\n\n // The name of the field, equal to options.field.name.value when\n // options.field is available. Useful if you reuse the same function for\n // multiple fields, and you need to know which field you're currently\n // processing. Always a string, even when options.field is null.\n fieldName: string;\n\n // The full field key used internally, including serialized key arguments.\n storeFieldName: string;\n\n // The FieldNode object used to read this field. Useful if you need to\n // know about other attributes of the field, such as its directives. This\n // option will be null when a string was passed to options.readField.\n field: FieldNode | null;\n\n variables?: TVars;\n\n // Utilities for dealing with { __ref } objects.\n isReference: typeof isReference;\n toReference: ToReferenceFunction;\n\n // A handy place to put field-specific data that you want to survive\n // across multiple read function calls. Useful for field-level caching,\n // if your read function does any expensive work.\n storage: StorageType;\n\n cache: InMemoryCache;\n\n // Helper function for reading other fields within the current object.\n // If a foreign object or reference is provided, the field will be read\n // from that object instead of the current object, so this function can\n // be used (together with isReference) to examine the cache outside the\n // current object. If a FieldNode is passed instead of a string, and\n // that FieldNode has arguments, the same options.variables will be used\n // to compute the argument values. Note that this function will invoke\n // custom read functions for other fields, if defined. Always returns\n // immutable data (enforced with Object.freeze in development).\n readField: ReadFieldFunction;\n\n // Returns true for non-normalized StoreObjects and non-dangling\n // References, indicating that readField(name, objOrRef) has a chance of\n // working. Useful for filtering out dangling references from lists.\n canRead: CanReadFunction;\n\n // Instead of just merging objects with { ...existing, ...incoming }, this\n // helper function can be used to merge objects in a way that respects any\n // custom merge functions defined for their fields.\n mergeObjects: MergeObjectsFunction;\n}\n\ntype MergeObjectsFunction = (\n existing: T,\n incoming: T\n) => T;\n\nexport type FieldReadFunction<\n TExisting = any,\n TReadResult = TExisting,\n TOptions extends FieldFunctionOptions = FieldFunctionOptions,\n> = (\n // When reading a field, one often needs to know about any existing\n // value stored for that field. If the field is read before any value\n // has been written to the cache, this existing parameter will be\n // undefined, which makes it easy to use a default parameter expression\n // to supply the initial value. This parameter is positional (rather\n // than one of the named options) because that makes it possible for the\n // developer to annotate it with a type, without also having to provide\n // a whole new type for the options object.\n existing: SafeReadonly | undefined,\n options: TOptions\n) => TReadResult | undefined;\n\nexport type FieldMergeFunction<\n TExisting = any,\n TIncoming = TExisting,\n // Passing the whole FieldFunctionOptions makes the current definition\n // independent from its implementation\n TOptions extends FieldFunctionOptions = FieldFunctionOptions,\n> = (\n existing: SafeReadonly | undefined,\n // The incoming parameter needs to be positional as well, for the same\n // reasons discussed in FieldReadFunction above.\n incoming: SafeReadonly,\n options: TOptions\n) => SafeReadonly;\n\nconst nullKeyFieldsFn: KeyFieldsFunction = () => void 0;\nconst simpleKeyArgsFn: KeyArgsFunction = (_args, context) => context.fieldName;\n\n// These merge functions can be selected by specifying merge:true or\n// merge:false in a field policy.\nconst mergeTrueFn: FieldMergeFunction = (\n existing,\n incoming,\n { mergeObjects }\n) => mergeObjects(existing, incoming);\nconst mergeFalseFn: FieldMergeFunction = (_, incoming) => incoming;\n\nexport type PossibleTypesMap = {\n [supertype: string]: string[];\n};\n\nexport class Policies {\n private typePolicies: {\n [__typename: string]: {\n keyFn?: KeyFieldsFunction;\n merge?: FieldMergeFunction;\n fields: {\n [fieldName: string]: {\n keyFn?: KeyArgsFunction;\n read?: FieldReadFunction;\n merge?: FieldMergeFunction;\n };\n };\n };\n } = Object.create(null);\n\n private toBeAdded: {\n [__typename: string]: TypePolicy[];\n } = Object.create(null);\n\n // Map from subtype names to sets of supertype names. Note that this\n // representation inverts the structure of possibleTypes (whose keys are\n // supertypes and whose values are arrays of subtypes) because it tends\n // to be much more efficient to search upwards than downwards.\n private supertypeMap = new Map>();\n\n // Any fuzzy subtypes specified by possibleTypes will be converted to\n // RegExp objects and recorded here. Every key of this map can also be\n // found in supertypeMap. In many cases this Map will be empty, which\n // means no fuzzy subtype checking will happen in fragmentMatches.\n private fuzzySubtypes = new Map();\n\n public readonly cache: InMemoryCache;\n\n public readonly rootIdsByTypename: Record =\n Object.create(null);\n public readonly rootTypenamesById: Record =\n Object.create(null);\n\n public readonly usingPossibleTypes = false;\n\n constructor(\n private config: {\n cache: InMemoryCache;\n dataIdFromObject?: KeyFieldsFunction;\n possibleTypes?: PossibleTypesMap;\n typePolicies?: TypePolicies;\n }\n ) {\n this.config = {\n dataIdFromObject: defaultDataIdFromObject,\n ...config,\n };\n\n this.cache = this.config.cache;\n\n this.setRootTypename(\"Query\");\n this.setRootTypename(\"Mutation\");\n this.setRootTypename(\"Subscription\");\n\n if (config.possibleTypes) {\n this.addPossibleTypes(config.possibleTypes);\n }\n\n if (config.typePolicies) {\n this.addTypePolicies(config.typePolicies);\n }\n }\n\n public identify(\n object: StoreObject,\n partialContext?: Partial\n ): [string?, StoreObject?] {\n const policies = this;\n\n const typename =\n (partialContext &&\n (partialContext.typename || partialContext.storeObject?.__typename)) ||\n object.__typename;\n\n // It should be possible to write root Query fields with writeFragment,\n // using { __typename: \"Query\", ... } as the data, but it does not make\n // sense to allow the same identification behavior for the Mutation and\n // Subscription types, since application code should never be writing\n // directly to (or reading directly from) those root objects.\n if (typename === this.rootTypenamesById.ROOT_QUERY) {\n return [\"ROOT_QUERY\"];\n }\n\n // Default context.storeObject to object if not otherwise provided.\n const storeObject =\n (partialContext && partialContext.storeObject) || object;\n\n const context: KeyFieldsContext = {\n ...partialContext,\n typename,\n storeObject,\n readField:\n (partialContext && partialContext.readField) ||\n function () {\n const options = normalizeReadFieldOptions(arguments, storeObject);\n return policies.readField(options, {\n store: policies.cache[\"data\"],\n variables: options.variables,\n });\n },\n };\n\n let id: KeyFieldsResult;\n\n const policy = typename && this.getTypePolicy(typename);\n let keyFn = (policy && policy.keyFn) || this.config.dataIdFromObject;\n while (keyFn) {\n const specifierOrId = keyFn({ ...object, ...storeObject }, context);\n if (isArray(specifierOrId)) {\n keyFn = keyFieldsFnFromSpecifier(specifierOrId);\n } else {\n id = specifierOrId;\n break;\n }\n }\n\n id = id ? String(id) : void 0;\n return context.keyObject ? [id, context.keyObject] : [id];\n }\n\n public addTypePolicies(typePolicies: TypePolicies) {\n Object.keys(typePolicies).forEach((typename) => {\n const { queryType, mutationType, subscriptionType, ...incoming } =\n typePolicies[typename];\n\n // Though {query,mutation,subscription}Type configurations are rare,\n // it's important to call setRootTypename as early as possible,\n // since these configurations should apply consistently for the\n // entire lifetime of the cache. Also, since only one __typename can\n // qualify as one of these root types, these three properties cannot\n // be inherited, unlike the rest of the incoming properties. That\n // restriction is convenient, because the purpose of this.toBeAdded\n // is to delay the processing of type/field policies until the first\n // time they're used, allowing policies to be added in any order as\n // long as all relevant policies (including policies for supertypes)\n // have been added by the time a given policy is used for the first\n // time. In other words, since inheritance doesn't matter for these\n // properties, there's also no need to delay their processing using\n // the this.toBeAdded queue.\n if (queryType) this.setRootTypename(\"Query\", typename);\n if (mutationType) this.setRootTypename(\"Mutation\", typename);\n if (subscriptionType) this.setRootTypename(\"Subscription\", typename);\n\n if (hasOwn.call(this.toBeAdded, typename)) {\n this.toBeAdded[typename].push(incoming);\n } else {\n this.toBeAdded[typename] = [incoming];\n }\n });\n }\n\n private updateTypePolicy(typename: string, incoming: TypePolicy) {\n const existing = this.getTypePolicy(typename);\n const { keyFields, fields } = incoming;\n\n function setMerge(\n existing: { merge?: FieldMergeFunction | boolean },\n merge?: FieldMergeFunction | boolean\n ) {\n existing.merge =\n typeof merge === \"function\" ? merge\n // Pass merge:true as a shorthand for a merge implementation\n // that returns options.mergeObjects(existing, incoming).\n : merge === true ? mergeTrueFn\n // Pass merge:false to make incoming always replace existing\n // without any warnings about data clobbering.\n : merge === false ? mergeFalseFn\n : existing.merge;\n }\n\n // Type policies can define merge functions, as an alternative to\n // using field policies to merge child objects.\n setMerge(existing, incoming.merge);\n\n existing.keyFn =\n // Pass false to disable normalization for this typename.\n keyFields === false ? nullKeyFieldsFn\n // Pass an array of strings to use those fields to compute a\n // composite ID for objects of this typename.\n : isArray(keyFields) ? keyFieldsFnFromSpecifier(keyFields)\n // Pass a function to take full control over identification.\n : typeof keyFields === \"function\" ? keyFields\n // Leave existing.keyFn unchanged if above cases fail.\n : existing.keyFn;\n\n if (fields) {\n Object.keys(fields).forEach((fieldName) => {\n const existing = this.getFieldPolicy(typename, fieldName, true)!;\n const incoming = fields[fieldName];\n\n if (typeof incoming === \"function\") {\n existing.read = incoming;\n } else {\n const { keyArgs, read, merge } = incoming;\n\n existing.keyFn =\n // Pass false to disable argument-based differentiation of\n // field identities.\n keyArgs === false ? simpleKeyArgsFn\n // Pass an array of strings to use named arguments to\n // compute a composite identity for the field.\n : isArray(keyArgs) ? keyArgsFnFromSpecifier(keyArgs)\n // Pass a function to take full control over field identity.\n : typeof keyArgs === \"function\" ? keyArgs\n // Leave existing.keyFn unchanged if above cases fail.\n : existing.keyFn;\n\n if (typeof read === \"function\") {\n existing.read = read;\n }\n\n setMerge(existing, merge);\n }\n\n if (existing.read && existing.merge) {\n // If we have both a read and a merge function, assume\n // keyArgs:false, because read and merge together can take\n // responsibility for interpreting arguments in and out. This\n // default assumption can always be overridden by specifying\n // keyArgs explicitly in the FieldPolicy.\n existing.keyFn = existing.keyFn || simpleKeyArgsFn;\n }\n });\n }\n }\n\n private setRootTypename(\n which: \"Query\" | \"Mutation\" | \"Subscription\",\n typename: string = which\n ) {\n const rootId = \"ROOT_\" + which.toUpperCase();\n const old = this.rootTypenamesById[rootId];\n if (typename !== old) {\n invariant(\n !old || old === which,\n `Cannot change root %s __typename more than once`,\n which\n );\n // First, delete any old __typename associated with this rootId from\n // rootIdsByTypename.\n if (old) delete this.rootIdsByTypename[old];\n // Now make this the only __typename that maps to this rootId.\n this.rootIdsByTypename[typename] = rootId;\n // Finally, update the __typename associated with this rootId.\n this.rootTypenamesById[rootId] = typename;\n }\n }\n\n public addPossibleTypes(possibleTypes: PossibleTypesMap) {\n (this.usingPossibleTypes as boolean) = true;\n Object.keys(possibleTypes).forEach((supertype) => {\n // Make sure all types have an entry in this.supertypeMap, even if\n // their supertype set is empty, so we can return false immediately\n // from policies.fragmentMatches for unknown supertypes.\n this.getSupertypeSet(supertype, true);\n\n possibleTypes[supertype].forEach((subtype) => {\n this.getSupertypeSet(subtype, true)!.add(supertype);\n const match = subtype.match(TypeOrFieldNameRegExp);\n if (!match || match[0] !== subtype) {\n // TODO Don't interpret just any invalid typename as a RegExp.\n this.fuzzySubtypes.set(subtype, new RegExp(subtype));\n }\n });\n });\n }\n\n private getTypePolicy(typename: string): Policies[\"typePolicies\"][string] {\n if (!hasOwn.call(this.typePolicies, typename)) {\n const policy: Policies[\"typePolicies\"][string] = (this.typePolicies[\n typename\n ] = Object.create(null));\n policy.fields = Object.create(null);\n\n // When the TypePolicy for typename is first accessed, instead of\n // starting with an empty policy object, inherit any properties or\n // fields from the type policies of the supertypes of typename.\n //\n // Any properties or fields defined explicitly within the TypePolicy\n // for typename will take precedence, and if there are multiple\n // supertypes, the properties of policies whose types were added\n // later via addPossibleTypes will take precedence over those of\n // earlier supertypes. TODO Perhaps we should warn about these\n // conflicts in development, and recommend defining the property\n // explicitly in the subtype policy?\n //\n // Field policy inheritance is atomic/shallow: you can't inherit a\n // field policy and then override just its read function, since read\n // and merge functions often need to cooperate, so changing only one\n // of them would be a recipe for inconsistency.\n //\n // Once the TypePolicy for typename has been accessed, its properties can\n // still be updated directly using addTypePolicies, but future changes to\n // inherited supertype policies will not be reflected in this subtype\n // policy, because this code runs at most once per typename.\n let supertypes = this.supertypeMap.get(typename);\n if (!supertypes && this.fuzzySubtypes.size) {\n // To make the inheritance logic work for unknown typename strings that\n // may have fuzzy supertypes, we give this typename an empty supertype\n // set and then populate it with any fuzzy supertypes that match.\n supertypes = this.getSupertypeSet(typename, true)!;\n // This only works for typenames that are directly matched by a fuzzy\n // supertype. What if there is an intermediate chain of supertypes?\n // While possible, that situation can only be solved effectively by\n // specifying the intermediate relationships via possibleTypes, manually\n // and in a non-fuzzy way.\n this.fuzzySubtypes.forEach((regExp, fuzzy) => {\n if (regExp.test(typename)) {\n // The fuzzy parameter is just the original string version of regExp\n // (not a valid __typename string), but we can look up the\n // associated supertype(s) in this.supertypeMap.\n const fuzzySupertypes = this.supertypeMap.get(fuzzy);\n if (fuzzySupertypes) {\n fuzzySupertypes.forEach((supertype) =>\n supertypes!.add(supertype)\n );\n }\n }\n });\n }\n if (supertypes && supertypes.size) {\n supertypes.forEach((supertype) => {\n const { fields, ...rest } = this.getTypePolicy(supertype);\n Object.assign(policy, rest);\n Object.assign(policy.fields, fields);\n });\n }\n }\n\n const inbox = this.toBeAdded[typename];\n if (inbox && inbox.length) {\n // Merge the pending policies into this.typePolicies, in the order they\n // were originally passed to addTypePolicy.\n inbox.splice(0).forEach((policy) => {\n this.updateTypePolicy(typename, policy);\n });\n }\n\n return this.typePolicies[typename];\n }\n\n private getFieldPolicy(\n typename: string | undefined,\n fieldName: string,\n createIfMissing: boolean\n ):\n | {\n keyFn?: KeyArgsFunction;\n read?: FieldReadFunction;\n merge?: FieldMergeFunction;\n }\n | undefined {\n if (typename) {\n const fieldPolicies = this.getTypePolicy(typename).fields;\n return (\n fieldPolicies[fieldName] ||\n (createIfMissing && (fieldPolicies[fieldName] = Object.create(null)))\n );\n }\n }\n\n private getSupertypeSet(\n subtype: string,\n createIfMissing: boolean\n ): Set | undefined {\n let supertypeSet = this.supertypeMap.get(subtype);\n if (!supertypeSet && createIfMissing) {\n this.supertypeMap.set(subtype, (supertypeSet = new Set()));\n }\n return supertypeSet;\n }\n\n public fragmentMatches(\n fragment: InlineFragmentNode | FragmentDefinitionNode,\n typename: string | undefined,\n result?: Record,\n variables?: Record\n ): boolean {\n if (!fragment.typeCondition) return true;\n\n // If the fragment has a type condition but the object we're matching\n // against does not have a __typename, the fragment cannot match.\n if (!typename) return false;\n\n const supertype = fragment.typeCondition.name.value;\n // Common case: fragment type condition and __typename are the same.\n if (typename === supertype) return true;\n\n if (this.usingPossibleTypes && this.supertypeMap.has(supertype)) {\n const typenameSupertypeSet = this.getSupertypeSet(typename, true)!;\n const workQueue = [typenameSupertypeSet];\n const maybeEnqueue = (subtype: string) => {\n const supertypeSet = this.getSupertypeSet(subtype, false);\n if (\n supertypeSet &&\n supertypeSet.size &&\n workQueue.indexOf(supertypeSet) < 0\n ) {\n workQueue.push(supertypeSet);\n }\n };\n\n // We need to check fuzzy subtypes only if we encountered fuzzy\n // subtype strings in addPossibleTypes, and only while writing to\n // the cache, since that's when selectionSetMatchesResult gives a\n // strong signal of fragment matching. The StoreReader class calls\n // policies.fragmentMatches without passing a result object, so\n // needToCheckFuzzySubtypes is always false while reading.\n let needToCheckFuzzySubtypes = !!(result && this.fuzzySubtypes.size);\n let checkingFuzzySubtypes = false;\n\n // It's important to keep evaluating workQueue.length each time through\n // the loop, because the queue can grow while we're iterating over it.\n for (let i = 0; i < workQueue.length; ++i) {\n const supertypeSet = workQueue[i];\n\n if (supertypeSet.has(supertype)) {\n if (!typenameSupertypeSet.has(supertype)) {\n if (checkingFuzzySubtypes) {\n invariant.warn(\n `Inferring subtype %s of supertype %s`,\n typename,\n supertype\n );\n }\n // Record positive results for faster future lookup.\n // Unfortunately, we cannot safely cache negative results,\n // because new possibleTypes data could always be added to the\n // Policies class.\n typenameSupertypeSet.add(supertype);\n }\n return true;\n }\n\n supertypeSet.forEach(maybeEnqueue);\n\n if (\n needToCheckFuzzySubtypes &&\n // Start checking fuzzy subtypes only after exhausting all\n // non-fuzzy subtypes (after the final iteration of the loop).\n i === workQueue.length - 1 &&\n // We could wait to compare fragment.selectionSet to result\n // after we verify the supertype, but this check is often less\n // expensive than that search, and we will have to do the\n // comparison anyway whenever we find a potential match.\n selectionSetMatchesResult(fragment.selectionSet, result!, variables)\n ) {\n // We don't always need to check fuzzy subtypes (if no result\n // was provided, or !this.fuzzySubtypes.size), but, when we do,\n // we only want to check them once.\n needToCheckFuzzySubtypes = false;\n checkingFuzzySubtypes = true;\n\n // If we find any fuzzy subtypes that match typename, extend the\n // workQueue to search through the supertypes of those fuzzy\n // subtypes. Otherwise the for-loop will terminate and we'll\n // return false below.\n this.fuzzySubtypes.forEach((regExp, fuzzyString) => {\n const match = typename.match(regExp);\n if (match && match[0] === typename) {\n maybeEnqueue(fuzzyString);\n }\n });\n }\n }\n }\n\n return false;\n }\n\n public hasKeyArgs(typename: string | undefined, fieldName: string) {\n const policy = this.getFieldPolicy(typename, fieldName, false);\n return !!(policy && policy.keyFn);\n }\n\n public getStoreFieldName(fieldSpec: FieldSpecifier): string {\n const { typename, fieldName } = fieldSpec;\n const policy = this.getFieldPolicy(typename, fieldName, false);\n let storeFieldName: Exclude, KeySpecifier>;\n\n let keyFn = policy && policy.keyFn;\n if (keyFn && typename) {\n const context: Parameters[1] = {\n typename,\n fieldName,\n field: fieldSpec.field || null,\n variables: fieldSpec.variables,\n };\n const args = argsFromFieldSpecifier(fieldSpec);\n while (keyFn) {\n const specifierOrString = keyFn(args, context);\n if (isArray(specifierOrString)) {\n keyFn = keyArgsFnFromSpecifier(specifierOrString);\n } else {\n // If the custom keyFn returns a falsy value, fall back to\n // fieldName instead.\n storeFieldName = specifierOrString || fieldName;\n break;\n }\n }\n }\n\n if (storeFieldName === void 0) {\n storeFieldName =\n fieldSpec.field ?\n storeKeyNameFromField(fieldSpec.field, fieldSpec.variables)\n : getStoreKeyName(fieldName, argsFromFieldSpecifier(fieldSpec));\n }\n\n // Returning false from a keyArgs function is like configuring\n // keyArgs: false, but more dynamic.\n if (storeFieldName === false) {\n return fieldName;\n }\n\n // Make sure custom field names start with the actual field.name.value\n // of the field, so we can always figure out which properties of a\n // StoreObject correspond to which original field names.\n return fieldName === fieldNameFromStoreName(storeFieldName) ? storeFieldName\n : fieldName + \":\" + storeFieldName;\n }\n\n public readField(\n options: ReadFieldOptions,\n context: ReadMergeModifyContext\n ): SafeReadonly | undefined {\n const objectOrReference = options.from;\n if (!objectOrReference) return;\n\n const nameOrField = options.field || options.fieldName;\n if (!nameOrField) return;\n\n if (options.typename === void 0) {\n const typename = context.store.getFieldValue(\n objectOrReference,\n \"__typename\"\n );\n if (typename) options.typename = typename;\n }\n\n const storeFieldName = this.getStoreFieldName(options);\n const fieldName = fieldNameFromStoreName(storeFieldName);\n const existing = context.store.getFieldValue(\n objectOrReference,\n storeFieldName\n );\n const policy = this.getFieldPolicy(options.typename, fieldName, false);\n const read = policy && policy.read;\n\n if (read) {\n const readOptions = makeFieldFunctionOptions(\n this,\n objectOrReference,\n options,\n context,\n context.store.getStorage(\n isReference(objectOrReference) ?\n objectOrReference.__ref\n : objectOrReference,\n storeFieldName\n )\n );\n\n // Call read(existing, readOptions) with cacheSlot holding this.cache.\n return cacheSlot.withValue(this.cache, read, [\n existing,\n readOptions,\n ]) as SafeReadonly;\n }\n\n return existing;\n }\n\n public getReadFunction(\n typename: string | undefined,\n fieldName: string\n ): FieldReadFunction | undefined {\n const policy = this.getFieldPolicy(typename, fieldName, false);\n return policy && policy.read;\n }\n\n public getMergeFunction(\n parentTypename: string | undefined,\n fieldName: string,\n childTypename: string | undefined\n ): FieldMergeFunction | undefined {\n let policy:\n | Policies[\"typePolicies\"][string]\n | Policies[\"typePolicies\"][string][\"fields\"][string]\n | undefined = this.getFieldPolicy(parentTypename, fieldName, false);\n let merge = policy && policy.merge;\n if (!merge && childTypename) {\n policy = this.getTypePolicy(childTypename);\n merge = policy && policy.merge;\n }\n return merge;\n }\n\n public runMergeFunction(\n existing: StoreValue,\n incoming: StoreValue,\n { field, typename, merge }: MergeInfo,\n context: WriteContext,\n storage?: StorageType\n ) {\n if (merge === mergeTrueFn) {\n // Instead of going to the trouble of creating a full\n // FieldFunctionOptions object and calling mergeTrueFn, we can\n // simply call mergeObjects, as mergeTrueFn would.\n return makeMergeObjectsFunction(context.store)(\n existing as StoreObject,\n incoming as StoreObject\n );\n }\n\n if (merge === mergeFalseFn) {\n // Likewise for mergeFalseFn, whose implementation is even simpler.\n return incoming;\n }\n\n // If cache.writeQuery or cache.writeFragment was called with\n // options.overwrite set to true, we still call merge functions, but\n // the existing data is always undefined, so the merge function will\n // not attempt to combine the incoming data with the existing data.\n if (context.overwrite) {\n existing = void 0;\n }\n\n return merge(\n existing,\n incoming,\n makeFieldFunctionOptions(\n this,\n // Unlike options.readField for read functions, we do not fall\n // back to the current object if no foreignObjOrRef is provided,\n // because it's not clear what the current object should be for\n // merge functions: the (possibly undefined) existing object, or\n // the incoming object? If you think your merge function needs\n // to read sibling fields in order to produce a new value for\n // the current field, you might want to rethink your strategy,\n // because that's a recipe for making merge behavior sensitive\n // to the order in which fields are written into the cache.\n // However, readField(name, ref) is useful for merge functions\n // that need to deduplicate child objects and references.\n void 0,\n {\n typename,\n fieldName: field.name.value,\n field,\n variables: context.variables,\n },\n context,\n storage || Object.create(null)\n )\n );\n }\n}\n\nfunction makeFieldFunctionOptions(\n policies: Policies,\n objectOrReference: StoreObject | Reference | undefined,\n fieldSpec: FieldSpecifier,\n context: ReadMergeModifyContext,\n storage: StorageType\n): FieldFunctionOptions {\n const storeFieldName = policies.getStoreFieldName(fieldSpec);\n const fieldName = fieldNameFromStoreName(storeFieldName);\n const variables = fieldSpec.variables || context.variables;\n const { toReference, canRead } = context.store;\n\n return {\n args: argsFromFieldSpecifier(fieldSpec),\n field: fieldSpec.field || null,\n fieldName,\n storeFieldName,\n variables,\n isReference,\n toReference,\n storage,\n cache: policies.cache,\n canRead,\n readField() {\n return policies.readField(\n normalizeReadFieldOptions(arguments, objectOrReference, variables),\n context\n );\n },\n mergeObjects: makeMergeObjectsFunction(context.store),\n };\n}\n\nexport function normalizeReadFieldOptions(\n readFieldArgs: IArguments,\n objectOrReference: StoreObject | Reference | undefined,\n variables?: ReadMergeModifyContext[\"variables\"]\n): ReadFieldOptions {\n const { 0: fieldNameOrOptions, 1: from, length: argc } = readFieldArgs;\n\n let options: ReadFieldOptions;\n\n if (typeof fieldNameOrOptions === \"string\") {\n options = {\n fieldName: fieldNameOrOptions,\n // Default to objectOrReference only when no second argument was\n // passed for the from parameter, not when undefined is explicitly\n // passed as the second argument.\n from: argc > 1 ? from : objectOrReference,\n };\n } else {\n options = { ...fieldNameOrOptions };\n // Default to objectOrReference only when fieldNameOrOptions.from is\n // actually omitted, rather than just undefined.\n if (!hasOwn.call(options, \"from\")) {\n options.from = objectOrReference;\n }\n }\n\n if (__DEV__ && options.from === void 0) {\n invariant.warn(\n `Undefined 'from' passed to readField with arguments %s`,\n stringifyForDisplay(Array.from(readFieldArgs))\n );\n }\n\n if (void 0 === options.variables) {\n options.variables = variables;\n }\n\n return options;\n}\n\nfunction makeMergeObjectsFunction(\n store: NormalizedCache\n): MergeObjectsFunction {\n return function mergeObjects(existing, incoming) {\n if (isArray(existing) || isArray(incoming)) {\n throw newInvariantError(\"Cannot automatically merge arrays\");\n }\n\n // These dynamic checks are necessary because the parameters of a\n // custom merge function can easily have the any type, so the type\n // system cannot always enforce the StoreObject | Reference parameter\n // types of options.mergeObjects.\n if (isNonNullObject(existing) && isNonNullObject(incoming)) {\n const eType = store.getFieldValue(existing, \"__typename\");\n const iType = store.getFieldValue(incoming, \"__typename\");\n const typesDiffer = eType && iType && eType !== iType;\n\n if (typesDiffer) {\n return incoming;\n }\n\n if (isReference(existing) && storeValueIsStoreObject(incoming)) {\n // Update the normalized EntityStore for the entity identified by\n // existing.__ref, preferring/overwriting any fields contributed by the\n // newer incoming StoreObject.\n store.merge(existing.__ref, incoming);\n return existing;\n }\n\n if (storeValueIsStoreObject(existing) && isReference(incoming)) {\n // Update the normalized EntityStore for the entity identified by\n // incoming.__ref, taking fields from the older existing object only if\n // those fields are not already present in the newer StoreObject\n // identified by incoming.__ref.\n store.merge(existing, incoming.__ref);\n return incoming;\n }\n\n if (\n storeValueIsStoreObject(existing) &&\n storeValueIsStoreObject(incoming)\n ) {\n return { ...existing, ...incoming };\n }\n }\n\n return incoming;\n };\n}\n","import { invariant, newInvariantError } from \"../../utilities/globals/index.js\";\nimport { equal } from \"@wry/equality\";\nimport { Trie } from \"@wry/trie\";\nimport type { SelectionSetNode, FieldNode } from \"graphql\";\nimport { Kind } from \"graphql\";\n\nimport type {\n FragmentMap,\n FragmentMapFunction,\n StoreValue,\n StoreObject,\n Reference,\n} from \"../../utilities/index.js\";\nimport {\n getFragmentFromSelection,\n getDefaultValues,\n getOperationDefinition,\n getTypenameFromResult,\n makeReference,\n isField,\n resultKeyNameFromField,\n isReference,\n shouldInclude,\n cloneDeep,\n addTypenameToDocument,\n isNonEmptyArray,\n argumentsObjectFromField,\n canonicalStringify,\n} from \"../../utilities/index.js\";\n\nimport type {\n NormalizedCache,\n ReadMergeModifyContext,\n MergeTree,\n InMemoryCacheConfig,\n} from \"./types.js\";\nimport {\n isArray,\n makeProcessedFieldsMerger,\n fieldNameFromStoreName,\n storeValueIsStoreObject,\n extractFragmentContext,\n} from \"./helpers.js\";\nimport type { StoreReader } from \"./readFromStore.js\";\nimport type { InMemoryCache } from \"./inMemoryCache.js\";\nimport type { EntityStore } from \"./entityStore.js\";\nimport type { Cache } from \"../../core/index.js\";\nimport { normalizeReadFieldOptions } from \"./policies.js\";\nimport type { ReadFieldFunction } from \"../core/types/common.js\";\n\nexport interface WriteContext extends ReadMergeModifyContext {\n readonly written: {\n [dataId: string]: SelectionSetNode[];\n };\n readonly fragmentMap: FragmentMap;\n lookupFragment: FragmentMapFunction;\n // General-purpose deep-merge function for use during writes.\n merge(existing: T, incoming: T): T;\n // If true, merge functions will be called with undefined existing data.\n overwrite: boolean;\n incomingById: Map<\n string,\n {\n storeObject: StoreObject;\n mergeTree?: MergeTree;\n fieldNodeSet: Set;\n }\n >;\n // Directive metadata for @client and @defer. We could use a bitfield for this\n // information to save some space, and use that bitfield number as the keys in\n // the context.flavors Map.\n clientOnly: boolean;\n deferred: boolean;\n flavors: Map;\n}\n\ntype FlavorableWriteContext = Pick<\n WriteContext,\n \"clientOnly\" | \"deferred\" | \"flavors\"\n>;\n\n// Since there are only four possible combinations of context.clientOnly and\n// context.deferred values, we should need at most four \"flavors\" of any given\n// WriteContext. To avoid creating multiple copies of the same context, we cache\n// the contexts in the context.flavors Map (shared by all flavors) according to\n// their clientOnly and deferred values (always in that order).\nfunction getContextFlavor(\n context: TContext,\n clientOnly: TContext[\"clientOnly\"],\n deferred: TContext[\"deferred\"]\n): TContext {\n const key = `${clientOnly}${deferred}`;\n let flavored = context.flavors.get(key);\n if (!flavored) {\n context.flavors.set(\n key,\n (flavored =\n context.clientOnly === clientOnly && context.deferred === deferred ?\n context\n : {\n ...context,\n clientOnly,\n deferred,\n })\n );\n }\n return flavored as TContext;\n}\n\ninterface ProcessSelectionSetOptions {\n dataId?: string;\n result: Record;\n selectionSet: SelectionSetNode;\n context: WriteContext;\n mergeTree: MergeTree;\n}\n\nexport class StoreWriter {\n constructor(\n public readonly cache: InMemoryCache,\n private reader?: StoreReader,\n private fragments?: InMemoryCacheConfig[\"fragments\"]\n ) {}\n\n public writeToStore(\n store: NormalizedCache,\n { query, result, dataId, variables, overwrite }: Cache.WriteOptions\n ): Reference | undefined {\n const operationDefinition = getOperationDefinition(query)!;\n const merger = makeProcessedFieldsMerger();\n\n variables = {\n ...getDefaultValues(operationDefinition),\n ...variables!,\n };\n\n const context: WriteContext = {\n store,\n written: Object.create(null),\n merge(existing: T, incoming: T) {\n return merger.merge(existing, incoming) as T;\n },\n variables,\n varString: canonicalStringify(variables),\n ...extractFragmentContext(query, this.fragments),\n overwrite: !!overwrite,\n incomingById: new Map(),\n clientOnly: false,\n deferred: false,\n flavors: new Map(),\n };\n\n const ref = this.processSelectionSet({\n result: result || Object.create(null),\n dataId,\n selectionSet: operationDefinition.selectionSet,\n mergeTree: { map: new Map() },\n context,\n });\n\n if (!isReference(ref)) {\n throw newInvariantError(`Could not identify object %s`, result);\n }\n\n // So far, the store has not been modified, so now it's time to process\n // context.incomingById and merge those incoming fields into context.store.\n context.incomingById.forEach(\n ({ storeObject, mergeTree, fieldNodeSet }, dataId) => {\n const entityRef = makeReference(dataId);\n\n if (mergeTree && mergeTree.map.size) {\n const applied = this.applyMerges(\n mergeTree,\n entityRef,\n storeObject,\n context\n );\n if (isReference(applied)) {\n // Assume References returned by applyMerges have already been merged\n // into the store. See makeMergeObjectsFunction in policies.ts for an\n // example of how this can happen.\n return;\n }\n // Otherwise, applyMerges returned a StoreObject, whose fields we should\n // merge into the store (see store.merge statement below).\n storeObject = applied;\n }\n\n if (__DEV__ && !context.overwrite) {\n const fieldsWithSelectionSets: Record =\n Object.create(null);\n fieldNodeSet.forEach((field) => {\n if (field.selectionSet) {\n fieldsWithSelectionSets[field.name.value] = true;\n }\n });\n\n const hasSelectionSet = (storeFieldName: string) =>\n fieldsWithSelectionSets[fieldNameFromStoreName(storeFieldName)] ===\n true;\n\n const hasMergeFunction = (storeFieldName: string) => {\n const childTree = mergeTree && mergeTree.map.get(storeFieldName);\n return Boolean(childTree && childTree.info && childTree.info.merge);\n };\n\n Object.keys(storeObject).forEach((storeFieldName) => {\n // If a merge function was defined for this field, trust that it\n // did the right thing about (not) clobbering data. If the field\n // has no selection set, it's a scalar field, so it doesn't need\n // a merge function (even if it's an object, like JSON data).\n if (\n hasSelectionSet(storeFieldName) &&\n !hasMergeFunction(storeFieldName)\n ) {\n warnAboutDataLoss(\n entityRef,\n storeObject,\n storeFieldName,\n context.store\n );\n }\n });\n }\n\n store.merge(dataId, storeObject);\n }\n );\n\n // Any IDs written explicitly to the cache will be retained as\n // reachable root IDs for garbage collection purposes. Although this\n // logic includes root IDs like ROOT_QUERY and ROOT_MUTATION, their\n // retainment counts are effectively ignored because cache.gc() always\n // includes them in its root ID set.\n store.retain(ref.__ref);\n\n return ref;\n }\n\n private processSelectionSet({\n dataId,\n result,\n selectionSet,\n context,\n // This object allows processSelectionSet to report useful information\n // to its callers without explicitly returning that information.\n mergeTree,\n }: ProcessSelectionSetOptions): StoreObject | Reference {\n const { policies } = this.cache;\n\n // This variable will be repeatedly updated using context.merge to\n // accumulate all fields that need to be written into the store.\n let incoming: StoreObject = Object.create(null);\n\n // If typename was not passed in, infer it. Note that typename is\n // always passed in for tricky-to-infer cases such as \"Query\" for\n // ROOT_QUERY.\n const typename: string | undefined =\n (dataId && policies.rootTypenamesById[dataId]) ||\n getTypenameFromResult(result, selectionSet, context.fragmentMap) ||\n (dataId && (context.store.get(dataId, \"__typename\") as string));\n\n if (\"string\" === typeof typename) {\n incoming.__typename = typename;\n }\n\n // This readField function will be passed as context.readField in the\n // KeyFieldsContext object created within policies.identify (called below).\n // In addition to reading from the existing context.store (thanks to the\n // policies.readField(options, context) line at the very bottom), this\n // version of readField can read from Reference objects that are currently\n // pending in context.incomingById, which is important whenever keyFields\n // need to be extracted from a child object that processSelectionSet has\n // turned into a Reference.\n const readField: ReadFieldFunction = function (this: void) {\n const options = normalizeReadFieldOptions(\n arguments,\n incoming,\n context.variables\n );\n\n if (isReference(options.from)) {\n const info = context.incomingById.get(options.from.__ref);\n if (info) {\n const result = policies.readField(\n {\n ...options,\n from: info.storeObject,\n },\n context\n );\n\n if (result !== void 0) {\n return result;\n }\n }\n }\n\n return policies.readField(options, context);\n };\n\n const fieldNodeSet = new Set();\n\n this.flattenFields(\n selectionSet,\n result,\n // This WriteContext will be the default context value for fields returned\n // by the flattenFields method, but some fields may be assigned a modified\n // context, depending on the presence of @client and other directives.\n context,\n typename\n ).forEach((context, field) => {\n const resultFieldKey = resultKeyNameFromField(field);\n const value = result[resultFieldKey];\n\n fieldNodeSet.add(field);\n\n if (value !== void 0) {\n const storeFieldName = policies.getStoreFieldName({\n typename,\n fieldName: field.name.value,\n field,\n variables: context.variables,\n });\n\n const childTree = getChildMergeTree(mergeTree, storeFieldName);\n\n let incomingValue = this.processFieldValue(\n value,\n field,\n // Reset context.clientOnly and context.deferred to their default\n // values before processing nested selection sets.\n field.selectionSet ?\n getContextFlavor(context, false, false)\n : context,\n childTree\n );\n\n // To determine if this field holds a child object with a merge function\n // defined in its type policy (see PR #7070), we need to figure out the\n // child object's __typename.\n let childTypename: string | undefined;\n\n // The field's value can be an object that has a __typename only if the\n // field has a selection set. Otherwise incomingValue is scalar.\n if (\n field.selectionSet &&\n (isReference(incomingValue) || storeValueIsStoreObject(incomingValue))\n ) {\n childTypename = readField(\"__typename\", incomingValue);\n }\n\n const merge = policies.getMergeFunction(\n typename,\n field.name.value,\n childTypename\n );\n\n if (merge) {\n childTree.info = {\n // TODO Check compatibility against any existing childTree.field?\n field,\n typename,\n merge,\n };\n } else {\n maybeRecycleChildMergeTree(mergeTree, storeFieldName);\n }\n\n incoming = context.merge(incoming, {\n [storeFieldName]: incomingValue,\n });\n } else if (\n __DEV__ &&\n !context.clientOnly &&\n !context.deferred &&\n !addTypenameToDocument.added(field) &&\n // If the field has a read function, it may be a synthetic field or\n // provide a default value, so its absence from the written data should\n // not be cause for alarm.\n !policies.getReadFunction(typename, field.name.value)\n ) {\n invariant.error(\n `Missing field '%s' while writing result %o`,\n resultKeyNameFromField(field),\n result\n );\n }\n });\n\n // Identify the result object, even if dataId was already provided,\n // since we always need keyObject below.\n try {\n const [id, keyObject] = policies.identify(result, {\n typename,\n selectionSet,\n fragmentMap: context.fragmentMap,\n storeObject: incoming,\n readField,\n });\n\n // If dataId was not provided, fall back to the id just generated by\n // policies.identify.\n dataId = dataId || id;\n\n // Write any key fields that were used during identification, even if\n // they were not mentioned in the original query.\n if (keyObject) {\n // TODO Reverse the order of the arguments?\n incoming = context.merge(incoming, keyObject);\n }\n } catch (e) {\n // If dataId was provided, tolerate failure of policies.identify.\n if (!dataId) throw e;\n }\n\n if (\"string\" === typeof dataId) {\n const dataRef = makeReference(dataId);\n\n // Avoid processing the same entity object using the same selection\n // set more than once. We use an array instead of a Set since most\n // entity IDs will be written using only one selection set, so the\n // size of this array is likely to be very small, meaning indexOf is\n // likely to be faster than Set.prototype.has.\n const sets = context.written[dataId] || (context.written[dataId] = []);\n if (sets.indexOf(selectionSet) >= 0) return dataRef;\n sets.push(selectionSet);\n\n // If we're about to write a result object into the store, but we\n // happen to know that the exact same (===) result object would be\n // returned if we were to reread the result with the same inputs,\n // then we can skip the rest of the processSelectionSet work for\n // this object, and immediately return a Reference to it.\n if (\n this.reader &&\n this.reader.isFresh(result, dataRef, selectionSet, context)\n ) {\n return dataRef;\n }\n\n const previous = context.incomingById.get(dataId);\n if (previous) {\n previous.storeObject = context.merge(previous.storeObject, incoming);\n previous.mergeTree = mergeMergeTrees(previous.mergeTree, mergeTree);\n fieldNodeSet.forEach((field) => previous.fieldNodeSet.add(field));\n } else {\n context.incomingById.set(dataId, {\n storeObject: incoming,\n // Save a reference to mergeTree only if it is not empty, because\n // empty MergeTrees may be recycled by maybeRecycleChildMergeTree and\n // reused for entirely different parts of the result tree.\n mergeTree: mergeTreeIsEmpty(mergeTree) ? void 0 : mergeTree,\n fieldNodeSet,\n });\n }\n\n return dataRef;\n }\n\n return incoming;\n }\n\n private processFieldValue(\n value: any,\n field: FieldNode,\n context: WriteContext,\n mergeTree: MergeTree\n ): StoreValue {\n if (!field.selectionSet || value === null) {\n // In development, we need to clone scalar values so that they can be\n // safely frozen with maybeDeepFreeze in readFromStore.ts. In production,\n // it's cheaper to store the scalar values directly in the cache.\n return __DEV__ ? cloneDeep(value) : value;\n }\n\n if (isArray(value)) {\n return value.map((item, i) => {\n const value = this.processFieldValue(\n item,\n field,\n context,\n getChildMergeTree(mergeTree, i)\n );\n maybeRecycleChildMergeTree(mergeTree, i);\n return value;\n });\n }\n\n return this.processSelectionSet({\n result: value,\n selectionSet: field.selectionSet,\n context,\n mergeTree,\n });\n }\n\n // Implements https://spec.graphql.org/draft/#sec-Field-Collection, but with\n // some additions for tracking @client and @defer directives.\n private flattenFields<\n TContext extends Pick<\n WriteContext,\n | \"clientOnly\"\n | \"deferred\"\n | \"flavors\"\n | \"fragmentMap\"\n | \"lookupFragment\"\n | \"variables\"\n >,\n >(\n selectionSet: SelectionSetNode,\n result: Record,\n context: TContext,\n typename = getTypenameFromResult(result, selectionSet, context.fragmentMap)\n ): Map {\n const fieldMap = new Map();\n const { policies } = this.cache;\n\n const limitingTrie = new Trie<{\n // Tracks whether (selectionSet, clientOnly, deferred) has been flattened\n // before. The GraphQL specification only uses the fragment name for\n // skipping previously visited fragments, but the top-level fragment\n // selection set corresponds 1:1 with the fagment name (and is slightly\n // easier too work with), and we need to consider clientOnly and deferred\n // values as well, potentially revisiting selection sets that were\n // previously visited with different inherited configurations of those\n // directives.\n visited?: boolean;\n }>(false); // No need for WeakMap, since limitingTrie does not escape.\n\n (function flatten(\n this: void,\n selectionSet: SelectionSetNode,\n inheritedContext: TContext\n ) {\n const visitedNode = limitingTrie.lookup(\n selectionSet,\n // Because we take inheritedClientOnly and inheritedDeferred into\n // consideration here (in addition to selectionSet), it's possible for\n // the same selection set to be flattened more than once, if it appears\n // in the query with different @client and/or @directive configurations.\n inheritedContext.clientOnly,\n inheritedContext.deferred\n );\n if (visitedNode.visited) return;\n visitedNode.visited = true;\n\n selectionSet.selections.forEach((selection) => {\n if (!shouldInclude(selection, context.variables)) return;\n\n let { clientOnly, deferred } = inheritedContext;\n if (\n // Since the presence of @client or @defer on this field can only\n // cause clientOnly or deferred to become true, we can skip the\n // forEach loop if both clientOnly and deferred are already true.\n !(clientOnly && deferred) &&\n isNonEmptyArray(selection.directives)\n ) {\n selection.directives.forEach((dir) => {\n const name = dir.name.value;\n if (name === \"client\") clientOnly = true;\n if (name === \"defer\") {\n const args = argumentsObjectFromField(dir, context.variables);\n // The @defer directive takes an optional args.if boolean\n // argument, similar to @include(if: boolean). Note that\n // @defer(if: false) does not make context.deferred false, but\n // instead behaves as if there was no @defer directive.\n if (!args || (args as { if?: boolean }).if !== false) {\n deferred = true;\n }\n // TODO In the future, we may want to record args.label using\n // context.deferred, if a label is specified.\n }\n });\n }\n\n if (isField(selection)) {\n const existing = fieldMap.get(selection);\n if (existing) {\n // If this field has been visited along another recursive path\n // before, the final context should have clientOnly or deferred set\n // to true only if *all* paths have the directive (hence the &&).\n clientOnly = clientOnly && existing.clientOnly;\n deferred = deferred && existing.deferred;\n }\n\n fieldMap.set(\n selection,\n getContextFlavor(context, clientOnly, deferred)\n );\n } else {\n const fragment = getFragmentFromSelection(\n selection,\n context.lookupFragment\n );\n\n if (!fragment && selection.kind === Kind.FRAGMENT_SPREAD) {\n throw newInvariantError(\n `No fragment named %s`,\n selection.name.value\n );\n }\n\n if (\n fragment &&\n policies.fragmentMatches(\n fragment,\n typename,\n result,\n context.variables\n )\n ) {\n flatten(\n fragment.selectionSet,\n getContextFlavor(context, clientOnly, deferred)\n );\n }\n }\n });\n })(selectionSet, context);\n\n return fieldMap;\n }\n\n private applyMerges(\n mergeTree: MergeTree,\n existing: StoreValue,\n incoming: T,\n context: WriteContext,\n getStorageArgs?: Parameters\n ): T | Reference {\n if (mergeTree.map.size && !isReference(incoming)) {\n const e: StoreObject | Reference | undefined =\n // Items in the same position in different arrays are not\n // necessarily related to each other, so when incoming is an array\n // we process its elements as if there was no existing data.\n (\n !isArray(incoming) &&\n // Likewise, existing must be either a Reference or a StoreObject\n // in order for its fields to be safe to merge with the fields of\n // the incoming object.\n (isReference(existing) || storeValueIsStoreObject(existing))\n ) ?\n existing\n : void 0;\n\n // This narrowing is implied by mergeTree.map.size > 0 and\n // !isReference(incoming), though TypeScript understandably cannot\n // hope to infer this type.\n const i = incoming as StoreObject | StoreValue[];\n\n // The options.storage objects provided to read and merge functions\n // are derived from the identity of the parent object plus a\n // sequence of storeFieldName strings/numbers identifying the nested\n // field name path of each field value to be merged.\n if (e && !getStorageArgs) {\n getStorageArgs = [isReference(e) ? e.__ref : e];\n }\n\n // It's possible that applying merge functions to this subtree will\n // not change the incoming data, so this variable tracks the fields\n // that did change, so we can create a new incoming object when (and\n // only when) at least one incoming field has changed. We use a Map\n // to preserve the type of numeric keys.\n let changedFields: Map | undefined;\n\n const getValue = (\n from: typeof e | typeof i,\n name: string | number\n ): StoreValue => {\n return (\n isArray(from) ?\n typeof name === \"number\" ?\n from[name]\n : void 0\n : context.store.getFieldValue(from, String(name))\n );\n };\n\n mergeTree.map.forEach((childTree, storeFieldName) => {\n const eVal = getValue(e, storeFieldName);\n const iVal = getValue(i, storeFieldName);\n // If we have no incoming data, leave any existing data untouched.\n if (void 0 === iVal) return;\n if (getStorageArgs) {\n getStorageArgs.push(storeFieldName);\n }\n const aVal = this.applyMerges(\n childTree,\n eVal,\n iVal,\n context,\n getStorageArgs\n );\n if (aVal !== iVal) {\n changedFields = changedFields || new Map();\n changedFields.set(storeFieldName, aVal);\n }\n if (getStorageArgs) {\n invariant(getStorageArgs.pop() === storeFieldName);\n }\n });\n\n if (changedFields) {\n // Shallow clone i so we can add changed fields to it.\n incoming = (isArray(i) ? i.slice(0) : { ...i }) as T;\n changedFields.forEach((value, name) => {\n (incoming as any)[name] = value;\n });\n }\n }\n\n if (mergeTree.info) {\n return this.cache.policies.runMergeFunction(\n existing,\n incoming,\n mergeTree.info,\n context,\n getStorageArgs && context.store.getStorage(...getStorageArgs)\n );\n }\n\n return incoming;\n }\n}\n\nconst emptyMergeTreePool: MergeTree[] = [];\n\nfunction getChildMergeTree(\n { map }: MergeTree,\n name: string | number\n): MergeTree {\n if (!map.has(name)) {\n map.set(name, emptyMergeTreePool.pop() || { map: new Map() });\n }\n return map.get(name)!;\n}\n\nfunction mergeMergeTrees(\n left: MergeTree | undefined,\n right: MergeTree | undefined\n): MergeTree {\n if (left === right || !right || mergeTreeIsEmpty(right)) return left!;\n if (!left || mergeTreeIsEmpty(left)) return right;\n\n const info =\n left.info && right.info ?\n {\n ...left.info,\n ...right.info,\n }\n : left.info || right.info;\n\n const needToMergeMaps = left.map.size && right.map.size;\n const map =\n needToMergeMaps ? new Map()\n : left.map.size ? left.map\n : right.map;\n\n const merged = { info, map };\n\n if (needToMergeMaps) {\n const remainingRightKeys = new Set(right.map.keys());\n\n left.map.forEach((leftTree, key) => {\n merged.map.set(key, mergeMergeTrees(leftTree, right.map.get(key)));\n remainingRightKeys.delete(key);\n });\n\n remainingRightKeys.forEach((key) => {\n merged.map.set(\n key,\n mergeMergeTrees(right.map.get(key), left.map.get(key))\n );\n });\n }\n\n return merged;\n}\n\nfunction mergeTreeIsEmpty(tree: MergeTree | undefined): boolean {\n return !tree || !(tree.info || tree.map.size);\n}\n\nfunction maybeRecycleChildMergeTree({ map }: MergeTree, name: string | number) {\n const childTree = map.get(name);\n if (childTree && mergeTreeIsEmpty(childTree)) {\n emptyMergeTreePool.push(childTree);\n map.delete(name);\n }\n}\n\nconst warnings = new Set();\n\n// Note that this function is unused in production, and thus should be\n// pruned by any well-configured minifier.\nfunction warnAboutDataLoss(\n existingRef: Reference,\n incomingObj: StoreObject,\n storeFieldName: string,\n store: NormalizedCache\n) {\n const getChild = (objOrRef: StoreObject | Reference): StoreObject | false => {\n const child = store.getFieldValue(objOrRef, storeFieldName);\n return typeof child === \"object\" && child;\n };\n\n const existing = getChild(existingRef);\n if (!existing) return;\n\n const incoming = getChild(incomingObj);\n if (!incoming) return;\n\n // It's always safe to replace a reference, since it refers to data\n // safely stored elsewhere.\n if (isReference(existing)) return;\n\n // If the values are structurally equivalent, we do not need to worry\n // about incoming replacing existing.\n if (equal(existing, incoming)) return;\n\n // If we're replacing every key of the existing object, then the\n // existing data would be overwritten even if the objects were\n // normalized, so warning would not be helpful here.\n if (\n Object.keys(existing).every(\n (key) => store.getFieldValue(incoming, key) !== void 0\n )\n ) {\n return;\n }\n\n const parentType =\n store.getFieldValue(existingRef, \"__typename\") ||\n store.getFieldValue(incomingObj, \"__typename\");\n const fieldName = fieldNameFromStoreName(storeFieldName);\n const typeDotName = `${parentType}.${fieldName}`;\n // Avoid warning more than once for the same type and field name.\n if (warnings.has(typeDotName)) return;\n warnings.add(typeDotName);\n\n const childTypenames: string[] = [];\n // Arrays do not have __typename fields, and always need a custom merge\n // function, even if their elements are normalized entities.\n if (!isArray(existing) && !isArray(incoming)) {\n [existing, incoming].forEach((child) => {\n const typename = store.getFieldValue(child, \"__typename\");\n if (typeof typename === \"string\" && !childTypenames.includes(typename)) {\n childTypenames.push(typename);\n }\n });\n }\n\n invariant.warn(\n `Cache data may be lost when replacing the %s field of a %s object.\n\nThis could cause additional (usually avoidable) network requests to fetch data that were otherwise cached.\n\nTo address this problem (which is not a bug in Apollo Client), %sdefine a custom merge function for the %s field, so InMemoryCache can safely merge these objects:\n\n existing: %o\n incoming: %o\n\nFor more information about these options, please refer to the documentation:\n\n * Ensuring entity objects have IDs: https://go.apollo.dev/c/generating-unique-identifiers\n * Defining custom merge functions: https://go.apollo.dev/c/merging-non-normalized-objects\n`,\n fieldName,\n parentType,\n childTypenames.length ?\n \"either ensure all objects of type \" +\n childTypenames.join(\" and \") +\n \" have an ID or a custom merge function, or \"\n : \"\",\n typeDotName,\n { ...existing },\n { ...incoming }\n );\n}\n","import { invariant } from \"../../utilities/globals/index.js\";\n\n// Make builtins like Map and Set safe to use with non-extensible objects.\nimport \"./fixPolyfills.js\";\n\nimport type { DocumentNode } from \"graphql\";\nimport type { OptimisticWrapperFunction } from \"optimism\";\nimport { wrap } from \"optimism\";\nimport { equal } from \"@wry/equality\";\n\nimport { ApolloCache } from \"../core/cache.js\";\nimport type { Cache } from \"../core/types/Cache.js\";\nimport { MissingFieldError } from \"../core/types/common.js\";\nimport type { StoreObject, Reference } from \"../../utilities/index.js\";\nimport {\n addTypenameToDocument,\n isReference,\n DocumentTransform,\n canonicalStringify,\n print,\n cacheSizes,\n defaultCacheSizes,\n} from \"../../utilities/index.js\";\nimport type { InMemoryCacheConfig, NormalizedCacheObject } from \"./types.js\";\nimport { StoreReader } from \"./readFromStore.js\";\nimport { StoreWriter } from \"./writeToStore.js\";\nimport { EntityStore, supportsResultCaching } from \"./entityStore.js\";\nimport { makeVar, forgetCache, recallCache } from \"./reactiveVars.js\";\nimport { Policies } from \"./policies.js\";\nimport { hasOwn, normalizeConfig, shouldCanonizeResults } from \"./helpers.js\";\nimport type { OperationVariables } from \"../../core/index.js\";\nimport { getInMemoryCacheMemoryInternals } from \"../../utilities/caching/getMemoryInternals.js\";\n\ntype BroadcastOptions = Pick<\n Cache.BatchOptions,\n \"optimistic\" | \"onWatchUpdated\"\n>;\n\nexport class InMemoryCache extends ApolloCache {\n private data!: EntityStore;\n private optimisticData!: EntityStore;\n\n protected config: InMemoryCacheConfig;\n private watches = new Set();\n private addTypename: boolean;\n\n private storeReader!: StoreReader;\n private storeWriter!: StoreWriter;\n private addTypenameTransform = new DocumentTransform(addTypenameToDocument);\n\n private maybeBroadcastWatch!: OptimisticWrapperFunction<\n [Cache.WatchOptions, BroadcastOptions?],\n any,\n [Cache.WatchOptions]\n >;\n\n // Override the default value, since InMemoryCache result objects are frozen\n // in development and expected to remain logically immutable in production.\n public readonly assumeImmutableResults = true;\n\n // Dynamically imported code can augment existing typePolicies or\n // possibleTypes by calling cache.policies.addTypePolicies or\n // cache.policies.addPossibletypes.\n public readonly policies: Policies;\n\n public readonly makeVar = makeVar;\n\n constructor(config: InMemoryCacheConfig = {}) {\n super();\n this.config = normalizeConfig(config);\n this.addTypename = !!this.config.addTypename;\n\n this.policies = new Policies({\n cache: this,\n dataIdFromObject: this.config.dataIdFromObject,\n possibleTypes: this.config.possibleTypes,\n typePolicies: this.config.typePolicies,\n });\n\n this.init();\n }\n\n private init() {\n // Passing { resultCaching: false } in the InMemoryCache constructor options\n // will completely disable dependency tracking, which will improve memory\n // usage but worsen the performance of repeated reads.\n const rootStore = (this.data = new EntityStore.Root({\n policies: this.policies,\n resultCaching: this.config.resultCaching,\n }));\n\n // When no optimistic writes are currently active, cache.optimisticData ===\n // cache.data, so there are no additional layers on top of the actual data.\n // When an optimistic update happens, this.optimisticData will become a\n // linked list of EntityStore Layer objects that terminates with the\n // original this.data cache object.\n this.optimisticData = rootStore.stump;\n\n this.resetResultCache();\n }\n\n private resetResultCache(resetResultIdentities?: boolean) {\n const previousReader = this.storeReader;\n const { fragments } = this.config;\n\n // The StoreWriter is mostly stateless and so doesn't really need to be\n // reset, but it does need to have its writer.storeReader reference updated,\n // so it's simpler to update this.storeWriter as well.\n this.storeWriter = new StoreWriter(\n this,\n (this.storeReader = new StoreReader({\n cache: this,\n addTypename: this.addTypename,\n resultCacheMaxSize: this.config.resultCacheMaxSize,\n canonizeResults: shouldCanonizeResults(this.config),\n canon:\n resetResultIdentities ? void 0 : (\n previousReader && previousReader.canon\n ),\n fragments,\n })),\n fragments\n );\n\n this.maybeBroadcastWatch = wrap(\n (c: Cache.WatchOptions, options?: BroadcastOptions) => {\n return this.broadcastWatch(c, options);\n },\n {\n max:\n this.config.resultCacheMaxSize ||\n cacheSizes[\"inMemoryCache.maybeBroadcastWatch\"] ||\n defaultCacheSizes[\"inMemoryCache.maybeBroadcastWatch\"],\n makeCacheKey: (c: Cache.WatchOptions) => {\n // Return a cache key (thus enabling result caching) only if we're\n // currently using a data store that can track cache dependencies.\n const store = c.optimistic ? this.optimisticData : this.data;\n if (supportsResultCaching(store)) {\n const { optimistic, id, variables } = c;\n return store.makeCacheKey(\n c.query,\n // Different watches can have the same query, optimistic\n // status, rootId, and variables, but if their callbacks are\n // different, the (identical) result needs to be delivered to\n // each distinct callback. The easiest way to achieve that\n // separation is to include c.callback in the cache key for\n // maybeBroadcastWatch calls. See issue #5733.\n c.callback,\n canonicalStringify({ optimistic, id, variables })\n );\n }\n },\n }\n );\n\n // Since we have thrown away all the cached functions that depend on the\n // CacheGroup dependencies maintained by EntityStore, we should also reset\n // all CacheGroup dependency information.\n new Set([this.data.group, this.optimisticData.group]).forEach((group) =>\n group.resetCaching()\n );\n }\n\n public restore(data: NormalizedCacheObject): this {\n this.init();\n // Since calling this.init() discards/replaces the entire StoreReader, along\n // with the result caches it maintains, this.data.replace(data) won't have\n // to bother deleting the old data.\n if (data) this.data.replace(data);\n return this;\n }\n\n public extract(optimistic: boolean = false): NormalizedCacheObject {\n return (optimistic ? this.optimisticData : this.data).extract();\n }\n\n public read(options: Cache.ReadOptions): T | null {\n const {\n // Since read returns data or null, without any additional metadata\n // about whether/where there might have been missing fields, the\n // default behavior cannot be returnPartialData = true (like it is\n // for the diff method), since defaulting to true would violate the\n // integrity of the T in the return type. However, partial data may\n // be useful in some cases, so returnPartialData:true may be\n // specified explicitly.\n returnPartialData = false,\n } = options;\n try {\n return (\n this.storeReader.diffQueryAgainstStore({\n ...options,\n store: options.optimistic ? this.optimisticData : this.data,\n config: this.config,\n returnPartialData,\n }).result || null\n );\n } catch (e) {\n if (e instanceof MissingFieldError) {\n // Swallow MissingFieldError and return null, so callers do not need to\n // worry about catching \"normal\" exceptions resulting from incomplete\n // cache data. Unexpected errors will be re-thrown. If you need more\n // information about which fields were missing, use cache.diff instead,\n // and examine diffResult.missing.\n return null;\n }\n throw e;\n }\n }\n\n public write(options: Cache.WriteOptions): Reference | undefined {\n try {\n ++this.txCount;\n return this.storeWriter.writeToStore(this.data, options);\n } finally {\n if (!--this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n }\n\n public modify = Record>(\n options: Cache.ModifyOptions\n ): boolean {\n if (hasOwn.call(options, \"id\") && !options.id) {\n // To my knowledge, TypeScript does not currently provide a way to\n // enforce that an optional property?:type must *not* be undefined\n // when present. That ability would be useful here, because we want\n // options.id to default to ROOT_QUERY only when no options.id was\n // provided. If the caller attempts to pass options.id with a\n // falsy/undefined value (perhaps because cache.identify failed), we\n // should not assume the goal was to modify the ROOT_QUERY object.\n // We could throw, but it seems natural to return false to indicate\n // that nothing was modified.\n return false;\n }\n const store =\n (\n options.optimistic // Defaults to false.\n ) ?\n this.optimisticData\n : this.data;\n try {\n ++this.txCount;\n return store.modify(options.id || \"ROOT_QUERY\", options.fields);\n } finally {\n if (!--this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n }\n\n public diff(\n options: Cache.DiffOptions\n ): Cache.DiffResult {\n return this.storeReader.diffQueryAgainstStore({\n ...options,\n store: options.optimistic ? this.optimisticData : this.data,\n rootId: options.id || \"ROOT_QUERY\",\n config: this.config,\n });\n }\n\n public watch(\n watch: Cache.WatchOptions\n ): () => void {\n if (!this.watches.size) {\n // In case we previously called forgetCache(this) because\n // this.watches became empty (see below), reattach this cache to any\n // reactive variables on which it previously depended. It might seem\n // paradoxical that we're able to recall something we supposedly\n // forgot, but the point of calling forgetCache(this) is to silence\n // useless broadcasts while this.watches is empty, and to allow the\n // cache to be garbage collected. If, however, we manage to call\n // recallCache(this) here, this cache object must not have been\n // garbage collected yet, and should resume receiving updates from\n // reactive variables, now that it has a watcher to notify.\n recallCache(this);\n }\n this.watches.add(watch);\n if (watch.immediate) {\n this.maybeBroadcastWatch(watch);\n }\n return () => {\n // Once we remove the last watch from this.watches, cache.broadcastWatches\n // no longer does anything, so we preemptively tell the reactive variable\n // system to exclude this cache from future broadcasts.\n if (this.watches.delete(watch) && !this.watches.size) {\n forgetCache(this);\n }\n // Remove this watch from the LRU cache managed by the\n // maybeBroadcastWatch OptimisticWrapperFunction, to prevent memory\n // leaks involving the closure of watch.callback.\n this.maybeBroadcastWatch.forget(watch);\n };\n }\n\n public gc(options?: {\n // If true, also free non-essential result cache memory by bulk-releasing\n // this.{store{Reader,Writer},maybeBroadcastWatch}. Defaults to false.\n resetResultCache?: boolean;\n // If resetResultCache is true, this.storeReader.canon will be preserved by\n // default, but can also be discarded by passing resetResultIdentities:true.\n // Defaults to false.\n resetResultIdentities?: boolean;\n }) {\n canonicalStringify.reset();\n print.reset();\n this.addTypenameTransform.resetCache();\n this.config.fragments?.resetCaches();\n const ids = this.optimisticData.gc();\n if (options && !this.txCount) {\n if (options.resetResultCache) {\n this.resetResultCache(options.resetResultIdentities);\n } else if (options.resetResultIdentities) {\n this.storeReader.resetCanon();\n }\n }\n return ids;\n }\n\n // Call this method to ensure the given root ID remains in the cache after\n // garbage collection, along with its transitive child entities. Note that\n // the cache automatically retains all directly written entities. By default,\n // the retainment persists after optimistic updates are removed. Pass true\n // for the optimistic argument if you would prefer for the retainment to be\n // discarded when the top-most optimistic layer is removed. Returns the\n // resulting (non-negative) retainment count.\n public retain(rootId: string, optimistic?: boolean): number {\n return (optimistic ? this.optimisticData : this.data).retain(rootId);\n }\n\n // Call this method to undo the effect of the retain method, above. Once the\n // retainment count falls to zero, the given ID will no longer be preserved\n // during garbage collection, though it may still be preserved by other safe\n // entities that refer to it. Returns the resulting (non-negative) retainment\n // count, in case that's useful.\n public release(rootId: string, optimistic?: boolean): number {\n return (optimistic ? this.optimisticData : this.data).release(rootId);\n }\n\n // Returns the canonical ID for a given StoreObject, obeying typePolicies\n // and keyFields (and dataIdFromObject, if you still use that). At minimum,\n // the object must contain a __typename and any primary key fields required\n // to identify entities of that type. If you pass a query result object, be\n // sure that none of the primary key fields have been renamed by aliasing.\n // If you pass a Reference object, its __ref ID string will be returned.\n public identify(object: StoreObject | Reference): string | undefined {\n if (isReference(object)) return object.__ref;\n try {\n return this.policies.identify(object)[0];\n } catch (e) {\n invariant.warn(e);\n }\n }\n\n public evict(options: Cache.EvictOptions): boolean {\n if (!options.id) {\n if (hasOwn.call(options, \"id\")) {\n // See comment in modify method about why we return false when\n // options.id exists but is falsy/undefined.\n return false;\n }\n options = { ...options, id: \"ROOT_QUERY\" };\n }\n try {\n // It's unlikely that the eviction will end up invoking any other\n // cache update operations while it's running, but {in,de}crementing\n // this.txCount still seems like a good idea, for uniformity with\n // the other update methods.\n ++this.txCount;\n // Pass this.data as a limit on the depth of the eviction, so evictions\n // during optimistic updates (when this.data is temporarily set equal to\n // this.optimisticData) do not escape their optimistic Layer.\n return this.optimisticData.evict(options, this.data);\n } finally {\n if (!--this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n }\n\n public reset(options?: Cache.ResetOptions): Promise {\n this.init();\n\n canonicalStringify.reset();\n\n if (options && options.discardWatches) {\n // Similar to what happens in the unsubscribe function returned by\n // cache.watch, applied to all current watches.\n this.watches.forEach((watch) => this.maybeBroadcastWatch.forget(watch));\n this.watches.clear();\n forgetCache(this);\n } else {\n // Calling this.init() above unblocks all maybeBroadcastWatch caching, so\n // this.broadcastWatches() triggers a broadcast to every current watcher\n // (letting them know their data is now missing). This default behavior is\n // convenient because it means the watches do not have to be manually\n // reestablished after resetting the cache. To prevent this broadcast and\n // cancel all watches, pass true for options.discardWatches.\n this.broadcastWatches();\n }\n\n return Promise.resolve();\n }\n\n public removeOptimistic(idToRemove: string) {\n const newOptimisticData = this.optimisticData.removeLayer(idToRemove);\n if (newOptimisticData !== this.optimisticData) {\n this.optimisticData = newOptimisticData;\n this.broadcastWatches();\n }\n }\n\n private txCount = 0;\n\n public batch(\n options: Cache.BatchOptions\n ): TUpdateResult {\n const {\n update,\n optimistic = true,\n removeOptimistic,\n onWatchUpdated,\n } = options;\n\n let updateResult: TUpdateResult;\n const perform = (layer?: EntityStore): TUpdateResult => {\n const { data, optimisticData } = this;\n ++this.txCount;\n if (layer) {\n this.data = this.optimisticData = layer;\n }\n try {\n return (updateResult = update(this));\n } finally {\n --this.txCount;\n this.data = data;\n this.optimisticData = optimisticData;\n }\n };\n\n const alreadyDirty = new Set();\n\n if (onWatchUpdated && !this.txCount) {\n // If an options.onWatchUpdated callback is provided, we want to call it\n // with only the Cache.WatchOptions objects affected by options.update,\n // but there might be dirty watchers already waiting to be broadcast that\n // have nothing to do with the update. To prevent including those watchers\n // in the post-update broadcast, we perform this initial broadcast to\n // collect the dirty watchers, so we can re-dirty them later, after the\n // post-update broadcast, allowing them to receive their pending\n // broadcasts the next time broadcastWatches is called, just as they would\n // if we never called cache.batch.\n this.broadcastWatches({\n ...options,\n onWatchUpdated(watch) {\n alreadyDirty.add(watch);\n return false;\n },\n });\n }\n\n if (typeof optimistic === \"string\") {\n // Note that there can be multiple layers with the same optimistic ID.\n // When removeOptimistic(id) is called for that id, all matching layers\n // will be removed, and the remaining layers will be reapplied.\n this.optimisticData = this.optimisticData.addLayer(optimistic, perform);\n } else if (optimistic === false) {\n // Ensure both this.data and this.optimisticData refer to the root\n // (non-optimistic) layer of the cache during the update. Note that\n // this.data could be a Layer if we are currently executing an optimistic\n // update function, but otherwise will always be an EntityStore.Root\n // instance.\n perform(this.data);\n } else {\n // Otherwise, leave this.data and this.optimisticData unchanged and run\n // the update with broadcast batching.\n perform();\n }\n\n if (typeof removeOptimistic === \"string\") {\n this.optimisticData = this.optimisticData.removeLayer(removeOptimistic);\n }\n\n // Note: if this.txCount > 0, then alreadyDirty.size === 0, so this code\n // takes the else branch and calls this.broadcastWatches(options), which\n // does nothing when this.txCount > 0.\n if (onWatchUpdated && alreadyDirty.size) {\n this.broadcastWatches({\n ...options,\n onWatchUpdated(watch, diff) {\n const result = onWatchUpdated.call(this, watch, diff);\n if (result !== false) {\n // Since onWatchUpdated did not return false, this diff is\n // about to be broadcast to watch.callback, so we don't need\n // to re-dirty it with the other alreadyDirty watches below.\n alreadyDirty.delete(watch);\n }\n return result;\n },\n });\n // Silently re-dirty any watches that were already dirty before the update\n // was performed, and were not broadcast just now.\n if (alreadyDirty.size) {\n alreadyDirty.forEach((watch) => this.maybeBroadcastWatch.dirty(watch));\n }\n } else {\n // If alreadyDirty is empty or we don't have an onWatchUpdated\n // function, we don't need to go to the trouble of wrapping\n // options.onWatchUpdated.\n this.broadcastWatches(options);\n }\n\n return updateResult!;\n }\n\n public performTransaction(\n update: (cache: InMemoryCache) => any,\n optimisticId?: string | null\n ) {\n return this.batch({\n update,\n optimistic: optimisticId || optimisticId !== null,\n });\n }\n\n public transformDocument(document: DocumentNode): DocumentNode {\n return this.addTypenameToDocument(this.addFragmentsToDocument(document));\n }\n\n protected broadcastWatches(options?: BroadcastOptions) {\n if (!this.txCount) {\n this.watches.forEach((c) => this.maybeBroadcastWatch(c, options));\n }\n }\n\n private addFragmentsToDocument(document: DocumentNode) {\n const { fragments } = this.config;\n return fragments ? fragments.transform(document) : document;\n }\n\n private addTypenameToDocument(document: DocumentNode) {\n if (this.addTypename) {\n return this.addTypenameTransform.transformDocument(document);\n }\n return document;\n }\n\n // This method is wrapped by maybeBroadcastWatch, which is called by\n // broadcastWatches, so that we compute and broadcast results only when\n // the data that would be broadcast might have changed. It would be\n // simpler to check for changes after recomputing a result but before\n // broadcasting it, but this wrapping approach allows us to skip both\n // the recomputation and the broadcast, in most cases.\n private broadcastWatch(c: Cache.WatchOptions, options?: BroadcastOptions) {\n const { lastDiff } = c;\n\n // Both WatchOptions and DiffOptions extend ReadOptions, and DiffOptions\n // currently requires no additional properties, so we can use c (a\n // WatchOptions object) as DiffOptions, without having to allocate a new\n // object, and without having to enumerate the relevant properties (query,\n // variables, etc.) explicitly. There will be some additional properties\n // (lastDiff, callback, etc.), but cache.diff ignores them.\n const diff = this.diff(c);\n\n if (options) {\n if (c.optimistic && typeof options.optimistic === \"string\") {\n diff.fromOptimisticTransaction = true;\n }\n\n if (\n options.onWatchUpdated &&\n options.onWatchUpdated.call(this, c, diff, lastDiff) === false\n ) {\n // Returning false from the onWatchUpdated callback will prevent\n // calling c.callback(diff) for this watcher.\n return;\n }\n }\n\n if (!lastDiff || !equal(lastDiff.result, diff.result)) {\n c.callback((c.lastDiff = diff), lastDiff);\n }\n }\n\n /**\n * @experimental\n * @internal\n * This is not a stable API - it is used in development builds to expose\n * information to the DevTools.\n * Use at your own risk!\n */\n public getMemoryInternals?: typeof getInMemoryCacheMemoryInternals;\n}\n\nif (__DEV__) {\n InMemoryCache.prototype.getMemoryInternals = getInMemoryCacheMemoryInternals;\n}\n","import { ApolloClient, InMemoryCache, HttpLink } from \"@apollo/client/core\";\n\nimport GET_ELECTION_LOG_ENTRIES from \"./operations/get_election_log_entries\";\nimport PROCESS_KEY_CEREMONY_STEP from \"./operations/process_key_ceremony_step\";\nimport PROCESS_TALLY_STEP from \"./operations/process_tally_step\";\nimport GET_LOG_ENTRY from \"./operations/get_log_entry\";\nimport GET_PENDING_MESSAGE_BY_MESSAGE_ID from \"./operations/get_pending_message_by_message_id\";\n\n/**\n * This is the Bulletin Board API client that will use Apollo's client to\n * interact with our GraphQL schema using both http and websocket connections.\n */\nexport class GraphQLClient {\n /**\n * Initializes the class given the correct params. Since we need to handle\n * both http and websocket connections we need to create two links and use either\n * of them depending on the GraphQL operation.\n *\n * @constructor\n * @param {Object} params - An object that include the following options.\n * - {String} apiEndpointUrl - The http endpoint used to perform queries and mutations.\n * - {Object?} headers - An optional object of headers to be included on http requests.\n */\n constructor({ apiEndpointUrl, headers }) {\n const httpLink = new HttpLink({\n uri: apiEndpointUrl,\n headers,\n });\n\n this.apolloClient = new ApolloClient({\n link: httpLink,\n cache: new InMemoryCache(),\n });\n }\n\n /**\n * Query a log entry for the given election unique id and the given content hash.\n *\n * @param {Object} params - An object that includes the following options.\n * - {String} electionUniqueId - The election's unique id.\n * - {String} contentHash - The log entry content hash.\n * @returns {Promise>} - A log entry.\n * @throws Will throw an error if the request is rejected.\n */\n async getLogEntry({ electionUniqueId, contentHash }) {\n const result = await this.apolloClient.query({\n query: GET_LOG_ENTRY,\n variables: {\n electionUniqueId,\n contentHash,\n },\n });\n return result.data.logEntry;\n }\n\n /**\n * Query all log entries for the given election unique id.\n *\n * @param {Object} params - An object that include the following options.\n * - {String} electionUniqueId - The election's unique id.\n * - {String} after - The last log entry id received, to avoid including those entries again.\n * - {Array} types - The list of type of messages to retrieve.\n * @returns {Promise>} - A collection of log entries.\n * @throws Will throw an error if the request is rejected.\n */\n async getElectionLogEntries({ electionUniqueId, after, types }) {\n const result = await this.apolloClient.query({\n query: GET_ELECTION_LOG_ENTRIES,\n variables: {\n electionUniqueId,\n after,\n types,\n },\n fetchPolicy: \"no-cache\",\n });\n\n return result.data.election.logEntries;\n }\n\n /**\n * Process a key ceremony step sending a signed message.\n *\n * @param {Object} params - An object that include the following options.\n * - {String} messageId - The message id.\n * - {String} signedData - The signed data to be processed.\n * @returns {Promise} - A pending message created.\n * @throws Will throw an error if the request is rejected or the data contains an error.\n */\n async processKeyCeremonyStep({ messageId, signedData }) {\n const result = await this.apolloClient.mutate({\n mutation: PROCESS_KEY_CEREMONY_STEP,\n variables: {\n messageId,\n signedData,\n },\n });\n\n if (result.data.processKeyCeremonyStep.error) {\n throw new Error(result.data.processKeyCeremonyStep.error);\n }\n\n return result.data.processKeyCeremonyStep.pendingMessage;\n }\n\n /**\n * Query PendingMessages for a given messageId\n *\n * @param {Object} params - An object that include the following options.\n * - {String} messageId - The messageId\n * @returns {Promise} - The pending message received.\n * @throws Will throw an error if the request is rejected.\n */\n async getPendingMessageByMessageId({ messageId }) {\n const result = await this.apolloClient.query({\n query: GET_PENDING_MESSAGE_BY_MESSAGE_ID,\n variables: {\n messageId,\n },\n });\n\n return result.data.pendingMessage;\n }\n\n /**\n * Process a tally step sending a signed message.\n *\n * @param {Object} params - An object that include the following options.\n * - {String} messageId - The message id.\n * - {String} signedData - The signed data to be processed.\n * @returns {Promise} - A pending message created.\n * @throws Will throw an error if the request is rejected or the data contains an error.\n */\n async processTallyStep({ messageId, signedData }) {\n const result = await this.apolloClient.mutate({\n mutation: PROCESS_TALLY_STEP,\n variables: {\n messageId,\n signedData,\n },\n });\n\n if (result.data.processTallyStep.error) {\n throw new Error(result.data.processTallyStep.error);\n }\n\n return result.data.processTallyStep.pendingMessage;\n }\n}\n","import { GraphQLClient } from \"./graphql-client\";\n\nexport const WAIT_TIME_MS = 1_000; // 1s\n\n/**\n * This is a facade over the API client specific implementation.\n */\nexport class Client {\n /**\n * Initializes the API client using the same params.\n *\n * @constructor\n * @param {Object} params - An object that include the same params as the API client.\n */\n constructor(params) {\n this.apiClient = new GraphQLClient(params);\n }\n\n /**\n * Query a log entry for the given election unique id and the given content hash.\n *\n * @param {Object} params - An object that include the following options.\n * - {String} electionUniqueId - The election's unique id.\n * - {String} contentHash - The log entry content hash.\n * @returns {Promise>} - A log entry.\n * @throws Will throw an error if the request is rejected.\n */\n getLogEntry({ electionUniqueId, contentHash }) {\n return this.apiClient.getLogEntry({ electionUniqueId, contentHash });\n }\n\n /**\n * Query all log entries for the given election id.\n *\n * @param {Object} params - An object that include the following options.\n * - {String} electionUniqueId - The election's unique id.\n * - {String} after - The last log entry id received, to avoid including those entries again.\n * - {Array} types - The list of type of messages to retrieve.\n * @returns {Promise>} - A collection of log entries.\n * @throws Will throw an error if the request is rejected.\n */\n getElectionLogEntries(params) {\n return this.apiClient.getElectionLogEntries(params);\n }\n\n /**\n * Process a key ceremony step sending a signed message.\n *\n * @param {Object} params - An object that includes the data to perform the operation.\n * @returns {Promise} - A pending message created.\n * @throws Will throw an error if the request is rejected or the data contains an error.\n */\n processKeyCeremonyStep(params) {\n return this.apiClient.processKeyCeremonyStep(params);\n }\n\n /**\n * Process a tally step sending a signed message.\n *\n * @param {Object} params - An object that includes the data to perform the operation.\n * @returns {Promise} - A pending message created.\n * @throws Will throw an error if the request is rejected or the data contains an error.\n */\n processTallyStep(params) {\n return this.apiClient.processTallyStep(params);\n }\n\n /**\n * Wait until a pending message is processed\n *\n * @param {String} messageId - the unique identifier of a message\n * @param {Integer} [waitTime=WAIT_TIME_MS] - the interval to wait for the pending message to be processed\n * @returns {Promise} - Returns the PendingMessage\n */\n waitForPendingMessageToBeProcessed(messageId, waitTime = WAIT_TIME_MS) {\n return new Promise((resolve) => {\n const intervalId = setInterval(() => {\n this.apiClient\n .getPendingMessageByMessageId({\n messageId,\n })\n .then((pendingMessage) => {\n if (pendingMessage.status !== \"enqueued\") {\n clearInterval(intervalId);\n resolve(pendingMessage);\n }\n });\n }, waitTime);\n });\n }\n}\n","/* eslint-disable camelcase */\nimport { EventManager } from \"./event_manager\";\nimport { MessageParser } from \"../client/message-parser\";\nimport { MessageIdentifier, TRUSTEE_TYPE } from \"../client/message-identifier\";\n\nexport const WAIT_TIME_MS = 100; // 0.1s\n\n/**\n * This class encapsulates all the behavior that is needed to interact with the evoting\n * system as a Trustee role.\n */\nexport class Trustee {\n /**\n * Initializes the class with the given params.\n *\n * @constructor\n * @param {Object} params - An object that contains the initialization params.\n * - {String} uniqueId - The trustee identifier.\n * - {String} authorityPublicKeyJSON - The authority identification public key.\n * - {Object} identificationKeys - A object that contains both the public and private key for\n * the corresponding trustee.\n * - {Object} wrapperAdapter - An object to interact with the trustee wrapper.\n * - {Object?} options - An optional object with some extra options.\n */\n constructor({\n uniqueId,\n authorityPublicKeyJSON,\n identificationKeys,\n wrapperAdapter,\n options,\n }) {\n this.uniqueId = uniqueId;\n this.identificationKeys = identificationKeys;\n this.election = null;\n this.options = options || { waitUntilNextCheck: WAIT_TIME_MS };\n this.wrapperAdapter = wrapperAdapter;\n this.parser = new MessageParser({ authorityPublicKeyJSON });\n this.events = new EventManager();\n this.nextLogEntryIndexToProcess = 0;\n this.lastMessageProcessedWithResult = null;\n this.hasSetupKeyCeremony = false;\n }\n\n /**\n * Performs some operations to setup the trustee.\n *\n * Initializes a subscription to store new log entries for the given election.\n *\n * @returns {Promise}\n */\n async setup() {\n if (this.election === null) {\n throw new Error(\"election is not set.\");\n }\n await this.wrapperAdapter.setup();\n return this.election.subscribeToLogEntriesChanges();\n }\n\n /**\n * Performs some operations to clean up after the key ceremony is done.\n *\n * @returns {undefined}\n */\n tearDown() {\n this.election.unsubscribeToLogEntriesChanges();\n }\n\n /**\n * Setup the key ceremony process processing the first log entry and yielding its result.\n * Then it sends the result to the bulletin board and mark the setup as done.\n *\n * @generator\n * @yields {String} - The state of the trustee to be able to perform future restores.\n * @returns {Promise}\n */\n async *setupKeyCeremony() {\n let message;\n while (!message) {\n message = await this.waitForNextLogEntryResult();\n }\n\n yield await this.wrapperAdapter.backup();\n await this.processKeyCeremonyStep(message);\n this.hasSetupKeyCeremony = true;\n return this.hasSetupKeyCeremony;\n }\n\n /**\n * Starts or continues with the key ceremony process.\n *\n * @returns {Promise}\n * @throws An exception is raised if the trustee needs to be restored or\n * there is a problem with the client.\n */\n async runKeyCeremony() {\n if (!this.hasSetupKeyCeremony) {\n throw new Error(\"The key ceremony has not been setup yet\");\n }\n\n if (await this.needsToBeRestored()) {\n throw new Error(\"You need to restore the wrapper state to continue\");\n }\n\n return this.waitForNextLogEntryResult().then(async (message) => {\n await this.processKeyCeremonyStep(message);\n\n if (await this.wrapperAdapter.isKeyCeremonyDone()) {\n return this.tearDown();\n }\n\n return this.runKeyCeremony();\n });\n }\n\n /**\n * Starts or continues with the tally process.\n *\n * @returns {Promise}\n * @throws An exception is raised if the trustee needs to be restored or\n * there is a problem with the client.\n */\n async runTally() {\n if (await this.needsToBeRestored()) {\n throw new Error(\"You need to restore the wrapper state to continue\");\n }\n\n return this.waitForNextLogEntryResult().then(async (message) => {\n await this.processTallyStep(message);\n\n if (await this.wrapperAdapter.isTallyDone()) {\n return this.tearDown();\n }\n\n return this.runTally();\n });\n }\n\n /**\n * Whether the trustee state needs to be restored or not.\n *\n * @returns {Promise}\n */\n async needsToBeRestored() {\n const lastMessageFromTrustee = this.election.getLastMessageFromTrustee(\n this.uniqueId,\n );\n\n return lastMessageFromTrustee && (await this.wrapperAdapter.isFresh());\n }\n\n /**\n * Restore the trustee state from the given state string. It uses the last message sent to check that the state is valid.\n *\n * @param {string} wrapperState - As string with the trustee state retrieved from the backup method.\n * @returns {Promise}\n */\n async restore(wrapperState) {\n const lastMessageFromTrustee = this.election.getLastMessageFromTrustee(\n this.uniqueId,\n );\n\n this.hasSetupKeyCeremony =\n lastMessageFromTrustee &&\n (await this.wrapperAdapter.restore(wrapperState));\n\n return this.hasSetupKeyCeremony;\n }\n\n /**\n * Creates an interval that will check periodically if there are new log entries\n * to process. The interval is done when a new log entry is processed and it has\n * a result.\n *\n * @private\n * @returns {Promise}\n */\n async waitForNextLogEntryResult() {\n await new Promise((resolve) => {\n const intervalId = setInterval(async () => {\n const { logEntries } = this.election;\n\n if (logEntries.length > this.nextLogEntryIndexToProcess) {\n clearInterval(intervalId);\n resolve();\n }\n }, this.options.waitUntilNextCheck);\n });\n\n return this.processNextLogEntry();\n }\n\n /**\n * Processes the next log entry and outputs the result. It broadcasts an event\n * when the message is received and another one when it is processed.\n *\n * @private\n * @returns {Promise}\n */\n async processNextLogEntry() {\n const { logEntries } = this.election;\n const message = logEntries[this.nextLogEntryIndexToProcess];\n\n this.events.broadcastMessageReceived(message);\n\n const { messageIdentifier, decodedData } = await this.parser.parse(message);\n\n const result = await this.wrapperAdapter.processMessage(\n messageIdentifier.typeSubtype,\n decodedData,\n );\n\n this.events.broadcastMessageProcessed(message, result);\n\n this.nextLogEntryIndexToProcess += 1;\n\n if (result) {\n const { messageType, content } = result;\n return {\n message_id: MessageIdentifier.format(\n this.election.uniqueId,\n messageType,\n TRUSTEE_TYPE,\n this.uniqueId,\n ),\n content,\n };\n }\n\n return result;\n }\n\n /**\n * If there is a message to be sent that has not been sent already it is signed\n * and send it to the bulletin board as a key ceremony step.\n *\n * @private\n * @returns {Promise}\n */\n async processKeyCeremonyStep(message) {\n if (message && !this.isMessageAlreadyLogged(message)) {\n const signedData = await this.signMessage(message);\n return this.election.bulletinBoardClient.processKeyCeremonyStep({\n messageId: message.message_id,\n signedData,\n });\n }\n }\n\n /**\n * If there is a message to be sent that has not been sent already it is signed\n * and send it to the bulletin board as a trustee step.\n *\n * @private\n * @returns {Promise}\n */\n async processTallyStep(message) {\n if (message && !this.isMessageAlreadyLogged(message)) {\n const signedData = await this.signMessage(message);\n return this.election.bulletinBoardClient.processTallyStep({\n messageId: message.message_id,\n signedData,\n });\n }\n }\n\n /**\n * Whether the message is already in the election log or not.\n *\n * @private\n * @returns {Boolean}\n */\n isMessageAlreadyLogged({ message_id }) {\n const { logEntries } = this.election;\n return logEntries.find((logEntry) => logEntry.messageId === message_id);\n }\n\n /**\n * Signs a message using the trustee identification keys.\n *\n * @private\n * @param {Object} message - The message to be signed.\n * @returns {Promise}\n */\n signMessage(message) {\n return this.identificationKeys.sign({\n iat: Math.floor(new Date() / 1000),\n ...message,\n });\n }\n}\n","// show a message to the user if comunication is lost\nimport \"src/decidim/elections/broken_promises_handler\";\n\nimport { Client } from \"@decidim/decidim-bulletin_board\";\n\n$(async () => {\n const $inPersonVoteWrapper = $(\"#in-person-vote-wrapper\");\n if ($inPersonVoteWrapper.length > 0) {\n const bulletinBoardClient = new Client({\n apiEndpointUrl: $inPersonVoteWrapper.data(\"apiEndpointUrl\")\n });\n const messageId = $inPersonVoteWrapper.data(\"messageId\");\n\n await bulletinBoardClient.waitForPendingMessageToBeProcessed(messageId);\n\n $(\"form.update_vote_status\").trigger(\"submit\");\n }\n\n $(\"#js-verify-document\").on(\"click\", () => {\n $(\"#verify-document\").attr(\"hidden\", true);\n $(\"#complete-voting\").attr(\"hidden\", false);\n });\n});\n","import \"src/decidim/votings/in-person-vote\";\nimport \"src/decidim/votings/polling_officer_zone/edit-closure\";\nimport \"src/decidim/votings/polling_officer_zone/sign-closure\";\nimport \"src/decidim/votings/polling_officer_zone/in-person-vote\";\nimport \"src/decidim/votings/polling_officer_zone/new-closure\";\n\n// Images\nrequire.context(\"../images\", true)\n\n// CSS\nimport \"stylesheets/decidim/votings/votings.scss\"\n"],"names":["map","webpackContext","req","id","webpackContextResolve","__webpack_require__","o","e","Error","code","keys","Object","resolve","module","exports","window","addEventListener","event","Decidim","currentDialogs","document","getElementById","innerHTML","reason","toString","indexOf","hidden","open","$","$validBallotsInput","$blankBallotsInput","$nullBallotsInput","checkTotals","totalBallots","data","parseInt","val","attr","on","target","is","$submitBtn","$modalBtn","$totalBallotsInput","$electionVotesInput","find","html","modalPollingOfficerNotes","trim","notSigned","prop","byteLength","b64","lens","getLens","validLen","placeHoldersLen","toByteArray","tmp","i","arr","Arr","_byteLength","curByte","len","revLookup","charCodeAt","fromByteArray","uint8","length","extraBytes","parts","maxChunkLength","len2","push","encodeChunk","lookup","join","Uint8Array","Array","start","end","num","output","pad_string_1","require","encode","input","encoding","Buffer","isBuffer","fromBase64","from","toBase64","base64url","replace","base64","decode","toBuffer","defineProperty","value","stringLength","diff","position","padLength","paddedStringLength","buffer","alloc","write","_typeof","Symbol","iterator","constructor","prototype","ieee754","customInspectSymbol","K_MAX_LENGTH","createBuffer","RangeError","buf","setPrototypeOf","arg","encodingOrOffset","TypeError","allocUnsafe","string","isEncoding","actual","slice","fromString","ArrayBuffer","isView","arrayView","isInstance","copy","fromArrayBuffer","byteOffset","fromArrayLike","fromArrayView","SharedArrayBuffer","valueOf","b","obj","checked","undefined","numberIsNaN","type","isArray","fromObject","toPrimitive","assertSize","size","array","mustMatch","arguments","loweredCase","utf8ToBytes","base64ToBytes","toLowerCase","slowToString","this","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","n","m","bidirectionalIndexOf","dir","arrayIndexOf","call","lastIndexOf","indexSize","arrLength","valLength","String","read","readUInt16BE","foundIndex","found","j","hexWrite","offset","Number","remaining","strLen","parsed","substr","utf8Write","blitBuffer","asciiWrite","str","byteArray","asciiToBytes","base64Write","ucs2Write","units","c","hi","lo","utf16leToBytes","Math","min","res","secondByte","thirdByte","fourthByte","tempCodePoint","firstByte","codePoint","bytesPerSequence","codePoints","MAX_ARGUMENTS_LENGTH","fromCharCode","apply","decodeCodePointsArray","TYPED_ARRAY_SUPPORT","proto","foo","typedArraySupport","console","error","enumerable","get","poolSize","fill","allocUnsafeSlow","_isBuffer","compare","a","x","y","concat","list","pos","set","swap16","swap32","swap64","toLocaleString","equals","inspect","max","thisStart","thisEnd","thisCopy","targetCopy","includes","isFinite","toJSON","_arr","ret","out","hexSliceLookupTable","bytes","checkOffset","ext","checkInt","checkIEEE754","writeFloat","littleEndian","noAssert","writeDouble","newBuf","subarray","readUintLE","readUIntLE","mul","readUintBE","readUIntBE","readUint8","readUInt8","readUint16LE","readUInt16LE","readUint16BE","readUint32LE","readUInt32LE","readUint32BE","readUInt32BE","readIntLE","pow","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readFloatLE","readFloatBE","readDoubleLE","readDoubleBE","writeUintLE","writeUIntLE","writeUintBE","writeUIntBE","writeUint8","writeUInt8","writeUint16LE","writeUInt16LE","writeUint16BE","writeUInt16BE","writeUint32LE","writeUInt32LE","writeUint32BE","writeUInt32BE","writeIntLE","limit","sub","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeFloatLE","writeFloatBE","writeDoubleLE","writeDoubleBE","targetStart","copyWithin","INVALID_BASE64_RE","Infinity","leadSurrogate","split","base64clean","src","dst","name","alphabet","table","i16","isFunction","vertxNext","customSchedulerFn","asap","callback","queue","flush","scheduleFlush","browserWindow","browserGlobal","BrowserMutationObserver","MutationObserver","WebKitMutationObserver","isNode","self","process","isWorker","Uint8ClampedArray","importScripts","MessageChannel","useSetTimeout","globalSetTimeout","setTimeout","channel","iterations","observer","node","then","onFulfillment","onRejection","parent","child","noop","PROMISE_ID","makePromise","_state","invokeCallback","_result","subscribe","resolve$1","object","promise","nextTick","createTextNode","observe","characterData","port1","onmessage","port2","postMessage","vertx","Function","runOnLoop","runOnContext","attemptVertx","random","substring","PENDING","FULFILLED","REJECTED","handleMaybeThenable","maybeThenable","then$$1","thenable","fulfill","reject","handleOwnThenable","sealed","fulfillmentHandler","rejectionHandler","tryThen","_label","handleForeignThenable","publishRejection","_onerror","publish","_subscribers","subscribers","settled","detail","hasCallback","succeeded","Enumerator","Constructor","_instanceConstructor","_remaining","_enumerate","_eachEntry","entry","resolve$$1","_then","didError","_settledAt","Promise$1","_willSettleAt","state","enumerator","Promise","resolver","needsResolver","initializePromise","needsNew","all","entries","race","_","_setScheduler","scheduleFn","_setAsap","asapFn","_asap","polyfill","local","global","P","promiseToString","cast","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","d","s","NaN","rt","abs","isNaN","floor","log","LN2","DataView","getNative","hashClear","hashDelete","hashGet","hashHas","hashSet","Hash","index","clear","has","baseCreate","baseLodash","LazyWrapper","__wrapped__","__actions__","__dir__","__filtered__","__iteratees__","__takeCount__","__views__","listCacheClear","listCacheDelete","listCacheGet","listCacheHas","listCacheSet","ListCache","LodashWrapper","chainAll","__chain__","__index__","__values__","Map","mapCacheClear","mapCacheDelete","mapCacheGet","mapCacheHas","mapCacheSet","MapCache","Set","setCacheAdd","setCacheHas","SetCache","values","__data__","add","stackClear","stackDelete","stackGet","stackHas","stackSet","Stack","WeakMap","func","thisArg","args","iteratee","predicate","resIndex","result","baseIndexOf","comparator","baseTimes","isArguments","isIndex","isTypedArray","hasOwnProperty","inherited","isArr","isArg","isBuff","isType","skipIndexes","key","baseAssignValue","eq","objValue","copyObject","source","keysIn","number","lower","upper","arrayEach","assignValue","baseAssign","baseAssignIn","cloneBuffer","copyArray","copySymbols","copySymbolsIn","getAllKeys","getAllKeysIn","getTag","initCloneArray","initCloneByTag","initCloneObject","isMap","isObject","isSet","argsTag","funcTag","objectTag","cloneableTags","baseClone","bitmask","customizer","stack","isDeep","isFlat","isFull","tag","isFunc","stacked","forEach","subValue","props","objectCreate","create","toInteger","toLength","fromIndex","fromRight","arrayPush","isFlattenable","baseFlatten","depth","isStrict","baseFor","createBaseFor","castPath","toKey","path","keysFunc","symbolsFunc","getRawTag","objectToString","symToStringTag","toStringTag","baseFindIndex","baseIsNaN","strictIndexOf","arrayIncludes","arrayIncludesWith","arrayMap","baseUnary","cacheHas","nativeMin","arrays","othLength","othIndex","caches","maxLength","seen","outer","computed","cache","baseGetTag","isObjectLike","isMasked","toSource","reIsHostCtor","funcProto","objectProto","funcToString","reIsNative","RegExp","test","isLength","typedArrayTags","isPrototype","nativeKeys","nativeKeysIn","isProto","assignMergeValue","baseMergeDeep","safeGet","baseMerge","srcIndex","srcValue","newValue","cloneTypedArray","isArrayLikeObject","isPlainObject","toPlainObject","mergeFunc","isCommon","isTyped","basePickBy","hasIn","paths","baseGet","baseSet","identity","overRest","setToString","lastIndex","nested","metaMap","baseSetData","constant","baseSetToString","isSymbol","symbolProto","symbolToString","baseToString","trimmedEndIndex","reTrimStart","createSet","setToArray","seenIndex","last","isKey","stringToPath","arrayBuffer","root","freeExports","nodeType","freeModule","cloneArrayBuffer","dataView","reFlags","regexp","exec","symbolValueOf","symbol","typedArray","nativeMax","partials","holders","isCurried","argsIndex","argsLength","holdersLength","leftIndex","leftLength","rangeLength","isUncurried","holdersIndex","rightIndex","rightLength","isNew","getSymbols","getSymbolsIn","coreJsData","placeholder","baseRest","isIterateeCall","assigner","sources","guard","iterable","createCtor","isBind","Ctor","wrapper","thisBinding","createHybrid","createRecurry","getHolder","replaceHolders","arity","composeArgs","composeArgsRight","countHolders","reorder","partialsRight","holdersRight","argPos","ary","isAry","isBindKey","isFlip","holdersCount","newHolders","fn","reverse","isLaziable","setData","setWrapToString","wrapFunc","isCurry","newData","createBind","createCurry","createPartial","getData","mergeData","flatten","freeGlobal","baseGetAllKeys","realNames","otherFunc","isKeyable","baseIsNative","getValue","getPrototype","overArg","getPrototypeOf","nativeObjectToString","isOwn","unmasked","arrayFilter","stubArray","propertyIsEnumerable","nativeGetSymbols","getOwnPropertySymbols","mapTag","promiseTag","setTag","weakMapTag","dataViewTag","dataViewCtorString","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","ctorString","reWrapDetails","reSplitDetails","match","hasFunc","nativeCreate","cloneDataView","cloneRegExp","cloneSymbol","reWrapComment","details","spreadableSymbol","isConcatSpreadable","reIsUint","isArrayLike","reIsDeepProp","reIsPlainProp","getFuncName","lodash","funcName","other","uid","maskSrcKey","IE_PROTO","assocIndexOf","splice","pop","getMapData","memoize","PLACEHOLDER","WRAP_ARY_FLAG","srcBitmask","newBitmask","isCombo","freeProcess","nodeUtil","types","binding","transform","otherArgs","baseSlice","indexes","oldArray","freeSelf","shortOut","getWrapDetails","insertWrapDetails","updateWrapDetails","reference","nativeNow","Date","now","count","lastCalled","stamp","pairs","LARGE_ARRAY_SIZE","memoizeCapped","rePropName","reEscapeChar","quote","subString","reWhitespace","charAt","wrapFlags","pair","sort","clone","createAssigner","assign","baseFill","baseHasIn","hasPath","baseIntersection","castArrayLikeObject","intersection","mapped","baseIsArguments","stubFalse","baseIsMap","nodeIsMap","objectCtorString","baseIsSet","nodeIsSet","baseIsTypedArray","nodeIsTypedArray","arrayLikeKeys","baseKeys","baseKeysIn","memoized","Cache","merge","baseUnset","customOmitClone","flatRest","omit","CLONE_DEEP_FLAG","createWrap","partialRight","basePick","pick","toNumber","INFINITY","toFinite","remainder","baseClamp","baseTrim","reIsBadHex","reIsBinary","reIsOctal","freeParseInt","isBinary","baseUniq","wrapperClone","forge","registerAlgorithm","mode","cipher","aes","Algorithm","startEncrypting","iv","_createCipher","decrypt","createEncryptionCipher","startDecrypting","createDecryptionCipher","init","initialize","blockSize","encrypt","inBlock","outBlock","_updateBlock","_w","_init","options","util","putByte","getInt32","encryptOp","_expandKey","modes","ecb","cbc","cfb","ofb","ctr","gcm","sbox","isbox","rcon","mix","imix","Nb","xtime","e2","e4","e8","sx","sx2","me","ime","ei","temp","w","iNk","Nk","m0","m1","m2","m3","wnew","wi","a2","b2","c2","Nr","round","algorithm","toUpperCase","createDecipher","createCipher","ByteBuffer","asn1","_checkBufferLength","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","composed","bitStringContents","original","excludeBitStringContents","obj1","obj2","equal","includeBitStringContents","getBerValueLength","getByte","getInt","_fromDer","b1","longFormBytes","_getValueLength","strict","getBytes","decodeBitStrings","savedRead","savedRemaining","unused","used","tc","ex","getInt16","asn1Options","fromDer","parseAllBytes","byteCount","toDer","useBitStringContents","putBytes","putBuffer","putInt16","lenBytes","oidToDer","oid","valueBytes","derToOid","utcTimeToDate","utc","date","year","MM","DD","hh","mm","ss","setUTCFullYear","setUTCHours","setTime","generalizedTimeToDate","gentime","YYYY","fff","isUTC","parseFloat","setFullYear","setHours","dateToUtcTime","rval","format","getUTCFullYear","getUTCMonth","getUTCDate","getUTCHours","getUTCMinutes","getUTCSeconds","dateToGeneralizedTime","integerToDer","putSignedInt","integer","derToInteger","getSignedInt","validate","v","capture","errors","optional","captureAsn1","captureBitStringContents","captureBitStringValue","_nonLatinRegex","prettyPrint","level","indentation","indent","IA5String","subvalues","pki","oids","bytesToHex","decodeUtf8","message","api","_reverseAlphabets","maxline","base","first","digits","carry","at","_encodeWithByteBuffer","regex","k","algorithms","getAlgorithm","BlockCipher","_finish","_input","_op","_decrypt","opts","update","compact","finish","pad","unpad","overflow","afterFinish","transformIV","ints","blocks","inc32","block","from64To32","_ints","_inBlock","_outBlock","putInt32","padding","fillWithByte","truncate","_prev","_iv","_partialBlock","_partialOutput","_partialBytes","inputLength","partialBytes","_R","additionalData","_cipherLength","_tagLength","tagLength","_tag","_hashBlock","_hashSubkey","componentBits","_m","generateHashTable","ivLength","_j0","ghash","_aDataLength","_s","lengths","multiply","z_i","v_i","lsb","tableMultiply","z","x_i","ah","h","bits","multiplier","perInt","shft","generateSubHashTable","mid","half","m_i","m_j","des","_keys","pc2bytes0","pc2bytes1","pc2bytes2","pc2bytes3","pc2bytes4","pc2bytes5","pc2bytes6","pc2bytes7","pc2bytes8","pc2bytes9","pc2bytes10","pc2bytes11","pc2bytes12","pc2bytes13","shifts","left","right","lefttmp","righttmp","_createKeys","spfunction1","spfunction2","spfunction3","spfunction4","spfunction5","spfunction6","spfunction7","spfunction8","looping","endloop","loopinc","right1","right2","usePureJavaScript","hmac","_key","_md","_ipadding","_opadding","ctx","md","keylen","blockLength","digest","inner","getMac","dbits","jsbn","BigInteger","fromNumber","nbi","am3","xl","xh","l","navigator","am","appName","DB","DM","DV","FV","F1","F2","rr","vv","BI_RM","BI_RC","int2char","intAt","nbv","r","fromInt","nbits","t","Classic","Montgomery","mp","invDigit","mpl","mph","um","mt2","op_and","op_or","op_xor","op_andnot","lbit","cbit","NullExp","nNop","Barrett","r2","q3","ONE","dlShiftTo","mu","divide","convert","compareTo","mod","revert","reduce","divRemTo","mulTo","multiplyTo","sqrTo","squareTo","ZERO","subTo","copyTo","u0","clamp","drShiftTo","fromRadix","mi","sh","lShiftTo","bs","cbs","bm","ds","rShiftTo","q","pm","pt","ts","ms","nsh","ys","y0","yt","d1","d2","qd","isEven","exp","g","negate","toRadix","km","p","bitLength","modPowInt","multiplyUpperTo","multiplyLowerTo","dAddOffset","lowprimes","lplim","chunkSize","signum","cs","intValue","dMultiply","testBit","bitwiseTo","shiftLeft","isProbablePrime","nextBytes","op","f","changeBit","addTo","modInt","millerRabin","n1","subtract","getLowestSetBit","shiftRight","prng","modPow","byteValue","shortValue","and","or","xor","andNot","not","bitCount","setBit","clearBit","flipBit","divideAndRemainder","k1","g2","is1","modInverse","ac","u","gcd","mgf","mgf1","generate","seed","maskLen","ceil","digestLength","_IN","_I_","pbe","encryptedPrivateKeyValidator","PBES2AlgorithmsValidator","pkcs12PbeParamsValidator","hash","prfOidToMessageDigest","prfOid","prfAlgorithm","supported","prfAlgorithmToMessageDigest","factory","sha512","encryptPrivateKeyInfo","password","saltSize","dkLen","encryptionAlgorithm","encryptedData","salt","getBytesSync","countBytes","ivLen","encOid","cipherFn","dk","pkcs5","pbkdf2","params","hexToBytes","createPbkdf2Params","saltBytes","generatePkcs12Key","decryptPrivateKeyInfo","encryptionOid","getCipher","encryptionParams","encrypted","encryptedPrivateKeyToPem","epki","msg","body","pem","encryptedPrivateKeyFromPem","headerType","procType","encryptRsaPrivateKey","rsaKey","legacy","wrapRsaPrivateKey","privateKeyToAsn1","opensslDeriveBytes","version","dekInfo","parameters","decryptRsaPrivateKey","rc2","privateKeyFromAsn1","iter","sha1","passBuf","D","Slen","S","Plen","I","B","Inew","chunk","setAt","getCipherForPBES2","getCipherForPKCS12PBE","supportedOids","kdfOid","kdfSalt","kdfIterationCount","encIv","dIvLen","md5","digests","crypto","isNodejs","pbkdf2Sync","err","hLen","prf","u_c","u_c1","int32ToBytes","xorBytes","setImmediate","foldHeader","header","insertSpace","$1","candidate","insert","ltrim","contentDomain","headers","encode64","rMessage","rHeader","rCRLF","decode64","lines","li","line","nl","next","vi","pkcs1","rsa_mgf1","maskLength","encode_rsa_oaep","label","mgf1Md","keyLength","lHash","PS","PS_length","seedLength","dbMask","maskedDB","seedMask","decode_rsa_oaep","em","expectedLength","maskedSeed","db","lHashPrime","in_ps","p12","pkcs12","contentInfoValidator","pfxValidator","safeBagValidator","attributeValidator","certBagValidator","_getBagsByAttribute","safeContents","attrName","attrValue","bagType","safeBags","bag","attributes","_decodePkcs7Data","_decryptSafeContents","pkcs7","encryptedDataValidator","contentType","encAlgorithm","encParameter","encryptedContentAsn1","_decodeSafeContents","safeBag","validator","decoder","bagId","_decodeBagAttributes","bagAttributes","bagAsn1","bagValue","pkcs8ShroudedKeyBag","keyBag","certBag","certId","x509Certificate","certAsn1","cert","certificateFromAsn1","decodedAttrs","pkcs12FromAsn1","pfx","getBags","filter","localKeyId","localKeyIdHex","friendlyName","getBagsByFriendlyName","getBagsByLocalKeyId","content","mac","macKeyBytes","macAlgorithm","sha256","sha384","macSalt","macIterations","macKey","generateKey","macDigest","authSafe","contentInfo","_decodeAuthenticatedSafe","toPkcs12Asn1","useMac","generateLocalKeyId","bagAttrs","pairedCert","certificateFromPem","certificateToAsn1","attrs","contents","chain","certSafeBags","certBagAttrs","certSafeBag","certSafeContents","certCI","pkAsn1","keySafeContents","keyCI","macData","safe","macValue","p7","_recipientFromAsn1","recipientInfoValidator","issuer","RDNAttributesAsArray","serialNumber","serial","toHex","encryptedContent","parameter","encKey","_recipientsToAsn1","recipients","distinguishedNameToAsn1","_signerToAsn1","digestAlgorithm","authenticatedAttributesAsn1","signatureAlgorithm","signature","unauthenticatedAttributes","attrsAsn1","_attributeToAsn1","messageDigest","signingTime","jan_1_1950","jan_1_2050","timestamp","parse","_fromAsn1","rawCapture","_decryptContent","ciph","messageFromPem","messageFromAsn1","messageToPem","pemObj","toAsn1","envelopedData","createEnvelopedData","createEncryptedData","signedData","createSignedData","fromAsn1","certificates","crls","signers","digestAlgorithmIdentifiers","signerInfos","signedDataValidator","certs","sign","addSigner","signer","certificate","privateKeyFromPem","authenticatedAttributes","rsaEncryption","encodeUtf8","detached","detachedContent","mds","ai","_signersToAsn1","addSignerInfos","addDigestAlgorithmIds","verify","addCertificate","addCertificateRevokationList","crl","envelopedDataValidator","infos","_recipientsFromAsn1","recipientInfos","ec","findRecipient","sAttr","rAttr","recipient","privKey","desCBC","addRecipient","publicKey","keyLen","ciphFn","p7v","pkcs7asn1","encryptedContentInfoValidator","signerValidator","pemToDer","privateKeyToPem","privateKeyInfoToPem","prime","GCD_30_DELTA","THIRTY","generateProbablePrime","rng","Worker","primeincFindPrimeWithoutWorkers","generateRandom","numWorkers","workers","workLoad","range","workerScript","estimateCores","cores","workerMessage","terminate","hex","primeincFindPrimeWithWorkers","primeincFindPrime","mrTests","getMillerRabinTests","millerRabinTests","maxBlockTime","_primeinc","deltaIdx","bits1","_crypto","versions","plugin","time","reseeds","generated","keyBytes","pools","_reseedSync","messageLength","_seed","needed","collect","seedFileSync","_2powK","seedBytes","formatKey","formatSeed","defaultSeedFile","getRandomValues","globalScope","msCrypto","entropy","Uint32Array","QuotaExceededError","pool","generateSync","increment","seedFile","_reseed","randomBytes","collectInt","registerWorker","worker","listener","removeEventListener","pss","saltLength","sLen","salt_","pssobj","modBits","emBits","emLen","mHash","m_","ps","mask","checkLen","jQuery","prng_aes","_prng_aes_output","_prng_aes_buffer","spawnPrng","_ctx","_navBytes","mousemove","clientX","clientY","keypress","charCode","createInstance","piTable","rol","word","ror","expandKey","effKeyBits","L","T","T1","T8","TM","mixRound","mashRound","_output","K","getInt16Le","R","runPlan","plan","putInt16Le","ptr","rsa","privateKeyValidator","rsaPrivateKeyValidator","rsaPublicKeyValidator","publicKeyValidator","digestInfoValidator","emsaPkcs1v15encode","oidBytes","digestInfo","_modPow","pub","dP","dQ","qInv","xp","xq","_encodePkcs1_v1_5","bt","eb","padByte","padNum","numZeros","padBytes","_decodePkcs1_v1_5","ml","_bnToBytes","_getMillerRabinTests","_detectNodeCrypto","_detectSubtleCrypto","subtle","_detectSubtleMsCrypto","_intToUint8Array","yhex","ed","zeros","expected","xhex","createKeyPairGenerationState","eInt","qBits","pBits","pqState","stepKeyPairGenerationState","t2","t1","total","p1","q1","phi","privateKey","setPrivateKey","setPublicKey","generateKeyPair","modulusLength","publicExponent","publicKeyEncoding","privateKeyEncoding","priv","publicKeyFromPem","exportKey","pkcs8","setRsaPublicKey","genOp","oncomplete","exportOp","onerror","keypair","generateKeyPairSync","getPrime","_generateKeyPair","scheme","schemeOptions","_parseAllDigestBytes","algorithmIdentifier","md2","sha224","setRsaPrivateKey","privateKeyModulus","privateKeyPublicExponent","privateKeyPrivateExponent","privateKeyPrime1","privateKeyPrime2","privateKeyExponent1","privateKeyExponent2","privateKeyCoefficient","privateKeyToRSAPrivateKey","publicKeyFromAsn1","publicKeyOid","rsaPublicKey","publicKeyModulus","publicKeyExponent","publicKeyToAsn1","publicKeyToSubjectPublicKeyInfo","publicKeyToRSAPublicKey","_initialized","_padding","fillString","fullMessageLength","messageLengthSize","messageLength64","int32s","h0","h1","h2","h3","h4","_update","finalBlock","s2","_k","h5","h6","h7","s0","maj","_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","baseN","_checkBitsParam","ByteStringBuffer","isArrayBuffer","isArrayBufferView","_constructedStringLength","browser","callbacks","stopPropagation","div","createElement","oldSetImmediate","setAttribute","_optimizeConstructedString","isEmpty","putString","putInt24","putInt24Le","putInt32Le","putInt","getInt24","getInt24Le","getInt32Le","DataBuffer","readOffset","growSize","writeOffset","accommodate","amount","setUint8","view","binary","raw","Uint16Array","text","utf16","setInt16","setInt8","setInt32","getInt8","getUint8","utf8","s1","s3","_base64","_base64Idx","_base58","chr1","chr2","chr3","enc1","enc2","enc3","enc4","unescape","encodeURIComponent","decodeURIComponent","escape","base58","deflate","inflate","_setStorageObject","removeItem","JSON","stringify","setItem","_getStorageObject","getItem","_setItem","_getItem","_removeItem","empty","_clearItems","_callStorageFunction","location","done","exception","idx","localStorage","clearItems","part","re","argi","formatNumber","decimals","dec_point","thousands_sep","toFixed","formatSize","bytesFromIP","ip","bytesFromIPv4","bytesFromIPv6","blanks","bytesToIP","bytesToIPv4","bytesToIPv6","zeroGroups","zeroMaxGroup","group","unshift","hardwareConcurrency","Blob","blobUrl","URL","createObjectURL","st","et","sample","samples","avg","revokeObjectURL","results","overlaps","r1","overlap","_shortNames","x509CertificateValidator","rsassaPssParameterValidator","certificationRequestInfoValidator","certificationRequestValidator","_getAttribute","shortName","rdn","si","valueTagClass","CRIAttributesAsArray","seq","extensionRequest","extensions","certificateExtensionFromAsn1","_readSignatureParameters","fillDefaults","algorithmOid","hashOid","maskGenOid","maskGenHashOid","_createSignatureDigest","signatureOid","_verifySignature","sha1WithRSAEncryption","sha1WithRSASignature","signatureParameters","_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","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","tbsCertificate","getTBSCertificate","issued","expectedIssuer","actualIssuer","isIssuer","iattr","sattr","verifySubjectKeyIdentifier","certVersion","certSerialNumber","certSignatureOid","certSignatureParams","certinfoSignatureOid","certinfoSignatureParams","certSignature","certValidity1UTCTime","certValidity2GeneralizedTime","certValidity3UTCTime","certValidity4GeneralizedTime","imd","ibytes","certIssuer","certIssuerUniqueId","smd","sbytes","certSubject","certSubjectUniqueId","certExtensions","certificateExtensionsFromAsn1","subjectPublicKeyInfo","extseq","critical","ev","gn","createCertificationRequest","csrVersion","csrSignatureOid","csrSignatureParams","csrSignature","certificationRequestInfo","certificationRequestInfoSubject","getAttribute","addAttribute","certificationRequestInfoAttributes","setAttributes","getCertificationRequestInfo","cri","_dateToAsn1","tbs","certificateExtensionsToAsn1","dn","createCaStore","caStore","getBySubject","ensureSubjectHasHash","getIssuer","hasCertificate","der1","listAllCertificates","certList","removeCertificate","certificateError","bad_certificate","unsupported_certificate","certificate_revoked","certificate_expired","certificate_unknown","unknown_ca","verifyCertificateChain","validityCheckDate","shift","selfSigned","parents","verified","se","keyUsage","basicConstraints","bcExt","keyUsageExt","vfd","helpers","HMAC","sha","checkIv","commonCbcEncryptFN","setupFallback","pdata","nodeCrypto","createCipheriv","subtleCrypto","importKey","alg","cdata","commonCbcDecryptFN","createDecipheriv","checkKey","cbcHmacEncryptFN","commonEncrypt","eKey","iKey","adata","aad","mdata","int64ToBuffer","cbcHmacDecryptFN","commonDecrypt","EncryptionLabel","IntegrityLabel","DotLabel","generateCek","masterKey","epu","epv","masterSize","cekSize","int32ToBuffer","generateCik","cikSize","concatKdfCbcHmacEncryptFN","cek","cik","kdata","promises","concatKdfCbcHmacDecryptFN","loose","aesCbcHmacSha2","CONSTANTS","GCM","gcmEncryptFN","wrap","commonChecks","prepareResults","setAAD","getAuthTag","tagStart","amt","CHUNK_SIZE","clen","poff","doChunk","plen","gcmDecryptFN","setAuthTag","coff","aesGcm","A0","longToBigEndian","kwEncryptFN","A","jdx","wrapKey","kwDecryptFN","unwrapKey","aesKw","concatDeriveFn","hashLen","HASHLENGTH","otherInfo","N","okm","step","derive","ENCLENGTH","KEYLENGTH","NONCELENGTH","direct","once","ecc","EC_KEYSIZES","convertToObj","isPublic","asBuffer","UNCOMPRESSED","EC_OID","ERR_MSG","countPadding","stop","convertToForge","crv","asPublicKey","asPrivateKey","convertToJWK","key_ops","use","convertToBuffer","curveSize","derToConcat","seqLength","rLength","rOffset","sLength","sOffset","rPadding","sPadding","rPad","sPad","concatToDer","rsBytes","shortLength","convertToPEM","isPrivate","curveNameToOid","ecUtil","hkdf","idealHash","curve","ecdh","doEcdhesCommonDerive","pubKey","prependLen","algId","apu","apv","public","validatePublic","kdf","ECDH","shared","pk","form","isValid","createECDH","secret","computeSecret","algParams","namedCurve","deriveBits","unwrap","kw","epk","ecrypt","enc","idealCurve","ecdsaSignFN","nodejs","nodeHash","getHashes","createSign","ecdsaVerifyFN","createVerify","valid","rs","ecdsa","MAX_INT32","getCryptoSubtle","getCryptoNodeJS","webcrypto","fallback","impl","check","DOMException","NOT_SUPPORTED_ERR","hkdfDeriveFn","info","expand","hmacSignFN","checkKeyLength","createHmac","sig","hmacVerifyFN","vrfy","implementations","ALGS_DIGEST","ALGS_DERIVE","ALGS_SIGN","ALGS_VRFY","ALGS_ENC","ALGS_DEC","KW","NULL_BUFFER","fixSalt","pbkdf2Fn","prepareProps","itrs","keyval","mainAlgo","pbes2EncryptFN","deriveAlg","p2s","p2c","pbes2","pbes2DecryptFN","dp","dq","qi","convertToPem","cacheKey","rsaUtil","nodeSupport","RSA1_5","nodeSupportCheck","constants","rsaesEncryptFn","publicEncrypt","rsaesDecryptFn","privateDecrypt","rsaes","nodePSSsupport","RSA_PSS_SALTLEN_DIGEST","rsassaV15SignFn","rsassaV15VerifyFn","rsassaPssSignFn","RSA_PKCS1_PSS_PADDING","rsassaPssVerifyFn","rsassa","createHash","Long","pack","E1","E1L","E1B","LOOKUP","generateLookup","arrayCopy","srcPos","dest","destPos","arrayEqual","a1","asBytes","intToBigEndian","asInts","bigEndianToInt","oneAsInts","shiftRightN","nInv","r0","multiplyP","multiplyP8","multipliers","cipherHelpers","Gcm","nonce","bufLength","bufBlock","H","zeroBlock","J0","gHASH","X","gHASHBlock","SAt","SAtPre","atBlock","atBlockPos","atLength","atLengthPre","counter","bufOff","totalLength","processAADBytes","inV","inOff","outOff","resultLen","inLen","outputBlock","isZero","initCipher","extra","gCTRPartial","greaterThan","gHASHPartial","gCTRBlock","getNextCounterBlock","outb","off","Y","multiplyH","Gcm8KMultiplier","M","inb","low","high","ns","bigEndianToLong","X9ECParameters","fromHex","getCurve","getG","getN","getH","G","CURVES","ECCurveFp","decodePointHex","secp384r1","secp521r1","secp256r1","hex2bn","bn2bin","bn","bin2bn","keySizeBytes","normalizeEcdsa","log2n","mdLen","ECPublicKey","ECPointFp","fromBigInteger","point","ECPrivateKey","contains","u1","u2","multiplyTwo","getX","toBigInteger","toPublicKey","getY","keysize","pubkey","privkey","ECFieldElementFp","zinv","infinity","reducer","square","isInfinity","twice","getInfinity","THREE","x1","y1","v2","v3","x1v2","zu2","x3","y3","z3","y1z1","y1sqz1","neg","hBit","both","getP","getA","getB","xHex","yHex","encodePointHex","oLen","modeRaw","_blocks","originalModInverse","JWS","JWA","JWE","JWK","canYouSee","AlgConfig","pako","DEFAULT_OPTIONS","JWEDecrypter","ks","globalOpts","assumedKey","keystore","isKeyStore","extraHandlers","handlers","handlerKeys","algSpec","protected","encrypted_key","ciphertext","fields","protect","algKey","rcptList","crit","unprotected","asKey","toObject","jwe","processKey","rcpt","algPromise","prekey","kid","processing","prepare","enkKey","payload","plaintext","zip","inflateRaw","complete","decrypter","createDecrypt","contentAlg","generateCEK","DEFAULTS","JWEEncrypter","cfg","finalized","protectAll","encAlg","rcpts","single","one","tks","rpromise","algAlg","jwk","MODE_ENCRYPT","wrapped","rjwe","kty","procR","lenProtect","unprotect","lenUnprotect","deflateRaw","flattened","encrypter","createEncrypt","rcptStart","MODE_WRAP","ref","some","freeze","createKeyStore","uuidv4","v4","uniq","ALGORITHMS","HELPERS","UTIL","prints","excluded","json","INTERNALS","THUMBPRINT_KEY","included","COMMON_PROPS","THUMBPRINT_HASH","thumbprint","MODE_SIGN","MODE_VERIFY","MODE_DECRYPT","MODE_UNWRAP","algs","signKey","signProps","verifyKey","verifyProps","encryptKey","encryptProps","decryptKey","decryptProps","wrapProps","unwrapProps","ecutil","depsecc","BaseKey","SIG_ALGS","WRAP_ALGS","oidToCurveName","JWKEcCfg","unpackProps","validators","embeddedPrivateKey","JWKEcFactory","import","keyOid","keyParams","keyValue","config","register","X509CertificateValidator","allowed","JWKStore","KeyStore","JWKRegistry","GLOBAL_REGISTRY","importFrom","registry","der","field","processCert","commonName","x5t","keysets","keytype","extras","factors","fromPEM","candidates","matches","supports","items","remove","asKeyStore","store","createKey","KeyRegistry","ENC_ALGS","adjustDecryptProps","adjustEncryptProps","JWKOctetCfg","mins","JWKOctetFactory","rsau","JWKRsaCfg","JWKRsaFactory","incoming","outgoing","JWSSigner","signatories","sigs","signatures","jws","signs","signStart","signList","allFields","signatory","allowEmbeddedKey","JWSVerifier","sigList","processSig","x5c","verifier","jose","perform","prot","quoteRE","algspec","fmt","specAllowed","specDisallowed","ptnAllowed","ptnDisallowed","ptn","prefix","wildcard","suffix","makeRE","Boolean","DEFAULT_GROW_SIZE","delta","begin","getBuffer","orig","putNative","ctors","typedArrayCtors","Float32Array","Float64Array","ta","ctor","findTypedArrayFor","_require","Deflate","gzip","_require2","Inflate","ungzip","zlib_deflate","utils","strings","ZStream","Z_NO_FLUSH","Z_SYNC_FLUSH","Z_FULL_FLUSH","Z_FINISH","Z_OK","Z_STREAM_END","Z_DEFAULT_COMPRESSION","Z_DEFAULT_STRATEGY","Z_DEFLATED","method","windowBits","memLevel","strategy","opt","ended","chunks","strm","avail_out","status","deflateInit2","deflateSetHeader","dictionary","dict","string2buf","deflateSetDictionary","_dict_set","deflator","flush_mode","_flush_mode","next_in","avail_in","next_out","onData","deflateEnd","onEnd","flattenChunks","zlib_inflate","GZheader","Z_NEED_DICT","Z_STREAM_ERROR","Z_DATA_ERROR","Z_MEM_ERROR","to","inflateInit2","inflateGetHeader","inflateSetDictionary","inflator","last_avail_out","inflateReset","next_out_utf8","utf8border","tail","utf8str","buf2string","inflateEnd","_has","STR_APPLY_UIA_OK","__","_utf8len","TextEncoder","m_pos","str_len","buf_len","TextDecoder","utf16buf","c_len","buf2binstring","adler","Z_PARTIAL_FLUSH","Z_BLOCK","Z_TREES","Z_ERRNO","Z_BUF_ERROR","Z_NO_COMPRESSION","Z_BEST_SPEED","Z_BEST_COMPRESSION","Z_FILTERED","Z_HUFFMAN_ONLY","Z_RLE","Z_FIXED","Z_BINARY","Z_TEXT","Z_UNKNOWN","crcTable","makeTable","crc","_tr_init","_tr_stored_block","_tr_flush_block","_tr_tally","_tr_align","adler32","crc32","MAX_MATCH","MIN_LOOKAHEAD","INIT_STATE","BUSY_STATE","FINISH_STATE","errorCode","rank","zero","slide_hash","wsize","w_size","hash_size","head","prev","HASH","hash_shift","hash_mask","flush_pending","pending","pending_buf","pending_out","total_out","flush_block_only","block_start","strstart","put_byte","putShortMSB","read_buf","total_in","longest_match","cur_match","chain_length","max_chain_length","scan","best_len","prev_length","nice_match","_win","wmask","w_mask","strend","scan_end1","scan_end","good_match","lookahead","match_start","fill_window","more","_w_size","window_size","ins_h","deflate_stored","have","min_block","pending_buf_size","bi_valid","high_water","deflate_fast","hash_head","bflush","match_length","max_lazy_match","MIN_MATCH","sym_next","deflate_slow","max_insert","prev_match","match_available","Config","good_length","max_lazy","nice_length","max_chain","configuration_table","DeflateState","gzhead","gzindex","last_flush","w_bits","hash_bits","dyn_ltree","HEAP_SIZE","dyn_dtree","bl_tree","l_desc","d_desc","bl_desc","bl_count","MAX_BITS","heap","heap_len","heap_max","sym_buf","lit_bufsize","sym_end","opt_len","static_len","bi_buf","deflateStateCheck","deflateResetKeep","data_type","deflateReset","deflateInit","old_flush","hcrc","os","beg","gzhead_extra","bstate","deflate_huff","deflate_rle","dictLength","tmpDict","avail","deflateInfo","xflags","extra_len","BAD","_in","_out","dmax","whave","wnext","s_window","hold","lcode","dcode","lmask","dmask","here","dist","from_source","lencode","distcode","lenbits","distbits","top","dolen","dodist","sane","inflate_fast","inflate_table","HEAD","DICT","TYPE","TYPEDO","COPY_","LEN_","LEN","CHECK","MEM","zswap32","InflateState","havedict","flags","wbits","ncode","nlen","ndist","work","lendyn","distdyn","back","was","lenfix","distfix","inflateStateCheck","inflateResetKeep","Int32Array","inflateReset2","virgin","fixedtables","sym","updatewindow","inflateInit","put","here_bits","here_op","here_val","last_bits","last_op","last_val","hbuf","order","inf_leave","inflateInfo","MAXBITS","lbase","lext","dbase","dext","lens_index","codes","table_index","incr","curr","drop","huff","offs","LITERALS","L_CODES","D_CODES","extra_lbits","extra_dbits","extra_blbits","bl_order","static_ltree","static_dtree","_dist_code","_length_code","base_length","static_l_desc","static_d_desc","static_bl_desc","base_dist","StaticTreeDesc","static_tree","extra_bits","extra_base","elems","max_length","has_stree","TreeDesc","dyn_tree","stat_desc","max_code","d_code","put_short","send_bits","send_code","tree","bi_reverse","gen_codes","next_code","init_block","END_BLOCK","bi_windup","smaller","_n2","_m2","pqdownheap","compress_block","ltree","dtree","lc","build_tree","desc","stree","xbits","gen_bitlen","scan_tree","curlen","prevlen","nextlen","max_count","min_count","REP_3_6","REPZ_3_10","REPZ_11_138","send_tree","static_init_done","stored_len","LENGTH_CODES","tr_static_init","opt_lenb","static_lenb","max_blindex","block_mask","detect_data_type","BL_CODES","build_bl_tree","lcodes","dcodes","blcodes","send_all_trees","STATIC_TREES","bi_flush","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","clearTimeout","currentQueue","draining","queueIndex","cleanUpNextTick","drainQueue","timeout","run","marker","runClearTimeout","Item","title","env","argv","addListener","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","listeners","cwd","chdir","umask","rnds8","bind","uuid","REGEX","byteToHex","_nodeId","_clockseq","_lastMSecs","_lastNSecs","clockseq","msecs","nsecs","dt","tl","tmh","hashfunc","generateUUID","namespace","stringToBytes","DNS","getOutputLength","inputLength8","safeAdd","lsw","md5cmn","cnt","md5ff","md5gg","md5hh","md5ii","length32","hexTab","md5ToHexEncodedArray","olda","oldb","oldc","oldd","wordsToMd5","length8","bytesToWords","v35","rnds","ROTL","_i","_i2","W","_t","_t2","doc","loc","collectFragmentReferences","refs","kind","selectionSet","selections","selection","variableDefinitions","def","definitions","definitionRefs","findOperation","element","operationName","newDoc","opRefs","allRefs","newRefs","refName","prevRefs","childRef","oneQuery","wasm","WebAssembly","Instance","Module","unsigned","isLong","ctz32","clz32","__isLong__","INT_CACHE","UINT_CACHE","cachedObj","fromBits","UZERO","TWO_PWR_64_DBL","MAX_UNSIGNED_VALUE","TWO_PWR_63_DBL","MIN_VALUE","MAX_VALUE","TWO_PWR_32_DBL","lowBits","highBits","pow_dbl","radix","radixToPower","power","fromValue","TWO_PWR_16_DBL","TWO_PWR_24","UONE","NEG_ONE","LongPrototype","toInt","isNegative","radixLong","rem1","rem","remDiv","getHighBits","getHighBitsUnsigned","getLowBits","getLowBitsUnsigned","getNumBitsAbs","bit","eqz","isPositive","isOdd","notEquals","neq","ne","lessThan","comp","lt","lessThanOrEqual","lte","le","gt","greaterThanOrEqual","gte","ge","thisNeg","otherNeg","addend","a48","a32","a16","a00","b48","b32","b16","c48","c32","c16","c00","subtrahend","b00","divisor","approx","toUnsigned","shru","shr","shl","log2","approxRes","approxRem","modulo","countLeadingZeros","clz","countTrailingZeros","ctz","numBits","shiftRightUnsigned","shr_u","rotateLeft","rotl","rotateRight","rotr","toSigned","toBytes","toBytesLE","toBytesBE","fromBytes","fromBytesLE","fromBytesBE","_default","__webpack_module_cache__","moduleId","cachedModule","loaded","__webpack_modules__","getter","__esModule","definition","globalThis","nmd","children","extendStatics","__proto__","__extends","__assign","__rest","__awaiter","_arguments","generator","fulfilled","rejected","__generator","sent","trys","ops","verb","__spreadArray","ar","SuppressedError","genericMessage","_a","InvariantError","_super","_this","framesToPop","invariant","condition","verbosityLevels","verbosityLevel","wrapConsoleMethod","debug","warn","maybe","thunk","prefixCounts","makeUniqueId","stringifyForDisplay","space","undefId","arg0","getHandledErrorMsg","getFallbackErrorMsg","originalInvariant","newInvariantError","optionalParams","ApolloErrorMessageHandler","messageArgs","__DEV__","_createForOfIteratorHelperLoose","allowArrayLike","it","minLen","_arrayLikeToArray","_unsupportedIterableToArray","arr2","_defineProperties","descriptor","configurable","writable","_createClass","protoProps","staticProps","hasSymbols","hasSymbol","getSymbol","observable","SymbolIterator","SymbolObservable","SymbolSpecies","getMethod","getSpecies","Observable","isObservable","hostReportError","enqueue","cleanupSubscription","subscription","cleanup","_cleanup","unsubscribe","closeSubscription","_observer","_queue","notifySubscription","onNotify","flushSubscription","Subscription","subscriber","subscriptionObserver","SubscriptionObserver","_subscription","_proto2","_subscriber","_proto3","_this2","_this3","_this4","C","hasSeed","hasValue","acc","_this5","_len","startNext","flatMap","_this6","subscriptions","completeIfDone","closed","_step","_iterator","item","of","_len2","_key2","isNonNullObject","getFragmentQueryDocument","fragmentName","actualFragmentName","fragments","operation","createFragmentMap","symTable","fragment","getFragmentFromSelection","fragmentMap","defaultDispose","_WeakRef","WeakRef","deref","_WeakMap","_FinalizationRegistry","FinalizationRegistry","unregister","WeakCache","dispose","_classCallCheck","newest","oldest","unfinalizedNodes","finalizationScheduled","finalize","keyRef","queueMicrotask","deleteNode","getNode","older","newer","scheduleFinalization","StrongCache","scheduledCleanup","WeakSet","schedule","clean","AutoCleanedWeakCache","AutoCleanedStrongCache","cacheSizeSymbol","cacheSizes","globalCaches","registerGlobalCache","getSize","getApolloClientMemoryInternals","limits","parser","canonicalStringify","print","fromEntries","sizes","_b","_c","links","linkInfo","link","queryManager","getDocumentInfo","documentTransforms","transformInfo","documentTransform","_e","_d","getMemoryInternals","getInMemoryCacheMemoryInternals","_getApolloCacheMemoryInternals","addTypenameDocumentTransform","inMemoryCache","executeSelectionSet","getWrapperInformation","executeSubSelectedArray","maybeBroadcastWatch","fragmentRegistry","findFragmentSpreads","getApolloCacheMemoryInternals","fragmentQueryDocuments","isWrapper","isDefined","recurseTransformInfo","sortingMap","stableObjectReplacer","reset","every","everyKeyInOrder","unsortedKey","sortedKeys","sortedKey","sortedObject_1","makeReference","__ref","isReference","valueToObjectRepresentation","argObj","variables","isIntValue","isFloatValue","isBooleanValue","isStringValue","isObjectValue","nestedArgObj_1","isVariable","variableValue","isListValue","listValue","nestedArgArrayObj","isEnumValue","isNullValue","KNOWN_DIRECTIVES","storeKeyNameStringify","getStoreKeyName","fieldName","directives","filterKeys","filteredArgs_1","completeFieldName","stringifiedArgs","setStringify","previous","argumentsObjectFromField","argObj_1","resultKeyNameFromField","alias","getTypenameFromResult","isField","__typename","fragments_1","typename","checkDocument","operations","getOperationDefinition","getOperationName","getFragmentDefinitions","getQueryDefinition","queryDef","getMainDefinition","queryDoc","fragmentDefinition","getDefaultValues","defaultValues","defs","defaultValue","variable","passthrough","forward","toLink","handler","ApolloLink","isTerminating","request","leftLink","rightLink","execute","starting","context","createOperation","transformedOperation","query","transformOperation","OPERATION_FIELDS","validateOperation","second","firstLink","nextLink","onError","setOnError","devAssert","MAX_ARRAY_LENGTH","MAX_RECURSIVE_DEPTH","formatValue","seenValues","previouslySeenValues","_toConsumableArray","isJSONable","jsonValue","formatArray","getObjectTag","properties","_ref","_ref2","_slicedToArray","formatObject","formatObjectValue","OperationTypeNode","Kind","QueryDocumentKeys","Name","Document","OperationDefinition","VariableDefinition","Variable","SelectionSet","Field","Argument","FragmentSpread","InlineFragment","FragmentDefinition","IntValue","FloatValue","StringValue","BooleanValue","NullValue","EnumValue","ListValue","ObjectValue","ObjectField","Directive","NamedType","ListType","NonNullType","SchemaDefinition","OperationTypeDefinition","ScalarTypeDefinition","ObjectTypeDefinition","FieldDefinition","InputValueDefinition","InterfaceTypeDefinition","UnionTypeDefinition","EnumTypeDefinition","EnumValueDefinition","InputObjectTypeDefinition","DirectiveDefinition","SchemaExtension","ScalarTypeExtension","ObjectTypeExtension","InterfaceTypeExtension","UnionTypeExtension","EnumTypeExtension","InputObjectTypeExtension","kindValues","maybeNode","maybeKind","BREAK","visit","visitor","visitorKeys","enterLeaveMap","_Object$values","getEnterLeaveForKind","inArray","edits","ancestors","isLeaving","isEdited","editOffset","_createForOfIteratorHelper","_step$value","editKey","editValue","arrayKey","defineProperties","getOwnPropertyDescriptors","_step2","_iterator2","_step2$value","_node$kind","_enterLeaveMap$get","_enterLeaveMap$get2","visitFn","leave","enter","kindVisitor","shouldInclude","directive","isInclusionDirective","directiveArguments","directiveName","ifArgument","ifValue","getInclusionDirectives","evaledValue","hasDirectives","names","nameSet","uniqueCount","hasClientExports","serializeFetchParameter","serialized","parseError","canUseWeakMap","product","HermesInternal","canUseWeakSet","canUseSymbol","canUseAsyncIteratorSymbol","asyncIterator","userAgent","nodeStreamIterator","stream","waiting","shiftedArr","readerIterator","reader","responseIterator","response","resolved","isAsyncIterableIterator","getReader","isReadableStream","isStreamableBlob","isBlob","pipe","isNodeReadableStream","throwServerError","statusCode","PROTOCOL_ERRORS_SYMBOL","ApolloError","graphQLErrors","protocolErrors","clientErrors","networkError","errorMessage","extraInfo","isNonEmptyArray","mergeDeep","mergeDeepArray","merger","DeepMerger","defaultReconciler","property","reconciler","pastCopies","sourceKey","targetValue","shallowCopyForMerge","isExecutionPatchIncrementalResult","isApolloPayloadResult","mergeIncrementalData","prevResult","mergedData","incremental","parent_1","parseHeaders","headerText","headersInit","name_1","parseJsonBody","bodyText","getResult","isWhiteSpace","escapedRegExp","escapedReplacer","escapeSequences","printCache","printDocASTReducer","varDefs","_ref3","argsLine","_ref4","_ref5","_ref6","typeCondition","_ref7","_ref8","_ref9","_ref10","escapedValue","isSingleLine","forceLeadingNewLine","hasTrailingTripleQuotes","endsWith","hasTrailingQuote","hasTrailingSlash","forceTrailingNewline","printAsMultipleLines","minimize","skipLeadingNewLine","printBlockString","_ref11","_ref12","_ref13","_ref14","_ref15","_ref16","_ref17","_ref18","_ref19","_ref20","description","operationTypes","_ref21","_ref22","_ref23","interfaces","_ref24","hasMultilineItems","_ref25","_ref26","_ref27","_ref28","_ref29","_ref30","_ref31","repeatable","locations","_ref32","_ref33","_ref34","_ref35","_ref36","_ref37","_ref38","maybeArray","_maybeArray$filter$jo","separator","maybeString","_maybeArray$some","ast","origPrint","fallbackHttpConfig","http","includeQuery","includeExtensions","preserveHeaderCase","accept","defaultPrinter","printer","selectHttpOptionsAndBodyInternal","configs","credentials","normalizedHeaders_1","headerData","originalName","normalizedHeaders","removeDuplicateHeaders","fromError","errorValue","TYPENAME_FIELD","FIELD","NAME","FRAGMENT_SPREAD","nullIfDocIsEmpty","fragmentDef","getFragmentDefinition","getDirectiveMatcher","tests","testConfig","makeInUseGetterFunction","defaultKey","inUse","fragmentSpreads","removeDirectivesFromDocument","getInUseByOperationName","getInUseByFragmentName","getInUse","ancestor","OPERATION_DEFINITION","FRAGMENT_DEFINITION","operationCount","directiveMatcher","shouldRemoveField","nodeDirectives","originalFragmentDefsByPath","firstVisitMadeChanges","fieldOrInlineFragmentVisitor","docWithoutDirectiveSubtrees","_parent","_path","removed","populateTransitiveVars","transitiveVars","childFragmentName","varName","allFragmentNamesUsed","enterVisitor","usedVariableNames_1","varDef","addTypenameToDocument","added","buildQueryFromSelectionSet","removeClientSetsFromDocument","backupFetch","fetch","createHttpLink","linkOptions","uri","preferredFetch","useGETForQueries","includeUnusedVariables","requestOptions","fetcher","checkFetcher","linkConfig","fetchOptions","chosenURI","fallbackURI","contextURI","getContext","selectURI","clientAwarenessHeaders","clientAwareness","contextHeaders","contextConfig","transformedQuery","unusedNames","controller","signal","AbortController","isSubscription","hasDefer","acceptHeader","queryParams","addQueryParam","serializedVariables","serializedExtensions","preFragment","fragmentStart","queryParamsPrefix","newURI","rewriteURIForGET","currentFetch","observerNext","setContext","ctype","nextValue","boundaryVal","boundary","running","searchFrom","bi","contentType_1","hasNext","readMultipartBody","handleError","abort","HttpLink","_Object$prototype","fnToStr","previousComparisons","full","aTag","previouslyCompared","aKeys","definedKeys","bKeys","keyCount","aIterator","_info$value","aKey","aValue","aCode","nativeCodeSuffix","isDefinedKey","bSet","defaultMakeData","_Array$prototype","Trie","weakness","makeData","lookupArray","getChildTrie","peekArray","mapFor","removeArray","weak","strong","isObjRef","currentContext","MISSING_VALUE","idCounter","ignored","globalKey","globalHost","Slot","slots","saved","noContext","parentEntrySlot","arrayFromSet","maybeUnsubscribe","entryOrDep","emptySetPool","POOL_TARGET_SIZE","assert","optionalMessage","valueIs","valueGet","valueCopy","Entry","childValues","dirtyChildren","dirty","recomputing","deps","mightBeDirty","rememberParent","forgetChildren","withValue","recomputeNewValue","setDirty","maybeSubscribe","reportClean","setClean","reallyRecompute","reportDirty","eachParent","forgetChild","dep","reportDirtyChild","reportCleanChild","oldValueCopy","normalizeResult","parentCount","parentWasClean","childValue","removeDirtyChild","dc","_value","forgetDeps","defaultKeyTrie","EntryMethods","forget","depsByKey","depend","dependOn","entryMethodName","defaultMakeCacheKey","trie","originalFunction","_ref$max","keyArgs","_ref$makeCacheKey","makeCacheKey","_ref$cache","cacheOption","optimistic","recompute","dirtyKey","peekKey","peek","forgetKey","getKey","DocumentTransform","resultCache","getCacheKey","cached","resetCache","transformDocument","stableCacheKeys_1","performWork","cacheKeys","transformedDocument","otherTransform","asyncMap","mapFn","catchFn","promiseQueue","makeCallback","examiner","graphQLResultHasError","getGraphQLErrorsFromResult","incrementalResult","iterateObserversSafely","observers","argument","observersWithMethod","obs","fixObservableSubclass","subclass","species","isPromiseLike","NetworkStatus","Concast","addObserver","removeObserver","latest","notify","nextResultListeners","cancel","deliverLastMessage","nextOrError","beforeNext","called","isNetworkRequestInFlight","networkStatus","objects","cloneDeep","cloneDeepHelper","copy_1","copy_2","equalByQuery","aData","aRest","bData","bRest","equalBySelectionSet","aResult","bResult","seenSelections","selectionHasNonreactiveDirective","resultKey","aResultChild","bResultChild","childSelectionSet","aChildIsArray","bChildIsArray","length_1","directiveIsNonreactive","ObservableQuery","queryInfo","subObserver","defaultSubscriptionObserverErrorCallback","reobserve","tearDownQuery","waitForOwnResult","skipCacheDataFor","fetchPolicy","isTornDown","defaultOptions","watchQuery","defaultFetchPolicy","_f","initialFetchPolicy","queryId","generateQueryId","opDef","queryName","lastQuery","removeQuery","resetDiff","getCurrentResult","saveAsLastResult","lastResult","getLastResult","ready","loading","hasForcedResolvers","getDiff","returnPartialData","partial","partialRefetch","logMissingFieldErrors","missing","updateLastResult","isDifferentFromLastResult","newResult","hasNonreactiveDirective","getLast","variablesMustMatch","getLastError","resetLastResults","resetQueryStoreErrors","resetErrors","refetch","reobserveOptions","pollInterval","vars","fetchMore","fetchMoreOptions","combinedOptions","qid","originalNetworkStatus","notifyOnNetworkStatusChange","updatedQuerySet","fetchMoreResult","batch","updateQuery","writeQuery","onWatchUpdated","watch","reobserveCacheFirst","subscribeToMore","startGraphQLSubscription","subscriptionData","setOptions","newOptions","silentSetOptions","setVariables","startPolling","updatePolling","stopPolling","applyNextFetchPolicy","nextFetchPolicy","newNetworkStatus","setObservableQuery","ssrMode","pollingInfo","hasObservers","interval","skipPollAttempt","poll","maybeFetch","assumeImmutableResults","reobserveAsConcast","useDisposableConcast","oldVariables","oldFetchPolicy","mergedOptions","finishWaitingForOwnResult","concast","fromLink","reportResult","reportError","lastError","isDifferent","errorResult","stopQuery","obsQuery","currentFetchPolicy","isSelectionNode","INLINE_FRAGMENT","cacheSlot","cacheInfoMap","getCacheInfo","forgetCache","rv","makeVar","broadcastWatches","broadcast","oldListeners","attach","onNextChange","attachCache","LocalState","resolvers","fragmentMatcher","selectionsToResolveCache","addResolvers","setFragmentMatcher","resolverGroup","setResolvers","getResolvers","runResolvers","remoteResult","onlyRunForcedResolvers","resolveDocument","localResult","getFragmentMatcher","clientQuery","serverQuery","prepareContext","identify","addExportedVariables","document_1","buildRootValueFromCache","exportedVariables","shouldForceResolvers","forceResolvers","rootValue_1","rootValue","mainDefinition","selectionsToResolve","collectSelectionsToResolve","definitionOperation","defaultOperationType","execContext","resolveSelectionSet","isClientFieldDescendant","resultsToMerge","resolveField","fieldResult","isInlineFragment","fragmentResult","aliasedFieldName","aliasUsed","defaultResult","resultPromise","resolverType","resolverMap","isClientField","resolveSubSelectedArray","isSingleASTNode","collectByDefinition","definitionNode","matches_1","___","spread","fragmentSelections","destructiveMethodCounts","wrapDestructiveCacheMethod","methodName","cancelNotifyTimeout","QueryInfo","lastRequestId","stopped","observableQuery","lastDiff","getDiffOptions","updateWatch","oq","updateLastDiff","canonizeResults","setDiff","oldDiff","notifyTimeout","oqListener","fromOptimisticTransaction","shouldNotify","watchOptions","watcher","lastWatch","resetLastWrite","lastWrite","shouldWrite","dmCount","markResult","cacheWriteBehavior","shouldWriteResult","errorPolicy","performTransaction","overwrite","diffOptions","markReady","markError","ignoreErrors","writeWithErrors","IGNORE","QueryManager","queryDeduplication","onBroadcast","localState","defaultContext","queries","fetchCancelFns","transformCache","queryIdCounter","requestIdCounter","mutationIdCounter","inFlightLinkObservables","defaultDocumentTransform","mutationStore","_info","stopQueryNoBroadcast","cancelPendingFetches","mutate","mutation","optimisticResponse","updateQueries","refetchQueries","awaitRefetchQueries","updateWithProxyFn","onQueryUpdated","_g","keepRootFields","mutationId","generateMutationId","transformForLink","getVariables","_j","mutationStoreValue","isOptimistic","markMutationOptimistic","broadcastQueries","getObservableFromLink","storeResult","markMutationResult","removeOptimistic","cacheWrites","skipCache","dataId","asQuery","updateQueries_1","updater","currentQueryResult","nextQueryResult","mutationResult","queryVariables","results_1","updateCache","isFinalResult","isExecutionPatchInitialResult","modify","DELETE","include","recordOptimisticTransaction","fetchQuery","fetchConcastWithInfo","getQueryStore","cacheEntry","defaultVars","generateRequestId","stopQueryInStore","stopQueryInStoreNoBroadcast","clearStore","discardWatches","getObservableQueries","queryNamesAndDocs","legacyQueryOptions","getQuery","nameOrDoc","reFetchObservableQueries","includeStandby","observableQueryPromises","makeObservable","hasErrors","hasProtocolErrors","graphQLResultHasProtocolErrors","observablePromise_1","getLocalState","deduplication","inFlightLinkObservables_1","forceFetch","printedServerQuery_1","varJson_1","getResultsFromLink","requestId","linkDocument","aqr","containsDataFromLink","defaults","normalized","fromVariables","sourcesWithInfo","fetchQueryByPolicy","cleanupCancelFn","includedQueriesById","refetchWritePolicy","oldNetworkStatus","readCache","resultsFromCache","fromData","resultsFromLink","newContext","mergeOptions","hasSuggestedDevtools","ApolloClient","resetStoreCallbacks","clearStoreCallbacks","ssrForceFetchDelay","connectToDevTools","__APOLLO_CLIENT__","typeDefs","clientAwarenessName","clientAwarenessVersion","disableNetworkFetches","watchFragment","resetStore","devToolsHookCb","action","mutations","extract","windowWithDevTools","devtoolsSymbol","__APOLLO_DEVTOOLS_GLOBAL_HOOK__","protocol","nav","ua","url","__actionHookForDevTools","cb","__requestRaw","onResetStore","onClearStore","setLocalStateFragmentMatcher","setLink","newLink","ApolloCache","getFragmentDoc","updateResult","optimisticId","transaction","gc","readQuery","rootId","latestDiff","immediate","readFragment","writeFragment","updateFragment","MissingFieldError","deepFreeze","workSet","isFrozen","shallowFreeze","getOwnPropertyNames","maybeDeepFreeze","hasOwn","isNullish","defaultDataIdFromObject","_id","keyObject","defaultConfig","dataIdFromObject","addTypename","resultCaching","shouldCanonizeResults","TypeOrFieldNameRegExp","fieldNameFromStoreName","storeFieldName","selectionSetMatchesResult","storeValueIsStoreObject","extractFragmentContext","lookupFragment","delModifier","INVALIDATE","EntityStore","policies","rootIds","getFieldValue","objectOrReference","canRead","objOrRef","toReference","objOrIdOrRef","mergeIntoStore","storeObject","rootTypenamesById","Layer","dependOnExistence","existing","merged","storeObjectReconciler","caching","fieldsToDirty_1","__exists","hasKeyArgs","changedFields_1","needToMerge_1","allDeleted_1","sharedDetails_1","readField","fieldNameOrOptions","fieldValue","storage","getStorage","checkReference","seenReference","someNonReference","newValue_1","getStoreFieldName","evict","evicted","extraRootIds","getRootIdSet","__META","rest_1","retain","release","ids","snapshot","findChildRefIds","idsToRemove","root_1","found_1","workSet_1","keyMaker","CacheGroup","resetCaching","makeDepKey","maybeDependOnExistenceOfEntity","entityId","supportsResultCaching","Root","stump","Stump","storageTrie","addLayer","layerId","replay","removeLayer","ownStoreObject","parentStoreObject","fromParent","existingObject","incomingObject","existingValue","incomingValue","ObjectCanon","known","passes","keysByJSON","admit","isKnown","isObjectOrArray","pass","shallowCopy","proto_1","array_1","firstValueIndex_1","sorted","obj_1","execSelectionSetKeyArgs","StoreReader","knownResults","canon","peekArgs","enclosingRef","execSelectionSetImpl","resultCacheMaxSize","varString","execSubSelectedArrayImpl","resetCanon","diffQueryAgainstStore","rootRef","execResult","firstMissing","isFresh","objectsToMerge","missingMerger","handleMissing","resultName","rootIdsByTypename","fragmentMatches","finalResult","frozen","childResult","getTypenameFromStoreObject","assertSelectionSetForIdValue","specifierInfoCache","lookupSpecifierInfo","spec","keyFieldsFnFromSpecifier","specifier","keyFieldsFn","collectSpecifierPaths","schemaKeyPath","extracted","extractKeyPath","extractKey","keyArgsFnFromSpecifier","keyArgsFn","collected","keyPath","firstKey","firstChar","variableName","varKeyPath","directiveName_1","directiveArgs","extractor","getSpecifierPaths","toMerge","paths_1","currentPath_1","normalize","argsFromFieldSpecifier","nullKeyFieldsFn","simpleKeyArgsFn","_args","mergeTrueFn","mergeObjects","mergeFalseFn","Policies","typePolicies","toBeAdded","supertypeMap","fuzzySubtypes","usingPossibleTypes","setRootTypename","possibleTypes","addPossibleTypes","addTypePolicies","partialContext","ROOT_QUERY","normalizeReadFieldOptions","policy","getTypePolicy","keyFn","specifierOrId","queryType","mutationType","subscriptionType","updateTypePolicy","keyFields","setMerge","getFieldPolicy","which","old","supertype","getSupertypeSet","subtype","policy_1","supertypes_1","regExp","fuzzy","fuzzySupertypes","rest","inbox","createIfMissing","fieldPolicies","supertypeSet","typenameSupertypeSet","workQueue_1","maybeEnqueue_1","needToCheckFuzzySubtypes","checkingFuzzySubtypes","fuzzyString","fieldSpec","specifierOrString","directivesObj","storeKeyNameFromField","readOptions","makeFieldFunctionOptions","getReadFunction","getMergeFunction","parentTypename","childTypename","runMergeFunction","makeMergeObjectsFunction","readFieldArgs","argc","eType","iType","getContextFlavor","clientOnly","deferred","flavored","flavors","StoreWriter","writeToStore","operationDefinition","written","incomingById","processSelectionSet","mergeTree","fieldNodeSet","entityRef","applied","applyMerges","fieldsWithSelectionSets_1","hasSelectionSet_1","childTree","hasMergeFunction_1","existingRef","incomingObj","getChild","parentType","typeDotName","warnings","childTypenames","warnAboutDataLoss","result_1","flattenFields","resultFieldKey","getChildMergeTree","processFieldValue","maybeRecycleChildMergeTree","dataRef","sets","previous_1","mergeMergeTrees","mergeTreeIsEmpty","fieldMap","limitingTrie","inheritedContext","visitedNode","visited","getStorageArgs","e_1","i_1","getValue_1","eVal","iVal","aVal","emptyMergeTreePool","needToMergeMaps","remainingRightKeys_1","leftTree","InMemoryCache","watches","addTypenameTransform","txCount","normalizeConfig","rootStore","optimisticData","resetResultCache","resetResultIdentities","previousReader","storeReader","storeWriter","broadcastWatch","restore","resetCaches","idToRemove","newOptimisticData","layer","alreadyDirty","addFragmentsToDocument","_regeneratorRuntime","define","Generator","Context","makeInvokeMethod","tryCatch","GeneratorFunction","GeneratorFunctionPrototype","defineIteratorMethods","_invoke","AsyncIterator","invoke","__await","callInvokeWithMethodAndArg","delegate","maybeInvokeDelegate","_sent","dispatchException","abrupt","nextLoc","pushTryEntry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","displayName","isGeneratorFunction","mark","awrap","async","handle","delegateYield","asyncGeneratorStep","_asyncToGenerator","_next","_throw","_toPropertyKey","_toPrimitive","GraphQLClient","apiEndpointUrl","httpLink","apolloClient","_getLogEntry","_callee","electionUniqueId","contentHash","_context","GET_LOG_ENTRY","logEntry","_x","_getElectionLogEntries","_callee2","after","_context2","GET_ELECTION_LOG_ENTRIES","election","logEntries","_x2","_processKeyCeremonyStep","_callee3","messageId","_context3","PROCESS_KEY_CEREMONY_STEP","processKeyCeremonyStep","pendingMessage","_x3","_getPendingMessageByMessageId","_callee4","_context4","GET_PENDING_MESSAGE_BY_MESSAGE_ID","_x4","_processTallyStep","_callee5","_context5","PROCESS_TALLY_STEP","processTallyStep","_x5","Client","apiClient","getLogEntry","getElectionLogEntries","waitTime","intervalId","setInterval","getPendingMessageByMessageId","clearInterval","_AsyncGenerator","resume","_OverloadYield","settle","$inPersonVoteWrapper","bulletinBoardClient","waitForPendingMessageToBeProcessed","trigger"],"sourceRoot":""}