{"version":3,"file":"index.cjs","sources":["../../node_modules/xml2js/lib/defaults.js","../../node_modules/xmlbuilder/lib/Utility.js","../../node_modules/xmlbuilder/lib/XMLDOMImplementation.js","../../node_modules/xmlbuilder/lib/XMLDOMErrorHandler.js","../../node_modules/xmlbuilder/lib/XMLDOMStringList.js","../../node_modules/xmlbuilder/lib/XMLDOMConfiguration.js","../../node_modules/xmlbuilder/lib/NodeType.js","../../node_modules/xmlbuilder/lib/XMLAttribute.js","../../node_modules/xmlbuilder/lib/XMLNamedNodeMap.js","../../node_modules/xmlbuilder/lib/XMLElement.js","../../node_modules/xmlbuilder/lib/XMLCharacterData.js","../../node_modules/xmlbuilder/lib/XMLCData.js","../../node_modules/xmlbuilder/lib/XMLComment.js","../../node_modules/xmlbuilder/lib/XMLDeclaration.js","../../node_modules/xmlbuilder/lib/XMLDTDAttList.js","../../node_modules/xmlbuilder/lib/XMLDTDEntity.js","../../node_modules/xmlbuilder/lib/XMLDTDElement.js","../../node_modules/xmlbuilder/lib/XMLDTDNotation.js","../../node_modules/xmlbuilder/lib/XMLDocType.js","../../node_modules/xmlbuilder/lib/XMLRaw.js","../../node_modules/xmlbuilder/lib/XMLText.js","../../node_modules/xmlbuilder/lib/XMLProcessingInstruction.js","../../node_modules/xmlbuilder/lib/XMLDummy.js","../../node_modules/xmlbuilder/lib/XMLNodeList.js","../../node_modules/xmlbuilder/lib/DocumentPosition.js","../../node_modules/xmlbuilder/lib/XMLNode.js","../../node_modules/xmlbuilder/lib/XMLStringifier.js","../../node_modules/xmlbuilder/lib/WriterState.js","../../node_modules/xmlbuilder/lib/XMLWriterBase.js","../../node_modules/xmlbuilder/lib/XMLStringWriter.js","../../node_modules/xmlbuilder/lib/XMLDocument.js","../../node_modules/xmlbuilder/lib/XMLDocumentCB.js","../../node_modules/xmlbuilder/lib/XMLStreamWriter.js","../../node_modules/xml2js/lib/builder.js","../../node_modules/xmlbuilder/lib/index.js","../../node_modules/sax/lib/sax.js","../../node_modules/xml2js/lib/bom.js","../../node_modules/xml2js/lib/processors.js","../../node_modules/xml2js/lib/parser.js","../../node_modules/xml2js/lib/xml2js.js","../../node_modules/xpath/xpath.js","../../node_modules/@xmldom/xmldom/lib/conventions.js","../../node_modules/@xmldom/xmldom/lib/dom.js","../../node_modules/@xmldom/xmldom/lib/entities.js","../../node_modules/@xmldom/xmldom/lib/sax.js","../../node_modules/@xmldom/xmldom/lib/dom-parser.js","../../node_modules/@xmldom/is-dom-node/dist/index.js","../../node_modules/xml-crypto/lib/utils.js","../../node_modules/xml-crypto/lib/hash-algorithms.js","../../node_modules/xml-crypto/lib/types.js","../../node_modules/xml-crypto/lib/signature-algorithms.js","../../node_modules/xml-crypto/lib/signed-xml.js","../../node_modules/@xmldom/xmldom/lib/index.js","../../node_modules/xml-crypto/lib/c14n-canonicalization.js","../../node_modules/xml-crypto/lib/exclusive-canonicalization.js","../../node_modules/xml-crypto/lib/enveloped-signature.js","../../node_modules/xml-crypto/lib/index.js","../../src/adapters/XmlBuilder.ts","../../src/adapters/SchemaLoader.ts","../../node_modules/xml-js/lib/array-helper.js","../../node_modules/xml-js/lib/options-helper.js","../../node_modules/xml-js/lib/xml2js.js","../../node_modules/xml-js/lib/xml2json.js","../../node_modules/xml-js/lib/js2xml.js","../../node_modules/xml-js/lib/json2xml.js","../../node_modules/xml-js/lib/index.js","../../src/core/utils/XmlParser.ts","../../node_modules/xsd-assembler/dist/cjs/index.js","../../src/core/utils/Utility.ts","../../src/modules/dfe/base/GerarConsulta.ts","../../node_modules/@babel/runtime/helpers/esm/typeof.js","../../node_modules/date-fns/esm/_lib/toInteger/index.js","../../node_modules/date-fns/esm/_lib/requiredArgs/index.js","../../node_modules/date-fns/esm/toDate/index.js","../../node_modules/date-fns/esm/_lib/defaultOptions/index.js","../../node_modules/date-fns/esm/isValid/index.js","../../node_modules/date-fns/esm/isDate/index.js","../../node_modules/date-fns/esm/subMilliseconds/index.js","../../node_modules/date-fns/esm/addMilliseconds/index.js","../../node_modules/date-fns/esm/_lib/startOfUTCISOWeek/index.js","../../node_modules/date-fns/esm/_lib/getUTCISOWeekYear/index.js","../../node_modules/date-fns/esm/_lib/getUTCISOWeek/index.js","../../node_modules/date-fns/esm/_lib/startOfUTCISOWeekYear/index.js","../../node_modules/date-fns/esm/_lib/startOfUTCWeek/index.js","../../node_modules/date-fns/esm/_lib/getUTCWeekYear/index.js","../../node_modules/date-fns/esm/_lib/getUTCWeek/index.js","../../node_modules/date-fns/esm/_lib/startOfUTCWeekYear/index.js","../../node_modules/date-fns/esm/_lib/addLeadingZeros/index.js","../../node_modules/date-fns/esm/_lib/format/lightFormatters/index.js","../../node_modules/date-fns/esm/_lib/format/formatters/index.js","../../node_modules/date-fns/esm/_lib/getUTCDayOfYear/index.js","../../node_modules/date-fns/esm/_lib/format/longFormatters/index.js","../../node_modules/date-fns/esm/_lib/protectedTokens/index.js","../../node_modules/date-fns/esm/locale/en-US/_lib/formatDistance/index.js","../../node_modules/date-fns/esm/locale/_lib/buildFormatLongFn/index.js","../../node_modules/date-fns/esm/locale/en-US/_lib/formatLong/index.js","../../node_modules/date-fns/esm/locale/en-US/_lib/formatRelative/index.js","../../node_modules/date-fns/esm/locale/_lib/buildLocalizeFn/index.js","../../node_modules/date-fns/esm/locale/_lib/buildMatchFn/index.js","../../node_modules/date-fns/esm/locale/en-US/_lib/match/index.js","../../node_modules/date-fns/esm/locale/en-US/index.js","../../node_modules/date-fns/esm/locale/en-US/_lib/localize/index.js","../../node_modules/date-fns/esm/locale/_lib/buildMatchPatternFn/index.js","../../node_modules/date-fns/esm/format/index.js","../../node_modules/date-fns/esm/_lib/getTimezoneOffsetInMilliseconds/index.js","../../node_modules/date-fns/esm/parseISO/index.js","../../node_modules/date-fns/esm/constants/index.js","../../src/modules/dfe/base/SaveFiles.ts","../../node_modules/axios/lib/helpers/bind.js","../../node_modules/axios/lib/utils.js","../../node_modules/axios/lib/core/AxiosError.js","../../node_modules/combined-stream/lib/combined_stream.js","../../node_modules/delayed-stream/lib/delayed_stream.js","../../node_modules/mime-types/index.js","../../node_modules/mime-db/index.js","../../node_modules/asynckit/lib/async.js","../../node_modules/asynckit/lib/defer.js","../../node_modules/asynckit/lib/abort.js","../../node_modules/asynckit/lib/iterate.js","../../node_modules/asynckit/lib/state.js","../../node_modules/asynckit/lib/terminator.js","../../node_modules/asynckit/parallel.js","../../node_modules/asynckit/serialOrdered.js","../../node_modules/asynckit/serial.js","../../node_modules/asynckit/index.js","../../node_modules/axios/node_modules/form-data/lib/populate.js","../../node_modules/axios/node_modules/form-data/lib/form_data.js","../../node_modules/axios/lib/helpers/toFormData.js","../../node_modules/axios/lib/helpers/AxiosURLSearchParams.js","../../node_modules/axios/lib/helpers/buildURL.js","../../node_modules/axios/lib/core/InterceptorManager.js","../../node_modules/axios/lib/defaults/transitional.js","../../node_modules/axios/lib/platform/node/classes/URLSearchParams.js","../../node_modules/axios/lib/platform/node/index.js","../../node_modules/axios/lib/platform/common/utils.js","../../node_modules/axios/lib/platform/index.js","../../node_modules/axios/lib/helpers/formDataToJSON.js","../../node_modules/axios/lib/defaults/index.js","../../node_modules/axios/lib/helpers/toURLEncodedForm.js","../../node_modules/axios/lib/helpers/parseHeaders.js","../../node_modules/axios/lib/core/AxiosHeaders.js","../../node_modules/axios/lib/core/transformData.js","../../node_modules/axios/lib/cancel/isCancel.js","../../node_modules/axios/lib/cancel/CanceledError.js","../../node_modules/axios/lib/core/settle.js","../../node_modules/axios/lib/core/buildFullPath.js","../../node_modules/axios/lib/helpers/isAbsoluteURL.js","../../node_modules/axios/lib/helpers/combineURLs.js","../../node_modules/proxy-from-env/index.js","../../node_modules/ms/index.js","../../node_modules/debug/src/common.js","../../node_modules/has-flag/index.js","../../node_modules/debug/src/node.js","../../node_modules/supports-color/index.js","../../node_modules/debug/src/index.js","../../node_modules/debug/src/browser.js","../../node_modules/follow-redirects/index.js","../../node_modules/follow-redirects/debug.js","../../node_modules/axios/lib/helpers/parseProtocol.js","../../node_modules/axios/lib/helpers/fromDataURI.js","../../node_modules/axios/lib/helpers/AxiosTransformStream.js","../../node_modules/axios/lib/helpers/readBlob.js","../../node_modules/axios/lib/helpers/formDataToStream.js","../../node_modules/axios/lib/helpers/ZlibHeaderTransformStream.js","../../node_modules/axios/lib/helpers/callbackify.js","../../node_modules/axios/lib/helpers/progressEventReducer.js","../../node_modules/axios/lib/helpers/speedometer.js","../../node_modules/axios/lib/helpers/throttle.js","../../node_modules/axios/lib/adapters/http.js","../../node_modules/axios/lib/helpers/isURLSameOrigin.js","../../node_modules/axios/lib/helpers/cookies.js","../../node_modules/axios/lib/core/mergeConfig.js","../../node_modules/axios/lib/helpers/resolveConfig.js","../../node_modules/axios/lib/adapters/xhr.js","../../node_modules/axios/lib/helpers/composeSignals.js","../../node_modules/axios/lib/helpers/trackStream.js","../../node_modules/axios/lib/adapters/fetch.js","../../node_modules/axios/lib/adapters/adapters.js","../../node_modules/axios/lib/core/dispatchRequest.js","../../node_modules/axios/lib/helpers/validator.js","../../node_modules/axios/lib/core/Axios.js","../../node_modules/axios/lib/cancel/CancelToken.js","../../node_modules/axios/lib/helpers/HttpStatusCode.js","../../node_modules/axios/lib/axios.js","../../node_modules/axios/lib/env/data.js","../../node_modules/axios/lib/helpers/spread.js","../../node_modules/axios/lib/helpers/isAxiosError.js","../../src/modules/environment/AxiosHttpClient.ts","../../src/modules/environment/HttpClientBuilder.ts","../../src/modules/environment/ValidateEnvironment.ts","../../node_modules/node-forge/lib/forge.js","../../node_modules/node-forge/lib/baseN.js","../../node_modules/node-forge/lib/util.js","../../node_modules/node-forge/lib/cipher.js","../../node_modules/node-forge/lib/cipherModes.js","../../node_modules/node-forge/lib/aes.js","../../node_modules/node-forge/lib/oids.js","../../node_modules/node-forge/lib/asn1.js","../../node_modules/node-forge/lib/md.js","../../node_modules/node-forge/lib/hmac.js","../../node_modules/node-forge/lib/md5.js","../../node_modules/node-forge/lib/pem.js","../../node_modules/node-forge/lib/des.js","../../node_modules/node-forge/lib/pbkdf2.js","../../node_modules/node-forge/lib/sha256.js","../../node_modules/node-forge/lib/prng.js","../../node_modules/node-forge/lib/random.js","../../node_modules/node-forge/lib/rc2.js","../../node_modules/node-forge/lib/jsbn.js","../../node_modules/node-forge/lib/sha1.js","../../node_modules/node-forge/lib/pkcs1.js","../../node_modules/node-forge/lib/prime.js","../../node_modules/node-forge/lib/rsa.js","../../node_modules/node-forge/lib/pbe.js","../../node_modules/node-forge/lib/pkcs7asn1.js","../../node_modules/node-forge/lib/mgf1.js","../../node_modules/node-forge/lib/pss.js","../../node_modules/node-forge/lib/x509.js","../../node_modules/node-forge/lib/mgf.js","../../node_modules/node-forge/lib/pkcs12.js","../../node_modules/node-forge/lib/pki.js","../../node_modules/node-forge/lib/tls.js","../../node_modules/node-forge/lib/aesCipherSuites.js","../../node_modules/node-forge/lib/sha512.js","../../node_modules/node-forge/lib/asn1-validator.js","../../node_modules/node-forge/lib/ed25519.js","../../node_modules/node-forge/lib/pkcs7.js","../../node_modules/node-forge/lib/index.js","../../node_modules/node-forge/lib/kem.js","../../node_modules/node-forge/lib/log.js","../../node_modules/node-forge/lib/md.all.js","../../node_modules/node-forge/lib/ssh.js","../../src/modules/environment/LoadCertificate.ts","../../src/modules/environment/Environment.ts","../../src/core/utils/getCodIBGE.ts","../../src/modules/dfe/base/BaseNFe.ts","../../src/modules/dfe/nfe/services/NFEStatusServico/NFEStatusServicoService.ts","../../src/modules/dfe/nfe/operations/NFEConsultaProtocolo/NFEconsultaProtocolo.ts","../../src/modules/dfe/nfe/operations/NFERecepcaoEvento/NFEEpec.ts","../../src/modules/dfe/nfe/operations/NFERecepcaoEvento/NFECancelamento.ts","../../src/modules/dfe/nfe/operations/NFERecepcaoEvento/NFECienciaDaOperacao.ts","../../src/modules/dfe/nfe/operations/NFERecepcaoEvento/NFEConfirmacaoDaOperacao.ts","../../src/modules/dfe/nfe/operations/NFERecepcaoEvento/NFEOperacaoNaoRealizada.ts","../../node_modules/nodemailer/lib/fetch/index.js","../../node_modules/nodemailer/lib/fetch/cookies.js","../../node_modules/nodemailer/lib/shared/index.js","../../node_modules/nodemailer/lib/mime-funcs/mime-types.js","../../node_modules/nodemailer/lib/punycode/index.js","../../node_modules/nodemailer/lib/base64/index.js","../../node_modules/nodemailer/lib/qp/index.js","../../node_modules/nodemailer/lib/mime-funcs/index.js","../../node_modules/nodemailer/lib/addressparser/index.js","../../node_modules/nodemailer/lib/mime-node/le-windows.js","../../node_modules/nodemailer/lib/mime-node/index.js","../../node_modules/nodemailer/lib/mime-node/last-newline.js","../../node_modules/nodemailer/lib/mime-node/le-unix.js","../../node_modules/nodemailer/lib/dkim/sign.js","../../node_modules/nodemailer/lib/dkim/index.js","../../node_modules/nodemailer/lib/dkim/message-parser.js","../../node_modules/nodemailer/lib/dkim/relaxed-body.js","../../node_modules/nodemailer/lib/mailer/index.js","../../node_modules/nodemailer/lib/mail-composer/index.js","../../node_modules/nodemailer/lib/smtp-connection/http-proxy-client.js","../../node_modules/nodemailer/lib/mailer/mail-message.js","../../node_modules/nodemailer/lib/smtp-connection/index.js","../../node_modules/nodemailer/lib/smtp-connection/data-stream.js","../../node_modules/nodemailer/lib/xoauth2/index.js","../../node_modules/nodemailer/lib/well-known/index.js","../../node_modules/nodemailer/lib/smtp-pool/index.js","../../node_modules/nodemailer/lib/smtp-pool/pool-resource.js","../../node_modules/nodemailer/lib/ses-transport/index.js","../../node_modules/nodemailer/lib/nodemailer.js","../../node_modules/nodemailer/lib/smtp-transport/index.js","../../node_modules/nodemailer/lib/sendmail-transport/index.js","../../node_modules/nodemailer/lib/stream-transport/index.js","../../node_modules/nodemailer/lib/json-transport/index.js","../../src/adapters/MailAdapter.ts","../../node_modules/qrcode/lib/can-promise.js","../../node_modules/qrcode/lib/core/utils.js","../../node_modules/qrcode/lib/core/error-correction-level.js","../../node_modules/qrcode/lib/core/error-correction-code.js","../../node_modules/qrcode/lib/core/polynomial.js","../../node_modules/qrcode/lib/core/galois-field.js","../../node_modules/qrcode/lib/core/version-check.js","../../node_modules/qrcode/lib/core/regex.js","../../node_modules/qrcode/lib/core/mode.js","../../node_modules/qrcode/lib/core/version.js","../../node_modules/dijkstrajs/dijkstra.js","../../node_modules/qrcode/lib/core/segments.js","../../node_modules/qrcode/lib/core/numeric-data.js","../../node_modules/qrcode/lib/core/alphanumeric-data.js","../../node_modules/qrcode/lib/core/byte-data.js","../../node_modules/qrcode/lib/core/kanji-data.js","../../node_modules/qrcode/lib/core/qrcode.js","../../node_modules/qrcode/lib/core/bit-buffer.js","../../node_modules/qrcode/lib/core/bit-matrix.js","../../node_modules/qrcode/lib/core/alignment-pattern.js","../../node_modules/qrcode/lib/core/finder-pattern.js","../../node_modules/qrcode/lib/core/mask-pattern.js","../../node_modules/qrcode/lib/core/reed-solomon-encoder.js","../../node_modules/qrcode/lib/core/format-info.js","../../node_modules/pngjs/lib/chunkstream.js","../../node_modules/pngjs/lib/interlace.js","../../node_modules/pngjs/lib/paeth-predictor.js","../../node_modules/pngjs/lib/filter-parse.js","../../node_modules/pngjs/lib/constants.js","../../node_modules/pngjs/lib/crc.js","../../node_modules/pngjs/lib/parser.js","../../node_modules/pngjs/lib/bitmapper.js","../../node_modules/pngjs/lib/format-normaliser.js","../../node_modules/pngjs/lib/parser-async.js","../../node_modules/pngjs/lib/filter-parse-async.js","../../node_modules/pngjs/lib/packer.js","../../node_modules/pngjs/lib/bitpacker.js","../../node_modules/pngjs/lib/filter-pack.js","../../node_modules/pngjs/lib/sync-inflate.js","../../node_modules/pngjs/lib/sync-reader.js","../../node_modules/pngjs/lib/parser-sync.js","../../node_modules/pngjs/lib/filter-parse-sync.js","../../node_modules/pngjs/lib/png-sync.js","../../node_modules/pngjs/lib/packer-sync.js","../../node_modules/pngjs/lib/png.js","../../node_modules/pngjs/lib/packer-async.js","../../node_modules/qrcode/lib/renderer/utils.js","../../node_modules/qrcode/lib/renderer/terminal.js","../../node_modules/qrcode/lib/renderer/terminal/terminal.js","../../node_modules/qrcode/lib/renderer/terminal/terminal-small.js","../../node_modules/qrcode/lib/renderer/svg-tag.js","../../node_modules/qrcode/lib/renderer/canvas.js","../../node_modules/qrcode/lib/server.js","../../node_modules/qrcode/lib/renderer/png.js","../../node_modules/qrcode/lib/renderer/utf8.js","../../node_modules/qrcode/lib/renderer/svg.js","../../node_modules/qrcode/lib/browser.js","../../node_modules/qrcode/lib/index.js","../../src/core/utils/ValidaCPFCNPJ.ts","../../src/core/utils/getDesTipoPag.ts","../../src/modules/dfe/danfe/NFCEGerarDanfe/NFCEGerarDanfe.ts","../../src/modules/dfe/danfe/NFEGerarDanfe/NFEGerarDanfe.ts","../../src/modules/dfe/nfce/operations/NFCEAutorizacao/NFCEAutorizacao.ts","../../src/modules/dfe/nfe/operations/NFEDistribuicaoDFe/NFEDistribuicaoDFe.ts","../../src/modules/dfe/nfe/operations/NFEDistribuicaoDFe/NFEDistribuicaoDFePorChave.ts","../../src/modules/dfe/nfe/operations/NFEDistribuicaoDFe/NFEDistribuicaoDFePorNSU.ts","../../src/modules/dfe/nfe/operations/NFEDistribuicaoDFe/NFEDistribuicaoDFePorUltNSU.ts","../../src/modules/dfe/nfe/operations/NFEInutilizacao/NFEInutilizacao.ts","../../src/modules/dfe/nfe/operations/NFERecepcaoEvento/NFECartaDeCorrecao.ts","../../src/modules/dfe/nfe/operations/NFERecepcaoEvento/NFEDesconhecimentoDaOperacao.ts","../../src/modules/dfe/nfe/operations/NFERetornoAutorizacao/NFERetornoAutorizacao.ts","../../src/core/utils/NFEImposto.ts","../../src/modules/dfe/nfe/services/NFERetornoAutorizacao/NFERetornoAutorizacaoService.ts","../../src/modules/dfe/nfe/services/NFEAutorizacao/NFEAutorizacaoService.ts","../../src/modules/dfe/nfe/services/NFEConsultaProtocolo/NFEconsultaProtocoloService.ts","../../src/modules/dfe/nfe/operations/NFEStatusServico/NFEStatusServico.ts","../../src/modules/dfe/nfe/operations/NFERecepcaoEvento/NFERecepcaoEvento.ts","../../src/modules/dfe/nfe/services/NFERecepcaoEvento/NFERecepcaoEventoService.ts","../../src/modules/dfe/nfe/services/NFERecepcaoEvento/NFECancelamentoService.ts","../../src/modules/dfe/nfe/services/NFERecepcaoEvento/NFECartaDeCorrecaoService.ts","../../src/modules/dfe/nfe/services/NFERecepcaoEvento/NFECienciaDaOperacaoService.ts","../../src/modules/dfe/nfe/services/NFERecepcaoEvento/NFEDesconhecimentoDaOperacaoService.ts","../../src/modules/dfe/nfe/services/NFERecepcaoEvento/NFEEpecService.ts","../../src/modules/dfe/nfe/services/NFERecepcaoEvento/NFEOperacaoNaoRealizadaService.ts","../../src/modules/dfe/nfe/operations/NFEAutorizacao/NFEAutorizacao.ts","../../node_modules/pako/dist/pako.esm.mjs","../../src/modules/dfe/nfe/services/NFEDistribuicaoDFe/util/DistribuicaoHandler.ts","../../src/modules/dfe/nfe/services/NFEDistribuicaoDFe/NFEDistribuicaoDFeService.ts","../../src/modules/dfe/nfe/services/NFEDistribuicaoDFe/NFEDistribuicaoDFePorUltNSU.ts","../../src/modules/dfe/nfe/services/NFEDistribuicaoDFe/NFEDistribuicaoDFePorNSU.ts","../../src/modules/dfe/nfe/services/NFEDistribuicaoDFe/NFEDistribuicaoDFePorChave.ts","../../src/modules/dfe/nfe/services/NFEInutilizacao/NFEInutilizacaoService.ts","../../node_modules/crypt/crypt.js","../../node_modules/charenc/charenc.js","../../node_modules/sha1/sha1.js","../../src/modules/dfe/nfce/services/NFCEAutorizacao/util/NFCEQRCode.ts","../../src/modules/dfe/nfce/services/NFCERetornoAutorizacao/NFCERetornoAutorizacaoService.ts","../../src/modules/dfe/nfce/operations/NFCERetornoAutorizacao/NFCERetornoAutorizacao.ts","../../src/modules/dfe/nfce/services/NFCEAutorizacao/NFCEAutorizacaoService.ts","../../src/modules/dfe/nfe/services/NFeWizard/NFeWizardService.ts","../../src/adapters/NFeWizard.ts"],"sourcesContent":["// Generated by CoffeeScript 1.12.7\n(function() {\n  exports.defaults = {\n    \"0.1\": {\n      explicitCharkey: false,\n      trim: true,\n      normalize: true,\n      normalizeTags: false,\n      attrkey: \"@\",\n      charkey: \"#\",\n      explicitArray: false,\n      ignoreAttrs: false,\n      mergeAttrs: false,\n      explicitRoot: false,\n      validator: null,\n      xmlns: false,\n      explicitChildren: false,\n      childkey: '@@',\n      charsAsChildren: false,\n      includeWhiteChars: false,\n      async: false,\n      strict: true,\n      attrNameProcessors: null,\n      attrValueProcessors: null,\n      tagNameProcessors: null,\n      valueProcessors: null,\n      emptyTag: ''\n    },\n    \"0.2\": {\n      explicitCharkey: false,\n      trim: false,\n      normalize: false,\n      normalizeTags: false,\n      attrkey: \"$\",\n      charkey: \"_\",\n      explicitArray: true,\n      ignoreAttrs: false,\n      mergeAttrs: false,\n      explicitRoot: true,\n      validator: null,\n      xmlns: false,\n      explicitChildren: false,\n      preserveChildrenOrder: false,\n      childkey: '$$',\n      charsAsChildren: false,\n      includeWhiteChars: false,\n      async: false,\n      strict: true,\n      attrNameProcessors: null,\n      attrValueProcessors: null,\n      tagNameProcessors: null,\n      valueProcessors: null,\n      rootName: 'root',\n      xmldec: {\n        'version': '1.0',\n        'encoding': 'UTF-8',\n        'standalone': true\n      },\n      doctype: null,\n      renderOpts: {\n        'pretty': true,\n        'indent': '  ',\n        'newline': '\\n'\n      },\n      headless: false,\n      chunkSize: 10000,\n      emptyTag: '',\n      cdata: false\n    }\n  };\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var assign, getValue, isArray, isEmpty, isFunction, isObject, isPlainObject,\n    slice = [].slice,\n    hasProp = {}.hasOwnProperty;\n\n  assign = function() {\n    var i, key, len, source, sources, target;\n    target = arguments[0], sources = 2 <= arguments.length ? slice.call(arguments, 1) : [];\n    if (isFunction(Object.assign)) {\n      Object.assign.apply(null, arguments);\n    } else {\n      for (i = 0, len = sources.length; i < len; i++) {\n        source = sources[i];\n        if (source != null) {\n          for (key in source) {\n            if (!hasProp.call(source, key)) continue;\n            target[key] = source[key];\n          }\n        }\n      }\n    }\n    return target;\n  };\n\n  isFunction = function(val) {\n    return !!val && Object.prototype.toString.call(val) === '[object Function]';\n  };\n\n  isObject = function(val) {\n    var ref;\n    return !!val && ((ref = typeof val) === 'function' || ref === 'object');\n  };\n\n  isArray = function(val) {\n    if (isFunction(Array.isArray)) {\n      return Array.isArray(val);\n    } else {\n      return Object.prototype.toString.call(val) === '[object Array]';\n    }\n  };\n\n  isEmpty = function(val) {\n    var key;\n    if (isArray(val)) {\n      return !val.length;\n    } else {\n      for (key in val) {\n        if (!hasProp.call(val, key)) continue;\n        return false;\n      }\n      return true;\n    }\n  };\n\n  isPlainObject = function(val) {\n    var ctor, proto;\n    return isObject(val) && (proto = Object.getPrototypeOf(val)) && (ctor = proto.constructor) && (typeof ctor === 'function') && (ctor instanceof ctor) && (Function.prototype.toString.call(ctor) === Function.prototype.toString.call(Object));\n  };\n\n  getValue = function(obj) {\n    if (isFunction(obj.valueOf)) {\n      return obj.valueOf();\n    } else {\n      return obj;\n    }\n  };\n\n  module.exports.assign = assign;\n\n  module.exports.isFunction = isFunction;\n\n  module.exports.isObject = isObject;\n\n  module.exports.isArray = isArray;\n\n  module.exports.isEmpty = isEmpty;\n\n  module.exports.isPlainObject = isPlainObject;\n\n  module.exports.getValue = getValue;\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var XMLDOMImplementation;\n\n  module.exports = XMLDOMImplementation = (function() {\n    function XMLDOMImplementation() {}\n\n    XMLDOMImplementation.prototype.hasFeature = function(feature, version) {\n      return true;\n    };\n\n    XMLDOMImplementation.prototype.createDocumentType = function(qualifiedName, publicId, systemId) {\n      throw new Error(\"This DOM method is not implemented.\");\n    };\n\n    XMLDOMImplementation.prototype.createDocument = function(namespaceURI, qualifiedName, doctype) {\n      throw new Error(\"This DOM method is not implemented.\");\n    };\n\n    XMLDOMImplementation.prototype.createHTMLDocument = function(title) {\n      throw new Error(\"This DOM method is not implemented.\");\n    };\n\n    XMLDOMImplementation.prototype.getFeature = function(feature, version) {\n      throw new Error(\"This DOM method is not implemented.\");\n    };\n\n    return XMLDOMImplementation;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var XMLDOMErrorHandler;\n\n  module.exports = XMLDOMErrorHandler = (function() {\n    function XMLDOMErrorHandler() {}\n\n    XMLDOMErrorHandler.prototype.handleError = function(error) {\n      throw new Error(error);\n    };\n\n    return XMLDOMErrorHandler;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var XMLDOMStringList;\n\n  module.exports = XMLDOMStringList = (function() {\n    function XMLDOMStringList(arr) {\n      this.arr = arr || [];\n    }\n\n    Object.defineProperty(XMLDOMStringList.prototype, 'length', {\n      get: function() {\n        return this.arr.length;\n      }\n    });\n\n    XMLDOMStringList.prototype.item = function(index) {\n      return this.arr[index] || null;\n    };\n\n    XMLDOMStringList.prototype.contains = function(str) {\n      return this.arr.indexOf(str) !== -1;\n    };\n\n    return XMLDOMStringList;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var XMLDOMConfiguration, XMLDOMErrorHandler, XMLDOMStringList;\n\n  XMLDOMErrorHandler = require('./XMLDOMErrorHandler');\n\n  XMLDOMStringList = require('./XMLDOMStringList');\n\n  module.exports = XMLDOMConfiguration = (function() {\n    function XMLDOMConfiguration() {\n      var clonedSelf;\n      this.defaultParams = {\n        \"canonical-form\": false,\n        \"cdata-sections\": false,\n        \"comments\": false,\n        \"datatype-normalization\": false,\n        \"element-content-whitespace\": true,\n        \"entities\": true,\n        \"error-handler\": new XMLDOMErrorHandler(),\n        \"infoset\": true,\n        \"validate-if-schema\": false,\n        \"namespaces\": true,\n        \"namespace-declarations\": true,\n        \"normalize-characters\": false,\n        \"schema-location\": '',\n        \"schema-type\": '',\n        \"split-cdata-sections\": true,\n        \"validate\": false,\n        \"well-formed\": true\n      };\n      this.params = clonedSelf = Object.create(this.defaultParams);\n    }\n\n    Object.defineProperty(XMLDOMConfiguration.prototype, 'parameterNames', {\n      get: function() {\n        return new XMLDOMStringList(Object.keys(this.defaultParams));\n      }\n    });\n\n    XMLDOMConfiguration.prototype.getParameter = function(name) {\n      if (this.params.hasOwnProperty(name)) {\n        return this.params[name];\n      } else {\n        return null;\n      }\n    };\n\n    XMLDOMConfiguration.prototype.canSetParameter = function(name, value) {\n      return true;\n    };\n\n    XMLDOMConfiguration.prototype.setParameter = function(name, value) {\n      if (value != null) {\n        return this.params[name] = value;\n      } else {\n        return delete this.params[name];\n      }\n    };\n\n    return XMLDOMConfiguration;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  module.exports = {\n    Element: 1,\n    Attribute: 2,\n    Text: 3,\n    CData: 4,\n    EntityReference: 5,\n    EntityDeclaration: 6,\n    ProcessingInstruction: 7,\n    Comment: 8,\n    Document: 9,\n    DocType: 10,\n    DocumentFragment: 11,\n    NotationDeclaration: 12,\n    Declaration: 201,\n    Raw: 202,\n    AttributeDeclaration: 203,\n    ElementDeclaration: 204,\n    Dummy: 205\n  };\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLAttribute, XMLNode;\n\n  NodeType = require('./NodeType');\n\n  XMLNode = require('./XMLNode');\n\n  module.exports = XMLAttribute = (function() {\n    function XMLAttribute(parent, name, value) {\n      this.parent = parent;\n      if (this.parent) {\n        this.options = this.parent.options;\n        this.stringify = this.parent.stringify;\n      }\n      if (name == null) {\n        throw new Error(\"Missing attribute name. \" + this.debugInfo(name));\n      }\n      this.name = this.stringify.name(name);\n      this.value = this.stringify.attValue(value);\n      this.type = NodeType.Attribute;\n      this.isId = false;\n      this.schemaTypeInfo = null;\n    }\n\n    Object.defineProperty(XMLAttribute.prototype, 'nodeType', {\n      get: function() {\n        return this.type;\n      }\n    });\n\n    Object.defineProperty(XMLAttribute.prototype, 'ownerElement', {\n      get: function() {\n        return this.parent;\n      }\n    });\n\n    Object.defineProperty(XMLAttribute.prototype, 'textContent', {\n      get: function() {\n        return this.value;\n      },\n      set: function(value) {\n        return this.value = value || '';\n      }\n    });\n\n    Object.defineProperty(XMLAttribute.prototype, 'namespaceURI', {\n      get: function() {\n        return '';\n      }\n    });\n\n    Object.defineProperty(XMLAttribute.prototype, 'prefix', {\n      get: function() {\n        return '';\n      }\n    });\n\n    Object.defineProperty(XMLAttribute.prototype, 'localName', {\n      get: function() {\n        return this.name;\n      }\n    });\n\n    Object.defineProperty(XMLAttribute.prototype, 'specified', {\n      get: function() {\n        return true;\n      }\n    });\n\n    XMLAttribute.prototype.clone = function() {\n      return Object.create(this);\n    };\n\n    XMLAttribute.prototype.toString = function(options) {\n      return this.options.writer.attribute(this, this.options.writer.filterOptions(options));\n    };\n\n    XMLAttribute.prototype.debugInfo = function(name) {\n      name = name || this.name;\n      if (name == null) {\n        return \"parent: <\" + this.parent.name + \">\";\n      } else {\n        return \"attribute: {\" + name + \"}, parent: <\" + this.parent.name + \">\";\n      }\n    };\n\n    XMLAttribute.prototype.isEqualNode = function(node) {\n      if (node.namespaceURI !== this.namespaceURI) {\n        return false;\n      }\n      if (node.prefix !== this.prefix) {\n        return false;\n      }\n      if (node.localName !== this.localName) {\n        return false;\n      }\n      if (node.value !== this.value) {\n        return false;\n      }\n      return true;\n    };\n\n    return XMLAttribute;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var XMLNamedNodeMap;\n\n  module.exports = XMLNamedNodeMap = (function() {\n    function XMLNamedNodeMap(nodes) {\n      this.nodes = nodes;\n    }\n\n    Object.defineProperty(XMLNamedNodeMap.prototype, 'length', {\n      get: function() {\n        return Object.keys(this.nodes).length || 0;\n      }\n    });\n\n    XMLNamedNodeMap.prototype.clone = function() {\n      return this.nodes = null;\n    };\n\n    XMLNamedNodeMap.prototype.getNamedItem = function(name) {\n      return this.nodes[name];\n    };\n\n    XMLNamedNodeMap.prototype.setNamedItem = function(node) {\n      var oldNode;\n      oldNode = this.nodes[node.nodeName];\n      this.nodes[node.nodeName] = node;\n      return oldNode || null;\n    };\n\n    XMLNamedNodeMap.prototype.removeNamedItem = function(name) {\n      var oldNode;\n      oldNode = this.nodes[name];\n      delete this.nodes[name];\n      return oldNode || null;\n    };\n\n    XMLNamedNodeMap.prototype.item = function(index) {\n      return this.nodes[Object.keys(this.nodes)[index]] || null;\n    };\n\n    XMLNamedNodeMap.prototype.getNamedItemNS = function(namespaceURI, localName) {\n      throw new Error(\"This DOM method is not implemented.\");\n    };\n\n    XMLNamedNodeMap.prototype.setNamedItemNS = function(node) {\n      throw new Error(\"This DOM method is not implemented.\");\n    };\n\n    XMLNamedNodeMap.prototype.removeNamedItemNS = function(namespaceURI, localName) {\n      throw new Error(\"This DOM method is not implemented.\");\n    };\n\n    return XMLNamedNodeMap;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLAttribute, XMLElement, XMLNamedNodeMap, XMLNode, getValue, isFunction, isObject, ref,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  ref = require('./Utility'), isObject = ref.isObject, isFunction = ref.isFunction, getValue = ref.getValue;\n\n  XMLNode = require('./XMLNode');\n\n  NodeType = require('./NodeType');\n\n  XMLAttribute = require('./XMLAttribute');\n\n  XMLNamedNodeMap = require('./XMLNamedNodeMap');\n\n  module.exports = XMLElement = (function(superClass) {\n    extend(XMLElement, superClass);\n\n    function XMLElement(parent, name, attributes) {\n      var child, j, len, ref1;\n      XMLElement.__super__.constructor.call(this, parent);\n      if (name == null) {\n        throw new Error(\"Missing element name. \" + this.debugInfo());\n      }\n      this.name = this.stringify.name(name);\n      this.type = NodeType.Element;\n      this.attribs = {};\n      this.schemaTypeInfo = null;\n      if (attributes != null) {\n        this.attribute(attributes);\n      }\n      if (parent.type === NodeType.Document) {\n        this.isRoot = true;\n        this.documentObject = parent;\n        parent.rootObject = this;\n        if (parent.children) {\n          ref1 = parent.children;\n          for (j = 0, len = ref1.length; j < len; j++) {\n            child = ref1[j];\n            if (child.type === NodeType.DocType) {\n              child.name = this.name;\n              break;\n            }\n          }\n        }\n      }\n    }\n\n    Object.defineProperty(XMLElement.prototype, 'tagName', {\n      get: function() {\n        return this.name;\n      }\n    });\n\n    Object.defineProperty(XMLElement.prototype, 'namespaceURI', {\n      get: function() {\n        return '';\n      }\n    });\n\n    Object.defineProperty(XMLElement.prototype, 'prefix', {\n      get: function() {\n        return '';\n      }\n    });\n\n    Object.defineProperty(XMLElement.prototype, 'localName', {\n      get: function() {\n        return this.name;\n      }\n    });\n\n    Object.defineProperty(XMLElement.prototype, 'id', {\n      get: function() {\n        throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n      }\n    });\n\n    Object.defineProperty(XMLElement.prototype, 'className', {\n      get: function() {\n        throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n      }\n    });\n\n    Object.defineProperty(XMLElement.prototype, 'classList', {\n      get: function() {\n        throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n      }\n    });\n\n    Object.defineProperty(XMLElement.prototype, 'attributes', {\n      get: function() {\n        if (!this.attributeMap || !this.attributeMap.nodes) {\n          this.attributeMap = new XMLNamedNodeMap(this.attribs);\n        }\n        return this.attributeMap;\n      }\n    });\n\n    XMLElement.prototype.clone = function() {\n      var att, attName, clonedSelf, ref1;\n      clonedSelf = Object.create(this);\n      if (clonedSelf.isRoot) {\n        clonedSelf.documentObject = null;\n      }\n      clonedSelf.attribs = {};\n      ref1 = this.attribs;\n      for (attName in ref1) {\n        if (!hasProp.call(ref1, attName)) continue;\n        att = ref1[attName];\n        clonedSelf.attribs[attName] = att.clone();\n      }\n      clonedSelf.children = [];\n      this.children.forEach(function(child) {\n        var clonedChild;\n        clonedChild = child.clone();\n        clonedChild.parent = clonedSelf;\n        return clonedSelf.children.push(clonedChild);\n      });\n      return clonedSelf;\n    };\n\n    XMLElement.prototype.attribute = function(name, value) {\n      var attName, attValue;\n      if (name != null) {\n        name = getValue(name);\n      }\n      if (isObject(name)) {\n        for (attName in name) {\n          if (!hasProp.call(name, attName)) continue;\n          attValue = name[attName];\n          this.attribute(attName, attValue);\n        }\n      } else {\n        if (isFunction(value)) {\n          value = value.apply();\n        }\n        if (this.options.keepNullAttributes && (value == null)) {\n          this.attribs[name] = new XMLAttribute(this, name, \"\");\n        } else if (value != null) {\n          this.attribs[name] = new XMLAttribute(this, name, value);\n        }\n      }\n      return this;\n    };\n\n    XMLElement.prototype.removeAttribute = function(name) {\n      var attName, j, len;\n      if (name == null) {\n        throw new Error(\"Missing attribute name. \" + this.debugInfo());\n      }\n      name = getValue(name);\n      if (Array.isArray(name)) {\n        for (j = 0, len = name.length; j < len; j++) {\n          attName = name[j];\n          delete this.attribs[attName];\n        }\n      } else {\n        delete this.attribs[name];\n      }\n      return this;\n    };\n\n    XMLElement.prototype.toString = function(options) {\n      return this.options.writer.element(this, this.options.writer.filterOptions(options));\n    };\n\n    XMLElement.prototype.att = function(name, value) {\n      return this.attribute(name, value);\n    };\n\n    XMLElement.prototype.a = function(name, value) {\n      return this.attribute(name, value);\n    };\n\n    XMLElement.prototype.getAttribute = function(name) {\n      if (this.attribs.hasOwnProperty(name)) {\n        return this.attribs[name].value;\n      } else {\n        return null;\n      }\n    };\n\n    XMLElement.prototype.setAttribute = function(name, value) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.getAttributeNode = function(name) {\n      if (this.attribs.hasOwnProperty(name)) {\n        return this.attribs[name];\n      } else {\n        return null;\n      }\n    };\n\n    XMLElement.prototype.setAttributeNode = function(newAttr) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.removeAttributeNode = function(oldAttr) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.getElementsByTagName = function(name) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.getAttributeNS = function(namespaceURI, localName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.setAttributeNS = function(namespaceURI, qualifiedName, value) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.removeAttributeNS = function(namespaceURI, localName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.getAttributeNodeNS = function(namespaceURI, localName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.setAttributeNodeNS = function(newAttr) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.getElementsByTagNameNS = function(namespaceURI, localName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.hasAttribute = function(name) {\n      return this.attribs.hasOwnProperty(name);\n    };\n\n    XMLElement.prototype.hasAttributeNS = function(namespaceURI, localName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.setIdAttribute = function(name, isId) {\n      if (this.attribs.hasOwnProperty(name)) {\n        return this.attribs[name].isId;\n      } else {\n        return isId;\n      }\n    };\n\n    XMLElement.prototype.setIdAttributeNS = function(namespaceURI, localName, isId) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.setIdAttributeNode = function(idAttr, isId) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.getElementsByTagName = function(tagname) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.getElementsByTagNameNS = function(namespaceURI, localName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.getElementsByClassName = function(classNames) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLElement.prototype.isEqualNode = function(node) {\n      var i, j, ref1;\n      if (!XMLElement.__super__.isEqualNode.apply(this, arguments).isEqualNode(node)) {\n        return false;\n      }\n      if (node.namespaceURI !== this.namespaceURI) {\n        return false;\n      }\n      if (node.prefix !== this.prefix) {\n        return false;\n      }\n      if (node.localName !== this.localName) {\n        return false;\n      }\n      if (node.attribs.length !== this.attribs.length) {\n        return false;\n      }\n      for (i = j = 0, ref1 = this.attribs.length - 1; 0 <= ref1 ? j <= ref1 : j >= ref1; i = 0 <= ref1 ? ++j : --j) {\n        if (!this.attribs[i].isEqualNode(node.attribs[i])) {\n          return false;\n        }\n      }\n      return true;\n    };\n\n    return XMLElement;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var XMLCharacterData, XMLNode,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  XMLNode = require('./XMLNode');\n\n  module.exports = XMLCharacterData = (function(superClass) {\n    extend(XMLCharacterData, superClass);\n\n    function XMLCharacterData(parent) {\n      XMLCharacterData.__super__.constructor.call(this, parent);\n      this.value = '';\n    }\n\n    Object.defineProperty(XMLCharacterData.prototype, 'data', {\n      get: function() {\n        return this.value;\n      },\n      set: function(value) {\n        return this.value = value || '';\n      }\n    });\n\n    Object.defineProperty(XMLCharacterData.prototype, 'length', {\n      get: function() {\n        return this.value.length;\n      }\n    });\n\n    Object.defineProperty(XMLCharacterData.prototype, 'textContent', {\n      get: function() {\n        return this.value;\n      },\n      set: function(value) {\n        return this.value = value || '';\n      }\n    });\n\n    XMLCharacterData.prototype.clone = function() {\n      return Object.create(this);\n    };\n\n    XMLCharacterData.prototype.substringData = function(offset, count) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLCharacterData.prototype.appendData = function(arg) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLCharacterData.prototype.insertData = function(offset, arg) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLCharacterData.prototype.deleteData = function(offset, count) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLCharacterData.prototype.replaceData = function(offset, count, arg) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLCharacterData.prototype.isEqualNode = function(node) {\n      if (!XMLCharacterData.__super__.isEqualNode.apply(this, arguments).isEqualNode(node)) {\n        return false;\n      }\n      if (node.data !== this.data) {\n        return false;\n      }\n      return true;\n    };\n\n    return XMLCharacterData;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLCData, XMLCharacterData,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  NodeType = require('./NodeType');\n\n  XMLCharacterData = require('./XMLCharacterData');\n\n  module.exports = XMLCData = (function(superClass) {\n    extend(XMLCData, superClass);\n\n    function XMLCData(parent, text) {\n      XMLCData.__super__.constructor.call(this, parent);\n      if (text == null) {\n        throw new Error(\"Missing CDATA text. \" + this.debugInfo());\n      }\n      this.name = \"#cdata-section\";\n      this.type = NodeType.CData;\n      this.value = this.stringify.cdata(text);\n    }\n\n    XMLCData.prototype.clone = function() {\n      return Object.create(this);\n    };\n\n    XMLCData.prototype.toString = function(options) {\n      return this.options.writer.cdata(this, this.options.writer.filterOptions(options));\n    };\n\n    return XMLCData;\n\n  })(XMLCharacterData);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLCharacterData, XMLComment,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  NodeType = require('./NodeType');\n\n  XMLCharacterData = require('./XMLCharacterData');\n\n  module.exports = XMLComment = (function(superClass) {\n    extend(XMLComment, superClass);\n\n    function XMLComment(parent, text) {\n      XMLComment.__super__.constructor.call(this, parent);\n      if (text == null) {\n        throw new Error(\"Missing comment text. \" + this.debugInfo());\n      }\n      this.name = \"#comment\";\n      this.type = NodeType.Comment;\n      this.value = this.stringify.comment(text);\n    }\n\n    XMLComment.prototype.clone = function() {\n      return Object.create(this);\n    };\n\n    XMLComment.prototype.toString = function(options) {\n      return this.options.writer.comment(this, this.options.writer.filterOptions(options));\n    };\n\n    return XMLComment;\n\n  })(XMLCharacterData);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLDeclaration, XMLNode, isObject,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  isObject = require('./Utility').isObject;\n\n  XMLNode = require('./XMLNode');\n\n  NodeType = require('./NodeType');\n\n  module.exports = XMLDeclaration = (function(superClass) {\n    extend(XMLDeclaration, superClass);\n\n    function XMLDeclaration(parent, version, encoding, standalone) {\n      var ref;\n      XMLDeclaration.__super__.constructor.call(this, parent);\n      if (isObject(version)) {\n        ref = version, version = ref.version, encoding = ref.encoding, standalone = ref.standalone;\n      }\n      if (!version) {\n        version = '1.0';\n      }\n      this.type = NodeType.Declaration;\n      this.version = this.stringify.xmlVersion(version);\n      if (encoding != null) {\n        this.encoding = this.stringify.xmlEncoding(encoding);\n      }\n      if (standalone != null) {\n        this.standalone = this.stringify.xmlStandalone(standalone);\n      }\n    }\n\n    XMLDeclaration.prototype.toString = function(options) {\n      return this.options.writer.declaration(this, this.options.writer.filterOptions(options));\n    };\n\n    return XMLDeclaration;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLDTDAttList, XMLNode,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  XMLNode = require('./XMLNode');\n\n  NodeType = require('./NodeType');\n\n  module.exports = XMLDTDAttList = (function(superClass) {\n    extend(XMLDTDAttList, superClass);\n\n    function XMLDTDAttList(parent, elementName, attributeName, attributeType, defaultValueType, defaultValue) {\n      XMLDTDAttList.__super__.constructor.call(this, parent);\n      if (elementName == null) {\n        throw new Error(\"Missing DTD element name. \" + this.debugInfo());\n      }\n      if (attributeName == null) {\n        throw new Error(\"Missing DTD attribute name. \" + this.debugInfo(elementName));\n      }\n      if (!attributeType) {\n        throw new Error(\"Missing DTD attribute type. \" + this.debugInfo(elementName));\n      }\n      if (!defaultValueType) {\n        throw new Error(\"Missing DTD attribute default. \" + this.debugInfo(elementName));\n      }\n      if (defaultValueType.indexOf('#') !== 0) {\n        defaultValueType = '#' + defaultValueType;\n      }\n      if (!defaultValueType.match(/^(#REQUIRED|#IMPLIED|#FIXED|#DEFAULT)$/)) {\n        throw new Error(\"Invalid default value type; expected: #REQUIRED, #IMPLIED, #FIXED or #DEFAULT. \" + this.debugInfo(elementName));\n      }\n      if (defaultValue && !defaultValueType.match(/^(#FIXED|#DEFAULT)$/)) {\n        throw new Error(\"Default value only applies to #FIXED or #DEFAULT. \" + this.debugInfo(elementName));\n      }\n      this.elementName = this.stringify.name(elementName);\n      this.type = NodeType.AttributeDeclaration;\n      this.attributeName = this.stringify.name(attributeName);\n      this.attributeType = this.stringify.dtdAttType(attributeType);\n      if (defaultValue) {\n        this.defaultValue = this.stringify.dtdAttDefault(defaultValue);\n      }\n      this.defaultValueType = defaultValueType;\n    }\n\n    XMLDTDAttList.prototype.toString = function(options) {\n      return this.options.writer.dtdAttList(this, this.options.writer.filterOptions(options));\n    };\n\n    return XMLDTDAttList;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLDTDEntity, XMLNode, isObject,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  isObject = require('./Utility').isObject;\n\n  XMLNode = require('./XMLNode');\n\n  NodeType = require('./NodeType');\n\n  module.exports = XMLDTDEntity = (function(superClass) {\n    extend(XMLDTDEntity, superClass);\n\n    function XMLDTDEntity(parent, pe, name, value) {\n      XMLDTDEntity.__super__.constructor.call(this, parent);\n      if (name == null) {\n        throw new Error(\"Missing DTD entity name. \" + this.debugInfo(name));\n      }\n      if (value == null) {\n        throw new Error(\"Missing DTD entity value. \" + this.debugInfo(name));\n      }\n      this.pe = !!pe;\n      this.name = this.stringify.name(name);\n      this.type = NodeType.EntityDeclaration;\n      if (!isObject(value)) {\n        this.value = this.stringify.dtdEntityValue(value);\n        this.internal = true;\n      } else {\n        if (!value.pubID && !value.sysID) {\n          throw new Error(\"Public and/or system identifiers are required for an external entity. \" + this.debugInfo(name));\n        }\n        if (value.pubID && !value.sysID) {\n          throw new Error(\"System identifier is required for a public external entity. \" + this.debugInfo(name));\n        }\n        this.internal = false;\n        if (value.pubID != null) {\n          this.pubID = this.stringify.dtdPubID(value.pubID);\n        }\n        if (value.sysID != null) {\n          this.sysID = this.stringify.dtdSysID(value.sysID);\n        }\n        if (value.nData != null) {\n          this.nData = this.stringify.dtdNData(value.nData);\n        }\n        if (this.pe && this.nData) {\n          throw new Error(\"Notation declaration is not allowed in a parameter entity. \" + this.debugInfo(name));\n        }\n      }\n    }\n\n    Object.defineProperty(XMLDTDEntity.prototype, 'publicId', {\n      get: function() {\n        return this.pubID;\n      }\n    });\n\n    Object.defineProperty(XMLDTDEntity.prototype, 'systemId', {\n      get: function() {\n        return this.sysID;\n      }\n    });\n\n    Object.defineProperty(XMLDTDEntity.prototype, 'notationName', {\n      get: function() {\n        return this.nData || null;\n      }\n    });\n\n    Object.defineProperty(XMLDTDEntity.prototype, 'inputEncoding', {\n      get: function() {\n        return null;\n      }\n    });\n\n    Object.defineProperty(XMLDTDEntity.prototype, 'xmlEncoding', {\n      get: function() {\n        return null;\n      }\n    });\n\n    Object.defineProperty(XMLDTDEntity.prototype, 'xmlVersion', {\n      get: function() {\n        return null;\n      }\n    });\n\n    XMLDTDEntity.prototype.toString = function(options) {\n      return this.options.writer.dtdEntity(this, this.options.writer.filterOptions(options));\n    };\n\n    return XMLDTDEntity;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLDTDElement, XMLNode,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  XMLNode = require('./XMLNode');\n\n  NodeType = require('./NodeType');\n\n  module.exports = XMLDTDElement = (function(superClass) {\n    extend(XMLDTDElement, superClass);\n\n    function XMLDTDElement(parent, name, value) {\n      XMLDTDElement.__super__.constructor.call(this, parent);\n      if (name == null) {\n        throw new Error(\"Missing DTD element name. \" + this.debugInfo());\n      }\n      if (!value) {\n        value = '(#PCDATA)';\n      }\n      if (Array.isArray(value)) {\n        value = '(' + value.join(',') + ')';\n      }\n      this.name = this.stringify.name(name);\n      this.type = NodeType.ElementDeclaration;\n      this.value = this.stringify.dtdElementValue(value);\n    }\n\n    XMLDTDElement.prototype.toString = function(options) {\n      return this.options.writer.dtdElement(this, this.options.writer.filterOptions(options));\n    };\n\n    return XMLDTDElement;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLDTDNotation, XMLNode,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  XMLNode = require('./XMLNode');\n\n  NodeType = require('./NodeType');\n\n  module.exports = XMLDTDNotation = (function(superClass) {\n    extend(XMLDTDNotation, superClass);\n\n    function XMLDTDNotation(parent, name, value) {\n      XMLDTDNotation.__super__.constructor.call(this, parent);\n      if (name == null) {\n        throw new Error(\"Missing DTD notation name. \" + this.debugInfo(name));\n      }\n      if (!value.pubID && !value.sysID) {\n        throw new Error(\"Public or system identifiers are required for an external entity. \" + this.debugInfo(name));\n      }\n      this.name = this.stringify.name(name);\n      this.type = NodeType.NotationDeclaration;\n      if (value.pubID != null) {\n        this.pubID = this.stringify.dtdPubID(value.pubID);\n      }\n      if (value.sysID != null) {\n        this.sysID = this.stringify.dtdSysID(value.sysID);\n      }\n    }\n\n    Object.defineProperty(XMLDTDNotation.prototype, 'publicId', {\n      get: function() {\n        return this.pubID;\n      }\n    });\n\n    Object.defineProperty(XMLDTDNotation.prototype, 'systemId', {\n      get: function() {\n        return this.sysID;\n      }\n    });\n\n    XMLDTDNotation.prototype.toString = function(options) {\n      return this.options.writer.dtdNotation(this, this.options.writer.filterOptions(options));\n    };\n\n    return XMLDTDNotation;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLDTDAttList, XMLDTDElement, XMLDTDEntity, XMLDTDNotation, XMLDocType, XMLNamedNodeMap, XMLNode, isObject,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  isObject = require('./Utility').isObject;\n\n  XMLNode = require('./XMLNode');\n\n  NodeType = require('./NodeType');\n\n  XMLDTDAttList = require('./XMLDTDAttList');\n\n  XMLDTDEntity = require('./XMLDTDEntity');\n\n  XMLDTDElement = require('./XMLDTDElement');\n\n  XMLDTDNotation = require('./XMLDTDNotation');\n\n  XMLNamedNodeMap = require('./XMLNamedNodeMap');\n\n  module.exports = XMLDocType = (function(superClass) {\n    extend(XMLDocType, superClass);\n\n    function XMLDocType(parent, pubID, sysID) {\n      var child, i, len, ref, ref1, ref2;\n      XMLDocType.__super__.constructor.call(this, parent);\n      this.type = NodeType.DocType;\n      if (parent.children) {\n        ref = parent.children;\n        for (i = 0, len = ref.length; i < len; i++) {\n          child = ref[i];\n          if (child.type === NodeType.Element) {\n            this.name = child.name;\n            break;\n          }\n        }\n      }\n      this.documentObject = parent;\n      if (isObject(pubID)) {\n        ref1 = pubID, pubID = ref1.pubID, sysID = ref1.sysID;\n      }\n      if (sysID == null) {\n        ref2 = [pubID, sysID], sysID = ref2[0], pubID = ref2[1];\n      }\n      if (pubID != null) {\n        this.pubID = this.stringify.dtdPubID(pubID);\n      }\n      if (sysID != null) {\n        this.sysID = this.stringify.dtdSysID(sysID);\n      }\n    }\n\n    Object.defineProperty(XMLDocType.prototype, 'entities', {\n      get: function() {\n        var child, i, len, nodes, ref;\n        nodes = {};\n        ref = this.children;\n        for (i = 0, len = ref.length; i < len; i++) {\n          child = ref[i];\n          if ((child.type === NodeType.EntityDeclaration) && !child.pe) {\n            nodes[child.name] = child;\n          }\n        }\n        return new XMLNamedNodeMap(nodes);\n      }\n    });\n\n    Object.defineProperty(XMLDocType.prototype, 'notations', {\n      get: function() {\n        var child, i, len, nodes, ref;\n        nodes = {};\n        ref = this.children;\n        for (i = 0, len = ref.length; i < len; i++) {\n          child = ref[i];\n          if (child.type === NodeType.NotationDeclaration) {\n            nodes[child.name] = child;\n          }\n        }\n        return new XMLNamedNodeMap(nodes);\n      }\n    });\n\n    Object.defineProperty(XMLDocType.prototype, 'publicId', {\n      get: function() {\n        return this.pubID;\n      }\n    });\n\n    Object.defineProperty(XMLDocType.prototype, 'systemId', {\n      get: function() {\n        return this.sysID;\n      }\n    });\n\n    Object.defineProperty(XMLDocType.prototype, 'internalSubset', {\n      get: function() {\n        throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n      }\n    });\n\n    XMLDocType.prototype.element = function(name, value) {\n      var child;\n      child = new XMLDTDElement(this, name, value);\n      this.children.push(child);\n      return this;\n    };\n\n    XMLDocType.prototype.attList = function(elementName, attributeName, attributeType, defaultValueType, defaultValue) {\n      var child;\n      child = new XMLDTDAttList(this, elementName, attributeName, attributeType, defaultValueType, defaultValue);\n      this.children.push(child);\n      return this;\n    };\n\n    XMLDocType.prototype.entity = function(name, value) {\n      var child;\n      child = new XMLDTDEntity(this, false, name, value);\n      this.children.push(child);\n      return this;\n    };\n\n    XMLDocType.prototype.pEntity = function(name, value) {\n      var child;\n      child = new XMLDTDEntity(this, true, name, value);\n      this.children.push(child);\n      return this;\n    };\n\n    XMLDocType.prototype.notation = function(name, value) {\n      var child;\n      child = new XMLDTDNotation(this, name, value);\n      this.children.push(child);\n      return this;\n    };\n\n    XMLDocType.prototype.toString = function(options) {\n      return this.options.writer.docType(this, this.options.writer.filterOptions(options));\n    };\n\n    XMLDocType.prototype.ele = function(name, value) {\n      return this.element(name, value);\n    };\n\n    XMLDocType.prototype.att = function(elementName, attributeName, attributeType, defaultValueType, defaultValue) {\n      return this.attList(elementName, attributeName, attributeType, defaultValueType, defaultValue);\n    };\n\n    XMLDocType.prototype.ent = function(name, value) {\n      return this.entity(name, value);\n    };\n\n    XMLDocType.prototype.pent = function(name, value) {\n      return this.pEntity(name, value);\n    };\n\n    XMLDocType.prototype.not = function(name, value) {\n      return this.notation(name, value);\n    };\n\n    XMLDocType.prototype.up = function() {\n      return this.root() || this.documentObject;\n    };\n\n    XMLDocType.prototype.isEqualNode = function(node) {\n      if (!XMLDocType.__super__.isEqualNode.apply(this, arguments).isEqualNode(node)) {\n        return false;\n      }\n      if (node.name !== this.name) {\n        return false;\n      }\n      if (node.publicId !== this.publicId) {\n        return false;\n      }\n      if (node.systemId !== this.systemId) {\n        return false;\n      }\n      return true;\n    };\n\n    return XMLDocType;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLNode, XMLRaw,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  NodeType = require('./NodeType');\n\n  XMLNode = require('./XMLNode');\n\n  module.exports = XMLRaw = (function(superClass) {\n    extend(XMLRaw, superClass);\n\n    function XMLRaw(parent, text) {\n      XMLRaw.__super__.constructor.call(this, parent);\n      if (text == null) {\n        throw new Error(\"Missing raw text. \" + this.debugInfo());\n      }\n      this.type = NodeType.Raw;\n      this.value = this.stringify.raw(text);\n    }\n\n    XMLRaw.prototype.clone = function() {\n      return Object.create(this);\n    };\n\n    XMLRaw.prototype.toString = function(options) {\n      return this.options.writer.raw(this, this.options.writer.filterOptions(options));\n    };\n\n    return XMLRaw;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLCharacterData, XMLText,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  NodeType = require('./NodeType');\n\n  XMLCharacterData = require('./XMLCharacterData');\n\n  module.exports = XMLText = (function(superClass) {\n    extend(XMLText, superClass);\n\n    function XMLText(parent, text) {\n      XMLText.__super__.constructor.call(this, parent);\n      if (text == null) {\n        throw new Error(\"Missing element text. \" + this.debugInfo());\n      }\n      this.name = \"#text\";\n      this.type = NodeType.Text;\n      this.value = this.stringify.text(text);\n    }\n\n    Object.defineProperty(XMLText.prototype, 'isElementContentWhitespace', {\n      get: function() {\n        throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n      }\n    });\n\n    Object.defineProperty(XMLText.prototype, 'wholeText', {\n      get: function() {\n        var next, prev, str;\n        str = '';\n        prev = this.previousSibling;\n        while (prev) {\n          str = prev.data + str;\n          prev = prev.previousSibling;\n        }\n        str += this.data;\n        next = this.nextSibling;\n        while (next) {\n          str = str + next.data;\n          next = next.nextSibling;\n        }\n        return str;\n      }\n    });\n\n    XMLText.prototype.clone = function() {\n      return Object.create(this);\n    };\n\n    XMLText.prototype.toString = function(options) {\n      return this.options.writer.text(this, this.options.writer.filterOptions(options));\n    };\n\n    XMLText.prototype.splitText = function(offset) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLText.prototype.replaceWholeText = function(content) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    return XMLText;\n\n  })(XMLCharacterData);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLCharacterData, XMLProcessingInstruction,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  NodeType = require('./NodeType');\n\n  XMLCharacterData = require('./XMLCharacterData');\n\n  module.exports = XMLProcessingInstruction = (function(superClass) {\n    extend(XMLProcessingInstruction, superClass);\n\n    function XMLProcessingInstruction(parent, target, value) {\n      XMLProcessingInstruction.__super__.constructor.call(this, parent);\n      if (target == null) {\n        throw new Error(\"Missing instruction target. \" + this.debugInfo());\n      }\n      this.type = NodeType.ProcessingInstruction;\n      this.target = this.stringify.insTarget(target);\n      this.name = this.target;\n      if (value) {\n        this.value = this.stringify.insValue(value);\n      }\n    }\n\n    XMLProcessingInstruction.prototype.clone = function() {\n      return Object.create(this);\n    };\n\n    XMLProcessingInstruction.prototype.toString = function(options) {\n      return this.options.writer.processingInstruction(this, this.options.writer.filterOptions(options));\n    };\n\n    XMLProcessingInstruction.prototype.isEqualNode = function(node) {\n      if (!XMLProcessingInstruction.__super__.isEqualNode.apply(this, arguments).isEqualNode(node)) {\n        return false;\n      }\n      if (node.target !== this.target) {\n        return false;\n      }\n      return true;\n    };\n\n    return XMLProcessingInstruction;\n\n  })(XMLCharacterData);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLDummy, XMLNode,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  XMLNode = require('./XMLNode');\n\n  NodeType = require('./NodeType');\n\n  module.exports = XMLDummy = (function(superClass) {\n    extend(XMLDummy, superClass);\n\n    function XMLDummy(parent) {\n      XMLDummy.__super__.constructor.call(this, parent);\n      this.type = NodeType.Dummy;\n    }\n\n    XMLDummy.prototype.clone = function() {\n      return Object.create(this);\n    };\n\n    XMLDummy.prototype.toString = function(options) {\n      return '';\n    };\n\n    return XMLDummy;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var XMLNodeList;\n\n  module.exports = XMLNodeList = (function() {\n    function XMLNodeList(nodes) {\n      this.nodes = nodes;\n    }\n\n    Object.defineProperty(XMLNodeList.prototype, 'length', {\n      get: function() {\n        return this.nodes.length || 0;\n      }\n    });\n\n    XMLNodeList.prototype.clone = function() {\n      return this.nodes = null;\n    };\n\n    XMLNodeList.prototype.item = function(index) {\n      return this.nodes[index] || null;\n    };\n\n    return XMLNodeList;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  module.exports = {\n    Disconnected: 1,\n    Preceding: 2,\n    Following: 4,\n    Contains: 8,\n    ContainedBy: 16,\n    ImplementationSpecific: 32\n  };\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var DocumentPosition, NodeType, XMLCData, XMLComment, XMLDeclaration, XMLDocType, XMLDummy, XMLElement, XMLNamedNodeMap, XMLNode, XMLNodeList, XMLProcessingInstruction, XMLRaw, XMLText, getValue, isEmpty, isFunction, isObject, ref1,\n    hasProp = {}.hasOwnProperty;\n\n  ref1 = require('./Utility'), isObject = ref1.isObject, isFunction = ref1.isFunction, isEmpty = ref1.isEmpty, getValue = ref1.getValue;\n\n  XMLElement = null;\n\n  XMLCData = null;\n\n  XMLComment = null;\n\n  XMLDeclaration = null;\n\n  XMLDocType = null;\n\n  XMLRaw = null;\n\n  XMLText = null;\n\n  XMLProcessingInstruction = null;\n\n  XMLDummy = null;\n\n  NodeType = null;\n\n  XMLNodeList = null;\n\n  XMLNamedNodeMap = null;\n\n  DocumentPosition = null;\n\n  module.exports = XMLNode = (function() {\n    function XMLNode(parent1) {\n      this.parent = parent1;\n      if (this.parent) {\n        this.options = this.parent.options;\n        this.stringify = this.parent.stringify;\n      }\n      this.value = null;\n      this.children = [];\n      this.baseURI = null;\n      if (!XMLElement) {\n        XMLElement = require('./XMLElement');\n        XMLCData = require('./XMLCData');\n        XMLComment = require('./XMLComment');\n        XMLDeclaration = require('./XMLDeclaration');\n        XMLDocType = require('./XMLDocType');\n        XMLRaw = require('./XMLRaw');\n        XMLText = require('./XMLText');\n        XMLProcessingInstruction = require('./XMLProcessingInstruction');\n        XMLDummy = require('./XMLDummy');\n        NodeType = require('./NodeType');\n        XMLNodeList = require('./XMLNodeList');\n        XMLNamedNodeMap = require('./XMLNamedNodeMap');\n        DocumentPosition = require('./DocumentPosition');\n      }\n    }\n\n    Object.defineProperty(XMLNode.prototype, 'nodeName', {\n      get: function() {\n        return this.name;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'nodeType', {\n      get: function() {\n        return this.type;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'nodeValue', {\n      get: function() {\n        return this.value;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'parentNode', {\n      get: function() {\n        return this.parent;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'childNodes', {\n      get: function() {\n        if (!this.childNodeList || !this.childNodeList.nodes) {\n          this.childNodeList = new XMLNodeList(this.children);\n        }\n        return this.childNodeList;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'firstChild', {\n      get: function() {\n        return this.children[0] || null;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'lastChild', {\n      get: function() {\n        return this.children[this.children.length - 1] || null;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'previousSibling', {\n      get: function() {\n        var i;\n        i = this.parent.children.indexOf(this);\n        return this.parent.children[i - 1] || null;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'nextSibling', {\n      get: function() {\n        var i;\n        i = this.parent.children.indexOf(this);\n        return this.parent.children[i + 1] || null;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'ownerDocument', {\n      get: function() {\n        return this.document() || null;\n      }\n    });\n\n    Object.defineProperty(XMLNode.prototype, 'textContent', {\n      get: function() {\n        var child, j, len, ref2, str;\n        if (this.nodeType === NodeType.Element || this.nodeType === NodeType.DocumentFragment) {\n          str = '';\n          ref2 = this.children;\n          for (j = 0, len = ref2.length; j < len; j++) {\n            child = ref2[j];\n            if (child.textContent) {\n              str += child.textContent;\n            }\n          }\n          return str;\n        } else {\n          return null;\n        }\n      },\n      set: function(value) {\n        throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n      }\n    });\n\n    XMLNode.prototype.setParent = function(parent) {\n      var child, j, len, ref2, results;\n      this.parent = parent;\n      if (parent) {\n        this.options = parent.options;\n        this.stringify = parent.stringify;\n      }\n      ref2 = this.children;\n      results = [];\n      for (j = 0, len = ref2.length; j < len; j++) {\n        child = ref2[j];\n        results.push(child.setParent(this));\n      }\n      return results;\n    };\n\n    XMLNode.prototype.element = function(name, attributes, text) {\n      var childNode, item, j, k, key, lastChild, len, len1, ref2, ref3, val;\n      lastChild = null;\n      if (attributes === null && (text == null)) {\n        ref2 = [{}, null], attributes = ref2[0], text = ref2[1];\n      }\n      if (attributes == null) {\n        attributes = {};\n      }\n      attributes = getValue(attributes);\n      if (!isObject(attributes)) {\n        ref3 = [attributes, text], text = ref3[0], attributes = ref3[1];\n      }\n      if (name != null) {\n        name = getValue(name);\n      }\n      if (Array.isArray(name)) {\n        for (j = 0, len = name.length; j < len; j++) {\n          item = name[j];\n          lastChild = this.element(item);\n        }\n      } else if (isFunction(name)) {\n        lastChild = this.element(name.apply());\n      } else if (isObject(name)) {\n        for (key in name) {\n          if (!hasProp.call(name, key)) continue;\n          val = name[key];\n          if (isFunction(val)) {\n            val = val.apply();\n          }\n          if (!this.options.ignoreDecorators && this.stringify.convertAttKey && key.indexOf(this.stringify.convertAttKey) === 0) {\n            lastChild = this.attribute(key.substr(this.stringify.convertAttKey.length), val);\n          } else if (!this.options.separateArrayItems && Array.isArray(val) && isEmpty(val)) {\n            lastChild = this.dummy();\n          } else if (isObject(val) && isEmpty(val)) {\n            lastChild = this.element(key);\n          } else if (!this.options.keepNullNodes && (val == null)) {\n            lastChild = this.dummy();\n          } else if (!this.options.separateArrayItems && Array.isArray(val)) {\n            for (k = 0, len1 = val.length; k < len1; k++) {\n              item = val[k];\n              childNode = {};\n              childNode[key] = item;\n              lastChild = this.element(childNode);\n            }\n          } else if (isObject(val)) {\n            if (!this.options.ignoreDecorators && this.stringify.convertTextKey && key.indexOf(this.stringify.convertTextKey) === 0) {\n              lastChild = this.element(val);\n            } else {\n              lastChild = this.element(key);\n              lastChild.element(val);\n            }\n          } else {\n            lastChild = this.element(key, val);\n          }\n        }\n      } else if (!this.options.keepNullNodes && text === null) {\n        lastChild = this.dummy();\n      } else {\n        if (!this.options.ignoreDecorators && this.stringify.convertTextKey && name.indexOf(this.stringify.convertTextKey) === 0) {\n          lastChild = this.text(text);\n        } else if (!this.options.ignoreDecorators && this.stringify.convertCDataKey && name.indexOf(this.stringify.convertCDataKey) === 0) {\n          lastChild = this.cdata(text);\n        } else if (!this.options.ignoreDecorators && this.stringify.convertCommentKey && name.indexOf(this.stringify.convertCommentKey) === 0) {\n          lastChild = this.comment(text);\n        } else if (!this.options.ignoreDecorators && this.stringify.convertRawKey && name.indexOf(this.stringify.convertRawKey) === 0) {\n          lastChild = this.raw(text);\n        } else if (!this.options.ignoreDecorators && this.stringify.convertPIKey && name.indexOf(this.stringify.convertPIKey) === 0) {\n          lastChild = this.instruction(name.substr(this.stringify.convertPIKey.length), text);\n        } else {\n          lastChild = this.node(name, attributes, text);\n        }\n      }\n      if (lastChild == null) {\n        throw new Error(\"Could not create any elements with: \" + name + \". \" + this.debugInfo());\n      }\n      return lastChild;\n    };\n\n    XMLNode.prototype.insertBefore = function(name, attributes, text) {\n      var child, i, newChild, refChild, removed;\n      if (name != null ? name.type : void 0) {\n        newChild = name;\n        refChild = attributes;\n        newChild.setParent(this);\n        if (refChild) {\n          i = children.indexOf(refChild);\n          removed = children.splice(i);\n          children.push(newChild);\n          Array.prototype.push.apply(children, removed);\n        } else {\n          children.push(newChild);\n        }\n        return newChild;\n      } else {\n        if (this.isRoot) {\n          throw new Error(\"Cannot insert elements at root level. \" + this.debugInfo(name));\n        }\n        i = this.parent.children.indexOf(this);\n        removed = this.parent.children.splice(i);\n        child = this.parent.element(name, attributes, text);\n        Array.prototype.push.apply(this.parent.children, removed);\n        return child;\n      }\n    };\n\n    XMLNode.prototype.insertAfter = function(name, attributes, text) {\n      var child, i, removed;\n      if (this.isRoot) {\n        throw new Error(\"Cannot insert elements at root level. \" + this.debugInfo(name));\n      }\n      i = this.parent.children.indexOf(this);\n      removed = this.parent.children.splice(i + 1);\n      child = this.parent.element(name, attributes, text);\n      Array.prototype.push.apply(this.parent.children, removed);\n      return child;\n    };\n\n    XMLNode.prototype.remove = function() {\n      var i, ref2;\n      if (this.isRoot) {\n        throw new Error(\"Cannot remove the root element. \" + this.debugInfo());\n      }\n      i = this.parent.children.indexOf(this);\n      [].splice.apply(this.parent.children, [i, i - i + 1].concat(ref2 = [])), ref2;\n      return this.parent;\n    };\n\n    XMLNode.prototype.node = function(name, attributes, text) {\n      var child, ref2;\n      if (name != null) {\n        name = getValue(name);\n      }\n      attributes || (attributes = {});\n      attributes = getValue(attributes);\n      if (!isObject(attributes)) {\n        ref2 = [attributes, text], text = ref2[0], attributes = ref2[1];\n      }\n      child = new XMLElement(this, name, attributes);\n      if (text != null) {\n        child.text(text);\n      }\n      this.children.push(child);\n      return child;\n    };\n\n    XMLNode.prototype.text = function(value) {\n      var child;\n      if (isObject(value)) {\n        this.element(value);\n      }\n      child = new XMLText(this, value);\n      this.children.push(child);\n      return this;\n    };\n\n    XMLNode.prototype.cdata = function(value) {\n      var child;\n      child = new XMLCData(this, value);\n      this.children.push(child);\n      return this;\n    };\n\n    XMLNode.prototype.comment = function(value) {\n      var child;\n      child = new XMLComment(this, value);\n      this.children.push(child);\n      return this;\n    };\n\n    XMLNode.prototype.commentBefore = function(value) {\n      var child, i, removed;\n      i = this.parent.children.indexOf(this);\n      removed = this.parent.children.splice(i);\n      child = this.parent.comment(value);\n      Array.prototype.push.apply(this.parent.children, removed);\n      return this;\n    };\n\n    XMLNode.prototype.commentAfter = function(value) {\n      var child, i, removed;\n      i = this.parent.children.indexOf(this);\n      removed = this.parent.children.splice(i + 1);\n      child = this.parent.comment(value);\n      Array.prototype.push.apply(this.parent.children, removed);\n      return this;\n    };\n\n    XMLNode.prototype.raw = function(value) {\n      var child;\n      child = new XMLRaw(this, value);\n      this.children.push(child);\n      return this;\n    };\n\n    XMLNode.prototype.dummy = function() {\n      var child;\n      child = new XMLDummy(this);\n      return child;\n    };\n\n    XMLNode.prototype.instruction = function(target, value) {\n      var insTarget, insValue, instruction, j, len;\n      if (target != null) {\n        target = getValue(target);\n      }\n      if (value != null) {\n        value = getValue(value);\n      }\n      if (Array.isArray(target)) {\n        for (j = 0, len = target.length; j < len; j++) {\n          insTarget = target[j];\n          this.instruction(insTarget);\n        }\n      } else if (isObject(target)) {\n        for (insTarget in target) {\n          if (!hasProp.call(target, insTarget)) continue;\n          insValue = target[insTarget];\n          this.instruction(insTarget, insValue);\n        }\n      } else {\n        if (isFunction(value)) {\n          value = value.apply();\n        }\n        instruction = new XMLProcessingInstruction(this, target, value);\n        this.children.push(instruction);\n      }\n      return this;\n    };\n\n    XMLNode.prototype.instructionBefore = function(target, value) {\n      var child, i, removed;\n      i = this.parent.children.indexOf(this);\n      removed = this.parent.children.splice(i);\n      child = this.parent.instruction(target, value);\n      Array.prototype.push.apply(this.parent.children, removed);\n      return this;\n    };\n\n    XMLNode.prototype.instructionAfter = function(target, value) {\n      var child, i, removed;\n      i = this.parent.children.indexOf(this);\n      removed = this.parent.children.splice(i + 1);\n      child = this.parent.instruction(target, value);\n      Array.prototype.push.apply(this.parent.children, removed);\n      return this;\n    };\n\n    XMLNode.prototype.declaration = function(version, encoding, standalone) {\n      var doc, xmldec;\n      doc = this.document();\n      xmldec = new XMLDeclaration(doc, version, encoding, standalone);\n      if (doc.children.length === 0) {\n        doc.children.unshift(xmldec);\n      } else if (doc.children[0].type === NodeType.Declaration) {\n        doc.children[0] = xmldec;\n      } else {\n        doc.children.unshift(xmldec);\n      }\n      return doc.root() || doc;\n    };\n\n    XMLNode.prototype.dtd = function(pubID, sysID) {\n      var child, doc, doctype, i, j, k, len, len1, ref2, ref3;\n      doc = this.document();\n      doctype = new XMLDocType(doc, pubID, sysID);\n      ref2 = doc.children;\n      for (i = j = 0, len = ref2.length; j < len; i = ++j) {\n        child = ref2[i];\n        if (child.type === NodeType.DocType) {\n          doc.children[i] = doctype;\n          return doctype;\n        }\n      }\n      ref3 = doc.children;\n      for (i = k = 0, len1 = ref3.length; k < len1; i = ++k) {\n        child = ref3[i];\n        if (child.isRoot) {\n          doc.children.splice(i, 0, doctype);\n          return doctype;\n        }\n      }\n      doc.children.push(doctype);\n      return doctype;\n    };\n\n    XMLNode.prototype.up = function() {\n      if (this.isRoot) {\n        throw new Error(\"The root node has no parent. Use doc() if you need to get the document object.\");\n      }\n      return this.parent;\n    };\n\n    XMLNode.prototype.root = function() {\n      var node;\n      node = this;\n      while (node) {\n        if (node.type === NodeType.Document) {\n          return node.rootObject;\n        } else if (node.isRoot) {\n          return node;\n        } else {\n          node = node.parent;\n        }\n      }\n    };\n\n    XMLNode.prototype.document = function() {\n      var node;\n      node = this;\n      while (node) {\n        if (node.type === NodeType.Document) {\n          return node;\n        } else {\n          node = node.parent;\n        }\n      }\n    };\n\n    XMLNode.prototype.end = function(options) {\n      return this.document().end(options);\n    };\n\n    XMLNode.prototype.prev = function() {\n      var i;\n      i = this.parent.children.indexOf(this);\n      if (i < 1) {\n        throw new Error(\"Already at the first node. \" + this.debugInfo());\n      }\n      return this.parent.children[i - 1];\n    };\n\n    XMLNode.prototype.next = function() {\n      var i;\n      i = this.parent.children.indexOf(this);\n      if (i === -1 || i === this.parent.children.length - 1) {\n        throw new Error(\"Already at the last node. \" + this.debugInfo());\n      }\n      return this.parent.children[i + 1];\n    };\n\n    XMLNode.prototype.importDocument = function(doc) {\n      var clonedRoot;\n      clonedRoot = doc.root().clone();\n      clonedRoot.parent = this;\n      clonedRoot.isRoot = false;\n      this.children.push(clonedRoot);\n      return this;\n    };\n\n    XMLNode.prototype.debugInfo = function(name) {\n      var ref2, ref3;\n      name = name || this.name;\n      if ((name == null) && !((ref2 = this.parent) != null ? ref2.name : void 0)) {\n        return \"\";\n      } else if (name == null) {\n        return \"parent: <\" + this.parent.name + \">\";\n      } else if (!((ref3 = this.parent) != null ? ref3.name : void 0)) {\n        return \"node: <\" + name + \">\";\n      } else {\n        return \"node: <\" + name + \">, parent: <\" + this.parent.name + \">\";\n      }\n    };\n\n    XMLNode.prototype.ele = function(name, attributes, text) {\n      return this.element(name, attributes, text);\n    };\n\n    XMLNode.prototype.nod = function(name, attributes, text) {\n      return this.node(name, attributes, text);\n    };\n\n    XMLNode.prototype.txt = function(value) {\n      return this.text(value);\n    };\n\n    XMLNode.prototype.dat = function(value) {\n      return this.cdata(value);\n    };\n\n    XMLNode.prototype.com = function(value) {\n      return this.comment(value);\n    };\n\n    XMLNode.prototype.ins = function(target, value) {\n      return this.instruction(target, value);\n    };\n\n    XMLNode.prototype.doc = function() {\n      return this.document();\n    };\n\n    XMLNode.prototype.dec = function(version, encoding, standalone) {\n      return this.declaration(version, encoding, standalone);\n    };\n\n    XMLNode.prototype.e = function(name, attributes, text) {\n      return this.element(name, attributes, text);\n    };\n\n    XMLNode.prototype.n = function(name, attributes, text) {\n      return this.node(name, attributes, text);\n    };\n\n    XMLNode.prototype.t = function(value) {\n      return this.text(value);\n    };\n\n    XMLNode.prototype.d = function(value) {\n      return this.cdata(value);\n    };\n\n    XMLNode.prototype.c = function(value) {\n      return this.comment(value);\n    };\n\n    XMLNode.prototype.r = function(value) {\n      return this.raw(value);\n    };\n\n    XMLNode.prototype.i = function(target, value) {\n      return this.instruction(target, value);\n    };\n\n    XMLNode.prototype.u = function() {\n      return this.up();\n    };\n\n    XMLNode.prototype.importXMLBuilder = function(doc) {\n      return this.importDocument(doc);\n    };\n\n    XMLNode.prototype.replaceChild = function(newChild, oldChild) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.removeChild = function(oldChild) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.appendChild = function(newChild) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.hasChildNodes = function() {\n      return this.children.length !== 0;\n    };\n\n    XMLNode.prototype.cloneNode = function(deep) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.normalize = function() {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.isSupported = function(feature, version) {\n      return true;\n    };\n\n    XMLNode.prototype.hasAttributes = function() {\n      return this.attribs.length !== 0;\n    };\n\n    XMLNode.prototype.compareDocumentPosition = function(other) {\n      var ref, res;\n      ref = this;\n      if (ref === other) {\n        return 0;\n      } else if (this.document() !== other.document()) {\n        res = DocumentPosition.Disconnected | DocumentPosition.ImplementationSpecific;\n        if (Math.random() < 0.5) {\n          res |= DocumentPosition.Preceding;\n        } else {\n          res |= DocumentPosition.Following;\n        }\n        return res;\n      } else if (ref.isAncestor(other)) {\n        return DocumentPosition.Contains | DocumentPosition.Preceding;\n      } else if (ref.isDescendant(other)) {\n        return DocumentPosition.Contains | DocumentPosition.Following;\n      } else if (ref.isPreceding(other)) {\n        return DocumentPosition.Preceding;\n      } else {\n        return DocumentPosition.Following;\n      }\n    };\n\n    XMLNode.prototype.isSameNode = function(other) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.lookupPrefix = function(namespaceURI) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.isDefaultNamespace = function(namespaceURI) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.lookupNamespaceURI = function(prefix) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.isEqualNode = function(node) {\n      var i, j, ref2;\n      if (node.nodeType !== this.nodeType) {\n        return false;\n      }\n      if (node.children.length !== this.children.length) {\n        return false;\n      }\n      for (i = j = 0, ref2 = this.children.length - 1; 0 <= ref2 ? j <= ref2 : j >= ref2; i = 0 <= ref2 ? ++j : --j) {\n        if (!this.children[i].isEqualNode(node.children[i])) {\n          return false;\n        }\n      }\n      return true;\n    };\n\n    XMLNode.prototype.getFeature = function(feature, version) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.setUserData = function(key, data, handler) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.getUserData = function(key) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLNode.prototype.contains = function(other) {\n      if (!other) {\n        return false;\n      }\n      return other === this || this.isDescendant(other);\n    };\n\n    XMLNode.prototype.isDescendant = function(node) {\n      var child, isDescendantChild, j, len, ref2;\n      ref2 = this.children;\n      for (j = 0, len = ref2.length; j < len; j++) {\n        child = ref2[j];\n        if (node === child) {\n          return true;\n        }\n        isDescendantChild = child.isDescendant(node);\n        if (isDescendantChild) {\n          return true;\n        }\n      }\n      return false;\n    };\n\n    XMLNode.prototype.isAncestor = function(node) {\n      return node.isDescendant(this);\n    };\n\n    XMLNode.prototype.isPreceding = function(node) {\n      var nodePos, thisPos;\n      nodePos = this.treePosition(node);\n      thisPos = this.treePosition(this);\n      if (nodePos === -1 || thisPos === -1) {\n        return false;\n      } else {\n        return nodePos < thisPos;\n      }\n    };\n\n    XMLNode.prototype.isFollowing = function(node) {\n      var nodePos, thisPos;\n      nodePos = this.treePosition(node);\n      thisPos = this.treePosition(this);\n      if (nodePos === -1 || thisPos === -1) {\n        return false;\n      } else {\n        return nodePos > thisPos;\n      }\n    };\n\n    XMLNode.prototype.treePosition = function(node) {\n      var found, pos;\n      pos = 0;\n      found = false;\n      this.foreachTreeNode(this.document(), function(childNode) {\n        pos++;\n        if (!found && childNode === node) {\n          return found = true;\n        }\n      });\n      if (found) {\n        return pos;\n      } else {\n        return -1;\n      }\n    };\n\n    XMLNode.prototype.foreachTreeNode = function(node, func) {\n      var child, j, len, ref2, res;\n      node || (node = this.document());\n      ref2 = node.children;\n      for (j = 0, len = ref2.length; j < len; j++) {\n        child = ref2[j];\n        if (res = func(child)) {\n          return res;\n        } else {\n          res = this.foreachTreeNode(child, func);\n          if (res) {\n            return res;\n          }\n        }\n      }\n    };\n\n    return XMLNode;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var XMLStringifier,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    hasProp = {}.hasOwnProperty;\n\n  module.exports = XMLStringifier = (function() {\n    function XMLStringifier(options) {\n      this.assertLegalName = bind(this.assertLegalName, this);\n      this.assertLegalChar = bind(this.assertLegalChar, this);\n      var key, ref, value;\n      options || (options = {});\n      this.options = options;\n      if (!this.options.version) {\n        this.options.version = '1.0';\n      }\n      ref = options.stringify || {};\n      for (key in ref) {\n        if (!hasProp.call(ref, key)) continue;\n        value = ref[key];\n        this[key] = value;\n      }\n    }\n\n    XMLStringifier.prototype.name = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalName('' + val || '');\n    };\n\n    XMLStringifier.prototype.text = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar(this.textEscape('' + val || ''));\n    };\n\n    XMLStringifier.prototype.cdata = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      val = '' + val || '';\n      val = val.replace(']]>', ']]]]><![CDATA[>');\n      return this.assertLegalChar(val);\n    };\n\n    XMLStringifier.prototype.comment = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      val = '' + val || '';\n      if (val.match(/--/)) {\n        throw new Error(\"Comment text cannot contain double-hypen: \" + val);\n      }\n      return this.assertLegalChar(val);\n    };\n\n    XMLStringifier.prototype.raw = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return '' + val || '';\n    };\n\n    XMLStringifier.prototype.attValue = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar(this.attEscape(val = '' + val || ''));\n    };\n\n    XMLStringifier.prototype.insTarget = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar('' + val || '');\n    };\n\n    XMLStringifier.prototype.insValue = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      val = '' + val || '';\n      if (val.match(/\\?>/)) {\n        throw new Error(\"Invalid processing instruction value: \" + val);\n      }\n      return this.assertLegalChar(val);\n    };\n\n    XMLStringifier.prototype.xmlVersion = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      val = '' + val || '';\n      if (!val.match(/1\\.[0-9]+/)) {\n        throw new Error(\"Invalid version number: \" + val);\n      }\n      return val;\n    };\n\n    XMLStringifier.prototype.xmlEncoding = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      val = '' + val || '';\n      if (!val.match(/^[A-Za-z](?:[A-Za-z0-9._-])*$/)) {\n        throw new Error(\"Invalid encoding: \" + val);\n      }\n      return this.assertLegalChar(val);\n    };\n\n    XMLStringifier.prototype.xmlStandalone = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      if (val) {\n        return \"yes\";\n      } else {\n        return \"no\";\n      }\n    };\n\n    XMLStringifier.prototype.dtdPubID = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar('' + val || '');\n    };\n\n    XMLStringifier.prototype.dtdSysID = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar('' + val || '');\n    };\n\n    XMLStringifier.prototype.dtdElementValue = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar('' + val || '');\n    };\n\n    XMLStringifier.prototype.dtdAttType = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar('' + val || '');\n    };\n\n    XMLStringifier.prototype.dtdAttDefault = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar('' + val || '');\n    };\n\n    XMLStringifier.prototype.dtdEntityValue = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar('' + val || '');\n    };\n\n    XMLStringifier.prototype.dtdNData = function(val) {\n      if (this.options.noValidation) {\n        return val;\n      }\n      return this.assertLegalChar('' + val || '');\n    };\n\n    XMLStringifier.prototype.convertAttKey = '@';\n\n    XMLStringifier.prototype.convertPIKey = '?';\n\n    XMLStringifier.prototype.convertTextKey = '#text';\n\n    XMLStringifier.prototype.convertCDataKey = '#cdata';\n\n    XMLStringifier.prototype.convertCommentKey = '#comment';\n\n    XMLStringifier.prototype.convertRawKey = '#raw';\n\n    XMLStringifier.prototype.assertLegalChar = function(str) {\n      var regex, res;\n      if (this.options.noValidation) {\n        return str;\n      }\n      regex = '';\n      if (this.options.version === '1.0') {\n        regex = /[\\0-\\x08\\x0B\\f\\x0E-\\x1F\\uFFFE\\uFFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF]/;\n        if (res = str.match(regex)) {\n          throw new Error(\"Invalid character in string: \" + str + \" at index \" + res.index);\n        }\n      } else if (this.options.version === '1.1') {\n        regex = /[\\0\\uFFFE\\uFFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF]/;\n        if (res = str.match(regex)) {\n          throw new Error(\"Invalid character in string: \" + str + \" at index \" + res.index);\n        }\n      }\n      return str;\n    };\n\n    XMLStringifier.prototype.assertLegalName = function(str) {\n      var regex;\n      if (this.options.noValidation) {\n        return str;\n      }\n      this.assertLegalChar(str);\n      regex = /^([:A-Z_a-z\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD]|[\\uD800-\\uDB7F][\\uDC00-\\uDFFF])([\\x2D\\.0-:A-Z_a-z\\xB7\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u037D\\u037F-\\u1FFF\\u200C\\u200D\\u203F\\u2040\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD]|[\\uD800-\\uDB7F][\\uDC00-\\uDFFF])*$/;\n      if (!str.match(regex)) {\n        throw new Error(\"Invalid character in name\");\n      }\n      return str;\n    };\n\n    XMLStringifier.prototype.textEscape = function(str) {\n      var ampregex;\n      if (this.options.noValidation) {\n        return str;\n      }\n      ampregex = this.options.noDoubleEncoding ? /(?!&\\S+;)&/g : /&/g;\n      return str.replace(ampregex, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/\\r/g, '&#xD;');\n    };\n\n    XMLStringifier.prototype.attEscape = function(str) {\n      var ampregex;\n      if (this.options.noValidation) {\n        return str;\n      }\n      ampregex = this.options.noDoubleEncoding ? /(?!&\\S+;)&/g : /&/g;\n      return str.replace(ampregex, '&amp;').replace(/</g, '&lt;').replace(/\"/g, '&quot;').replace(/\\t/g, '&#x9;').replace(/\\n/g, '&#xA;').replace(/\\r/g, '&#xD;');\n    };\n\n    return XMLStringifier;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  module.exports = {\n    None: 0,\n    OpenTag: 1,\n    InsideTag: 2,\n    CloseTag: 3\n  };\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, WriterState, XMLCData, XMLComment, XMLDTDAttList, XMLDTDElement, XMLDTDEntity, XMLDTDNotation, XMLDeclaration, XMLDocType, XMLDummy, XMLElement, XMLProcessingInstruction, XMLRaw, XMLText, XMLWriterBase, assign,\n    hasProp = {}.hasOwnProperty;\n\n  assign = require('./Utility').assign;\n\n  NodeType = require('./NodeType');\n\n  XMLDeclaration = require('./XMLDeclaration');\n\n  XMLDocType = require('./XMLDocType');\n\n  XMLCData = require('./XMLCData');\n\n  XMLComment = require('./XMLComment');\n\n  XMLElement = require('./XMLElement');\n\n  XMLRaw = require('./XMLRaw');\n\n  XMLText = require('./XMLText');\n\n  XMLProcessingInstruction = require('./XMLProcessingInstruction');\n\n  XMLDummy = require('./XMLDummy');\n\n  XMLDTDAttList = require('./XMLDTDAttList');\n\n  XMLDTDElement = require('./XMLDTDElement');\n\n  XMLDTDEntity = require('./XMLDTDEntity');\n\n  XMLDTDNotation = require('./XMLDTDNotation');\n\n  WriterState = require('./WriterState');\n\n  module.exports = XMLWriterBase = (function() {\n    function XMLWriterBase(options) {\n      var key, ref, value;\n      options || (options = {});\n      this.options = options;\n      ref = options.writer || {};\n      for (key in ref) {\n        if (!hasProp.call(ref, key)) continue;\n        value = ref[key];\n        this[\"_\" + key] = this[key];\n        this[key] = value;\n      }\n    }\n\n    XMLWriterBase.prototype.filterOptions = function(options) {\n      var filteredOptions, ref, ref1, ref2, ref3, ref4, ref5, ref6;\n      options || (options = {});\n      options = assign({}, this.options, options);\n      filteredOptions = {\n        writer: this\n      };\n      filteredOptions.pretty = options.pretty || false;\n      filteredOptions.allowEmpty = options.allowEmpty || false;\n      filteredOptions.indent = (ref = options.indent) != null ? ref : '  ';\n      filteredOptions.newline = (ref1 = options.newline) != null ? ref1 : '\\n';\n      filteredOptions.offset = (ref2 = options.offset) != null ? ref2 : 0;\n      filteredOptions.dontPrettyTextNodes = (ref3 = (ref4 = options.dontPrettyTextNodes) != null ? ref4 : options.dontprettytextnodes) != null ? ref3 : 0;\n      filteredOptions.spaceBeforeSlash = (ref5 = (ref6 = options.spaceBeforeSlash) != null ? ref6 : options.spacebeforeslash) != null ? ref5 : '';\n      if (filteredOptions.spaceBeforeSlash === true) {\n        filteredOptions.spaceBeforeSlash = ' ';\n      }\n      filteredOptions.suppressPrettyCount = 0;\n      filteredOptions.user = {};\n      filteredOptions.state = WriterState.None;\n      return filteredOptions;\n    };\n\n    XMLWriterBase.prototype.indent = function(node, options, level) {\n      var indentLevel;\n      if (!options.pretty || options.suppressPrettyCount) {\n        return '';\n      } else if (options.pretty) {\n        indentLevel = (level || 0) + options.offset + 1;\n        if (indentLevel > 0) {\n          return new Array(indentLevel).join(options.indent);\n        }\n      }\n      return '';\n    };\n\n    XMLWriterBase.prototype.endline = function(node, options, level) {\n      if (!options.pretty || options.suppressPrettyCount) {\n        return '';\n      } else {\n        return options.newline;\n      }\n    };\n\n    XMLWriterBase.prototype.attribute = function(att, options, level) {\n      var r;\n      this.openAttribute(att, options, level);\n      r = ' ' + att.name + '=\"' + att.value + '\"';\n      this.closeAttribute(att, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.cdata = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level) + '<![CDATA[';\n      options.state = WriterState.InsideTag;\n      r += node.value;\n      options.state = WriterState.CloseTag;\n      r += ']]>' + this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.comment = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level) + '<!-- ';\n      options.state = WriterState.InsideTag;\n      r += node.value;\n      options.state = WriterState.CloseTag;\n      r += ' -->' + this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.declaration = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level) + '<?xml';\n      options.state = WriterState.InsideTag;\n      r += ' version=\"' + node.version + '\"';\n      if (node.encoding != null) {\n        r += ' encoding=\"' + node.encoding + '\"';\n      }\n      if (node.standalone != null) {\n        r += ' standalone=\"' + node.standalone + '\"';\n      }\n      options.state = WriterState.CloseTag;\n      r += options.spaceBeforeSlash + '?>';\n      r += this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.docType = function(node, options, level) {\n      var child, i, len, r, ref;\n      level || (level = 0);\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level);\n      r += '<!DOCTYPE ' + node.root().name;\n      if (node.pubID && node.sysID) {\n        r += ' PUBLIC \"' + node.pubID + '\" \"' + node.sysID + '\"';\n      } else if (node.sysID) {\n        r += ' SYSTEM \"' + node.sysID + '\"';\n      }\n      if (node.children.length > 0) {\n        r += ' [';\n        r += this.endline(node, options, level);\n        options.state = WriterState.InsideTag;\n        ref = node.children;\n        for (i = 0, len = ref.length; i < len; i++) {\n          child = ref[i];\n          r += this.writeChildNode(child, options, level + 1);\n        }\n        options.state = WriterState.CloseTag;\n        r += ']';\n      }\n      options.state = WriterState.CloseTag;\n      r += options.spaceBeforeSlash + '>';\n      r += this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.element = function(node, options, level) {\n      var att, child, childNodeCount, firstChildNode, i, j, len, len1, name, prettySuppressed, r, ref, ref1, ref2;\n      level || (level = 0);\n      prettySuppressed = false;\n      r = '';\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r += this.indent(node, options, level) + '<' + node.name;\n      ref = node.attribs;\n      for (name in ref) {\n        if (!hasProp.call(ref, name)) continue;\n        att = ref[name];\n        r += this.attribute(att, options, level);\n      }\n      childNodeCount = node.children.length;\n      firstChildNode = childNodeCount === 0 ? null : node.children[0];\n      if (childNodeCount === 0 || node.children.every(function(e) {\n        return (e.type === NodeType.Text || e.type === NodeType.Raw) && e.value === '';\n      })) {\n        if (options.allowEmpty) {\n          r += '>';\n          options.state = WriterState.CloseTag;\n          r += '</' + node.name + '>' + this.endline(node, options, level);\n        } else {\n          options.state = WriterState.CloseTag;\n          r += options.spaceBeforeSlash + '/>' + this.endline(node, options, level);\n        }\n      } else if (options.pretty && childNodeCount === 1 && (firstChildNode.type === NodeType.Text || firstChildNode.type === NodeType.Raw) && (firstChildNode.value != null)) {\n        r += '>';\n        options.state = WriterState.InsideTag;\n        options.suppressPrettyCount++;\n        prettySuppressed = true;\n        r += this.writeChildNode(firstChildNode, options, level + 1);\n        options.suppressPrettyCount--;\n        prettySuppressed = false;\n        options.state = WriterState.CloseTag;\n        r += '</' + node.name + '>' + this.endline(node, options, level);\n      } else {\n        if (options.dontPrettyTextNodes) {\n          ref1 = node.children;\n          for (i = 0, len = ref1.length; i < len; i++) {\n            child = ref1[i];\n            if ((child.type === NodeType.Text || child.type === NodeType.Raw) && (child.value != null)) {\n              options.suppressPrettyCount++;\n              prettySuppressed = true;\n              break;\n            }\n          }\n        }\n        r += '>' + this.endline(node, options, level);\n        options.state = WriterState.InsideTag;\n        ref2 = node.children;\n        for (j = 0, len1 = ref2.length; j < len1; j++) {\n          child = ref2[j];\n          r += this.writeChildNode(child, options, level + 1);\n        }\n        options.state = WriterState.CloseTag;\n        r += this.indent(node, options, level) + '</' + node.name + '>';\n        if (prettySuppressed) {\n          options.suppressPrettyCount--;\n        }\n        r += this.endline(node, options, level);\n        options.state = WriterState.None;\n      }\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.writeChildNode = function(node, options, level) {\n      switch (node.type) {\n        case NodeType.CData:\n          return this.cdata(node, options, level);\n        case NodeType.Comment:\n          return this.comment(node, options, level);\n        case NodeType.Element:\n          return this.element(node, options, level);\n        case NodeType.Raw:\n          return this.raw(node, options, level);\n        case NodeType.Text:\n          return this.text(node, options, level);\n        case NodeType.ProcessingInstruction:\n          return this.processingInstruction(node, options, level);\n        case NodeType.Dummy:\n          return '';\n        case NodeType.Declaration:\n          return this.declaration(node, options, level);\n        case NodeType.DocType:\n          return this.docType(node, options, level);\n        case NodeType.AttributeDeclaration:\n          return this.dtdAttList(node, options, level);\n        case NodeType.ElementDeclaration:\n          return this.dtdElement(node, options, level);\n        case NodeType.EntityDeclaration:\n          return this.dtdEntity(node, options, level);\n        case NodeType.NotationDeclaration:\n          return this.dtdNotation(node, options, level);\n        default:\n          throw new Error(\"Unknown XML node type: \" + node.constructor.name);\n      }\n    };\n\n    XMLWriterBase.prototype.processingInstruction = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level) + '<?';\n      options.state = WriterState.InsideTag;\n      r += node.target;\n      if (node.value) {\n        r += ' ' + node.value;\n      }\n      options.state = WriterState.CloseTag;\n      r += options.spaceBeforeSlash + '?>';\n      r += this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.raw = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level);\n      options.state = WriterState.InsideTag;\n      r += node.value;\n      options.state = WriterState.CloseTag;\n      r += this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.text = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level);\n      options.state = WriterState.InsideTag;\n      r += node.value;\n      options.state = WriterState.CloseTag;\n      r += this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.dtdAttList = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level) + '<!ATTLIST';\n      options.state = WriterState.InsideTag;\n      r += ' ' + node.elementName + ' ' + node.attributeName + ' ' + node.attributeType;\n      if (node.defaultValueType !== '#DEFAULT') {\n        r += ' ' + node.defaultValueType;\n      }\n      if (node.defaultValue) {\n        r += ' \"' + node.defaultValue + '\"';\n      }\n      options.state = WriterState.CloseTag;\n      r += options.spaceBeforeSlash + '>' + this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.dtdElement = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level) + '<!ELEMENT';\n      options.state = WriterState.InsideTag;\n      r += ' ' + node.name + ' ' + node.value;\n      options.state = WriterState.CloseTag;\n      r += options.spaceBeforeSlash + '>' + this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.dtdEntity = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level) + '<!ENTITY';\n      options.state = WriterState.InsideTag;\n      if (node.pe) {\n        r += ' %';\n      }\n      r += ' ' + node.name;\n      if (node.value) {\n        r += ' \"' + node.value + '\"';\n      } else {\n        if (node.pubID && node.sysID) {\n          r += ' PUBLIC \"' + node.pubID + '\" \"' + node.sysID + '\"';\n        } else if (node.sysID) {\n          r += ' SYSTEM \"' + node.sysID + '\"';\n        }\n        if (node.nData) {\n          r += ' NDATA ' + node.nData;\n        }\n      }\n      options.state = WriterState.CloseTag;\n      r += options.spaceBeforeSlash + '>' + this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.dtdNotation = function(node, options, level) {\n      var r;\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      r = this.indent(node, options, level) + '<!NOTATION';\n      options.state = WriterState.InsideTag;\n      r += ' ' + node.name;\n      if (node.pubID && node.sysID) {\n        r += ' PUBLIC \"' + node.pubID + '\" \"' + node.sysID + '\"';\n      } else if (node.pubID) {\n        r += ' PUBLIC \"' + node.pubID + '\"';\n      } else if (node.sysID) {\n        r += ' SYSTEM \"' + node.sysID + '\"';\n      }\n      options.state = WriterState.CloseTag;\n      r += options.spaceBeforeSlash + '>' + this.endline(node, options, level);\n      options.state = WriterState.None;\n      this.closeNode(node, options, level);\n      return r;\n    };\n\n    XMLWriterBase.prototype.openNode = function(node, options, level) {};\n\n    XMLWriterBase.prototype.closeNode = function(node, options, level) {};\n\n    XMLWriterBase.prototype.openAttribute = function(att, options, level) {};\n\n    XMLWriterBase.prototype.closeAttribute = function(att, options, level) {};\n\n    return XMLWriterBase;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var XMLStringWriter, XMLWriterBase,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  XMLWriterBase = require('./XMLWriterBase');\n\n  module.exports = XMLStringWriter = (function(superClass) {\n    extend(XMLStringWriter, superClass);\n\n    function XMLStringWriter(options) {\n      XMLStringWriter.__super__.constructor.call(this, options);\n    }\n\n    XMLStringWriter.prototype.document = function(doc, options) {\n      var child, i, len, r, ref;\n      options = this.filterOptions(options);\n      r = '';\n      ref = doc.children;\n      for (i = 0, len = ref.length; i < len; i++) {\n        child = ref[i];\n        r += this.writeChildNode(child, options, 0);\n      }\n      if (options.pretty && r.slice(-options.newline.length) === options.newline) {\n        r = r.slice(0, -options.newline.length);\n      }\n      return r;\n    };\n\n    return XMLStringWriter;\n\n  })(XMLWriterBase);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, XMLDOMConfiguration, XMLDOMImplementation, XMLDocument, XMLNode, XMLStringWriter, XMLStringifier, isPlainObject,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  isPlainObject = require('./Utility').isPlainObject;\n\n  XMLDOMImplementation = require('./XMLDOMImplementation');\n\n  XMLDOMConfiguration = require('./XMLDOMConfiguration');\n\n  XMLNode = require('./XMLNode');\n\n  NodeType = require('./NodeType');\n\n  XMLStringifier = require('./XMLStringifier');\n\n  XMLStringWriter = require('./XMLStringWriter');\n\n  module.exports = XMLDocument = (function(superClass) {\n    extend(XMLDocument, superClass);\n\n    function XMLDocument(options) {\n      XMLDocument.__super__.constructor.call(this, null);\n      this.name = \"#document\";\n      this.type = NodeType.Document;\n      this.documentURI = null;\n      this.domConfig = new XMLDOMConfiguration();\n      options || (options = {});\n      if (!options.writer) {\n        options.writer = new XMLStringWriter();\n      }\n      this.options = options;\n      this.stringify = new XMLStringifier(options);\n    }\n\n    Object.defineProperty(XMLDocument.prototype, 'implementation', {\n      value: new XMLDOMImplementation()\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'doctype', {\n      get: function() {\n        var child, i, len, ref;\n        ref = this.children;\n        for (i = 0, len = ref.length; i < len; i++) {\n          child = ref[i];\n          if (child.type === NodeType.DocType) {\n            return child;\n          }\n        }\n        return null;\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'documentElement', {\n      get: function() {\n        return this.rootObject || null;\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'inputEncoding', {\n      get: function() {\n        return null;\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'strictErrorChecking', {\n      get: function() {\n        return false;\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'xmlEncoding', {\n      get: function() {\n        if (this.children.length !== 0 && this.children[0].type === NodeType.Declaration) {\n          return this.children[0].encoding;\n        } else {\n          return null;\n        }\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'xmlStandalone', {\n      get: function() {\n        if (this.children.length !== 0 && this.children[0].type === NodeType.Declaration) {\n          return this.children[0].standalone === 'yes';\n        } else {\n          return false;\n        }\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'xmlVersion', {\n      get: function() {\n        if (this.children.length !== 0 && this.children[0].type === NodeType.Declaration) {\n          return this.children[0].version;\n        } else {\n          return \"1.0\";\n        }\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'URL', {\n      get: function() {\n        return this.documentURI;\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'origin', {\n      get: function() {\n        return null;\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'compatMode', {\n      get: function() {\n        return null;\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'characterSet', {\n      get: function() {\n        return null;\n      }\n    });\n\n    Object.defineProperty(XMLDocument.prototype, 'contentType', {\n      get: function() {\n        return null;\n      }\n    });\n\n    XMLDocument.prototype.end = function(writer) {\n      var writerOptions;\n      writerOptions = {};\n      if (!writer) {\n        writer = this.options.writer;\n      } else if (isPlainObject(writer)) {\n        writerOptions = writer;\n        writer = this.options.writer;\n      }\n      return writer.document(this, writer.filterOptions(writerOptions));\n    };\n\n    XMLDocument.prototype.toString = function(options) {\n      return this.options.writer.document(this, this.options.writer.filterOptions(options));\n    };\n\n    XMLDocument.prototype.createElement = function(tagName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createDocumentFragment = function() {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createTextNode = function(data) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createComment = function(data) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createCDATASection = function(data) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createProcessingInstruction = function(target, data) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createAttribute = function(name) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createEntityReference = function(name) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.getElementsByTagName = function(tagname) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.importNode = function(importedNode, deep) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createElementNS = function(namespaceURI, qualifiedName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createAttributeNS = function(namespaceURI, qualifiedName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.getElementsByTagNameNS = function(namespaceURI, localName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.getElementById = function(elementId) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.adoptNode = function(source) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.normalizeDocument = function() {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.renameNode = function(node, namespaceURI, qualifiedName) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.getElementsByClassName = function(classNames) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createEvent = function(eventInterface) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createRange = function() {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createNodeIterator = function(root, whatToShow, filter) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    XMLDocument.prototype.createTreeWalker = function(root, whatToShow, filter) {\n      throw new Error(\"This DOM method is not implemented.\" + this.debugInfo());\n    };\n\n    return XMLDocument;\n\n  })(XMLNode);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, WriterState, XMLAttribute, XMLCData, XMLComment, XMLDTDAttList, XMLDTDElement, XMLDTDEntity, XMLDTDNotation, XMLDeclaration, XMLDocType, XMLDocument, XMLDocumentCB, XMLElement, XMLProcessingInstruction, XMLRaw, XMLStringWriter, XMLStringifier, XMLText, getValue, isFunction, isObject, isPlainObject, ref,\n    hasProp = {}.hasOwnProperty;\n\n  ref = require('./Utility'), isObject = ref.isObject, isFunction = ref.isFunction, isPlainObject = ref.isPlainObject, getValue = ref.getValue;\n\n  NodeType = require('./NodeType');\n\n  XMLDocument = require('./XMLDocument');\n\n  XMLElement = require('./XMLElement');\n\n  XMLCData = require('./XMLCData');\n\n  XMLComment = require('./XMLComment');\n\n  XMLRaw = require('./XMLRaw');\n\n  XMLText = require('./XMLText');\n\n  XMLProcessingInstruction = require('./XMLProcessingInstruction');\n\n  XMLDeclaration = require('./XMLDeclaration');\n\n  XMLDocType = require('./XMLDocType');\n\n  XMLDTDAttList = require('./XMLDTDAttList');\n\n  XMLDTDEntity = require('./XMLDTDEntity');\n\n  XMLDTDElement = require('./XMLDTDElement');\n\n  XMLDTDNotation = require('./XMLDTDNotation');\n\n  XMLAttribute = require('./XMLAttribute');\n\n  XMLStringifier = require('./XMLStringifier');\n\n  XMLStringWriter = require('./XMLStringWriter');\n\n  WriterState = require('./WriterState');\n\n  module.exports = XMLDocumentCB = (function() {\n    function XMLDocumentCB(options, onData, onEnd) {\n      var writerOptions;\n      this.name = \"?xml\";\n      this.type = NodeType.Document;\n      options || (options = {});\n      writerOptions = {};\n      if (!options.writer) {\n        options.writer = new XMLStringWriter();\n      } else if (isPlainObject(options.writer)) {\n        writerOptions = options.writer;\n        options.writer = new XMLStringWriter();\n      }\n      this.options = options;\n      this.writer = options.writer;\n      this.writerOptions = this.writer.filterOptions(writerOptions);\n      this.stringify = new XMLStringifier(options);\n      this.onDataCallback = onData || function() {};\n      this.onEndCallback = onEnd || function() {};\n      this.currentNode = null;\n      this.currentLevel = -1;\n      this.openTags = {};\n      this.documentStarted = false;\n      this.documentCompleted = false;\n      this.root = null;\n    }\n\n    XMLDocumentCB.prototype.createChildNode = function(node) {\n      var att, attName, attributes, child, i, len, ref1, ref2;\n      switch (node.type) {\n        case NodeType.CData:\n          this.cdata(node.value);\n          break;\n        case NodeType.Comment:\n          this.comment(node.value);\n          break;\n        case NodeType.Element:\n          attributes = {};\n          ref1 = node.attribs;\n          for (attName in ref1) {\n            if (!hasProp.call(ref1, attName)) continue;\n            att = ref1[attName];\n            attributes[attName] = att.value;\n          }\n          this.node(node.name, attributes);\n          break;\n        case NodeType.Dummy:\n          this.dummy();\n          break;\n        case NodeType.Raw:\n          this.raw(node.value);\n          break;\n        case NodeType.Text:\n          this.text(node.value);\n          break;\n        case NodeType.ProcessingInstruction:\n          this.instruction(node.target, node.value);\n          break;\n        default:\n          throw new Error(\"This XML node type is not supported in a JS object: \" + node.constructor.name);\n      }\n      ref2 = node.children;\n      for (i = 0, len = ref2.length; i < len; i++) {\n        child = ref2[i];\n        this.createChildNode(child);\n        if (child.type === NodeType.Element) {\n          this.up();\n        }\n      }\n      return this;\n    };\n\n    XMLDocumentCB.prototype.dummy = function() {\n      return this;\n    };\n\n    XMLDocumentCB.prototype.node = function(name, attributes, text) {\n      var ref1;\n      if (name == null) {\n        throw new Error(\"Missing node name.\");\n      }\n      if (this.root && this.currentLevel === -1) {\n        throw new Error(\"Document can only have one root node. \" + this.debugInfo(name));\n      }\n      this.openCurrent();\n      name = getValue(name);\n      if (attributes == null) {\n        attributes = {};\n      }\n      attributes = getValue(attributes);\n      if (!isObject(attributes)) {\n        ref1 = [attributes, text], text = ref1[0], attributes = ref1[1];\n      }\n      this.currentNode = new XMLElement(this, name, attributes);\n      this.currentNode.children = false;\n      this.currentLevel++;\n      this.openTags[this.currentLevel] = this.currentNode;\n      if (text != null) {\n        this.text(text);\n      }\n      return this;\n    };\n\n    XMLDocumentCB.prototype.element = function(name, attributes, text) {\n      var child, i, len, oldValidationFlag, ref1, root;\n      if (this.currentNode && this.currentNode.type === NodeType.DocType) {\n        this.dtdElement.apply(this, arguments);\n      } else {\n        if (Array.isArray(name) || isObject(name) || isFunction(name)) {\n          oldValidationFlag = this.options.noValidation;\n          this.options.noValidation = true;\n          root = new XMLDocument(this.options).element('TEMP_ROOT');\n          root.element(name);\n          this.options.noValidation = oldValidationFlag;\n          ref1 = root.children;\n          for (i = 0, len = ref1.length; i < len; i++) {\n            child = ref1[i];\n            this.createChildNode(child);\n            if (child.type === NodeType.Element) {\n              this.up();\n            }\n          }\n        } else {\n          this.node(name, attributes, text);\n        }\n      }\n      return this;\n    };\n\n    XMLDocumentCB.prototype.attribute = function(name, value) {\n      var attName, attValue;\n      if (!this.currentNode || this.currentNode.children) {\n        throw new Error(\"att() can only be used immediately after an ele() call in callback mode. \" + this.debugInfo(name));\n      }\n      if (name != null) {\n        name = getValue(name);\n      }\n      if (isObject(name)) {\n        for (attName in name) {\n          if (!hasProp.call(name, attName)) continue;\n          attValue = name[attName];\n          this.attribute(attName, attValue);\n        }\n      } else {\n        if (isFunction(value)) {\n          value = value.apply();\n        }\n        if (this.options.keepNullAttributes && (value == null)) {\n          this.currentNode.attribs[name] = new XMLAttribute(this, name, \"\");\n        } else if (value != null) {\n          this.currentNode.attribs[name] = new XMLAttribute(this, name, value);\n        }\n      }\n      return this;\n    };\n\n    XMLDocumentCB.prototype.text = function(value) {\n      var node;\n      this.openCurrent();\n      node = new XMLText(this, value);\n      this.onData(this.writer.text(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.cdata = function(value) {\n      var node;\n      this.openCurrent();\n      node = new XMLCData(this, value);\n      this.onData(this.writer.cdata(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.comment = function(value) {\n      var node;\n      this.openCurrent();\n      node = new XMLComment(this, value);\n      this.onData(this.writer.comment(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.raw = function(value) {\n      var node;\n      this.openCurrent();\n      node = new XMLRaw(this, value);\n      this.onData(this.writer.raw(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.instruction = function(target, value) {\n      var i, insTarget, insValue, len, node;\n      this.openCurrent();\n      if (target != null) {\n        target = getValue(target);\n      }\n      if (value != null) {\n        value = getValue(value);\n      }\n      if (Array.isArray(target)) {\n        for (i = 0, len = target.length; i < len; i++) {\n          insTarget = target[i];\n          this.instruction(insTarget);\n        }\n      } else if (isObject(target)) {\n        for (insTarget in target) {\n          if (!hasProp.call(target, insTarget)) continue;\n          insValue = target[insTarget];\n          this.instruction(insTarget, insValue);\n        }\n      } else {\n        if (isFunction(value)) {\n          value = value.apply();\n        }\n        node = new XMLProcessingInstruction(this, target, value);\n        this.onData(this.writer.processingInstruction(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      }\n      return this;\n    };\n\n    XMLDocumentCB.prototype.declaration = function(version, encoding, standalone) {\n      var node;\n      this.openCurrent();\n      if (this.documentStarted) {\n        throw new Error(\"declaration() must be the first node.\");\n      }\n      node = new XMLDeclaration(this, version, encoding, standalone);\n      this.onData(this.writer.declaration(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.doctype = function(root, pubID, sysID) {\n      this.openCurrent();\n      if (root == null) {\n        throw new Error(\"Missing root node name.\");\n      }\n      if (this.root) {\n        throw new Error(\"dtd() must come before the root node.\");\n      }\n      this.currentNode = new XMLDocType(this, pubID, sysID);\n      this.currentNode.rootNodeName = root;\n      this.currentNode.children = false;\n      this.currentLevel++;\n      this.openTags[this.currentLevel] = this.currentNode;\n      return this;\n    };\n\n    XMLDocumentCB.prototype.dtdElement = function(name, value) {\n      var node;\n      this.openCurrent();\n      node = new XMLDTDElement(this, name, value);\n      this.onData(this.writer.dtdElement(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.attList = function(elementName, attributeName, attributeType, defaultValueType, defaultValue) {\n      var node;\n      this.openCurrent();\n      node = new XMLDTDAttList(this, elementName, attributeName, attributeType, defaultValueType, defaultValue);\n      this.onData(this.writer.dtdAttList(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.entity = function(name, value) {\n      var node;\n      this.openCurrent();\n      node = new XMLDTDEntity(this, false, name, value);\n      this.onData(this.writer.dtdEntity(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.pEntity = function(name, value) {\n      var node;\n      this.openCurrent();\n      node = new XMLDTDEntity(this, true, name, value);\n      this.onData(this.writer.dtdEntity(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.notation = function(name, value) {\n      var node;\n      this.openCurrent();\n      node = new XMLDTDNotation(this, name, value);\n      this.onData(this.writer.dtdNotation(node, this.writerOptions, this.currentLevel + 1), this.currentLevel + 1);\n      return this;\n    };\n\n    XMLDocumentCB.prototype.up = function() {\n      if (this.currentLevel < 0) {\n        throw new Error(\"The document node has no parent.\");\n      }\n      if (this.currentNode) {\n        if (this.currentNode.children) {\n          this.closeNode(this.currentNode);\n        } else {\n          this.openNode(this.currentNode);\n        }\n        this.currentNode = null;\n      } else {\n        this.closeNode(this.openTags[this.currentLevel]);\n      }\n      delete this.openTags[this.currentLevel];\n      this.currentLevel--;\n      return this;\n    };\n\n    XMLDocumentCB.prototype.end = function() {\n      while (this.currentLevel >= 0) {\n        this.up();\n      }\n      return this.onEnd();\n    };\n\n    XMLDocumentCB.prototype.openCurrent = function() {\n      if (this.currentNode) {\n        this.currentNode.children = true;\n        return this.openNode(this.currentNode);\n      }\n    };\n\n    XMLDocumentCB.prototype.openNode = function(node) {\n      var att, chunk, name, ref1;\n      if (!node.isOpen) {\n        if (!this.root && this.currentLevel === 0 && node.type === NodeType.Element) {\n          this.root = node;\n        }\n        chunk = '';\n        if (node.type === NodeType.Element) {\n          this.writerOptions.state = WriterState.OpenTag;\n          chunk = this.writer.indent(node, this.writerOptions, this.currentLevel) + '<' + node.name;\n          ref1 = node.attribs;\n          for (name in ref1) {\n            if (!hasProp.call(ref1, name)) continue;\n            att = ref1[name];\n            chunk += this.writer.attribute(att, this.writerOptions, this.currentLevel);\n          }\n          chunk += (node.children ? '>' : '/>') + this.writer.endline(node, this.writerOptions, this.currentLevel);\n          this.writerOptions.state = WriterState.InsideTag;\n        } else {\n          this.writerOptions.state = WriterState.OpenTag;\n          chunk = this.writer.indent(node, this.writerOptions, this.currentLevel) + '<!DOCTYPE ' + node.rootNodeName;\n          if (node.pubID && node.sysID) {\n            chunk += ' PUBLIC \"' + node.pubID + '\" \"' + node.sysID + '\"';\n          } else if (node.sysID) {\n            chunk += ' SYSTEM \"' + node.sysID + '\"';\n          }\n          if (node.children) {\n            chunk += ' [';\n            this.writerOptions.state = WriterState.InsideTag;\n          } else {\n            this.writerOptions.state = WriterState.CloseTag;\n            chunk += '>';\n          }\n          chunk += this.writer.endline(node, this.writerOptions, this.currentLevel);\n        }\n        this.onData(chunk, this.currentLevel);\n        return node.isOpen = true;\n      }\n    };\n\n    XMLDocumentCB.prototype.closeNode = function(node) {\n      var chunk;\n      if (!node.isClosed) {\n        chunk = '';\n        this.writerOptions.state = WriterState.CloseTag;\n        if (node.type === NodeType.Element) {\n          chunk = this.writer.indent(node, this.writerOptions, this.currentLevel) + '</' + node.name + '>' + this.writer.endline(node, this.writerOptions, this.currentLevel);\n        } else {\n          chunk = this.writer.indent(node, this.writerOptions, this.currentLevel) + ']>' + this.writer.endline(node, this.writerOptions, this.currentLevel);\n        }\n        this.writerOptions.state = WriterState.None;\n        this.onData(chunk, this.currentLevel);\n        return node.isClosed = true;\n      }\n    };\n\n    XMLDocumentCB.prototype.onData = function(chunk, level) {\n      this.documentStarted = true;\n      return this.onDataCallback(chunk, level + 1);\n    };\n\n    XMLDocumentCB.prototype.onEnd = function() {\n      this.documentCompleted = true;\n      return this.onEndCallback();\n    };\n\n    XMLDocumentCB.prototype.debugInfo = function(name) {\n      if (name == null) {\n        return \"\";\n      } else {\n        return \"node: <\" + name + \">\";\n      }\n    };\n\n    XMLDocumentCB.prototype.ele = function() {\n      return this.element.apply(this, arguments);\n    };\n\n    XMLDocumentCB.prototype.nod = function(name, attributes, text) {\n      return this.node(name, attributes, text);\n    };\n\n    XMLDocumentCB.prototype.txt = function(value) {\n      return this.text(value);\n    };\n\n    XMLDocumentCB.prototype.dat = function(value) {\n      return this.cdata(value);\n    };\n\n    XMLDocumentCB.prototype.com = function(value) {\n      return this.comment(value);\n    };\n\n    XMLDocumentCB.prototype.ins = function(target, value) {\n      return this.instruction(target, value);\n    };\n\n    XMLDocumentCB.prototype.dec = function(version, encoding, standalone) {\n      return this.declaration(version, encoding, standalone);\n    };\n\n    XMLDocumentCB.prototype.dtd = function(root, pubID, sysID) {\n      return this.doctype(root, pubID, sysID);\n    };\n\n    XMLDocumentCB.prototype.e = function(name, attributes, text) {\n      return this.element(name, attributes, text);\n    };\n\n    XMLDocumentCB.prototype.n = function(name, attributes, text) {\n      return this.node(name, attributes, text);\n    };\n\n    XMLDocumentCB.prototype.t = function(value) {\n      return this.text(value);\n    };\n\n    XMLDocumentCB.prototype.d = function(value) {\n      return this.cdata(value);\n    };\n\n    XMLDocumentCB.prototype.c = function(value) {\n      return this.comment(value);\n    };\n\n    XMLDocumentCB.prototype.r = function(value) {\n      return this.raw(value);\n    };\n\n    XMLDocumentCB.prototype.i = function(target, value) {\n      return this.instruction(target, value);\n    };\n\n    XMLDocumentCB.prototype.att = function() {\n      if (this.currentNode && this.currentNode.type === NodeType.DocType) {\n        return this.attList.apply(this, arguments);\n      } else {\n        return this.attribute.apply(this, arguments);\n      }\n    };\n\n    XMLDocumentCB.prototype.a = function() {\n      if (this.currentNode && this.currentNode.type === NodeType.DocType) {\n        return this.attList.apply(this, arguments);\n      } else {\n        return this.attribute.apply(this, arguments);\n      }\n    };\n\n    XMLDocumentCB.prototype.ent = function(name, value) {\n      return this.entity(name, value);\n    };\n\n    XMLDocumentCB.prototype.pent = function(name, value) {\n      return this.pEntity(name, value);\n    };\n\n    XMLDocumentCB.prototype.not = function(name, value) {\n      return this.notation(name, value);\n    };\n\n    return XMLDocumentCB;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, WriterState, XMLStreamWriter, XMLWriterBase,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  NodeType = require('./NodeType');\n\n  XMLWriterBase = require('./XMLWriterBase');\n\n  WriterState = require('./WriterState');\n\n  module.exports = XMLStreamWriter = (function(superClass) {\n    extend(XMLStreamWriter, superClass);\n\n    function XMLStreamWriter(stream, options) {\n      this.stream = stream;\n      XMLStreamWriter.__super__.constructor.call(this, options);\n    }\n\n    XMLStreamWriter.prototype.endline = function(node, options, level) {\n      if (node.isLastRootNode && options.state === WriterState.CloseTag) {\n        return '';\n      } else {\n        return XMLStreamWriter.__super__.endline.call(this, node, options, level);\n      }\n    };\n\n    XMLStreamWriter.prototype.document = function(doc, options) {\n      var child, i, j, k, len, len1, ref, ref1, results;\n      ref = doc.children;\n      for (i = j = 0, len = ref.length; j < len; i = ++j) {\n        child = ref[i];\n        child.isLastRootNode = i === doc.children.length - 1;\n      }\n      options = this.filterOptions(options);\n      ref1 = doc.children;\n      results = [];\n      for (k = 0, len1 = ref1.length; k < len1; k++) {\n        child = ref1[k];\n        results.push(this.writeChildNode(child, options, 0));\n      }\n      return results;\n    };\n\n    XMLStreamWriter.prototype.attribute = function(att, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.attribute.call(this, att, options, level));\n    };\n\n    XMLStreamWriter.prototype.cdata = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.cdata.call(this, node, options, level));\n    };\n\n    XMLStreamWriter.prototype.comment = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.comment.call(this, node, options, level));\n    };\n\n    XMLStreamWriter.prototype.declaration = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.declaration.call(this, node, options, level));\n    };\n\n    XMLStreamWriter.prototype.docType = function(node, options, level) {\n      var child, j, len, ref;\n      level || (level = 0);\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      this.stream.write(this.indent(node, options, level));\n      this.stream.write('<!DOCTYPE ' + node.root().name);\n      if (node.pubID && node.sysID) {\n        this.stream.write(' PUBLIC \"' + node.pubID + '\" \"' + node.sysID + '\"');\n      } else if (node.sysID) {\n        this.stream.write(' SYSTEM \"' + node.sysID + '\"');\n      }\n      if (node.children.length > 0) {\n        this.stream.write(' [');\n        this.stream.write(this.endline(node, options, level));\n        options.state = WriterState.InsideTag;\n        ref = node.children;\n        for (j = 0, len = ref.length; j < len; j++) {\n          child = ref[j];\n          this.writeChildNode(child, options, level + 1);\n        }\n        options.state = WriterState.CloseTag;\n        this.stream.write(']');\n      }\n      options.state = WriterState.CloseTag;\n      this.stream.write(options.spaceBeforeSlash + '>');\n      this.stream.write(this.endline(node, options, level));\n      options.state = WriterState.None;\n      return this.closeNode(node, options, level);\n    };\n\n    XMLStreamWriter.prototype.element = function(node, options, level) {\n      var att, child, childNodeCount, firstChildNode, j, len, name, prettySuppressed, ref, ref1;\n      level || (level = 0);\n      this.openNode(node, options, level);\n      options.state = WriterState.OpenTag;\n      this.stream.write(this.indent(node, options, level) + '<' + node.name);\n      ref = node.attribs;\n      for (name in ref) {\n        if (!hasProp.call(ref, name)) continue;\n        att = ref[name];\n        this.attribute(att, options, level);\n      }\n      childNodeCount = node.children.length;\n      firstChildNode = childNodeCount === 0 ? null : node.children[0];\n      if (childNodeCount === 0 || node.children.every(function(e) {\n        return (e.type === NodeType.Text || e.type === NodeType.Raw) && e.value === '';\n      })) {\n        if (options.allowEmpty) {\n          this.stream.write('>');\n          options.state = WriterState.CloseTag;\n          this.stream.write('</' + node.name + '>');\n        } else {\n          options.state = WriterState.CloseTag;\n          this.stream.write(options.spaceBeforeSlash + '/>');\n        }\n      } else if (options.pretty && childNodeCount === 1 && (firstChildNode.type === NodeType.Text || firstChildNode.type === NodeType.Raw) && (firstChildNode.value != null)) {\n        this.stream.write('>');\n        options.state = WriterState.InsideTag;\n        options.suppressPrettyCount++;\n        prettySuppressed = true;\n        this.writeChildNode(firstChildNode, options, level + 1);\n        options.suppressPrettyCount--;\n        prettySuppressed = false;\n        options.state = WriterState.CloseTag;\n        this.stream.write('</' + node.name + '>');\n      } else {\n        this.stream.write('>' + this.endline(node, options, level));\n        options.state = WriterState.InsideTag;\n        ref1 = node.children;\n        for (j = 0, len = ref1.length; j < len; j++) {\n          child = ref1[j];\n          this.writeChildNode(child, options, level + 1);\n        }\n        options.state = WriterState.CloseTag;\n        this.stream.write(this.indent(node, options, level) + '</' + node.name + '>');\n      }\n      this.stream.write(this.endline(node, options, level));\n      options.state = WriterState.None;\n      return this.closeNode(node, options, level);\n    };\n\n    XMLStreamWriter.prototype.processingInstruction = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.processingInstruction.call(this, node, options, level));\n    };\n\n    XMLStreamWriter.prototype.raw = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.raw.call(this, node, options, level));\n    };\n\n    XMLStreamWriter.prototype.text = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.text.call(this, node, options, level));\n    };\n\n    XMLStreamWriter.prototype.dtdAttList = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.dtdAttList.call(this, node, options, level));\n    };\n\n    XMLStreamWriter.prototype.dtdElement = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.dtdElement.call(this, node, options, level));\n    };\n\n    XMLStreamWriter.prototype.dtdEntity = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.dtdEntity.call(this, node, options, level));\n    };\n\n    XMLStreamWriter.prototype.dtdNotation = function(node, options, level) {\n      return this.stream.write(XMLStreamWriter.__super__.dtdNotation.call(this, node, options, level));\n    };\n\n    return XMLStreamWriter;\n\n  })(XMLWriterBase);\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  \"use strict\";\n  var builder, defaults, escapeCDATA, requiresCDATA, wrapCDATA,\n    hasProp = {}.hasOwnProperty;\n\n  builder = require('xmlbuilder');\n\n  defaults = require('./defaults').defaults;\n\n  requiresCDATA = function(entry) {\n    return typeof entry === \"string\" && (entry.indexOf('&') >= 0 || entry.indexOf('>') >= 0 || entry.indexOf('<') >= 0);\n  };\n\n  wrapCDATA = function(entry) {\n    return \"<![CDATA[\" + (escapeCDATA(entry)) + \"]]>\";\n  };\n\n  escapeCDATA = function(entry) {\n    return entry.replace(']]>', ']]]]><![CDATA[>');\n  };\n\n  exports.Builder = (function() {\n    function Builder(opts) {\n      var key, ref, value;\n      this.options = {};\n      ref = defaults[\"0.2\"];\n      for (key in ref) {\n        if (!hasProp.call(ref, key)) continue;\n        value = ref[key];\n        this.options[key] = value;\n      }\n      for (key in opts) {\n        if (!hasProp.call(opts, key)) continue;\n        value = opts[key];\n        this.options[key] = value;\n      }\n    }\n\n    Builder.prototype.buildObject = function(rootObj) {\n      var attrkey, charkey, render, rootElement, rootName;\n      attrkey = this.options.attrkey;\n      charkey = this.options.charkey;\n      if ((Object.keys(rootObj).length === 1) && (this.options.rootName === defaults['0.2'].rootName)) {\n        rootName = Object.keys(rootObj)[0];\n        rootObj = rootObj[rootName];\n      } else {\n        rootName = this.options.rootName;\n      }\n      render = (function(_this) {\n        return function(element, obj) {\n          var attr, child, entry, index, key, value;\n          if (typeof obj !== 'object') {\n            if (_this.options.cdata && requiresCDATA(obj)) {\n              element.raw(wrapCDATA(obj));\n            } else {\n              element.txt(obj);\n            }\n          } else if (Array.isArray(obj)) {\n            for (index in obj) {\n              if (!hasProp.call(obj, index)) continue;\n              child = obj[index];\n              for (key in child) {\n                entry = child[key];\n                element = render(element.ele(key), entry).up();\n              }\n            }\n          } else {\n            for (key in obj) {\n              if (!hasProp.call(obj, key)) continue;\n              child = obj[key];\n              if (key === attrkey) {\n                if (typeof child === \"object\") {\n                  for (attr in child) {\n                    value = child[attr];\n                    element = element.att(attr, value);\n                  }\n                }\n              } else if (key === charkey) {\n                if (_this.options.cdata && requiresCDATA(child)) {\n                  element = element.raw(wrapCDATA(child));\n                } else {\n                  element = element.txt(child);\n                }\n              } else if (Array.isArray(child)) {\n                for (index in child) {\n                  if (!hasProp.call(child, index)) continue;\n                  entry = child[index];\n                  if (typeof entry === 'string') {\n                    if (_this.options.cdata && requiresCDATA(entry)) {\n                      element = element.ele(key).raw(wrapCDATA(entry)).up();\n                    } else {\n                      element = element.ele(key, entry).up();\n                    }\n                  } else {\n                    element = render(element.ele(key), entry).up();\n                  }\n                }\n              } else if (typeof child === \"object\") {\n                element = render(element.ele(key), child).up();\n              } else {\n                if (typeof child === 'string' && _this.options.cdata && requiresCDATA(child)) {\n                  element = element.ele(key).raw(wrapCDATA(child)).up();\n                } else {\n                  if (child == null) {\n                    child = '';\n                  }\n                  element = element.ele(key, child.toString()).up();\n                }\n              }\n            }\n          }\n          return element;\n        };\n      })(this);\n      rootElement = builder.create(rootName, this.options.xmldec, this.options.doctype, {\n        headless: this.options.headless,\n        allowSurrogateChars: this.options.allowSurrogateChars\n      });\n      return render(rootElement, rootObj).end(this.options.renderOpts);\n    };\n\n    return Builder;\n\n  })();\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  var NodeType, WriterState, XMLDOMImplementation, XMLDocument, XMLDocumentCB, XMLStreamWriter, XMLStringWriter, assign, isFunction, ref;\n\n  ref = require('./Utility'), assign = ref.assign, isFunction = ref.isFunction;\n\n  XMLDOMImplementation = require('./XMLDOMImplementation');\n\n  XMLDocument = require('./XMLDocument');\n\n  XMLDocumentCB = require('./XMLDocumentCB');\n\n  XMLStringWriter = require('./XMLStringWriter');\n\n  XMLStreamWriter = require('./XMLStreamWriter');\n\n  NodeType = require('./NodeType');\n\n  WriterState = require('./WriterState');\n\n  module.exports.create = function(name, xmldec, doctype, options) {\n    var doc, root;\n    if (name == null) {\n      throw new Error(\"Root element needs a name.\");\n    }\n    options = assign({}, xmldec, doctype, options);\n    doc = new XMLDocument(options);\n    root = doc.element(name);\n    if (!options.headless) {\n      doc.declaration(options);\n      if ((options.pubID != null) || (options.sysID != null)) {\n        doc.dtd(options);\n      }\n    }\n    return root;\n  };\n\n  module.exports.begin = function(options, onData, onEnd) {\n    var ref1;\n    if (isFunction(options)) {\n      ref1 = [options, onData], onData = ref1[0], onEnd = ref1[1];\n      options = {};\n    }\n    if (onData) {\n      return new XMLDocumentCB(options, onData, onEnd);\n    } else {\n      return new XMLDocument(options);\n    }\n  };\n\n  module.exports.stringWriter = function(options) {\n    return new XMLStringWriter(options);\n  };\n\n  module.exports.streamWriter = function(stream, options) {\n    return new XMLStreamWriter(stream, options);\n  };\n\n  module.exports.implementation = new XMLDOMImplementation();\n\n  module.exports.nodeType = NodeType;\n\n  module.exports.writerState = WriterState;\n\n}).call(this);\n",";(function (sax) { // wrapper for non-node envs\n  sax.parser = function (strict, opt) { return new SAXParser(strict, opt) }\n  sax.SAXParser = SAXParser\n  sax.SAXStream = SAXStream\n  sax.createStream = createStream\n\n  // When we pass the MAX_BUFFER_LENGTH position, start checking for buffer overruns.\n  // When we check, schedule the next check for MAX_BUFFER_LENGTH - (max(buffer lengths)),\n  // since that's the earliest that a buffer overrun could occur.  This way, checks are\n  // as rare as required, but as often as necessary to ensure never crossing this bound.\n  // Furthermore, buffers are only tested at most once per write(), so passing a very\n  // large string into write() might have undesirable effects, but this is manageable by\n  // the caller, so it is assumed to be safe.  Thus, a call to write() may, in the extreme\n  // edge case, result in creating at most one complete copy of the string passed in.\n  // Set to Infinity to have unlimited buffers.\n  sax.MAX_BUFFER_LENGTH = 64 * 1024\n\n  var buffers = [\n    'comment', 'sgmlDecl', 'textNode', 'tagName', 'doctype',\n    'procInstName', 'procInstBody', 'entity', 'attribName',\n    'attribValue', 'cdata', 'script'\n  ]\n\n  sax.EVENTS = [\n    'text',\n    'processinginstruction',\n    'sgmldeclaration',\n    'doctype',\n    'comment',\n    'opentagstart',\n    'attribute',\n    'opentag',\n    'closetag',\n    'opencdata',\n    'cdata',\n    'closecdata',\n    'error',\n    'end',\n    'ready',\n    'script',\n    'opennamespace',\n    'closenamespace'\n  ]\n\n  function SAXParser (strict, opt) {\n    if (!(this instanceof SAXParser)) {\n      return new SAXParser(strict, opt)\n    }\n\n    var parser = this\n    clearBuffers(parser)\n    parser.q = parser.c = ''\n    parser.bufferCheckPosition = sax.MAX_BUFFER_LENGTH\n    parser.opt = opt || {}\n    parser.opt.lowercase = parser.opt.lowercase || parser.opt.lowercasetags\n    parser.looseCase = parser.opt.lowercase ? 'toLowerCase' : 'toUpperCase'\n    parser.tags = []\n    parser.closed = parser.closedRoot = parser.sawRoot = false\n    parser.tag = parser.error = null\n    parser.strict = !!strict\n    parser.noscript = !!(strict || parser.opt.noscript)\n    parser.state = S.BEGIN\n    parser.strictEntities = parser.opt.strictEntities\n    parser.ENTITIES = parser.strictEntities ? Object.create(sax.XML_ENTITIES) : Object.create(sax.ENTITIES)\n    parser.attribList = []\n\n    // namespaces form a prototype chain.\n    // it always points at the current tag,\n    // which protos to its parent tag.\n    if (parser.opt.xmlns) {\n      parser.ns = Object.create(rootNS)\n    }\n\n    // disallow unquoted attribute values if not otherwise configured\n    // and strict mode is true\n    if (parser.opt.unquotedAttributeValues === undefined) {\n      parser.opt.unquotedAttributeValues = !strict;\n    }\n\n    // mostly just for error reporting\n    parser.trackPosition = parser.opt.position !== false\n    if (parser.trackPosition) {\n      parser.position = parser.line = parser.column = 0\n    }\n    emit(parser, 'onready')\n  }\n\n  if (!Object.create) {\n    Object.create = function (o) {\n      function F () {}\n      F.prototype = o\n      var newf = new F()\n      return newf\n    }\n  }\n\n  if (!Object.keys) {\n    Object.keys = function (o) {\n      var a = []\n      for (var i in o) if (o.hasOwnProperty(i)) a.push(i)\n      return a\n    }\n  }\n\n  function checkBufferLength (parser) {\n    var maxAllowed = Math.max(sax.MAX_BUFFER_LENGTH, 10)\n    var maxActual = 0\n    for (var i = 0, l = buffers.length; i < l; i++) {\n      var len = parser[buffers[i]].length\n      if (len > maxAllowed) {\n        // Text/cdata nodes can get big, and since they're buffered,\n        // we can get here under normal conditions.\n        // Avoid issues by emitting the text node now,\n        // so at least it won't get any bigger.\n        switch (buffers[i]) {\n          case 'textNode':\n            closeText(parser)\n            break\n\n          case 'cdata':\n            emitNode(parser, 'oncdata', parser.cdata)\n            parser.cdata = ''\n            break\n\n          case 'script':\n            emitNode(parser, 'onscript', parser.script)\n            parser.script = ''\n            break\n\n          default:\n            error(parser, 'Max buffer length exceeded: ' + buffers[i])\n        }\n      }\n      maxActual = Math.max(maxActual, len)\n    }\n    // schedule the next check for the earliest possible buffer overrun.\n    var m = sax.MAX_BUFFER_LENGTH - maxActual\n    parser.bufferCheckPosition = m + parser.position\n  }\n\n  function clearBuffers (parser) {\n    for (var i = 0, l = buffers.length; i < l; i++) {\n      parser[buffers[i]] = ''\n    }\n  }\n\n  function flushBuffers (parser) {\n    closeText(parser)\n    if (parser.cdata !== '') {\n      emitNode(parser, 'oncdata', parser.cdata)\n      parser.cdata = ''\n    }\n    if (parser.script !== '') {\n      emitNode(parser, 'onscript', parser.script)\n      parser.script = ''\n    }\n  }\n\n  SAXParser.prototype = {\n    end: function () { end(this) },\n    write: write,\n    resume: function () { this.error = null; return this },\n    close: function () { return this.write(null) },\n    flush: function () { flushBuffers(this) }\n  }\n\n  var Stream\n  try {\n    Stream = require('stream').Stream\n  } catch (ex) {\n    Stream = function () {}\n  }\n  if (!Stream) Stream = function () {}\n\n  var streamWraps = sax.EVENTS.filter(function (ev) {\n    return ev !== 'error' && ev !== 'end'\n  })\n\n  function createStream (strict, opt) {\n    return new SAXStream(strict, opt)\n  }\n\n  function SAXStream (strict, opt) {\n    if (!(this instanceof SAXStream)) {\n      return new SAXStream(strict, opt)\n    }\n\n    Stream.apply(this)\n\n    this._parser = new SAXParser(strict, opt)\n    this.writable = true\n    this.readable = true\n\n    var me = this\n\n    this._parser.onend = function () {\n      me.emit('end')\n    }\n\n    this._parser.onerror = function (er) {\n      me.emit('error', er)\n\n      // if didn't throw, then means error was handled.\n      // go ahead and clear error, so we can write again.\n      me._parser.error = null\n    }\n\n    this._decoder = null\n\n    streamWraps.forEach(function (ev) {\n      Object.defineProperty(me, 'on' + ev, {\n        get: function () {\n          return me._parser['on' + ev]\n        },\n        set: function (h) {\n          if (!h) {\n            me.removeAllListeners(ev)\n            me._parser['on' + ev] = h\n            return h\n          }\n          me.on(ev, h)\n        },\n        enumerable: true,\n        configurable: false\n      })\n    })\n  }\n\n  SAXStream.prototype = Object.create(Stream.prototype, {\n    constructor: {\n      value: SAXStream\n    }\n  })\n\n  SAXStream.prototype.write = function (data) {\n    if (typeof Buffer === 'function' &&\n      typeof Buffer.isBuffer === 'function' &&\n      Buffer.isBuffer(data)) {\n      if (!this._decoder) {\n        var SD = require('string_decoder').StringDecoder\n        this._decoder = new SD('utf8')\n      }\n      data = this._decoder.write(data)\n    }\n\n    this._parser.write(data.toString())\n    this.emit('data', data)\n    return true\n  }\n\n  SAXStream.prototype.end = function (chunk) {\n    if (chunk && chunk.length) {\n      this.write(chunk)\n    }\n    this._parser.end()\n    return true\n  }\n\n  SAXStream.prototype.on = function (ev, handler) {\n    var me = this\n    if (!me._parser['on' + ev] && streamWraps.indexOf(ev) !== -1) {\n      me._parser['on' + ev] = function () {\n        var args = arguments.length === 1 ? [arguments[0]] : Array.apply(null, arguments)\n        args.splice(0, 0, ev)\n        me.emit.apply(me, args)\n      }\n    }\n\n    return Stream.prototype.on.call(me, ev, handler)\n  }\n\n  // this really needs to be replaced with character classes.\n  // XML allows all manner of ridiculous numbers and digits.\n  var CDATA = '[CDATA['\n  var DOCTYPE = 'DOCTYPE'\n  var XML_NAMESPACE = 'http://www.w3.org/XML/1998/namespace'\n  var XMLNS_NAMESPACE = 'http://www.w3.org/2000/xmlns/'\n  var rootNS = { xml: XML_NAMESPACE, xmlns: XMLNS_NAMESPACE }\n\n  // http://www.w3.org/TR/REC-xml/#NT-NameStartChar\n  // This implementation works on strings, a single character at a time\n  // as such, it cannot ever support astral-plane characters (10000-EFFFF)\n  // without a significant breaking change to either this  parser, or the\n  // JavaScript language.  Implementation of an emoji-capable xml parser\n  // is left as an exercise for the reader.\n  var nameStart = /[:_A-Za-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD]/\n\n  var nameBody = /[:_A-Za-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD\\u00B7\\u0300-\\u036F\\u203F-\\u2040.\\d-]/\n\n  var entityStart = /[#:_A-Za-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD]/\n  var entityBody = /[#:_A-Za-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD\\u00B7\\u0300-\\u036F\\u203F-\\u2040.\\d-]/\n\n  function isWhitespace (c) {\n    return c === ' ' || c === '\\n' || c === '\\r' || c === '\\t'\n  }\n\n  function isQuote (c) {\n    return c === '\"' || c === '\\''\n  }\n\n  function isAttribEnd (c) {\n    return c === '>' || isWhitespace(c)\n  }\n\n  function isMatch (regex, c) {\n    return regex.test(c)\n  }\n\n  function notMatch (regex, c) {\n    return !isMatch(regex, c)\n  }\n\n  var S = 0\n  sax.STATE = {\n    BEGIN: S++, // leading byte order mark or whitespace\n    BEGIN_WHITESPACE: S++, // leading whitespace\n    TEXT: S++, // general stuff\n    TEXT_ENTITY: S++, // &amp and such.\n    OPEN_WAKA: S++, // <\n    SGML_DECL: S++, // <!BLARG\n    SGML_DECL_QUOTED: S++, // <!BLARG foo \"bar\n    DOCTYPE: S++, // <!DOCTYPE\n    DOCTYPE_QUOTED: S++, // <!DOCTYPE \"//blah\n    DOCTYPE_DTD: S++, // <!DOCTYPE \"//blah\" [ ...\n    DOCTYPE_DTD_QUOTED: S++, // <!DOCTYPE \"//blah\" [ \"foo\n    COMMENT_STARTING: S++, // <!-\n    COMMENT: S++, // <!--\n    COMMENT_ENDING: S++, // <!-- blah -\n    COMMENT_ENDED: S++, // <!-- blah --\n    CDATA: S++, // <![CDATA[ something\n    CDATA_ENDING: S++, // ]\n    CDATA_ENDING_2: S++, // ]]\n    PROC_INST: S++, // <?hi\n    PROC_INST_BODY: S++, // <?hi there\n    PROC_INST_ENDING: S++, // <?hi \"there\" ?\n    OPEN_TAG: S++, // <strong\n    OPEN_TAG_SLASH: S++, // <strong /\n    ATTRIB: S++, // <a\n    ATTRIB_NAME: S++, // <a foo\n    ATTRIB_NAME_SAW_WHITE: S++, // <a foo _\n    ATTRIB_VALUE: S++, // <a foo=\n    ATTRIB_VALUE_QUOTED: S++, // <a foo=\"bar\n    ATTRIB_VALUE_CLOSED: S++, // <a foo=\"bar\"\n    ATTRIB_VALUE_UNQUOTED: S++, // <a foo=bar\n    ATTRIB_VALUE_ENTITY_Q: S++, // <foo bar=\"&quot;\"\n    ATTRIB_VALUE_ENTITY_U: S++, // <foo bar=&quot\n    CLOSE_TAG: S++, // </a\n    CLOSE_TAG_SAW_WHITE: S++, // </a   >\n    SCRIPT: S++, // <script> ...\n    SCRIPT_ENDING: S++ // <script> ... <\n  }\n\n  sax.XML_ENTITIES = {\n    'amp': '&',\n    'gt': '>',\n    'lt': '<',\n    'quot': '\"',\n    'apos': \"'\"\n  }\n\n  sax.ENTITIES = {\n    'amp': '&',\n    'gt': '>',\n    'lt': '<',\n    'quot': '\"',\n    'apos': \"'\",\n    'AElig': 198,\n    'Aacute': 193,\n    'Acirc': 194,\n    'Agrave': 192,\n    'Aring': 197,\n    'Atilde': 195,\n    'Auml': 196,\n    'Ccedil': 199,\n    'ETH': 208,\n    'Eacute': 201,\n    'Ecirc': 202,\n    'Egrave': 200,\n    'Euml': 203,\n    'Iacute': 205,\n    'Icirc': 206,\n    'Igrave': 204,\n    'Iuml': 207,\n    'Ntilde': 209,\n    'Oacute': 211,\n    'Ocirc': 212,\n    'Ograve': 210,\n    'Oslash': 216,\n    'Otilde': 213,\n    'Ouml': 214,\n    'THORN': 222,\n    'Uacute': 218,\n    'Ucirc': 219,\n    'Ugrave': 217,\n    'Uuml': 220,\n    'Yacute': 221,\n    'aacute': 225,\n    'acirc': 226,\n    'aelig': 230,\n    'agrave': 224,\n    'aring': 229,\n    'atilde': 227,\n    'auml': 228,\n    'ccedil': 231,\n    'eacute': 233,\n    'ecirc': 234,\n    'egrave': 232,\n    'eth': 240,\n    'euml': 235,\n    'iacute': 237,\n    'icirc': 238,\n    'igrave': 236,\n    'iuml': 239,\n    'ntilde': 241,\n    'oacute': 243,\n    'ocirc': 244,\n    'ograve': 242,\n    'oslash': 248,\n    'otilde': 245,\n    'ouml': 246,\n    'szlig': 223,\n    'thorn': 254,\n    'uacute': 250,\n    'ucirc': 251,\n    'ugrave': 249,\n    'uuml': 252,\n    'yacute': 253,\n    'yuml': 255,\n    'copy': 169,\n    'reg': 174,\n    'nbsp': 160,\n    'iexcl': 161,\n    'cent': 162,\n    'pound': 163,\n    'curren': 164,\n    'yen': 165,\n    'brvbar': 166,\n    'sect': 167,\n    'uml': 168,\n    'ordf': 170,\n    'laquo': 171,\n    'not': 172,\n    'shy': 173,\n    'macr': 175,\n    'deg': 176,\n    'plusmn': 177,\n    'sup1': 185,\n    'sup2': 178,\n    'sup3': 179,\n    'acute': 180,\n    'micro': 181,\n    'para': 182,\n    'middot': 183,\n    'cedil': 184,\n    'ordm': 186,\n    'raquo': 187,\n    'frac14': 188,\n    'frac12': 189,\n    'frac34': 190,\n    'iquest': 191,\n    'times': 215,\n    'divide': 247,\n    'OElig': 338,\n    'oelig': 339,\n    'Scaron': 352,\n    'scaron': 353,\n    'Yuml': 376,\n    'fnof': 402,\n    'circ': 710,\n    'tilde': 732,\n    'Alpha': 913,\n    'Beta': 914,\n    'Gamma': 915,\n    'Delta': 916,\n    'Epsilon': 917,\n    'Zeta': 918,\n    'Eta': 919,\n    'Theta': 920,\n    'Iota': 921,\n    'Kappa': 922,\n    'Lambda': 923,\n    'Mu': 924,\n    'Nu': 925,\n    'Xi': 926,\n    'Omicron': 927,\n    'Pi': 928,\n    'Rho': 929,\n    'Sigma': 931,\n    'Tau': 932,\n    'Upsilon': 933,\n    'Phi': 934,\n    'Chi': 935,\n    'Psi': 936,\n    'Omega': 937,\n    'alpha': 945,\n    'beta': 946,\n    'gamma': 947,\n    'delta': 948,\n    'epsilon': 949,\n    'zeta': 950,\n    'eta': 951,\n    'theta': 952,\n    'iota': 953,\n    'kappa': 954,\n    'lambda': 955,\n    'mu': 956,\n    'nu': 957,\n    'xi': 958,\n    'omicron': 959,\n    'pi': 960,\n    'rho': 961,\n    'sigmaf': 962,\n    'sigma': 963,\n    'tau': 964,\n    'upsilon': 965,\n    'phi': 966,\n    'chi': 967,\n    'psi': 968,\n    'omega': 969,\n    'thetasym': 977,\n    'upsih': 978,\n    'piv': 982,\n    'ensp': 8194,\n    'emsp': 8195,\n    'thinsp': 8201,\n    'zwnj': 8204,\n    'zwj': 8205,\n    'lrm': 8206,\n    'rlm': 8207,\n    'ndash': 8211,\n    'mdash': 8212,\n    'lsquo': 8216,\n    'rsquo': 8217,\n    'sbquo': 8218,\n    'ldquo': 8220,\n    'rdquo': 8221,\n    'bdquo': 8222,\n    'dagger': 8224,\n    'Dagger': 8225,\n    'bull': 8226,\n    'hellip': 8230,\n    'permil': 8240,\n    'prime': 8242,\n    'Prime': 8243,\n    'lsaquo': 8249,\n    'rsaquo': 8250,\n    'oline': 8254,\n    'frasl': 8260,\n    'euro': 8364,\n    'image': 8465,\n    'weierp': 8472,\n    'real': 8476,\n    'trade': 8482,\n    'alefsym': 8501,\n    'larr': 8592,\n    'uarr': 8593,\n    'rarr': 8594,\n    'darr': 8595,\n    'harr': 8596,\n    'crarr': 8629,\n    'lArr': 8656,\n    'uArr': 8657,\n    'rArr': 8658,\n    'dArr': 8659,\n    'hArr': 8660,\n    'forall': 8704,\n    'part': 8706,\n    'exist': 8707,\n    'empty': 8709,\n    'nabla': 8711,\n    'isin': 8712,\n    'notin': 8713,\n    'ni': 8715,\n    'prod': 8719,\n    'sum': 8721,\n    'minus': 8722,\n    'lowast': 8727,\n    'radic': 8730,\n    'prop': 8733,\n    'infin': 8734,\n    'ang': 8736,\n    'and': 8743,\n    'or': 8744,\n    'cap': 8745,\n    'cup': 8746,\n    'int': 8747,\n    'there4': 8756,\n    'sim': 8764,\n    'cong': 8773,\n    'asymp': 8776,\n    'ne': 8800,\n    'equiv': 8801,\n    'le': 8804,\n    'ge': 8805,\n    'sub': 8834,\n    'sup': 8835,\n    'nsub': 8836,\n    'sube': 8838,\n    'supe': 8839,\n    'oplus': 8853,\n    'otimes': 8855,\n    'perp': 8869,\n    'sdot': 8901,\n    'lceil': 8968,\n    'rceil': 8969,\n    'lfloor': 8970,\n    'rfloor': 8971,\n    'lang': 9001,\n    'rang': 9002,\n    'loz': 9674,\n    'spades': 9824,\n    'clubs': 9827,\n    'hearts': 9829,\n    'diams': 9830\n  }\n\n  Object.keys(sax.ENTITIES).forEach(function (key) {\n    var e = sax.ENTITIES[key]\n    var s = typeof e === 'number' ? String.fromCharCode(e) : e\n    sax.ENTITIES[key] = s\n  })\n\n  for (var s in sax.STATE) {\n    sax.STATE[sax.STATE[s]] = s\n  }\n\n  // shorthand\n  S = sax.STATE\n\n  function emit (parser, event, data) {\n    parser[event] && parser[event](data)\n  }\n\n  function emitNode (parser, nodeType, data) {\n    if (parser.textNode) closeText(parser)\n    emit(parser, nodeType, data)\n  }\n\n  function closeText (parser) {\n    parser.textNode = textopts(parser.opt, parser.textNode)\n    if (parser.textNode) emit(parser, 'ontext', parser.textNode)\n    parser.textNode = ''\n  }\n\n  function textopts (opt, text) {\n    if (opt.trim) text = text.trim()\n    if (opt.normalize) text = text.replace(/\\s+/g, ' ')\n    return text\n  }\n\n  function error (parser, er) {\n    closeText(parser)\n    if (parser.trackPosition) {\n      er += '\\nLine: ' + parser.line +\n        '\\nColumn: ' + parser.column +\n        '\\nChar: ' + parser.c\n    }\n    er = new Error(er)\n    parser.error = er\n    emit(parser, 'onerror', er)\n    return parser\n  }\n\n  function end (parser) {\n    if (parser.sawRoot && !parser.closedRoot) strictFail(parser, 'Unclosed root tag')\n    if ((parser.state !== S.BEGIN) &&\n      (parser.state !== S.BEGIN_WHITESPACE) &&\n      (parser.state !== S.TEXT)) {\n      error(parser, 'Unexpected end')\n    }\n    closeText(parser)\n    parser.c = ''\n    parser.closed = true\n    emit(parser, 'onend')\n    SAXParser.call(parser, parser.strict, parser.opt)\n    return parser\n  }\n\n  function strictFail (parser, message) {\n    if (typeof parser !== 'object' || !(parser instanceof SAXParser)) {\n      throw new Error('bad call to strictFail')\n    }\n    if (parser.strict) {\n      error(parser, message)\n    }\n  }\n\n  function newTag (parser) {\n    if (!parser.strict) parser.tagName = parser.tagName[parser.looseCase]()\n    var parent = parser.tags[parser.tags.length - 1] || parser\n    var tag = parser.tag = { name: parser.tagName, attributes: {} }\n\n    // will be overridden if tag contails an xmlns=\"foo\" or xmlns:foo=\"bar\"\n    if (parser.opt.xmlns) {\n      tag.ns = parent.ns\n    }\n    parser.attribList.length = 0\n    emitNode(parser, 'onopentagstart', tag)\n  }\n\n  function qname (name, attribute) {\n    var i = name.indexOf(':')\n    var qualName = i < 0 ? [ '', name ] : name.split(':')\n    var prefix = qualName[0]\n    var local = qualName[1]\n\n    // <x \"xmlns\"=\"http://foo\">\n    if (attribute && name === 'xmlns') {\n      prefix = 'xmlns'\n      local = ''\n    }\n\n    return { prefix: prefix, local: local }\n  }\n\n  function attrib (parser) {\n    if (!parser.strict) {\n      parser.attribName = parser.attribName[parser.looseCase]()\n    }\n\n    if (parser.attribList.indexOf(parser.attribName) !== -1 ||\n      parser.tag.attributes.hasOwnProperty(parser.attribName)) {\n      parser.attribName = parser.attribValue = ''\n      return\n    }\n\n    if (parser.opt.xmlns) {\n      var qn = qname(parser.attribName, true)\n      var prefix = qn.prefix\n      var local = qn.local\n\n      if (prefix === 'xmlns') {\n        // namespace binding attribute. push the binding into scope\n        if (local === 'xml' && parser.attribValue !== XML_NAMESPACE) {\n          strictFail(parser,\n            'xml: prefix must be bound to ' + XML_NAMESPACE + '\\n' +\n            'Actual: ' + parser.attribValue)\n        } else if (local === 'xmlns' && parser.attribValue !== XMLNS_NAMESPACE) {\n          strictFail(parser,\n            'xmlns: prefix must be bound to ' + XMLNS_NAMESPACE + '\\n' +\n            'Actual: ' + parser.attribValue)\n        } else {\n          var tag = parser.tag\n          var parent = parser.tags[parser.tags.length - 1] || parser\n          if (tag.ns === parent.ns) {\n            tag.ns = Object.create(parent.ns)\n          }\n          tag.ns[local] = parser.attribValue\n        }\n      }\n\n      // defer onattribute events until all attributes have been seen\n      // so any new bindings can take effect. preserve attribute order\n      // so deferred events can be emitted in document order\n      parser.attribList.push([parser.attribName, parser.attribValue])\n    } else {\n      // in non-xmlns mode, we can emit the event right away\n      parser.tag.attributes[parser.attribName] = parser.attribValue\n      emitNode(parser, 'onattribute', {\n        name: parser.attribName,\n        value: parser.attribValue\n      })\n    }\n\n    parser.attribName = parser.attribValue = ''\n  }\n\n  function openTag (parser, selfClosing) {\n    if (parser.opt.xmlns) {\n      // emit namespace binding events\n      var tag = parser.tag\n\n      // add namespace info to tag\n      var qn = qname(parser.tagName)\n      tag.prefix = qn.prefix\n      tag.local = qn.local\n      tag.uri = tag.ns[qn.prefix] || ''\n\n      if (tag.prefix && !tag.uri) {\n        strictFail(parser, 'Unbound namespace prefix: ' +\n          JSON.stringify(parser.tagName))\n        tag.uri = qn.prefix\n      }\n\n      var parent = parser.tags[parser.tags.length - 1] || parser\n      if (tag.ns && parent.ns !== tag.ns) {\n        Object.keys(tag.ns).forEach(function (p) {\n          emitNode(parser, 'onopennamespace', {\n            prefix: p,\n            uri: tag.ns[p]\n          })\n        })\n      }\n\n      // handle deferred onattribute events\n      // Note: do not apply default ns to attributes:\n      //   http://www.w3.org/TR/REC-xml-names/#defaulting\n      for (var i = 0, l = parser.attribList.length; i < l; i++) {\n        var nv = parser.attribList[i]\n        var name = nv[0]\n        var value = nv[1]\n        var qualName = qname(name, true)\n        var prefix = qualName.prefix\n        var local = qualName.local\n        var uri = prefix === '' ? '' : (tag.ns[prefix] || '')\n        var a = {\n          name: name,\n          value: value,\n          prefix: prefix,\n          local: local,\n          uri: uri\n        }\n\n        // if there's any attributes with an undefined namespace,\n        // then fail on them now.\n        if (prefix && prefix !== 'xmlns' && !uri) {\n          strictFail(parser, 'Unbound namespace prefix: ' +\n            JSON.stringify(prefix))\n          a.uri = prefix\n        }\n        parser.tag.attributes[name] = a\n        emitNode(parser, 'onattribute', a)\n      }\n      parser.attribList.length = 0\n    }\n\n    parser.tag.isSelfClosing = !!selfClosing\n\n    // process the tag\n    parser.sawRoot = true\n    parser.tags.push(parser.tag)\n    emitNode(parser, 'onopentag', parser.tag)\n    if (!selfClosing) {\n      // special case for <script> in non-strict mode.\n      if (!parser.noscript && parser.tagName.toLowerCase() === 'script') {\n        parser.state = S.SCRIPT\n      } else {\n        parser.state = S.TEXT\n      }\n      parser.tag = null\n      parser.tagName = ''\n    }\n    parser.attribName = parser.attribValue = ''\n    parser.attribList.length = 0\n  }\n\n  function closeTag (parser) {\n    if (!parser.tagName) {\n      strictFail(parser, 'Weird empty close tag.')\n      parser.textNode += '</>'\n      parser.state = S.TEXT\n      return\n    }\n\n    if (parser.script) {\n      if (parser.tagName !== 'script') {\n        parser.script += '</' + parser.tagName + '>'\n        parser.tagName = ''\n        parser.state = S.SCRIPT\n        return\n      }\n      emitNode(parser, 'onscript', parser.script)\n      parser.script = ''\n    }\n\n    // first make sure that the closing tag actually exists.\n    // <a><b></c></b></a> will close everything, otherwise.\n    var t = parser.tags.length\n    var tagName = parser.tagName\n    if (!parser.strict) {\n      tagName = tagName[parser.looseCase]()\n    }\n    var closeTo = tagName\n    while (t--) {\n      var close = parser.tags[t]\n      if (close.name !== closeTo) {\n        // fail the first time in strict mode\n        strictFail(parser, 'Unexpected close tag')\n      } else {\n        break\n      }\n    }\n\n    // didn't find it.  we already failed for strict, so just abort.\n    if (t < 0) {\n      strictFail(parser, 'Unmatched closing tag: ' + parser.tagName)\n      parser.textNode += '</' + parser.tagName + '>'\n      parser.state = S.TEXT\n      return\n    }\n    parser.tagName = tagName\n    var s = parser.tags.length\n    while (s-- > t) {\n      var tag = parser.tag = parser.tags.pop()\n      parser.tagName = parser.tag.name\n      emitNode(parser, 'onclosetag', parser.tagName)\n\n      var x = {}\n      for (var i in tag.ns) {\n        x[i] = tag.ns[i]\n      }\n\n      var parent = parser.tags[parser.tags.length - 1] || parser\n      if (parser.opt.xmlns && tag.ns !== parent.ns) {\n        // remove namespace bindings introduced by tag\n        Object.keys(tag.ns).forEach(function (p) {\n          var n = tag.ns[p]\n          emitNode(parser, 'onclosenamespace', { prefix: p, uri: n })\n        })\n      }\n    }\n    if (t === 0) parser.closedRoot = true\n    parser.tagName = parser.attribValue = parser.attribName = ''\n    parser.attribList.length = 0\n    parser.state = S.TEXT\n  }\n\n  function parseEntity (parser) {\n    var entity = parser.entity\n    var entityLC = entity.toLowerCase()\n    var num\n    var numStr = ''\n\n    if (parser.ENTITIES[entity]) {\n      return parser.ENTITIES[entity]\n    }\n    if (parser.ENTITIES[entityLC]) {\n      return parser.ENTITIES[entityLC]\n    }\n    entity = entityLC\n    if (entity.charAt(0) === '#') {\n      if (entity.charAt(1) === 'x') {\n        entity = entity.slice(2)\n        num = parseInt(entity, 16)\n        numStr = num.toString(16)\n      } else {\n        entity = entity.slice(1)\n        num = parseInt(entity, 10)\n        numStr = num.toString(10)\n      }\n    }\n    entity = entity.replace(/^0+/, '')\n    if (isNaN(num) || numStr.toLowerCase() !== entity) {\n      strictFail(parser, 'Invalid character entity')\n      return '&' + parser.entity + ';'\n    }\n\n    return String.fromCodePoint(num)\n  }\n\n  function beginWhiteSpace (parser, c) {\n    if (c === '<') {\n      parser.state = S.OPEN_WAKA\n      parser.startTagPosition = parser.position\n    } else if (!isWhitespace(c)) {\n      // have to process this as a text node.\n      // weird, but happens.\n      strictFail(parser, 'Non-whitespace before first tag.')\n      parser.textNode = c\n      parser.state = S.TEXT\n    }\n  }\n\n  function charAt (chunk, i) {\n    var result = ''\n    if (i < chunk.length) {\n      result = chunk.charAt(i)\n    }\n    return result\n  }\n\n  function write (chunk) {\n    var parser = this\n    if (this.error) {\n      throw this.error\n    }\n    if (parser.closed) {\n      return error(parser,\n        'Cannot write after close. Assign an onready handler.')\n    }\n    if (chunk === null) {\n      return end(parser)\n    }\n    if (typeof chunk === 'object') {\n      chunk = chunk.toString()\n    }\n    var i = 0\n    var c = ''\n    while (true) {\n      c = charAt(chunk, i++)\n      parser.c = c\n\n      if (!c) {\n        break\n      }\n\n      if (parser.trackPosition) {\n        parser.position++\n        if (c === '\\n') {\n          parser.line++\n          parser.column = 0\n        } else {\n          parser.column++\n        }\n      }\n\n      switch (parser.state) {\n        case S.BEGIN:\n          parser.state = S.BEGIN_WHITESPACE\n          if (c === '\\uFEFF') {\n            continue\n          }\n          beginWhiteSpace(parser, c)\n          continue\n\n        case S.BEGIN_WHITESPACE:\n          beginWhiteSpace(parser, c)\n          continue\n\n        case S.TEXT:\n          if (parser.sawRoot && !parser.closedRoot) {\n            var starti = i - 1\n            while (c && c !== '<' && c !== '&') {\n              c = charAt(chunk, i++)\n              if (c && parser.trackPosition) {\n                parser.position++\n                if (c === '\\n') {\n                  parser.line++\n                  parser.column = 0\n                } else {\n                  parser.column++\n                }\n              }\n            }\n            parser.textNode += chunk.substring(starti, i - 1)\n          }\n          if (c === '<' && !(parser.sawRoot && parser.closedRoot && !parser.strict)) {\n            parser.state = S.OPEN_WAKA\n            parser.startTagPosition = parser.position\n          } else {\n            if (!isWhitespace(c) && (!parser.sawRoot || parser.closedRoot)) {\n              strictFail(parser, 'Text data outside of root node.')\n            }\n            if (c === '&') {\n              parser.state = S.TEXT_ENTITY\n            } else {\n              parser.textNode += c\n            }\n          }\n          continue\n\n        case S.SCRIPT:\n          // only non-strict\n          if (c === '<') {\n            parser.state = S.SCRIPT_ENDING\n          } else {\n            parser.script += c\n          }\n          continue\n\n        case S.SCRIPT_ENDING:\n          if (c === '/') {\n            parser.state = S.CLOSE_TAG\n          } else {\n            parser.script += '<' + c\n            parser.state = S.SCRIPT\n          }\n          continue\n\n        case S.OPEN_WAKA:\n          // either a /, ?, !, or text is coming next.\n          if (c === '!') {\n            parser.state = S.SGML_DECL\n            parser.sgmlDecl = ''\n          } else if (isWhitespace(c)) {\n            // wait for it...\n          } else if (isMatch(nameStart, c)) {\n            parser.state = S.OPEN_TAG\n            parser.tagName = c\n          } else if (c === '/') {\n            parser.state = S.CLOSE_TAG\n            parser.tagName = ''\n          } else if (c === '?') {\n            parser.state = S.PROC_INST\n            parser.procInstName = parser.procInstBody = ''\n          } else {\n            strictFail(parser, 'Unencoded <')\n            // if there was some whitespace, then add that in.\n            if (parser.startTagPosition + 1 < parser.position) {\n              var pad = parser.position - parser.startTagPosition\n              c = new Array(pad).join(' ') + c\n            }\n            parser.textNode += '<' + c\n            parser.state = S.TEXT\n          }\n          continue\n\n        case S.SGML_DECL:\n          if (parser.sgmlDecl + c === '--') {\n            parser.state = S.COMMENT\n            parser.comment = ''\n            parser.sgmlDecl = ''\n            continue;\n          }\n\n          if (parser.doctype && parser.doctype !== true && parser.sgmlDecl) {\n            parser.state = S.DOCTYPE_DTD\n            parser.doctype += '<!' + parser.sgmlDecl + c\n            parser.sgmlDecl = ''\n          } else if ((parser.sgmlDecl + c).toUpperCase() === CDATA) {\n            emitNode(parser, 'onopencdata')\n            parser.state = S.CDATA\n            parser.sgmlDecl = ''\n            parser.cdata = ''\n          } else if ((parser.sgmlDecl + c).toUpperCase() === DOCTYPE) {\n            parser.state = S.DOCTYPE\n            if (parser.doctype || parser.sawRoot) {\n              strictFail(parser,\n                'Inappropriately located doctype declaration')\n            }\n            parser.doctype = ''\n            parser.sgmlDecl = ''\n          } else if (c === '>') {\n            emitNode(parser, 'onsgmldeclaration', parser.sgmlDecl)\n            parser.sgmlDecl = ''\n            parser.state = S.TEXT\n          } else if (isQuote(c)) {\n            parser.state = S.SGML_DECL_QUOTED\n            parser.sgmlDecl += c\n          } else {\n            parser.sgmlDecl += c\n          }\n          continue\n\n        case S.SGML_DECL_QUOTED:\n          if (c === parser.q) {\n            parser.state = S.SGML_DECL\n            parser.q = ''\n          }\n          parser.sgmlDecl += c\n          continue\n\n        case S.DOCTYPE:\n          if (c === '>') {\n            parser.state = S.TEXT\n            emitNode(parser, 'ondoctype', parser.doctype)\n            parser.doctype = true // just remember that we saw it.\n          } else {\n            parser.doctype += c\n            if (c === '[') {\n              parser.state = S.DOCTYPE_DTD\n            } else if (isQuote(c)) {\n              parser.state = S.DOCTYPE_QUOTED\n              parser.q = c\n            }\n          }\n          continue\n\n        case S.DOCTYPE_QUOTED:\n          parser.doctype += c\n          if (c === parser.q) {\n            parser.q = ''\n            parser.state = S.DOCTYPE\n          }\n          continue\n\n        case S.DOCTYPE_DTD:\n          if (c === ']') {\n            parser.doctype += c\n            parser.state = S.DOCTYPE\n          } else if (c === '<') {\n            parser.state = S.OPEN_WAKA\n            parser.startTagPosition = parser.position\n          } else if (isQuote(c)) {\n            parser.doctype += c\n            parser.state = S.DOCTYPE_DTD_QUOTED\n            parser.q = c\n          } else {\n            parser.doctype += c\n          }\n          continue\n\n        case S.DOCTYPE_DTD_QUOTED:\n          parser.doctype += c\n          if (c === parser.q) {\n            parser.state = S.DOCTYPE_DTD\n            parser.q = ''\n          }\n          continue\n\n        case S.COMMENT:\n          if (c === '-') {\n            parser.state = S.COMMENT_ENDING\n          } else {\n            parser.comment += c\n          }\n          continue\n\n        case S.COMMENT_ENDING:\n          if (c === '-') {\n            parser.state = S.COMMENT_ENDED\n            parser.comment = textopts(parser.opt, parser.comment)\n            if (parser.comment) {\n              emitNode(parser, 'oncomment', parser.comment)\n            }\n            parser.comment = ''\n          } else {\n            parser.comment += '-' + c\n            parser.state = S.COMMENT\n          }\n          continue\n\n        case S.COMMENT_ENDED:\n          if (c !== '>') {\n            strictFail(parser, 'Malformed comment')\n            // allow <!-- blah -- bloo --> in non-strict mode,\n            // which is a comment of \" blah -- bloo \"\n            parser.comment += '--' + c\n            parser.state = S.COMMENT\n          } else if (parser.doctype && parser.doctype !== true) {\n            parser.state = S.DOCTYPE_DTD\n          } else {\n            parser.state = S.TEXT\n          }\n          continue\n\n        case S.CDATA:\n          if (c === ']') {\n            parser.state = S.CDATA_ENDING\n          } else {\n            parser.cdata += c\n          }\n          continue\n\n        case S.CDATA_ENDING:\n          if (c === ']') {\n            parser.state = S.CDATA_ENDING_2\n          } else {\n            parser.cdata += ']' + c\n            parser.state = S.CDATA\n          }\n          continue\n\n        case S.CDATA_ENDING_2:\n          if (c === '>') {\n            if (parser.cdata) {\n              emitNode(parser, 'oncdata', parser.cdata)\n            }\n            emitNode(parser, 'onclosecdata')\n            parser.cdata = ''\n            parser.state = S.TEXT\n          } else if (c === ']') {\n            parser.cdata += ']'\n          } else {\n            parser.cdata += ']]' + c\n            parser.state = S.CDATA\n          }\n          continue\n\n        case S.PROC_INST:\n          if (c === '?') {\n            parser.state = S.PROC_INST_ENDING\n          } else if (isWhitespace(c)) {\n            parser.state = S.PROC_INST_BODY\n          } else {\n            parser.procInstName += c\n          }\n          continue\n\n        case S.PROC_INST_BODY:\n          if (!parser.procInstBody && isWhitespace(c)) {\n            continue\n          } else if (c === '?') {\n            parser.state = S.PROC_INST_ENDING\n          } else {\n            parser.procInstBody += c\n          }\n          continue\n\n        case S.PROC_INST_ENDING:\n          if (c === '>') {\n            emitNode(parser, 'onprocessinginstruction', {\n              name: parser.procInstName,\n              body: parser.procInstBody\n            })\n            parser.procInstName = parser.procInstBody = ''\n            parser.state = S.TEXT\n          } else {\n            parser.procInstBody += '?' + c\n            parser.state = S.PROC_INST_BODY\n          }\n          continue\n\n        case S.OPEN_TAG:\n          if (isMatch(nameBody, c)) {\n            parser.tagName += c\n          } else {\n            newTag(parser)\n            if (c === '>') {\n              openTag(parser)\n            } else if (c === '/') {\n              parser.state = S.OPEN_TAG_SLASH\n            } else {\n              if (!isWhitespace(c)) {\n                strictFail(parser, 'Invalid character in tag name')\n              }\n              parser.state = S.ATTRIB\n            }\n          }\n          continue\n\n        case S.OPEN_TAG_SLASH:\n          if (c === '>') {\n            openTag(parser, true)\n            closeTag(parser)\n          } else {\n            strictFail(parser, 'Forward-slash in opening tag not followed by >')\n            parser.state = S.ATTRIB\n          }\n          continue\n\n        case S.ATTRIB:\n          // haven't read the attribute name yet.\n          if (isWhitespace(c)) {\n            continue\n          } else if (c === '>') {\n            openTag(parser)\n          } else if (c === '/') {\n            parser.state = S.OPEN_TAG_SLASH\n          } else if (isMatch(nameStart, c)) {\n            parser.attribName = c\n            parser.attribValue = ''\n            parser.state = S.ATTRIB_NAME\n          } else {\n            strictFail(parser, 'Invalid attribute name')\n          }\n          continue\n\n        case S.ATTRIB_NAME:\n          if (c === '=') {\n            parser.state = S.ATTRIB_VALUE\n          } else if (c === '>') {\n            strictFail(parser, 'Attribute without value')\n            parser.attribValue = parser.attribName\n            attrib(parser)\n            openTag(parser)\n          } else if (isWhitespace(c)) {\n            parser.state = S.ATTRIB_NAME_SAW_WHITE\n          } else if (isMatch(nameBody, c)) {\n            parser.attribName += c\n          } else {\n            strictFail(parser, 'Invalid attribute name')\n          }\n          continue\n\n        case S.ATTRIB_NAME_SAW_WHITE:\n          if (c === '=') {\n            parser.state = S.ATTRIB_VALUE\n          } else if (isWhitespace(c)) {\n            continue\n          } else {\n            strictFail(parser, 'Attribute without value')\n            parser.tag.attributes[parser.attribName] = ''\n            parser.attribValue = ''\n            emitNode(parser, 'onattribute', {\n              name: parser.attribName,\n              value: ''\n            })\n            parser.attribName = ''\n            if (c === '>') {\n              openTag(parser)\n            } else if (isMatch(nameStart, c)) {\n              parser.attribName = c\n              parser.state = S.ATTRIB_NAME\n            } else {\n              strictFail(parser, 'Invalid attribute name')\n              parser.state = S.ATTRIB\n            }\n          }\n          continue\n\n        case S.ATTRIB_VALUE:\n          if (isWhitespace(c)) {\n            continue\n          } else if (isQuote(c)) {\n            parser.q = c\n            parser.state = S.ATTRIB_VALUE_QUOTED\n          } else {\n            if (!parser.opt.unquotedAttributeValues) {\n              error(parser, 'Unquoted attribute value')\n            }\n            parser.state = S.ATTRIB_VALUE_UNQUOTED\n            parser.attribValue = c\n          }\n          continue\n\n        case S.ATTRIB_VALUE_QUOTED:\n          if (c !== parser.q) {\n            if (c === '&') {\n              parser.state = S.ATTRIB_VALUE_ENTITY_Q\n            } else {\n              parser.attribValue += c\n            }\n            continue\n          }\n          attrib(parser)\n          parser.q = ''\n          parser.state = S.ATTRIB_VALUE_CLOSED\n          continue\n\n        case S.ATTRIB_VALUE_CLOSED:\n          if (isWhitespace(c)) {\n            parser.state = S.ATTRIB\n          } else if (c === '>') {\n            openTag(parser)\n          } else if (c === '/') {\n            parser.state = S.OPEN_TAG_SLASH\n          } else if (isMatch(nameStart, c)) {\n            strictFail(parser, 'No whitespace between attributes')\n            parser.attribName = c\n            parser.attribValue = ''\n            parser.state = S.ATTRIB_NAME\n          } else {\n            strictFail(parser, 'Invalid attribute name')\n          }\n          continue\n\n        case S.ATTRIB_VALUE_UNQUOTED:\n          if (!isAttribEnd(c)) {\n            if (c === '&') {\n              parser.state = S.ATTRIB_VALUE_ENTITY_U\n            } else {\n              parser.attribValue += c\n            }\n            continue\n          }\n          attrib(parser)\n          if (c === '>') {\n            openTag(parser)\n          } else {\n            parser.state = S.ATTRIB\n          }\n          continue\n\n        case S.CLOSE_TAG:\n          if (!parser.tagName) {\n            if (isWhitespace(c)) {\n              continue\n            } else if (notMatch(nameStart, c)) {\n              if (parser.script) {\n                parser.script += '</' + c\n                parser.state = S.SCRIPT\n              } else {\n                strictFail(parser, 'Invalid tagname in closing tag.')\n              }\n            } else {\n              parser.tagName = c\n            }\n          } else if (c === '>') {\n            closeTag(parser)\n          } else if (isMatch(nameBody, c)) {\n            parser.tagName += c\n          } else if (parser.script) {\n            parser.script += '</' + parser.tagName\n            parser.tagName = ''\n            parser.state = S.SCRIPT\n          } else {\n            if (!isWhitespace(c)) {\n              strictFail(parser, 'Invalid tagname in closing tag')\n            }\n            parser.state = S.CLOSE_TAG_SAW_WHITE\n          }\n          continue\n\n        case S.CLOSE_TAG_SAW_WHITE:\n          if (isWhitespace(c)) {\n            continue\n          }\n          if (c === '>') {\n            closeTag(parser)\n          } else {\n            strictFail(parser, 'Invalid characters in closing tag')\n          }\n          continue\n\n        case S.TEXT_ENTITY:\n        case S.ATTRIB_VALUE_ENTITY_Q:\n        case S.ATTRIB_VALUE_ENTITY_U:\n          var returnState\n          var buffer\n          switch (parser.state) {\n            case S.TEXT_ENTITY:\n              returnState = S.TEXT\n              buffer = 'textNode'\n              break\n\n            case S.ATTRIB_VALUE_ENTITY_Q:\n              returnState = S.ATTRIB_VALUE_QUOTED\n              buffer = 'attribValue'\n              break\n\n            case S.ATTRIB_VALUE_ENTITY_U:\n              returnState = S.ATTRIB_VALUE_UNQUOTED\n              buffer = 'attribValue'\n              break\n          }\n\n          if (c === ';') {\n            var parsedEntity = parseEntity(parser)\n            if (parser.opt.unparsedEntities && !Object.values(sax.XML_ENTITIES).includes(parsedEntity)) {\n              parser.entity = ''\n              parser.state = returnState\n              parser.write(parsedEntity)\n            } else {\n              parser[buffer] += parsedEntity\n              parser.entity = ''\n              parser.state = returnState\n            }\n          } else if (isMatch(parser.entity.length ? entityBody : entityStart, c)) {\n            parser.entity += c\n          } else {\n            strictFail(parser, 'Invalid character in entity name')\n            parser[buffer] += '&' + parser.entity + c\n            parser.entity = ''\n            parser.state = returnState\n          }\n\n          continue\n\n        default: /* istanbul ignore next */ {\n          throw new Error(parser, 'Unknown state: ' + parser.state)\n        }\n      }\n    } // while\n\n    if (parser.position >= parser.bufferCheckPosition) {\n      checkBufferLength(parser)\n    }\n    return parser\n  }\n\n  /*! http://mths.be/fromcodepoint v0.1.0 by @mathias */\n  /* istanbul ignore next */\n  if (!String.fromCodePoint) {\n    (function () {\n      var stringFromCharCode = String.fromCharCode\n      var floor = Math.floor\n      var fromCodePoint = function () {\n        var MAX_SIZE = 0x4000\n        var codeUnits = []\n        var highSurrogate\n        var lowSurrogate\n        var index = -1\n        var length = arguments.length\n        if (!length) {\n          return ''\n        }\n        var result = ''\n        while (++index < length) {\n          var codePoint = Number(arguments[index])\n          if (\n            !isFinite(codePoint) || // `NaN`, `+Infinity`, or `-Infinity`\n            codePoint < 0 || // not a valid Unicode code point\n            codePoint > 0x10FFFF || // not a valid Unicode code point\n            floor(codePoint) !== codePoint // not an integer\n          ) {\n            throw RangeError('Invalid code point: ' + codePoint)\n          }\n          if (codePoint <= 0xFFFF) { // BMP code point\n            codeUnits.push(codePoint)\n          } else { // Astral code point; split in surrogate halves\n            // http://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae\n            codePoint -= 0x10000\n            highSurrogate = (codePoint >> 10) + 0xD800\n            lowSurrogate = (codePoint % 0x400) + 0xDC00\n            codeUnits.push(highSurrogate, lowSurrogate)\n          }\n          if (index + 1 === length || codeUnits.length > MAX_SIZE) {\n            result += stringFromCharCode.apply(null, codeUnits)\n            codeUnits.length = 0\n          }\n        }\n        return result\n      }\n      /* istanbul ignore next */\n      if (Object.defineProperty) {\n        Object.defineProperty(String, 'fromCodePoint', {\n          value: fromCodePoint,\n          configurable: true,\n          writable: true\n        })\n      } else {\n        String.fromCodePoint = fromCodePoint\n      }\n    }())\n  }\n})(typeof exports === 'undefined' ? this.sax = {} : exports)\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  \"use strict\";\n  exports.stripBOM = function(str) {\n    if (str[0] === '\\uFEFF') {\n      return str.substring(1);\n    } else {\n      return str;\n    }\n  };\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  \"use strict\";\n  var prefixMatch;\n\n  prefixMatch = new RegExp(/(?!xmlns)^.*:/);\n\n  exports.normalize = function(str) {\n    return str.toLowerCase();\n  };\n\n  exports.firstCharLowerCase = function(str) {\n    return str.charAt(0).toLowerCase() + str.slice(1);\n  };\n\n  exports.stripPrefix = function(str) {\n    return str.replace(prefixMatch, '');\n  };\n\n  exports.parseNumbers = function(str) {\n    if (!isNaN(str)) {\n      str = str % 1 === 0 ? parseInt(str, 10) : parseFloat(str);\n    }\n    return str;\n  };\n\n  exports.parseBooleans = function(str) {\n    if (/^(?:true|false)$/i.test(str)) {\n      str = str.toLowerCase() === 'true';\n    }\n    return str;\n  };\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  \"use strict\";\n  var bom, defaults, defineProperty, events, isEmpty, processItem, processors, sax, setImmediate,\n    bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; },\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  sax = require('sax');\n\n  events = require('events');\n\n  bom = require('./bom');\n\n  processors = require('./processors');\n\n  setImmediate = require('timers').setImmediate;\n\n  defaults = require('./defaults').defaults;\n\n  isEmpty = function(thing) {\n    return typeof thing === \"object\" && (thing != null) && Object.keys(thing).length === 0;\n  };\n\n  processItem = function(processors, item, key) {\n    var i, len, process;\n    for (i = 0, len = processors.length; i < len; i++) {\n      process = processors[i];\n      item = process(item, key);\n    }\n    return item;\n  };\n\n  defineProperty = function(obj, key, value) {\n    var descriptor;\n    descriptor = Object.create(null);\n    descriptor.value = value;\n    descriptor.writable = true;\n    descriptor.enumerable = true;\n    descriptor.configurable = true;\n    return Object.defineProperty(obj, key, descriptor);\n  };\n\n  exports.Parser = (function(superClass) {\n    extend(Parser, superClass);\n\n    function Parser(opts) {\n      this.parseStringPromise = bind(this.parseStringPromise, this);\n      this.parseString = bind(this.parseString, this);\n      this.reset = bind(this.reset, this);\n      this.assignOrPush = bind(this.assignOrPush, this);\n      this.processAsync = bind(this.processAsync, this);\n      var key, ref, value;\n      if (!(this instanceof exports.Parser)) {\n        return new exports.Parser(opts);\n      }\n      this.options = {};\n      ref = defaults[\"0.2\"];\n      for (key in ref) {\n        if (!hasProp.call(ref, key)) continue;\n        value = ref[key];\n        this.options[key] = value;\n      }\n      for (key in opts) {\n        if (!hasProp.call(opts, key)) continue;\n        value = opts[key];\n        this.options[key] = value;\n      }\n      if (this.options.xmlns) {\n        this.options.xmlnskey = this.options.attrkey + \"ns\";\n      }\n      if (this.options.normalizeTags) {\n        if (!this.options.tagNameProcessors) {\n          this.options.tagNameProcessors = [];\n        }\n        this.options.tagNameProcessors.unshift(processors.normalize);\n      }\n      this.reset();\n    }\n\n    Parser.prototype.processAsync = function() {\n      var chunk, err;\n      try {\n        if (this.remaining.length <= this.options.chunkSize) {\n          chunk = this.remaining;\n          this.remaining = '';\n          this.saxParser = this.saxParser.write(chunk);\n          return this.saxParser.close();\n        } else {\n          chunk = this.remaining.substr(0, this.options.chunkSize);\n          this.remaining = this.remaining.substr(this.options.chunkSize, this.remaining.length);\n          this.saxParser = this.saxParser.write(chunk);\n          return setImmediate(this.processAsync);\n        }\n      } catch (error1) {\n        err = error1;\n        if (!this.saxParser.errThrown) {\n          this.saxParser.errThrown = true;\n          return this.emit(err);\n        }\n      }\n    };\n\n    Parser.prototype.assignOrPush = function(obj, key, newValue) {\n      if (!(key in obj)) {\n        if (!this.options.explicitArray) {\n          return defineProperty(obj, key, newValue);\n        } else {\n          return defineProperty(obj, key, [newValue]);\n        }\n      } else {\n        if (!(obj[key] instanceof Array)) {\n          defineProperty(obj, key, [obj[key]]);\n        }\n        return obj[key].push(newValue);\n      }\n    };\n\n    Parser.prototype.reset = function() {\n      var attrkey, charkey, ontext, stack;\n      this.removeAllListeners();\n      this.saxParser = sax.parser(this.options.strict, {\n        trim: false,\n        normalize: false,\n        xmlns: this.options.xmlns\n      });\n      this.saxParser.errThrown = false;\n      this.saxParser.onerror = (function(_this) {\n        return function(error) {\n          _this.saxParser.resume();\n          if (!_this.saxParser.errThrown) {\n            _this.saxParser.errThrown = true;\n            return _this.emit(\"error\", error);\n          }\n        };\n      })(this);\n      this.saxParser.onend = (function(_this) {\n        return function() {\n          if (!_this.saxParser.ended) {\n            _this.saxParser.ended = true;\n            return _this.emit(\"end\", _this.resultObject);\n          }\n        };\n      })(this);\n      this.saxParser.ended = false;\n      this.EXPLICIT_CHARKEY = this.options.explicitCharkey;\n      this.resultObject = null;\n      stack = [];\n      attrkey = this.options.attrkey;\n      charkey = this.options.charkey;\n      this.saxParser.onopentag = (function(_this) {\n        return function(node) {\n          var key, newValue, obj, processedKey, ref;\n          obj = {};\n          obj[charkey] = \"\";\n          if (!_this.options.ignoreAttrs) {\n            ref = node.attributes;\n            for (key in ref) {\n              if (!hasProp.call(ref, key)) continue;\n              if (!(attrkey in obj) && !_this.options.mergeAttrs) {\n                obj[attrkey] = {};\n              }\n              newValue = _this.options.attrValueProcessors ? processItem(_this.options.attrValueProcessors, node.attributes[key], key) : node.attributes[key];\n              processedKey = _this.options.attrNameProcessors ? processItem(_this.options.attrNameProcessors, key) : key;\n              if (_this.options.mergeAttrs) {\n                _this.assignOrPush(obj, processedKey, newValue);\n              } else {\n                defineProperty(obj[attrkey], processedKey, newValue);\n              }\n            }\n          }\n          obj[\"#name\"] = _this.options.tagNameProcessors ? processItem(_this.options.tagNameProcessors, node.name) : node.name;\n          if (_this.options.xmlns) {\n            obj[_this.options.xmlnskey] = {\n              uri: node.uri,\n              local: node.local\n            };\n          }\n          return stack.push(obj);\n        };\n      })(this);\n      this.saxParser.onclosetag = (function(_this) {\n        return function() {\n          var cdata, emptyStr, key, node, nodeName, obj, objClone, old, s, xpath;\n          obj = stack.pop();\n          nodeName = obj[\"#name\"];\n          if (!_this.options.explicitChildren || !_this.options.preserveChildrenOrder) {\n            delete obj[\"#name\"];\n          }\n          if (obj.cdata === true) {\n            cdata = obj.cdata;\n            delete obj.cdata;\n          }\n          s = stack[stack.length - 1];\n          if (obj[charkey].match(/^\\s*$/) && !cdata) {\n            emptyStr = obj[charkey];\n            delete obj[charkey];\n          } else {\n            if (_this.options.trim) {\n              obj[charkey] = obj[charkey].trim();\n            }\n            if (_this.options.normalize) {\n              obj[charkey] = obj[charkey].replace(/\\s{2,}/g, \" \").trim();\n            }\n            obj[charkey] = _this.options.valueProcessors ? processItem(_this.options.valueProcessors, obj[charkey], nodeName) : obj[charkey];\n            if (Object.keys(obj).length === 1 && charkey in obj && !_this.EXPLICIT_CHARKEY) {\n              obj = obj[charkey];\n            }\n          }\n          if (isEmpty(obj)) {\n            if (typeof _this.options.emptyTag === 'function') {\n              obj = _this.options.emptyTag();\n            } else {\n              obj = _this.options.emptyTag !== '' ? _this.options.emptyTag : emptyStr;\n            }\n          }\n          if (_this.options.validator != null) {\n            xpath = \"/\" + ((function() {\n              var i, len, results;\n              results = [];\n              for (i = 0, len = stack.length; i < len; i++) {\n                node = stack[i];\n                results.push(node[\"#name\"]);\n              }\n              return results;\n            })()).concat(nodeName).join(\"/\");\n            (function() {\n              var err;\n              try {\n                return obj = _this.options.validator(xpath, s && s[nodeName], obj);\n              } catch (error1) {\n                err = error1;\n                return _this.emit(\"error\", err);\n              }\n            })();\n          }\n          if (_this.options.explicitChildren && !_this.options.mergeAttrs && typeof obj === 'object') {\n            if (!_this.options.preserveChildrenOrder) {\n              node = {};\n              if (_this.options.attrkey in obj) {\n                node[_this.options.attrkey] = obj[_this.options.attrkey];\n                delete obj[_this.options.attrkey];\n              }\n              if (!_this.options.charsAsChildren && _this.options.charkey in obj) {\n                node[_this.options.charkey] = obj[_this.options.charkey];\n                delete obj[_this.options.charkey];\n              }\n              if (Object.getOwnPropertyNames(obj).length > 0) {\n                node[_this.options.childkey] = obj;\n              }\n              obj = node;\n            } else if (s) {\n              s[_this.options.childkey] = s[_this.options.childkey] || [];\n              objClone = {};\n              for (key in obj) {\n                if (!hasProp.call(obj, key)) continue;\n                defineProperty(objClone, key, obj[key]);\n              }\n              s[_this.options.childkey].push(objClone);\n              delete obj[\"#name\"];\n              if (Object.keys(obj).length === 1 && charkey in obj && !_this.EXPLICIT_CHARKEY) {\n                obj = obj[charkey];\n              }\n            }\n          }\n          if (stack.length > 0) {\n            return _this.assignOrPush(s, nodeName, obj);\n          } else {\n            if (_this.options.explicitRoot) {\n              old = obj;\n              obj = {};\n              defineProperty(obj, nodeName, old);\n            }\n            _this.resultObject = obj;\n            _this.saxParser.ended = true;\n            return _this.emit(\"end\", _this.resultObject);\n          }\n        };\n      })(this);\n      ontext = (function(_this) {\n        return function(text) {\n          var charChild, s;\n          s = stack[stack.length - 1];\n          if (s) {\n            s[charkey] += text;\n            if (_this.options.explicitChildren && _this.options.preserveChildrenOrder && _this.options.charsAsChildren && (_this.options.includeWhiteChars || text.replace(/\\\\n/g, '').trim() !== '')) {\n              s[_this.options.childkey] = s[_this.options.childkey] || [];\n              charChild = {\n                '#name': '__text__'\n              };\n              charChild[charkey] = text;\n              if (_this.options.normalize) {\n                charChild[charkey] = charChild[charkey].replace(/\\s{2,}/g, \" \").trim();\n              }\n              s[_this.options.childkey].push(charChild);\n            }\n            return s;\n          }\n        };\n      })(this);\n      this.saxParser.ontext = ontext;\n      return this.saxParser.oncdata = (function(_this) {\n        return function(text) {\n          var s;\n          s = ontext(text);\n          if (s) {\n            return s.cdata = true;\n          }\n        };\n      })(this);\n    };\n\n    Parser.prototype.parseString = function(str, cb) {\n      var err;\n      if ((cb != null) && typeof cb === \"function\") {\n        this.on(\"end\", function(result) {\n          this.reset();\n          return cb(null, result);\n        });\n        this.on(\"error\", function(err) {\n          this.reset();\n          return cb(err);\n        });\n      }\n      try {\n        str = str.toString();\n        if (str.trim() === '') {\n          this.emit(\"end\", null);\n          return true;\n        }\n        str = bom.stripBOM(str);\n        if (this.options.async) {\n          this.remaining = str;\n          setImmediate(this.processAsync);\n          return this.saxParser;\n        }\n        return this.saxParser.write(str).close();\n      } catch (error1) {\n        err = error1;\n        if (!(this.saxParser.errThrown || this.saxParser.ended)) {\n          this.emit('error', err);\n          return this.saxParser.errThrown = true;\n        } else if (this.saxParser.ended) {\n          throw err;\n        }\n      }\n    };\n\n    Parser.prototype.parseStringPromise = function(str) {\n      return new Promise((function(_this) {\n        return function(resolve, reject) {\n          return _this.parseString(str, function(err, value) {\n            if (err) {\n              return reject(err);\n            } else {\n              return resolve(value);\n            }\n          });\n        };\n      })(this));\n    };\n\n    return Parser;\n\n  })(events);\n\n  exports.parseString = function(str, a, b) {\n    var cb, options, parser;\n    if (b != null) {\n      if (typeof b === 'function') {\n        cb = b;\n      }\n      if (typeof a === 'object') {\n        options = a;\n      }\n    } else {\n      if (typeof a === 'function') {\n        cb = a;\n      }\n      options = {};\n    }\n    parser = new exports.Parser(options);\n    return parser.parseString(str, cb);\n  };\n\n  exports.parseStringPromise = function(str, a) {\n    var options, parser;\n    if (typeof a === 'object') {\n      options = a;\n    }\n    parser = new exports.Parser(options);\n    return parser.parseStringPromise(str);\n  };\n\n}).call(this);\n","// Generated by CoffeeScript 1.12.7\n(function() {\n  \"use strict\";\n  var builder, defaults, parser, processors,\n    extend = function(child, parent) { for (var key in parent) { if (hasProp.call(parent, key)) child[key] = parent[key]; } function ctor() { this.constructor = child; } ctor.prototype = parent.prototype; child.prototype = new ctor(); child.__super__ = parent.prototype; return child; },\n    hasProp = {}.hasOwnProperty;\n\n  defaults = require('./defaults');\n\n  builder = require('./builder');\n\n  parser = require('./parser');\n\n  processors = require('./processors');\n\n  exports.defaults = defaults.defaults;\n\n  exports.processors = processors;\n\n  exports.ValidationError = (function(superClass) {\n    extend(ValidationError, superClass);\n\n    function ValidationError(message) {\n      this.message = message;\n    }\n\n    return ValidationError;\n\n  })(Error);\n\n  exports.Builder = builder.Builder;\n\n  exports.Parser = parser.Parser;\n\n  exports.parseString = parser.parseString;\n\n  exports.parseStringPromise = parser.parseStringPromise;\n\n}).call(this);\n","/*\r\n * xpath.js\r\n *\r\n * An XPath 1.0 library for JavaScript.\r\n *\r\n * Cameron McCormack <cam (at) mcc.id.au>\r\n *\r\n * This work is licensed under the MIT License.\r\n *\r\n * Revision 20: April 26, 2011\r\n *   Fixed a typo resulting in FIRST_ORDERED_NODE_TYPE results being wrong,\r\n *   thanks to <shi_a009 (at) hotmail.com>.\r\n *\r\n * Revision 19: November 29, 2005\r\n *   Nodesets now store their nodes in a height balanced tree, increasing\r\n *   performance for the common case of selecting nodes in document order,\r\n *   thanks to Sébastien Cramatte <contact (at) zeninteractif.com>.\r\n *   AVL tree code adapted from Raimund Neumann <rnova (at) gmx.net>.\r\n *\r\n * Revision 18: October 27, 2005\r\n *   DOM 3 XPath support.  Caveats:\r\n *     - namespace prefixes aren't resolved in XPathEvaluator.createExpression,\r\n *       but in XPathExpression.evaluate.\r\n *     - XPathResult.invalidIteratorState is not implemented.\r\n *\r\n * Revision 17: October 25, 2005\r\n *   Some core XPath function fixes and a patch to avoid crashing certain\r\n *   versions of MSXML in PathExpr.prototype.getOwnerElement, thanks to\r\n *   Sébastien Cramatte <contact (at) zeninteractif.com>.\r\n *\r\n * Revision 16: September 22, 2005\r\n *   Workarounds for some IE 5.5 deficiencies.\r\n *   Fixed problem with prefix node tests on attribute nodes.\r\n *\r\n * Revision 15: May 21, 2005\r\n *   Fixed problem with QName node tests on elements with an xmlns=\"...\".\r\n *\r\n * Revision 14: May 19, 2005\r\n *   Fixed QName node tests on attribute node regression.\r\n *\r\n * Revision 13: May 3, 2005\r\n *   Node tests are case insensitive now if working in an HTML DOM.\r\n *\r\n * Revision 12: April 26, 2005\r\n *   Updated licence.  Slight code changes to enable use of Dean\r\n *   Edwards' script compression, http://dean.edwards.name/packer/ .\r\n *\r\n * Revision 11: April 23, 2005\r\n *   Fixed bug with 'and' and 'or' operators, fix thanks to\r\n *   Sandy McArthur <sandy (at) mcarthur.org>.\r\n *\r\n * Revision 10: April 15, 2005\r\n *   Added support for a virtual root node, supposedly helpful for\r\n *   implementing XForms.  Fixed problem with QName node tests and\r\n *   the parent axis.\r\n *\r\n * Revision 9: March 17, 2005\r\n *   Namespace resolver tweaked so using the document node as the context\r\n *   for namespace lookups is equivalent to using the document element.\r\n *\r\n * Revision 8: February 13, 2005\r\n *   Handle implicit declaration of 'xmlns' namespace prefix.\r\n *   Fixed bug when comparing nodesets.\r\n *   Instance data can now be associated with a FunctionResolver, and\r\n *     workaround for MSXML not supporting 'localName' and 'getElementById',\r\n *     thanks to Grant Gongaware.\r\n *   Fix a few problems when the context node is the root node.\r\n *\r\n * Revision 7: February 11, 2005\r\n *   Default namespace resolver fix from Grant Gongaware\r\n *   <grant (at) gongaware.com>.\r\n *\r\n * Revision 6: February 10, 2005\r\n *   Fixed bug in 'number' function.\r\n *\r\n * Revision 5: February 9, 2005\r\n *   Fixed bug where text nodes not getting converted to string values.\r\n *\r\n * Revision 4: January 21, 2005\r\n *   Bug in 'name' function, fix thanks to Bill Edney.\r\n *   Fixed incorrect processing of namespace nodes.\r\n *   Fixed NamespaceResolver to resolve 'xml' namespace.\r\n *   Implemented union '|' operator.\r\n *\r\n * Revision 3: January 14, 2005\r\n *   Fixed bug with nodeset comparisons, bug lexing < and >.\r\n *\r\n * Revision 2: October 26, 2004\r\n *   QName node test namespace handling fixed.  Few other bug fixes.\r\n *\r\n * Revision 1: August 13, 2004\r\n *   Bug fixes from William J. Edney <bedney (at) technicalpursuit.com>.\r\n *   Added minimal licence.\r\n *\r\n * Initial version: June 14, 2004\r\n */\r\n\r\n// non-node wrapper\r\nvar xpath = (typeof exports === 'undefined') ? {} : exports;\r\n\r\n(function (exports) {\r\n    \"use strict\";\r\n\r\n    // functional helpers\r\n    function curry(func) {\r\n        var slice = Array.prototype.slice,\r\n            totalargs = func.length,\r\n            partial = function (args, fn) {\r\n                return function () {\r\n                    return fn.apply(this, args.concat(slice.call(arguments)));\r\n                }\r\n            },\r\n            fn = function () {\r\n                var args = slice.call(arguments);\r\n                return (args.length < totalargs) ?\r\n                    partial(args, fn) :\r\n                    func.apply(this, slice.apply(arguments, [0, totalargs]));\r\n            };\r\n        return fn;\r\n    }\r\n\r\n    var forEach = function (f, xs) {\r\n        for (var i = 0; i < xs.length; i += 1) {\r\n            f(xs[i], i, xs);\r\n        }\r\n    };\r\n\r\n    var reduce = function (f, seed, xs) {\r\n        var acc = seed;\r\n\r\n        forEach(function (x, i) { acc = f(acc, x, i); }, xs);\r\n\r\n        return acc;\r\n    };\r\n\r\n    var map = function (f, xs) {\r\n        var mapped = new Array(xs.length);\r\n\r\n        forEach(function (x, i) { mapped[i] = f(x); }, xs);\r\n\r\n        return mapped;\r\n    };\r\n\r\n    var filter = function (f, xs) {\r\n        var filtered = [];\r\n\r\n        forEach(function (x, i) { if (f(x, i)) { filtered.push(x); } }, xs);\r\n\r\n        return filtered;\r\n    };\r\n\r\n    var includes = function (values, value) {\r\n        for (var i = 0; i < values.length; i += 1) {\r\n            if (values[i] === value) {\r\n                return true;\r\n            }\r\n        }\r\n\r\n        return false;\r\n    };\r\n\r\n    function always(value) { return function () { return value; } }\r\n\r\n    function toString(x) { return x.toString(); }\r\n    var join = function (s, xs) { return xs.join(s); };\r\n    var wrap = function (pref, suf, str) { return pref + str + suf; };\r\n\r\n    var prototypeConcat = Array.prototype.concat;\r\n\r\n    // .apply() fails above a certain number of arguments - https://github.com/goto100/xpath/pull/98\r\n    var MAX_ARGUMENT_LENGTH = 32767;\r\n\r\n    function flatten(arr) {\r\n        var result = [];\r\n\r\n        for (var start = 0; start < arr.length; start += MAX_ARGUMENT_LENGTH) {\r\n            var chunk = arr.slice(start, start + MAX_ARGUMENT_LENGTH);\r\n            \r\n            result = prototypeConcat.apply(result, chunk);\r\n        }\r\n        \r\n        return result;\r\n    }\r\n\r\n    function assign(target, varArgs) { // .length of function is 2\r\n        var to = Object(target);\r\n\r\n        for (var index = 1; index < arguments.length; index++) {\r\n            var nextSource = arguments[index];\r\n\r\n            if (nextSource != null) { // Skip over if undefined or null\r\n                for (var nextKey in nextSource) {\r\n                    // Avoid bugs when hasOwnProperty is shadowed\r\n                    if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {\r\n                        to[nextKey] = nextSource[nextKey];\r\n                    }\r\n                }\r\n            }\r\n        }\r\n\r\n        return to;\r\n    }\r\n\r\n    var NodeTypes = {\r\n        ELEMENT_NODE: 1,\r\n        ATTRIBUTE_NODE: 2,\r\n        TEXT_NODE: 3,\r\n        CDATA_SECTION_NODE: 4,\r\n        PROCESSING_INSTRUCTION_NODE: 7,\r\n        COMMENT_NODE: 8,\r\n        DOCUMENT_NODE: 9,\r\n        DOCUMENT_TYPE_NODE: 10,\r\n        DOCUMENT_FRAGMENT_NODE: 11,\r\n    };\r\n\r\n    // XPathParser ///////////////////////////////////////////////////////////////\r\n\r\n    XPathParser.prototype = new Object();\r\n    XPathParser.prototype.constructor = XPathParser;\r\n    XPathParser.superclass = Object.prototype;\r\n\r\n    function XPathParser() {\r\n        this.init();\r\n    }\r\n\r\n    XPathParser.prototype.init = function () {\r\n        this.reduceActions = [];\r\n\r\n        this.reduceActions[3] = function (rhs) {\r\n            return new OrOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[5] = function (rhs) {\r\n            return new AndOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[7] = function (rhs) {\r\n            return new EqualsOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[8] = function (rhs) {\r\n            return new NotEqualOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[10] = function (rhs) {\r\n            return new LessThanOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[11] = function (rhs) {\r\n            return new GreaterThanOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[12] = function (rhs) {\r\n            return new LessThanOrEqualOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[13] = function (rhs) {\r\n            return new GreaterThanOrEqualOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[15] = function (rhs) {\r\n            return new PlusOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[16] = function (rhs) {\r\n            return new MinusOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[18] = function (rhs) {\r\n            return new MultiplyOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[19] = function (rhs) {\r\n            return new DivOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[20] = function (rhs) {\r\n            return new ModOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[22] = function (rhs) {\r\n            return new UnaryMinusOperation(rhs[1]);\r\n        };\r\n        this.reduceActions[24] = function (rhs) {\r\n            return new BarOperation(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[25] = function (rhs) {\r\n            return new PathExpr(undefined, undefined, rhs[0]);\r\n        };\r\n        this.reduceActions[27] = function (rhs) {\r\n            rhs[0].locationPath = rhs[2];\r\n            return rhs[0];\r\n        };\r\n        this.reduceActions[28] = function (rhs) {\r\n            rhs[0].locationPath = rhs[2];\r\n            rhs[0].locationPath.steps.unshift(new Step(Step.DESCENDANTORSELF, NodeTest.nodeTest, []));\r\n            return rhs[0];\r\n        };\r\n        this.reduceActions[29] = function (rhs) {\r\n            return new PathExpr(rhs[0], [], undefined);\r\n        };\r\n        this.reduceActions[30] = function (rhs) {\r\n            if (Utilities.instance_of(rhs[0], PathExpr)) {\r\n                if (rhs[0].filterPredicates == undefined) {\r\n                    rhs[0].filterPredicates = [];\r\n                }\r\n                rhs[0].filterPredicates.push(rhs[1]);\r\n                return rhs[0];\r\n            } else {\r\n                return new PathExpr(rhs[0], [rhs[1]], undefined);\r\n            }\r\n        };\r\n        this.reduceActions[32] = function (rhs) {\r\n            return rhs[1];\r\n        };\r\n        this.reduceActions[33] = function (rhs) {\r\n            return new XString(rhs[0]);\r\n        };\r\n        this.reduceActions[34] = function (rhs) {\r\n            return new XNumber(rhs[0]);\r\n        };\r\n        this.reduceActions[36] = function (rhs) {\r\n            return new FunctionCall(rhs[0], []);\r\n        };\r\n        this.reduceActions[37] = function (rhs) {\r\n            return new FunctionCall(rhs[0], rhs[2]);\r\n        };\r\n        this.reduceActions[38] = function (rhs) {\r\n            return [rhs[0]];\r\n        };\r\n        this.reduceActions[39] = function (rhs) {\r\n            rhs[2].unshift(rhs[0]);\r\n            return rhs[2];\r\n        };\r\n        this.reduceActions[43] = function (rhs) {\r\n            return new LocationPath(true, []);\r\n        };\r\n        this.reduceActions[44] = function (rhs) {\r\n            rhs[1].absolute = true;\r\n            return rhs[1];\r\n        };\r\n        this.reduceActions[46] = function (rhs) {\r\n            return new LocationPath(false, [rhs[0]]);\r\n        };\r\n        this.reduceActions[47] = function (rhs) {\r\n            rhs[0].steps.push(rhs[2]);\r\n            return rhs[0];\r\n        };\r\n        this.reduceActions[49] = function (rhs) {\r\n            return new Step(rhs[0], rhs[1], []);\r\n        };\r\n        this.reduceActions[50] = function (rhs) {\r\n            return new Step(Step.CHILD, rhs[0], []);\r\n        };\r\n        this.reduceActions[51] = function (rhs) {\r\n            return new Step(rhs[0], rhs[1], rhs[2]);\r\n        };\r\n        this.reduceActions[52] = function (rhs) {\r\n            return new Step(Step.CHILD, rhs[0], rhs[1]);\r\n        };\r\n        this.reduceActions[54] = function (rhs) {\r\n            return [rhs[0]];\r\n        };\r\n        this.reduceActions[55] = function (rhs) {\r\n            rhs[1].unshift(rhs[0]);\r\n            return rhs[1];\r\n        };\r\n        this.reduceActions[56] = function (rhs) {\r\n            if (rhs[0] == \"ancestor\") {\r\n                return Step.ANCESTOR;\r\n            } else if (rhs[0] == \"ancestor-or-self\") {\r\n                return Step.ANCESTORORSELF;\r\n            } else if (rhs[0] == \"attribute\") {\r\n                return Step.ATTRIBUTE;\r\n            } else if (rhs[0] == \"child\") {\r\n                return Step.CHILD;\r\n            } else if (rhs[0] == \"descendant\") {\r\n                return Step.DESCENDANT;\r\n            } else if (rhs[0] == \"descendant-or-self\") {\r\n                return Step.DESCENDANTORSELF;\r\n            } else if (rhs[0] == \"following\") {\r\n                return Step.FOLLOWING;\r\n            } else if (rhs[0] == \"following-sibling\") {\r\n                return Step.FOLLOWINGSIBLING;\r\n            } else if (rhs[0] == \"namespace\") {\r\n                return Step.NAMESPACE;\r\n            } else if (rhs[0] == \"parent\") {\r\n                return Step.PARENT;\r\n            } else if (rhs[0] == \"preceding\") {\r\n                return Step.PRECEDING;\r\n            } else if (rhs[0] == \"preceding-sibling\") {\r\n                return Step.PRECEDINGSIBLING;\r\n            } else if (rhs[0] == \"self\") {\r\n                return Step.SELF;\r\n            }\r\n            return -1;\r\n        };\r\n        this.reduceActions[57] = function (rhs) {\r\n            return Step.ATTRIBUTE;\r\n        };\r\n        this.reduceActions[59] = function (rhs) {\r\n            if (rhs[0] == \"comment\") {\r\n                return NodeTest.commentTest;\r\n            } else if (rhs[0] == \"text\") {\r\n                return NodeTest.textTest;\r\n            } else if (rhs[0] == \"processing-instruction\") {\r\n                return NodeTest.anyPiTest;\r\n            } else if (rhs[0] == \"node\") {\r\n                return NodeTest.nodeTest;\r\n            }\r\n            return new NodeTest(-1, undefined);\r\n        };\r\n        this.reduceActions[60] = function (rhs) {\r\n            return new NodeTest.PITest(rhs[2]);\r\n        };\r\n        this.reduceActions[61] = function (rhs) {\r\n            return rhs[1];\r\n        };\r\n        this.reduceActions[63] = function (rhs) {\r\n            rhs[1].absolute = true;\r\n            rhs[1].steps.unshift(new Step(Step.DESCENDANTORSELF, NodeTest.nodeTest, []));\r\n            return rhs[1];\r\n        };\r\n        this.reduceActions[64] = function (rhs) {\r\n            rhs[0].steps.push(new Step(Step.DESCENDANTORSELF, NodeTest.nodeTest, []));\r\n            rhs[0].steps.push(rhs[2]);\r\n            return rhs[0];\r\n        };\r\n        this.reduceActions[65] = function (rhs) {\r\n            return new Step(Step.SELF, NodeTest.nodeTest, []);\r\n        };\r\n        this.reduceActions[66] = function (rhs) {\r\n            return new Step(Step.PARENT, NodeTest.nodeTest, []);\r\n        };\r\n        this.reduceActions[67] = function (rhs) {\r\n            return new VariableReference(rhs[1]);\r\n        };\r\n        this.reduceActions[68] = function (rhs) {\r\n            return NodeTest.nameTestAny;\r\n        };\r\n        this.reduceActions[69] = function (rhs) {\r\n            return new NodeTest.NameTestPrefixAny(rhs[0].split(':')[0]);\r\n        };\r\n        this.reduceActions[70] = function (rhs) {\r\n            return new NodeTest.NameTestQName(rhs[0]);\r\n        };\r\n    };\r\n\r\n    XPathParser.actionTable = [\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \"                 s                  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"                rrrrr               \",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \"rs  rrrrrrrr s  sssssrrrrrr  rrs rs \",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \"                            s       \",\r\n        \"                            s       \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"  s                                 \",\r\n        \"                            s       \",\r\n        \" s           s  sssss          s  s \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"a                                   \",\r\n        \"r       s                    rr  r  \",\r\n        \"r      sr                    rr  r  \",\r\n        \"r   s  rr            s       rr  r  \",\r\n        \"r   rssrr            rss     rr  r  \",\r\n        \"r   rrrrr            rrrss   rr  r  \",\r\n        \"r   rrrrrsss         rrrrr   rr  r  \",\r\n        \"r   rrrrrrrr         rrrrr   rr  r  \",\r\n        \"r   rrrrrrrr         rrrrrs  rr  r  \",\r\n        \"r   rrrrrrrr         rrrrrr  rr  r  \",\r\n        \"r   rrrrrrrr         rrrrrr  rr  r  \",\r\n        \"r  srrrrrrrr         rrrrrrs rr sr  \",\r\n        \"r  srrrrrrrr         rrrrrrs rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r   rrrrrrrr         rrrrrr  rr  r  \",\r\n        \"r   rrrrrrrr         rrrrrr  rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"                sssss               \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr sr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"                             s      \",\r\n        \"r  srrrrrrrr         rrrrrrs rr  r  \",\r\n        \"r   rrrrrrrr         rrrrr   rr  r  \",\r\n        \"              s                     \",\r\n        \"                             s      \",\r\n        \"                rrrrr               \",\r\n        \" s s        sssssssss    s sss s  ss\",\r\n        \"r  srrrrrrrr         rrrrrrs rr  r  \",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s s        sssssssss      ss  s  ss\",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \" s           s  sssss          s  s \",\r\n        \" s           s  sssss          s  s \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \" s           s  sssss          s  s \",\r\n        \" s           s  sssss          s  s \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr sr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr sr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"                             s      \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"                             rr     \",\r\n        \"                             s      \",\r\n        \"                             rs     \",\r\n        \"r      sr                    rr  r  \",\r\n        \"r   s  rr            s       rr  r  \",\r\n        \"r   rssrr            rss     rr  r  \",\r\n        \"r   rssrr            rss     rr  r  \",\r\n        \"r   rrrrr            rrrss   rr  r  \",\r\n        \"r   rrrrr            rrrss   rr  r  \",\r\n        \"r   rrrrr            rrrss   rr  r  \",\r\n        \"r   rrrrr            rrrss   rr  r  \",\r\n        \"r   rrrrrsss         rrrrr   rr  r  \",\r\n        \"r   rrrrrsss         rrrrr   rr  r  \",\r\n        \"r   rrrrrrrr         rrrrr   rr  r  \",\r\n        \"r   rrrrrrrr         rrrrr   rr  r  \",\r\n        \"r   rrrrrrrr         rrrrr   rr  r  \",\r\n        \"r   rrrrrrrr         rrrrrr  rr  r  \",\r\n        \"                                 r  \",\r\n        \"                                 s  \",\r\n        \"r  srrrrrrrr         rrrrrrs rr  r  \",\r\n        \"r  srrrrrrrr         rrrrrrs rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr  r  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \" s s        sssssssss    s ss  s  ss\",\r\n        \"r  rrrrrrrrr         rrrrrrr rr rr  \",\r\n        \"                             r      \"\r\n    ];\r\n\r\n    XPathParser.actionTableNumber = [\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \"                 J                  \",\r\n        \"a  aaaaaaaaa         aaaaaaa aa  a  \",\r\n        \"                YYYYY               \",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \"K1  KKKKKKKK .  +*)('KKKKKK  KK# K\\\" \",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \"                            N       \",\r\n        \"                            O       \",\r\n        \"e  eeeeeeeee         eeeeeee ee ee  \",\r\n        \"f  fffffffff         fffffff ff ff  \",\r\n        \"d  ddddddddd         ddddddd dd dd  \",\r\n        \"B  BBBBBBBBB         BBBBBBB BB BB  \",\r\n        \"A  AAAAAAAAA         AAAAAAA AA AA  \",\r\n        \"  P                                 \",\r\n        \"                            Q       \",\r\n        \" 1           .  +*)('          #  \\\" \",\r\n        \"b  bbbbbbbbb         bbbbbbb bb  b  \",\r\n        \"                                    \",\r\n        \"!       S                    !!  !  \",\r\n        \"\\\"      T\\\"                    \\\"\\\"  \\\"  \",\r\n        \"$   V  $$            U       $$  $  \",\r\n        \"&   &ZY&&            &XW     &&  &  \",\r\n        \")   )))))            )))\\\\[   ))  )  \",\r\n        \".   ....._^]         .....   ..  .  \",\r\n        \"1   11111111         11111   11  1  \",\r\n        \"5   55555555         55555`  55  5  \",\r\n        \"7   77777777         777777  77  7  \",\r\n        \"9   99999999         999999  99  9  \",\r\n        \":  c::::::::         ::::::b :: a:  \",\r\n        \"I  fIIIIIIII         IIIIIIe II  I  \",\r\n        \"=  =========         ======= == ==  \",\r\n        \"?  ?????????         ??????? ?? ??  \",\r\n        \"C  CCCCCCCCC         CCCCCCC CC CC  \",\r\n        \"J   JJJJJJJJ         JJJJJJ  JJ  J  \",\r\n        \"M   MMMMMMMM         MMMMMM  MM  M  \",\r\n        \"N  NNNNNNNNN         NNNNNNN NN  N  \",\r\n        \"P  PPPPPPPPP         PPPPPPP PP  P  \",\r\n        \"                +*)('               \",\r\n        \"R  RRRRRRRRR         RRRRRRR RR aR  \",\r\n        \"U  UUUUUUUUU         UUUUUUU UU  U  \",\r\n        \"Z  ZZZZZZZZZ         ZZZZZZZ ZZ ZZ  \",\r\n        \"c  ccccccccc         ccccccc cc cc  \",\r\n        \"                             j      \",\r\n        \"L  fLLLLLLLL         LLLLLLe LL  L  \",\r\n        \"6   66666666         66666   66  6  \",\r\n        \"              k                     \",\r\n        \"                             l      \",\r\n        \"                XXXXX               \",\r\n        \" 1 0        /.-,+*)('    & %$m #  \\\"!\",\r\n        \"_  f________         ______e __  _  \",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('      %$  #  \\\"!\",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \" 1           .  +*)('          #  \\\" \",\r\n        \" 1           .  +*)('          #  \\\" \",\r\n        \">  >>>>>>>>>         >>>>>>> >> >>  \",\r\n        \" 1           .  +*)('          #  \\\" \",\r\n        \" 1           .  +*)('          #  \\\" \",\r\n        \"Q  QQQQQQQQQ         QQQQQQQ QQ aQ  \",\r\n        \"V  VVVVVVVVV         VVVVVVV VV aV  \",\r\n        \"T  TTTTTTTTT         TTTTTTT TT  T  \",\r\n        \"@  @@@@@@@@@         @@@@@@@ @@ @@  \",\r\n        \"                             \\x87      \",\r\n        \"[  [[[[[[[[[         [[[[[[[ [[ [[  \",\r\n        \"D  DDDDDDDDD         DDDDDDD DD DD  \",\r\n        \"                             HH     \",\r\n        \"                             \\x88      \",\r\n        \"                             F\\x89     \",\r\n        \"#      T#                    ##  #  \",\r\n        \"%   V  %%            U       %%  %  \",\r\n        \"'   'ZY''            'XW     ''  '  \",\r\n        \"(   (ZY((            (XW     ((  (  \",\r\n        \"+   +++++            +++\\\\[   ++  +  \",\r\n        \"*   *****            ***\\\\[   **  *  \",\r\n        \"-   -----            ---\\\\[   --  -  \",\r\n        \",   ,,,,,            ,,,\\\\[   ,,  ,  \",\r\n        \"0   00000_^]         00000   00  0  \",\r\n        \"/   /////_^]         /////   //  /  \",\r\n        \"2   22222222         22222   22  2  \",\r\n        \"3   33333333         33333   33  3  \",\r\n        \"4   44444444         44444   44  4  \",\r\n        \"8   88888888         888888  88  8  \",\r\n        \"                                 ^  \",\r\n        \"                                 \\x8a  \",\r\n        \";  f;;;;;;;;         ;;;;;;e ;;  ;  \",\r\n        \"<  f<<<<<<<<         <<<<<<e <<  <  \",\r\n        \"O  OOOOOOOOO         OOOOOOO OO  O  \",\r\n        \"`  `````````         ``````` ``  `  \",\r\n        \"S  SSSSSSSSS         SSSSSSS SS  S  \",\r\n        \"W  WWWWWWWWW         WWWWWWW WW  W  \",\r\n        \"\\\\  \\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\         \\\\\\\\\\\\\\\\\\\\\\\\\\\\ \\\\\\\\ \\\\\\\\  \",\r\n        \"E  EEEEEEEEE         EEEEEEE EE EE  \",\r\n        \" 1 0        /.-,+*)('    & %$  #  \\\"!\",\r\n        \"]  ]]]]]]]]]         ]]]]]]] ]] ]]  \",\r\n        \"                             G      \"\r\n    ];\r\n\r\n    XPathParser.gotoTable = [\r\n        \"3456789:;<=>?@ AB  CDEFGH IJ \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"L456789:;<=>?@ AB  CDEFGH IJ \",\r\n        \"            M        EFGH IJ \",\r\n        \"       N;<=>?@ AB  CDEFGH IJ \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"            S        EFGH IJ \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"              e              \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                        h  J \",\r\n        \"              i          j   \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"o456789:;<=>?@ ABpqCDEFGH IJ \",\r\n        \"                             \",\r\n        \"  r6789:;<=>?@ AB  CDEFGH IJ \",\r\n        \"   s789:;<=>?@ AB  CDEFGH IJ \",\r\n        \"    t89:;<=>?@ AB  CDEFGH IJ \",\r\n        \"    u89:;<=>?@ AB  CDEFGH IJ \",\r\n        \"     v9:;<=>?@ AB  CDEFGH IJ \",\r\n        \"     w9:;<=>?@ AB  CDEFGH IJ \",\r\n        \"     x9:;<=>?@ AB  CDEFGH IJ \",\r\n        \"     y9:;<=>?@ AB  CDEFGH IJ \",\r\n        \"      z:;<=>?@ AB  CDEFGH IJ \",\r\n        \"      {:;<=>?@ AB  CDEFGH IJ \",\r\n        \"       |;<=>?@ AB  CDEFGH IJ \",\r\n        \"       };<=>?@ AB  CDEFGH IJ \",\r\n        \"       ~;<=>?@ AB  CDEFGH IJ \",\r\n        \"         \\x7f=>?@ AB  CDEFGH IJ \",\r\n        \"\\x80456789:;<=>?@ AB  CDEFGH IJ\\x81\",\r\n        \"            \\x82        EFGH IJ \",\r\n        \"            \\x83        EFGH IJ \",\r\n        \"                             \",\r\n        \"                     \\x84 GH IJ \",\r\n        \"                     \\x85 GH IJ \",\r\n        \"              i          \\x86   \",\r\n        \"              i          \\x87   \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"                             \",\r\n        \"o456789:;<=>?@ AB\\x8cqCDEFGH IJ \",\r\n        \"                             \",\r\n        \"                             \"\r\n    ];\r\n\r\n    XPathParser.productions = [\r\n        [1, 1, 2],\r\n        [2, 1, 3],\r\n        [3, 1, 4],\r\n        [3, 3, 3, -9, 4],\r\n        [4, 1, 5],\r\n        [4, 3, 4, -8, 5],\r\n        [5, 1, 6],\r\n        [5, 3, 5, -22, 6],\r\n        [5, 3, 5, -5, 6],\r\n        [6, 1, 7],\r\n        [6, 3, 6, -23, 7],\r\n        [6, 3, 6, -24, 7],\r\n        [6, 3, 6, -6, 7],\r\n        [6, 3, 6, -7, 7],\r\n        [7, 1, 8],\r\n        [7, 3, 7, -25, 8],\r\n        [7, 3, 7, -26, 8],\r\n        [8, 1, 9],\r\n        [8, 3, 8, -12, 9],\r\n        [8, 3, 8, -11, 9],\r\n        [8, 3, 8, -10, 9],\r\n        [9, 1, 10],\r\n        [9, 2, -26, 9],\r\n        [10, 1, 11],\r\n        [10, 3, 10, -27, 11],\r\n        [11, 1, 12],\r\n        [11, 1, 13],\r\n        [11, 3, 13, -28, 14],\r\n        [11, 3, 13, -4, 14],\r\n        [13, 1, 15],\r\n        [13, 2, 13, 16],\r\n        [15, 1, 17],\r\n        [15, 3, -29, 2, -30],\r\n        [15, 1, -15],\r\n        [15, 1, -16],\r\n        [15, 1, 18],\r\n        [18, 3, -13, -29, -30],\r\n        [18, 4, -13, -29, 19, -30],\r\n        [19, 1, 20],\r\n        [19, 3, 20, -31, 19],\r\n        [20, 1, 2],\r\n        [12, 1, 14],\r\n        [12, 1, 21],\r\n        [21, 1, -28],\r\n        [21, 2, -28, 14],\r\n        [21, 1, 22],\r\n        [14, 1, 23],\r\n        [14, 3, 14, -28, 23],\r\n        [14, 1, 24],\r\n        [23, 2, 25, 26],\r\n        [23, 1, 26],\r\n        [23, 3, 25, 26, 27],\r\n        [23, 2, 26, 27],\r\n        [23, 1, 28],\r\n        [27, 1, 16],\r\n        [27, 2, 16, 27],\r\n        [25, 2, -14, -3],\r\n        [25, 1, -32],\r\n        [26, 1, 29],\r\n        [26, 3, -20, -29, -30],\r\n        [26, 4, -21, -29, -15, -30],\r\n        [16, 3, -33, 30, -34],\r\n        [30, 1, 2],\r\n        [22, 2, -4, 14],\r\n        [24, 3, 14, -4, 23],\r\n        [28, 1, -35],\r\n        [28, 1, -2],\r\n        [17, 2, -36, -18],\r\n        [29, 1, -17],\r\n        [29, 1, -19],\r\n        [29, 1, -18]\r\n    ];\r\n\r\n    XPathParser.DOUBLEDOT = 2;\r\n    XPathParser.DOUBLECOLON = 3;\r\n    XPathParser.DOUBLESLASH = 4;\r\n    XPathParser.NOTEQUAL = 5;\r\n    XPathParser.LESSTHANOREQUAL = 6;\r\n    XPathParser.GREATERTHANOREQUAL = 7;\r\n    XPathParser.AND = 8;\r\n    XPathParser.OR = 9;\r\n    XPathParser.MOD = 10;\r\n    XPathParser.DIV = 11;\r\n    XPathParser.MULTIPLYOPERATOR = 12;\r\n    XPathParser.FUNCTIONNAME = 13;\r\n    XPathParser.AXISNAME = 14;\r\n    XPathParser.LITERAL = 15;\r\n    XPathParser.NUMBER = 16;\r\n    XPathParser.ASTERISKNAMETEST = 17;\r\n    XPathParser.QNAME = 18;\r\n    XPathParser.NCNAMECOLONASTERISK = 19;\r\n    XPathParser.NODETYPE = 20;\r\n    XPathParser.PROCESSINGINSTRUCTIONWITHLITERAL = 21;\r\n    XPathParser.EQUALS = 22;\r\n    XPathParser.LESSTHAN = 23;\r\n    XPathParser.GREATERTHAN = 24;\r\n    XPathParser.PLUS = 25;\r\n    XPathParser.MINUS = 26;\r\n    XPathParser.BAR = 27;\r\n    XPathParser.SLASH = 28;\r\n    XPathParser.LEFTPARENTHESIS = 29;\r\n    XPathParser.RIGHTPARENTHESIS = 30;\r\n    XPathParser.COMMA = 31;\r\n    XPathParser.AT = 32;\r\n    XPathParser.LEFTBRACKET = 33;\r\n    XPathParser.RIGHTBRACKET = 34;\r\n    XPathParser.DOT = 35;\r\n    XPathParser.DOLLAR = 36;\r\n\r\n    XPathParser.prototype.tokenize = function (s1) {\r\n        var types = [];\r\n        var values = [];\r\n        var s = s1 + '\\0';\r\n\r\n        var pos = 0;\r\n        var c = s.charAt(pos++);\r\n        while (1) {\r\n            while (c == ' ' || c == '\\t' || c == '\\r' || c == '\\n') {\r\n                c = s.charAt(pos++);\r\n            }\r\n            if (c == '\\0' || pos >= s.length) {\r\n                break;\r\n            }\r\n\r\n            if (c == '(') {\r\n                types.push(XPathParser.LEFTPARENTHESIS);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == ')') {\r\n                types.push(XPathParser.RIGHTPARENTHESIS);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == '[') {\r\n                types.push(XPathParser.LEFTBRACKET);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == ']') {\r\n                types.push(XPathParser.RIGHTBRACKET);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == '@') {\r\n                types.push(XPathParser.AT);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == ',') {\r\n                types.push(XPathParser.COMMA);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == '|') {\r\n                types.push(XPathParser.BAR);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == '+') {\r\n                types.push(XPathParser.PLUS);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == '-') {\r\n                types.push(XPathParser.MINUS);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == '=') {\r\n                types.push(XPathParser.EQUALS);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n            if (c == '$') {\r\n                types.push(XPathParser.DOLLAR);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n\r\n            if (c == '.') {\r\n                c = s.charAt(pos++);\r\n                if (c == '.') {\r\n                    types.push(XPathParser.DOUBLEDOT);\r\n                    values.push(\"..\");\r\n                    c = s.charAt(pos++);\r\n                    continue;\r\n                }\r\n                if (c >= '0' && c <= '9') {\r\n                    var number = \".\" + c;\r\n                    c = s.charAt(pos++);\r\n                    while (c >= '0' && c <= '9') {\r\n                        number += c;\r\n                        c = s.charAt(pos++);\r\n                    }\r\n                    types.push(XPathParser.NUMBER);\r\n                    values.push(number);\r\n                    continue;\r\n                }\r\n                types.push(XPathParser.DOT);\r\n                values.push('.');\r\n                continue;\r\n            }\r\n\r\n            if (c == '\\'' || c == '\"') {\r\n                var delimiter = c;\r\n                var literal = \"\";\r\n                while (pos < s.length && (c = s.charAt(pos)) !== delimiter) {\r\n                    literal += c;\r\n                    pos += 1;\r\n                }\r\n                if (c !== delimiter) {\r\n                    throw XPathException.fromMessage(\"Unterminated string literal: \" + delimiter + literal);\r\n                }\r\n                pos += 1;\r\n                types.push(XPathParser.LITERAL);\r\n                values.push(literal);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n\r\n            if (c >= '0' && c <= '9') {\r\n                var number = c;\r\n                c = s.charAt(pos++);\r\n                while (c >= '0' && c <= '9') {\r\n                    number += c;\r\n                    c = s.charAt(pos++);\r\n                }\r\n                if (c == '.') {\r\n                    if (s.charAt(pos) >= '0' && s.charAt(pos) <= '9') {\r\n                        number += c;\r\n                        number += s.charAt(pos++);\r\n                        c = s.charAt(pos++);\r\n                        while (c >= '0' && c <= '9') {\r\n                            number += c;\r\n                            c = s.charAt(pos++);\r\n                        }\r\n                    }\r\n                }\r\n                types.push(XPathParser.NUMBER);\r\n                values.push(number);\r\n                continue;\r\n            }\r\n\r\n            if (c == '*') {\r\n                if (types.length > 0) {\r\n                    var last = types[types.length - 1];\r\n                    if (last != XPathParser.AT\r\n                        && last != XPathParser.DOUBLECOLON\r\n                        && last != XPathParser.LEFTPARENTHESIS\r\n                        && last != XPathParser.LEFTBRACKET\r\n                        && last != XPathParser.AND\r\n                        && last != XPathParser.OR\r\n                        && last != XPathParser.MOD\r\n                        && last != XPathParser.DIV\r\n                        && last != XPathParser.MULTIPLYOPERATOR\r\n                        && last != XPathParser.SLASH\r\n                        && last != XPathParser.DOUBLESLASH\r\n                        && last != XPathParser.BAR\r\n                        && last != XPathParser.PLUS\r\n                        && last != XPathParser.MINUS\r\n                        && last != XPathParser.EQUALS\r\n                        && last != XPathParser.NOTEQUAL\r\n                        && last != XPathParser.LESSTHAN\r\n                        && last != XPathParser.LESSTHANOREQUAL\r\n                        && last != XPathParser.GREATERTHAN\r\n                        && last != XPathParser.GREATERTHANOREQUAL) {\r\n                        types.push(XPathParser.MULTIPLYOPERATOR);\r\n                        values.push(c);\r\n                        c = s.charAt(pos++);\r\n                        continue;\r\n                    }\r\n                }\r\n                types.push(XPathParser.ASTERISKNAMETEST);\r\n                values.push(c);\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n\r\n            if (c == ':') {\r\n                if (s.charAt(pos) == ':') {\r\n                    types.push(XPathParser.DOUBLECOLON);\r\n                    values.push(\"::\");\r\n                    pos++;\r\n                    c = s.charAt(pos++);\r\n                    continue;\r\n                }\r\n            }\r\n\r\n            if (c == '/') {\r\n                c = s.charAt(pos++);\r\n                if (c == '/') {\r\n                    types.push(XPathParser.DOUBLESLASH);\r\n                    values.push(\"//\");\r\n                    c = s.charAt(pos++);\r\n                    continue;\r\n                }\r\n                types.push(XPathParser.SLASH);\r\n                values.push('/');\r\n                continue;\r\n            }\r\n\r\n            if (c == '!') {\r\n                if (s.charAt(pos) == '=') {\r\n                    types.push(XPathParser.NOTEQUAL);\r\n                    values.push(\"!=\");\r\n                    pos++;\r\n                    c = s.charAt(pos++);\r\n                    continue;\r\n                }\r\n            }\r\n\r\n            if (c == '<') {\r\n                if (s.charAt(pos) == '=') {\r\n                    types.push(XPathParser.LESSTHANOREQUAL);\r\n                    values.push(\"<=\");\r\n                    pos++;\r\n                    c = s.charAt(pos++);\r\n                    continue;\r\n                }\r\n                types.push(XPathParser.LESSTHAN);\r\n                values.push('<');\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n\r\n            if (c == '>') {\r\n                if (s.charAt(pos) == '=') {\r\n                    types.push(XPathParser.GREATERTHANOREQUAL);\r\n                    values.push(\">=\");\r\n                    pos++;\r\n                    c = s.charAt(pos++);\r\n                    continue;\r\n                }\r\n                types.push(XPathParser.GREATERTHAN);\r\n                values.push('>');\r\n                c = s.charAt(pos++);\r\n                continue;\r\n            }\r\n\r\n            if (c == '_' || Utilities.isLetter(c.charCodeAt(0))) {\r\n                var name = c;\r\n                c = s.charAt(pos++);\r\n                while (Utilities.isNCNameChar(c.charCodeAt(0))) {\r\n                    name += c;\r\n                    c = s.charAt(pos++);\r\n                }\r\n                if (types.length > 0) {\r\n                    var last = types[types.length - 1];\r\n                    if (last != XPathParser.AT\r\n                        && last != XPathParser.DOUBLECOLON\r\n                        && last != XPathParser.LEFTPARENTHESIS\r\n                        && last != XPathParser.LEFTBRACKET\r\n                        && last != XPathParser.AND\r\n                        && last != XPathParser.OR\r\n                        && last != XPathParser.MOD\r\n                        && last != XPathParser.DIV\r\n                        && last != XPathParser.MULTIPLYOPERATOR\r\n                        && last != XPathParser.SLASH\r\n                        && last != XPathParser.DOUBLESLASH\r\n                        && last != XPathParser.BAR\r\n                        && last != XPathParser.PLUS\r\n                        && last != XPathParser.MINUS\r\n                        && last != XPathParser.EQUALS\r\n                        && last != XPathParser.NOTEQUAL\r\n                        && last != XPathParser.LESSTHAN\r\n                        && last != XPathParser.LESSTHANOREQUAL\r\n                        && last != XPathParser.GREATERTHAN\r\n                        && last != XPathParser.GREATERTHANOREQUAL) {\r\n                        if (name == \"and\") {\r\n                            types.push(XPathParser.AND);\r\n                            values.push(name);\r\n                            continue;\r\n                        }\r\n                        if (name == \"or\") {\r\n                            types.push(XPathParser.OR);\r\n                            values.push(name);\r\n                            continue;\r\n                        }\r\n                        if (name == \"mod\") {\r\n                            types.push(XPathParser.MOD);\r\n                            values.push(name);\r\n                            continue;\r\n                        }\r\n                        if (name == \"div\") {\r\n                            types.push(XPathParser.DIV);\r\n                            values.push(name);\r\n                            continue;\r\n                        }\r\n                    }\r\n                }\r\n                if (c == ':') {\r\n                    if (s.charAt(pos) == '*') {\r\n                        types.push(XPathParser.NCNAMECOLONASTERISK);\r\n                        values.push(name + \":*\");\r\n                        pos++;\r\n                        c = s.charAt(pos++);\r\n                        continue;\r\n                    }\r\n                    if (s.charAt(pos) == '_' || Utilities.isLetter(s.charCodeAt(pos))) {\r\n                        name += ':';\r\n                        c = s.charAt(pos++);\r\n                        while (Utilities.isNCNameChar(c.charCodeAt(0))) {\r\n                            name += c;\r\n                            c = s.charAt(pos++);\r\n                        }\r\n                        if (c == '(') {\r\n                            types.push(XPathParser.FUNCTIONNAME);\r\n                            values.push(name);\r\n                            continue;\r\n                        }\r\n                        types.push(XPathParser.QNAME);\r\n                        values.push(name);\r\n                        continue;\r\n                    }\r\n                    if (s.charAt(pos) == ':') {\r\n                        types.push(XPathParser.AXISNAME);\r\n                        values.push(name);\r\n                        continue;\r\n                    }\r\n                }\r\n                if (c == '(') {\r\n                    if (name == \"comment\" || name == \"text\" || name == \"node\") {\r\n                        types.push(XPathParser.NODETYPE);\r\n                        values.push(name);\r\n                        continue;\r\n                    }\r\n                    if (name == \"processing-instruction\") {\r\n                        if (s.charAt(pos) == ')') {\r\n                            types.push(XPathParser.NODETYPE);\r\n                        } else {\r\n                            types.push(XPathParser.PROCESSINGINSTRUCTIONWITHLITERAL);\r\n                        }\r\n                        values.push(name);\r\n                        continue;\r\n                    }\r\n                    types.push(XPathParser.FUNCTIONNAME);\r\n                    values.push(name);\r\n                    continue;\r\n                }\r\n                types.push(XPathParser.QNAME);\r\n                values.push(name);\r\n                continue;\r\n            }\r\n\r\n            throw new Error(\"Unexpected character \" + c);\r\n        }\r\n        types.push(1);\r\n        values.push(\"[EOF]\");\r\n        return [types, values];\r\n    };\r\n\r\n    XPathParser.SHIFT = 's';\r\n    XPathParser.REDUCE = 'r';\r\n    XPathParser.ACCEPT = 'a';\r\n\r\n    XPathParser.prototype.parse = function (s) {\r\n        var types;\r\n        var values;\r\n        var res = this.tokenize(s);\r\n        if (res == undefined) {\r\n            return undefined;\r\n        }\r\n        types = res[0];\r\n        values = res[1];\r\n        var tokenPos = 0;\r\n        var state = [];\r\n        var tokenType = [];\r\n        var tokenValue = [];\r\n        var s;\r\n        var a;\r\n        var t;\r\n\r\n        state.push(0);\r\n        tokenType.push(1);\r\n        tokenValue.push(\"_S\");\r\n\r\n        a = types[tokenPos];\r\n        t = values[tokenPos++];\r\n        while (1) {\r\n            s = state[state.length - 1];\r\n            switch (XPathParser.actionTable[s].charAt(a - 1)) {\r\n                case XPathParser.SHIFT:\r\n                    tokenType.push(-a);\r\n                    tokenValue.push(t);\r\n                    state.push(XPathParser.actionTableNumber[s].charCodeAt(a - 1) - 32);\r\n                    a = types[tokenPos];\r\n                    t = values[tokenPos++];\r\n                    break;\r\n                case XPathParser.REDUCE:\r\n                    var num = XPathParser.productions[XPathParser.actionTableNumber[s].charCodeAt(a - 1) - 32][1];\r\n                    var rhs = [];\r\n                    for (var i = 0; i < num; i++) {\r\n                        tokenType.pop();\r\n                        rhs.unshift(tokenValue.pop());\r\n                        state.pop();\r\n                    }\r\n                    var s_ = state[state.length - 1];\r\n                    tokenType.push(XPathParser.productions[XPathParser.actionTableNumber[s].charCodeAt(a - 1) - 32][0]);\r\n                    if (this.reduceActions[XPathParser.actionTableNumber[s].charCodeAt(a - 1) - 32] == undefined) {\r\n                        tokenValue.push(rhs[0]);\r\n                    } else {\r\n                        tokenValue.push(this.reduceActions[XPathParser.actionTableNumber[s].charCodeAt(a - 1) - 32](rhs));\r\n                    }\r\n                    state.push(XPathParser.gotoTable[s_].charCodeAt(XPathParser.productions[XPathParser.actionTableNumber[s].charCodeAt(a - 1) - 32][0] - 2) - 33);\r\n                    break;\r\n                case XPathParser.ACCEPT:\r\n                    return new XPath(tokenValue.pop());\r\n                default:\r\n                    throw new Error(\"XPath parse error\");\r\n            }\r\n        }\r\n    };\r\n\r\n    // XPath /////////////////////////////////////////////////////////////////////\r\n\r\n    XPath.prototype = new Object();\r\n    XPath.prototype.constructor = XPath;\r\n    XPath.superclass = Object.prototype;\r\n\r\n    function XPath(e) {\r\n        this.expression = e;\r\n    }\r\n\r\n    XPath.prototype.toString = function () {\r\n        return this.expression.toString();\r\n    };\r\n\r\n    function setIfUnset(obj, prop, value) {\r\n        if (!(prop in obj)) {\r\n            obj[prop] = value;\r\n        }\r\n    }\r\n\r\n    XPath.prototype.evaluate = function (c) {\r\n        c.contextNode = c.expressionContextNode;\r\n        c.contextSize = 1;\r\n        c.contextPosition = 1;\r\n\r\n        // [2017-11-25] Removed usage of .implementation.hasFeature() since it does\r\n        //              not reliably detect HTML DOMs (always returns false in xmldom and true in browsers)\r\n        if (c.isHtml) {\r\n            setIfUnset(c, 'caseInsensitive', true);\r\n            setIfUnset(c, 'allowAnyNamespaceForNoPrefix', true);\r\n        }\r\n\r\n        setIfUnset(c, 'caseInsensitive', false);\r\n\r\n        return this.expression.evaluate(c);\r\n    };\r\n\r\n    XPath.XML_NAMESPACE_URI = \"http://www.w3.org/XML/1998/namespace\";\r\n    XPath.XMLNS_NAMESPACE_URI = \"http://www.w3.org/2000/xmlns/\";\r\n\r\n    // Expression ////////////////////////////////////////////////////////////////\r\n\r\n    Expression.prototype = new Object();\r\n    Expression.prototype.constructor = Expression;\r\n    Expression.superclass = Object.prototype;\r\n\r\n    function Expression() {\r\n    }\r\n\r\n    Expression.prototype.init = function () {\r\n    };\r\n\r\n    Expression.prototype.toString = function () {\r\n        return \"<Expression>\";\r\n    };\r\n\r\n    Expression.prototype.evaluate = function (c) {\r\n        throw new Error(\"Could not evaluate expression.\");\r\n    };\r\n\r\n    // UnaryOperation ////////////////////////////////////////////////////////////\r\n\r\n    UnaryOperation.prototype = new Expression();\r\n    UnaryOperation.prototype.constructor = UnaryOperation;\r\n    UnaryOperation.superclass = Expression.prototype;\r\n\r\n    function UnaryOperation(rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(rhs);\r\n        }\r\n    }\r\n\r\n    UnaryOperation.prototype.init = function (rhs) {\r\n        this.rhs = rhs;\r\n    };\r\n\r\n    // UnaryMinusOperation ///////////////////////////////////////////////////////\r\n\r\n    UnaryMinusOperation.prototype = new UnaryOperation();\r\n    UnaryMinusOperation.prototype.constructor = UnaryMinusOperation;\r\n    UnaryMinusOperation.superclass = UnaryOperation.prototype;\r\n\r\n    function UnaryMinusOperation(rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(rhs);\r\n        }\r\n    }\r\n\r\n    UnaryMinusOperation.prototype.init = function (rhs) {\r\n        UnaryMinusOperation.superclass.init.call(this, rhs);\r\n    };\r\n\r\n    UnaryMinusOperation.prototype.evaluate = function (c) {\r\n        return this.rhs.evaluate(c).number().negate();\r\n    };\r\n\r\n    UnaryMinusOperation.prototype.toString = function () {\r\n        return \"-\" + this.rhs.toString();\r\n    };\r\n\r\n    // BinaryOperation ///////////////////////////////////////////////////////////\r\n\r\n    BinaryOperation.prototype = new Expression();\r\n    BinaryOperation.prototype.constructor = BinaryOperation;\r\n    BinaryOperation.superclass = Expression.prototype;\r\n\r\n    function BinaryOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    BinaryOperation.prototype.init = function (lhs, rhs) {\r\n        this.lhs = lhs;\r\n        this.rhs = rhs;\r\n    };\r\n\r\n    // OrOperation ///////////////////////////////////////////////////////////////\r\n\r\n    OrOperation.prototype = new BinaryOperation();\r\n    OrOperation.prototype.constructor = OrOperation;\r\n    OrOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function OrOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    OrOperation.prototype.init = function (lhs, rhs) {\r\n        OrOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    OrOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" or \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    OrOperation.prototype.evaluate = function (c) {\r\n        var b = this.lhs.evaluate(c).bool();\r\n        if (b.booleanValue()) {\r\n            return b;\r\n        }\r\n        return this.rhs.evaluate(c).bool();\r\n    };\r\n\r\n    // AndOperation //////////////////////////////////////////////////////////////\r\n\r\n    AndOperation.prototype = new BinaryOperation();\r\n    AndOperation.prototype.constructor = AndOperation;\r\n    AndOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function AndOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    AndOperation.prototype.init = function (lhs, rhs) {\r\n        AndOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    AndOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" and \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    AndOperation.prototype.evaluate = function (c) {\r\n        var b = this.lhs.evaluate(c).bool();\r\n        if (!b.booleanValue()) {\r\n            return b;\r\n        }\r\n        return this.rhs.evaluate(c).bool();\r\n    };\r\n\r\n    // EqualsOperation ///////////////////////////////////////////////////////////\r\n\r\n    EqualsOperation.prototype = new BinaryOperation();\r\n    EqualsOperation.prototype.constructor = EqualsOperation;\r\n    EqualsOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function EqualsOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    EqualsOperation.prototype.init = function (lhs, rhs) {\r\n        EqualsOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    EqualsOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" = \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    EqualsOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).equals(this.rhs.evaluate(c));\r\n    };\r\n\r\n    // NotEqualOperation /////////////////////////////////////////////////////////\r\n\r\n    NotEqualOperation.prototype = new BinaryOperation();\r\n    NotEqualOperation.prototype.constructor = NotEqualOperation;\r\n    NotEqualOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function NotEqualOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    NotEqualOperation.prototype.init = function (lhs, rhs) {\r\n        NotEqualOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    NotEqualOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" != \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    NotEqualOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).notequal(this.rhs.evaluate(c));\r\n    };\r\n\r\n    // LessThanOperation /////////////////////////////////////////////////////////\r\n\r\n    LessThanOperation.prototype = new BinaryOperation();\r\n    LessThanOperation.prototype.constructor = LessThanOperation;\r\n    LessThanOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function LessThanOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    LessThanOperation.prototype.init = function (lhs, rhs) {\r\n        LessThanOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    LessThanOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).lessthan(this.rhs.evaluate(c));\r\n    };\r\n\r\n    LessThanOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" < \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    // GreaterThanOperation //////////////////////////////////////////////////////\r\n\r\n    GreaterThanOperation.prototype = new BinaryOperation();\r\n    GreaterThanOperation.prototype.constructor = GreaterThanOperation;\r\n    GreaterThanOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function GreaterThanOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    GreaterThanOperation.prototype.init = function (lhs, rhs) {\r\n        GreaterThanOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    GreaterThanOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).greaterthan(this.rhs.evaluate(c));\r\n    };\r\n\r\n    GreaterThanOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" > \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    // LessThanOrEqualOperation //////////////////////////////////////////////////\r\n\r\n    LessThanOrEqualOperation.prototype = new BinaryOperation();\r\n    LessThanOrEqualOperation.prototype.constructor = LessThanOrEqualOperation;\r\n    LessThanOrEqualOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function LessThanOrEqualOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    LessThanOrEqualOperation.prototype.init = function (lhs, rhs) {\r\n        LessThanOrEqualOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    LessThanOrEqualOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).lessthanorequal(this.rhs.evaluate(c));\r\n    };\r\n\r\n    LessThanOrEqualOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" <= \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    // GreaterThanOrEqualOperation ///////////////////////////////////////////////\r\n\r\n    GreaterThanOrEqualOperation.prototype = new BinaryOperation();\r\n    GreaterThanOrEqualOperation.prototype.constructor = GreaterThanOrEqualOperation;\r\n    GreaterThanOrEqualOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function GreaterThanOrEqualOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    GreaterThanOrEqualOperation.prototype.init = function (lhs, rhs) {\r\n        GreaterThanOrEqualOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    GreaterThanOrEqualOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).greaterthanorequal(this.rhs.evaluate(c));\r\n    };\r\n\r\n    GreaterThanOrEqualOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" >= \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    // PlusOperation /////////////////////////////////////////////////////////////\r\n\r\n    PlusOperation.prototype = new BinaryOperation();\r\n    PlusOperation.prototype.constructor = PlusOperation;\r\n    PlusOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function PlusOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    PlusOperation.prototype.init = function (lhs, rhs) {\r\n        PlusOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    PlusOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).number().plus(this.rhs.evaluate(c).number());\r\n    };\r\n\r\n    PlusOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" + \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    // MinusOperation ////////////////////////////////////////////////////////////\r\n\r\n    MinusOperation.prototype = new BinaryOperation();\r\n    MinusOperation.prototype.constructor = MinusOperation;\r\n    MinusOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function MinusOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    MinusOperation.prototype.init = function (lhs, rhs) {\r\n        MinusOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    MinusOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).number().minus(this.rhs.evaluate(c).number());\r\n    };\r\n\r\n    MinusOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" - \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    // MultiplyOperation /////////////////////////////////////////////////////////\r\n\r\n    MultiplyOperation.prototype = new BinaryOperation();\r\n    MultiplyOperation.prototype.constructor = MultiplyOperation;\r\n    MultiplyOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function MultiplyOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    MultiplyOperation.prototype.init = function (lhs, rhs) {\r\n        MultiplyOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    MultiplyOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).number().multiply(this.rhs.evaluate(c).number());\r\n    };\r\n\r\n    MultiplyOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" * \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    // DivOperation //////////////////////////////////////////////////////////////\r\n\r\n    DivOperation.prototype = new BinaryOperation();\r\n    DivOperation.prototype.constructor = DivOperation;\r\n    DivOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function DivOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    DivOperation.prototype.init = function (lhs, rhs) {\r\n        DivOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    DivOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).number().div(this.rhs.evaluate(c).number());\r\n    };\r\n\r\n    DivOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" div \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    // ModOperation //////////////////////////////////////////////////////////////\r\n\r\n    ModOperation.prototype = new BinaryOperation();\r\n    ModOperation.prototype.constructor = ModOperation;\r\n    ModOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function ModOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    ModOperation.prototype.init = function (lhs, rhs) {\r\n        ModOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    ModOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).number().mod(this.rhs.evaluate(c).number());\r\n    };\r\n\r\n    ModOperation.prototype.toString = function () {\r\n        return \"(\" + this.lhs.toString() + \" mod \" + this.rhs.toString() + \")\";\r\n    };\r\n\r\n    // BarOperation //////////////////////////////////////////////////////////////\r\n\r\n    BarOperation.prototype = new BinaryOperation();\r\n    BarOperation.prototype.constructor = BarOperation;\r\n    BarOperation.superclass = BinaryOperation.prototype;\r\n\r\n    function BarOperation(lhs, rhs) {\r\n        if (arguments.length > 0) {\r\n            this.init(lhs, rhs);\r\n        }\r\n    }\r\n\r\n    BarOperation.prototype.init = function (lhs, rhs) {\r\n        BarOperation.superclass.init.call(this, lhs, rhs);\r\n    };\r\n\r\n    BarOperation.prototype.evaluate = function (c) {\r\n        return this.lhs.evaluate(c).nodeset().union(this.rhs.evaluate(c).nodeset());\r\n    };\r\n\r\n    BarOperation.prototype.toString = function () {\r\n        return map(toString, [this.lhs, this.rhs]).join(' | ');\r\n    };\r\n\r\n    // PathExpr //////////////////////////////////////////////////////////////////\r\n\r\n    PathExpr.prototype = new Expression();\r\n    PathExpr.prototype.constructor = PathExpr;\r\n    PathExpr.superclass = Expression.prototype;\r\n\r\n    function PathExpr(filter, filterPreds, locpath) {\r\n        if (arguments.length > 0) {\r\n            this.init(filter, filterPreds, locpath);\r\n        }\r\n    }\r\n\r\n    PathExpr.prototype.init = function (filter, filterPreds, locpath) {\r\n        PathExpr.superclass.init.call(this);\r\n        this.filter = filter;\r\n        this.filterPredicates = filterPreds;\r\n        this.locationPath = locpath;\r\n    };\r\n\r\n    /**\r\n     * Returns the topmost node of the tree containing node\r\n     */\r\n    function findRoot(node) {\r\n        while (node && node.parentNode) {\r\n            node = node.parentNode;\r\n        }\r\n\r\n        return node;\r\n    }\r\n\r\n    PathExpr.applyPredicates = function (predicates, c, nodes) {\r\n        if (predicates.length === 0) {\r\n            return nodes;\r\n        }\r\n\r\n        var ctx = c.extend({});\r\n\r\n        return reduce(\r\n            function (inNodes, pred) {\r\n                ctx.contextSize = inNodes.length;\r\n\r\n                return filter(\r\n                    function (node, i) {\r\n                        ctx.contextNode = node;\r\n                        ctx.contextPosition = i + 1;\r\n\r\n                        return PathExpr.predicateMatches(pred, ctx);\r\n                    },\r\n                    inNodes\r\n                );\r\n            },\r\n            nodes,\r\n            predicates\r\n        );\r\n    };\r\n\r\n    PathExpr.getRoot = function (xpc, nodes) {\r\n        var firstNode = nodes[0];\r\n\r\n        if (firstNode.nodeType === NodeTypes.DOCUMENT_NODE) {\r\n            return firstNode;\r\n        }\r\n\r\n        if (xpc.virtualRoot) {\r\n            return xpc.virtualRoot;\r\n        }\r\n\r\n        var ownerDoc = firstNode.ownerDocument;\r\n\r\n        if (ownerDoc) {\r\n            return ownerDoc;\r\n        }\r\n\r\n        // IE 5.5 doesn't have ownerDocument?\r\n        var n = firstNode;\r\n        while (n.parentNode != null) {\r\n            n = n.parentNode;\r\n        }\r\n        return n;\r\n    }\r\n\r\n    PathExpr.applyStep = function (step, xpc, node) {\r\n        var self = this;\r\n        var newNodes = [];\r\n        xpc.contextNode = node;\r\n\r\n        switch (step.axis) {\r\n            case Step.ANCESTOR:\r\n                // look at all the ancestor nodes\r\n                if (xpc.contextNode === xpc.virtualRoot) {\r\n                    break;\r\n                }\r\n                var m;\r\n                if (xpc.contextNode.nodeType == NodeTypes.ATTRIBUTE_NODE) {\r\n                    m = PathExpr.getOwnerElement(xpc.contextNode);\r\n                } else {\r\n                    m = xpc.contextNode.parentNode;\r\n                }\r\n                while (m != null) {\r\n                    if (step.nodeTest.matches(m, xpc)) {\r\n                        newNodes.push(m);\r\n                    }\r\n                    if (m === xpc.virtualRoot) {\r\n                        break;\r\n                    }\r\n                    m = m.parentNode;\r\n                }\r\n                break;\r\n\r\n            case Step.ANCESTORORSELF:\r\n                // look at all the ancestor nodes and the current node\r\n                for (var m = xpc.contextNode; m != null; m = m.nodeType == NodeTypes.ATTRIBUTE_NODE ? PathExpr.getOwnerElement(m) : m.parentNode) {\r\n                    if (step.nodeTest.matches(m, xpc)) {\r\n                        newNodes.push(m);\r\n                    }\r\n                    if (m === xpc.virtualRoot) {\r\n                        break;\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case Step.ATTRIBUTE:\r\n                // look at the attributes\r\n                var nnm = xpc.contextNode.attributes;\r\n                if (nnm != null) {\r\n                    for (var k = 0; k < nnm.length; k++) {\r\n                        var m = nnm.item(k);\r\n                        if (step.nodeTest.matches(m, xpc)) {\r\n                            newNodes.push(m);\r\n                        }\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case Step.CHILD:\r\n                // look at all child elements\r\n                for (var m = xpc.contextNode.firstChild; m != null; m = m.nextSibling) {\r\n                    if (step.nodeTest.matches(m, xpc)) {\r\n                        newNodes.push(m);\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case Step.DESCENDANT:\r\n                // look at all descendant nodes\r\n                var st = [xpc.contextNode.firstChild];\r\n                while (st.length > 0) {\r\n                    for (var m = st.pop(); m != null;) {\r\n                        if (step.nodeTest.matches(m, xpc)) {\r\n                            newNodes.push(m);\r\n                        }\r\n                        if (m.firstChild != null) {\r\n                            st.push(m.nextSibling);\r\n                            m = m.firstChild;\r\n                        } else {\r\n                            m = m.nextSibling;\r\n                        }\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case Step.DESCENDANTORSELF:\r\n                // look at self\r\n                if (step.nodeTest.matches(xpc.contextNode, xpc)) {\r\n                    newNodes.push(xpc.contextNode);\r\n                }\r\n                // look at all descendant nodes\r\n                var st = [xpc.contextNode.firstChild];\r\n                while (st.length > 0) {\r\n                    for (var m = st.pop(); m != null;) {\r\n                        if (step.nodeTest.matches(m, xpc)) {\r\n                            newNodes.push(m);\r\n                        }\r\n                        if (m.firstChild != null) {\r\n                            st.push(m.nextSibling);\r\n                            m = m.firstChild;\r\n                        } else {\r\n                            m = m.nextSibling;\r\n                        }\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case Step.FOLLOWING:\r\n                if (xpc.contextNode === xpc.virtualRoot) {\r\n                    break;\r\n                }\r\n                var st = [];\r\n                if (xpc.contextNode.firstChild != null) {\r\n                    st.unshift(xpc.contextNode.firstChild);\r\n                } else {\r\n                    st.unshift(xpc.contextNode.nextSibling);\r\n                }\r\n                for (var m = xpc.contextNode.parentNode; m != null && m.nodeType != NodeTypes.DOCUMENT_NODE && m !== xpc.virtualRoot; m = m.parentNode) {\r\n                    st.unshift(m.nextSibling);\r\n                }\r\n                do {\r\n                    for (var m = st.pop(); m != null;) {\r\n                        if (step.nodeTest.matches(m, xpc)) {\r\n                            newNodes.push(m);\r\n                        }\r\n                        if (m.firstChild != null) {\r\n                            st.push(m.nextSibling);\r\n                            m = m.firstChild;\r\n                        } else {\r\n                            m = m.nextSibling;\r\n                        }\r\n                    }\r\n                } while (st.length > 0);\r\n                break;\r\n\r\n            case Step.FOLLOWINGSIBLING:\r\n                if (xpc.contextNode === xpc.virtualRoot) {\r\n                    break;\r\n                }\r\n                for (var m = xpc.contextNode.nextSibling; m != null; m = m.nextSibling) {\r\n                    if (step.nodeTest.matches(m, xpc)) {\r\n                        newNodes.push(m);\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case Step.NAMESPACE:\r\n                var n = {};\r\n                if (xpc.contextNode.nodeType == NodeTypes.ELEMENT_NODE) {\r\n                    n[\"xml\"] = XPath.XML_NAMESPACE_URI;\r\n                    n[\"xmlns\"] = XPath.XMLNS_NAMESPACE_URI;\r\n                    for (var m = xpc.contextNode; m != null && m.nodeType == NodeTypes.ELEMENT_NODE; m = m.parentNode) {\r\n                        for (var k = 0; k < m.attributes.length; k++) {\r\n                            var attr = m.attributes.item(k);\r\n                            var nm = String(attr.name);\r\n                            if (nm == \"xmlns\") {\r\n                                if (n[\"\"] == undefined) {\r\n                                    n[\"\"] = attr.value;\r\n                                }\r\n                            } else if (nm.length > 6 && nm.substring(0, 6) == \"xmlns:\") {\r\n                                var pre = nm.substring(6, nm.length);\r\n                                if (n[pre] == undefined) {\r\n                                    n[pre] = attr.value;\r\n                                }\r\n                            }\r\n                        }\r\n                    }\r\n                    for (var pre in n) {\r\n                        var nsn = new XPathNamespace(pre, n[pre], xpc.contextNode);\r\n                        if (step.nodeTest.matches(nsn, xpc)) {\r\n                            newNodes.push(nsn);\r\n                        }\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case Step.PARENT:\r\n                m = null;\r\n                if (xpc.contextNode !== xpc.virtualRoot) {\r\n                    if (xpc.contextNode.nodeType == NodeTypes.ATTRIBUTE_NODE) {\r\n                        m = PathExpr.getOwnerElement(xpc.contextNode);\r\n                    } else {\r\n                        m = xpc.contextNode.parentNode;\r\n                    }\r\n                }\r\n                if (m != null && step.nodeTest.matches(m, xpc)) {\r\n                    newNodes.push(m);\r\n                }\r\n                break;\r\n\r\n            case Step.PRECEDING:\r\n                var st;\r\n                if (xpc.virtualRoot != null) {\r\n                    st = [xpc.virtualRoot];\r\n                } else {\r\n                    // cannot rely on .ownerDocument because the node may be in a document fragment\r\n                    st = [findRoot(xpc.contextNode)];\r\n                }\r\n                outer: while (st.length > 0) {\r\n                    for (var m = st.pop(); m != null;) {\r\n                        if (m == xpc.contextNode) {\r\n                            break outer;\r\n                        }\r\n                        if (step.nodeTest.matches(m, xpc)) {\r\n                            newNodes.unshift(m);\r\n                        }\r\n                        if (m.firstChild != null) {\r\n                            st.push(m.nextSibling);\r\n                            m = m.firstChild;\r\n                        } else {\r\n                            m = m.nextSibling;\r\n                        }\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case Step.PRECEDINGSIBLING:\r\n                if (xpc.contextNode === xpc.virtualRoot) {\r\n                    break;\r\n                }\r\n                for (var m = xpc.contextNode.previousSibling; m != null; m = m.previousSibling) {\r\n                    if (step.nodeTest.matches(m, xpc)) {\r\n                        newNodes.push(m);\r\n                    }\r\n                }\r\n                break;\r\n\r\n            case Step.SELF:\r\n                if (step.nodeTest.matches(xpc.contextNode, xpc)) {\r\n                    newNodes.push(xpc.contextNode);\r\n                }\r\n                break;\r\n\r\n            default:\r\n        }\r\n\r\n        return newNodes;\r\n    };\r\n\r\n    function applyStepWithPredicates(step, xpc, node) {\r\n        return PathExpr.applyPredicates(\r\n            step.predicates,\r\n            xpc,\r\n            PathExpr.applyStep(step, xpc, node)\r\n        );\r\n    }\r\n\r\n    function applyStepToNodes(context, nodes, step) {\r\n        return flatten(\r\n            map(\r\n                applyStepWithPredicates.bind(null, step, context),\r\n                nodes\r\n            )\r\n        );\r\n    }\r\n\r\n    PathExpr.applySteps = function (steps, xpc, nodes) {\r\n        return reduce(\r\n            applyStepToNodes.bind(null, xpc),\r\n            nodes,\r\n            steps\r\n        );\r\n    }\r\n\r\n    PathExpr.prototype.applyFilter = function (c, xpc) {\r\n        if (!this.filter) {\r\n            return { nodes: [c.contextNode] };\r\n        }\r\n\r\n        var ns = this.filter.evaluate(c);\r\n\r\n        if (!Utilities.instance_of(ns, XNodeSet)) {\r\n            if (this.filterPredicates != null && this.filterPredicates.length > 0 || this.locationPath != null) {\r\n                throw new Error(\"Path expression filter must evaluate to a nodeset if predicates or location path are used\");\r\n            }\r\n\r\n            return { nonNodes: ns };\r\n        }\r\n\r\n        return {\r\n            nodes: PathExpr.applyPredicates(this.filterPredicates || [], xpc, ns.toUnsortedArray())\r\n        };\r\n    };\r\n\r\n    PathExpr.applyLocationPath = function (locationPath, xpc, nodes) {\r\n        if (!locationPath) {\r\n            return nodes;\r\n        }\r\n\r\n        var startNodes = locationPath.absolute ? [PathExpr.getRoot(xpc, nodes)] : nodes;\r\n\r\n        return PathExpr.applySteps(locationPath.steps, xpc, startNodes);\r\n    };\r\n\r\n    PathExpr.prototype.evaluate = function (c) {\r\n        var xpc = assign(new XPathContext(), c);\r\n\r\n        var filterResult = this.applyFilter(c, xpc);\r\n\r\n        if ('nonNodes' in filterResult) {\r\n            return filterResult.nonNodes;\r\n        }\r\n\r\n        var ns = new XNodeSet();\r\n        ns.addArray(PathExpr.applyLocationPath(this.locationPath, xpc, filterResult.nodes));\r\n        return ns;\r\n    };\r\n\r\n    PathExpr.predicateMatches = function (pred, c) {\r\n        var res = pred.evaluate(c);\r\n\r\n        return Utilities.instance_of(res, XNumber)\r\n            ? c.contextPosition === res.numberValue()\r\n            : res.booleanValue();\r\n    };\r\n\r\n    PathExpr.predicateString = function (predicate) {\r\n        return wrap('[', ']', predicate.toString());\r\n    }\r\n\r\n    PathExpr.predicatesString = function (predicates) {\r\n        return join(\r\n            '',\r\n            map(PathExpr.predicateString, predicates)\r\n        );\r\n    }\r\n\r\n    PathExpr.prototype.toString = function () {\r\n        if (this.filter != undefined) {\r\n            var filterStr = toString(this.filter);\r\n\r\n            if (Utilities.instance_of(this.filter, XString)) {\r\n                return wrap(\"'\", \"'\", filterStr);\r\n            }\r\n            if (this.filterPredicates != undefined && this.filterPredicates.length) {\r\n                return wrap('(', ')', filterStr) +\r\n                    PathExpr.predicatesString(this.filterPredicates);\r\n            }\r\n            if (this.locationPath != undefined) {\r\n                return filterStr +\r\n                    (this.locationPath.absolute ? '' : '/') +\r\n                    toString(this.locationPath);\r\n            }\r\n\r\n            return filterStr;\r\n        }\r\n\r\n        return toString(this.locationPath);\r\n    };\r\n\r\n    PathExpr.getOwnerElement = function (n) {\r\n        // DOM 2 has ownerElement\r\n        if (n.ownerElement) {\r\n            return n.ownerElement;\r\n        }\r\n        // DOM 1 Internet Explorer can use selectSingleNode (ironically)\r\n        try {\r\n            if (n.selectSingleNode) {\r\n                return n.selectSingleNode(\"..\");\r\n            }\r\n        } catch (e) {\r\n        }\r\n        // Other DOM 1 implementations must use this egregious search\r\n        var doc = n.nodeType == NodeTypes.DOCUMENT_NODE\r\n            ? n\r\n            : n.ownerDocument;\r\n        var elts = doc.getElementsByTagName(\"*\");\r\n        for (var i = 0; i < elts.length; i++) {\r\n            var elt = elts.item(i);\r\n            var nnm = elt.attributes;\r\n            for (var j = 0; j < nnm.length; j++) {\r\n                var an = nnm.item(j);\r\n                if (an === n) {\r\n                    return elt;\r\n                }\r\n            }\r\n        }\r\n        return null;\r\n    };\r\n\r\n    // LocationPath //////////////////////////////////////////////////////////////\r\n\r\n    LocationPath.prototype = new Object();\r\n    LocationPath.prototype.constructor = LocationPath;\r\n    LocationPath.superclass = Object.prototype;\r\n\r\n    function LocationPath(abs, steps) {\r\n        if (arguments.length > 0) {\r\n            this.init(abs, steps);\r\n        }\r\n    }\r\n\r\n    LocationPath.prototype.init = function (abs, steps) {\r\n        this.absolute = abs;\r\n        this.steps = steps;\r\n    };\r\n\r\n    LocationPath.prototype.toString = function () {\r\n        return (\r\n            (this.absolute ? '/' : '') +\r\n            map(toString, this.steps).join('/')\r\n        );\r\n    };\r\n\r\n    // Step //////////////////////////////////////////////////////////////////////\r\n\r\n    Step.prototype = new Object();\r\n    Step.prototype.constructor = Step;\r\n    Step.superclass = Object.prototype;\r\n\r\n    function Step(axis, nodetest, preds) {\r\n        if (arguments.length > 0) {\r\n            this.init(axis, nodetest, preds);\r\n        }\r\n    }\r\n\r\n    Step.prototype.init = function (axis, nodetest, preds) {\r\n        this.axis = axis;\r\n        this.nodeTest = nodetest;\r\n        this.predicates = preds;\r\n    };\r\n\r\n    Step.prototype.toString = function () {\r\n        return Step.STEPNAMES[this.axis] +\r\n            \"::\" +\r\n            this.nodeTest.toString() +\r\n            PathExpr.predicatesString(this.predicates);\r\n    };\r\n\r\n\r\n    Step.ANCESTOR = 0;\r\n    Step.ANCESTORORSELF = 1;\r\n    Step.ATTRIBUTE = 2;\r\n    Step.CHILD = 3;\r\n    Step.DESCENDANT = 4;\r\n    Step.DESCENDANTORSELF = 5;\r\n    Step.FOLLOWING = 6;\r\n    Step.FOLLOWINGSIBLING = 7;\r\n    Step.NAMESPACE = 8;\r\n    Step.PARENT = 9;\r\n    Step.PRECEDING = 10;\r\n    Step.PRECEDINGSIBLING = 11;\r\n    Step.SELF = 12;\r\n\r\n    Step.STEPNAMES = reduce(function (acc, x) { return acc[x[0]] = x[1], acc; }, {}, [\r\n        [Step.ANCESTOR, 'ancestor'],\r\n        [Step.ANCESTORORSELF, 'ancestor-or-self'],\r\n        [Step.ATTRIBUTE, 'attribute'],\r\n        [Step.CHILD, 'child'],\r\n        [Step.DESCENDANT, 'descendant'],\r\n        [Step.DESCENDANTORSELF, 'descendant-or-self'],\r\n        [Step.FOLLOWING, 'following'],\r\n        [Step.FOLLOWINGSIBLING, 'following-sibling'],\r\n        [Step.NAMESPACE, 'namespace'],\r\n        [Step.PARENT, 'parent'],\r\n        [Step.PRECEDING, 'preceding'],\r\n        [Step.PRECEDINGSIBLING, 'preceding-sibling'],\r\n        [Step.SELF, 'self']\r\n    ]);\r\n\r\n    // NodeTest //////////////////////////////////////////////////////////////////\r\n\r\n    NodeTest.prototype = new Object();\r\n    NodeTest.prototype.constructor = NodeTest;\r\n    NodeTest.superclass = Object.prototype;\r\n\r\n    function NodeTest(type, value) {\r\n        if (arguments.length > 0) {\r\n            this.init(type, value);\r\n        }\r\n    }\r\n\r\n    NodeTest.prototype.init = function (type, value) {\r\n        this.type = type;\r\n        this.value = value;\r\n    };\r\n\r\n    NodeTest.prototype.toString = function () {\r\n        return \"<unknown nodetest type>\";\r\n    };\r\n\r\n    NodeTest.prototype.matches = function (n, xpc) {\r\n        console.warn('unknown node test type');\r\n    };\r\n\r\n    NodeTest.NAMETESTANY = 0;\r\n    NodeTest.NAMETESTPREFIXANY = 1;\r\n    NodeTest.NAMETESTQNAME = 2;\r\n    NodeTest.COMMENT = 3;\r\n    NodeTest.TEXT = 4;\r\n    NodeTest.PI = 5;\r\n    NodeTest.NODE = 6;\r\n\r\n    NodeTest.isNodeType = function (types) {\r\n        return function (node) {\r\n            return includes(types, node.nodeType);\r\n        };\r\n    };\r\n\r\n    NodeTest.makeNodeTestType = function (type, members, ctor) {\r\n        var newType = ctor || function () { };\r\n\r\n        newType.prototype = new NodeTest(type);\r\n        newType.prototype.constructor = newType;\r\n\r\n        assign(newType.prototype, members);\r\n\r\n        return newType;\r\n    };\r\n    // create invariant node test for certain node types\r\n    NodeTest.makeNodeTypeTest = function (type, nodeTypes, stringVal) {\r\n        return new (NodeTest.makeNodeTestType(type, {\r\n            matches: NodeTest.isNodeType(nodeTypes),\r\n            toString: always(stringVal)\r\n        }))();\r\n    };\r\n\r\n    NodeTest.hasPrefix = function (node) {\r\n        return node.prefix || (node.nodeName || node.tagName).indexOf(':') !== -1;\r\n    };\r\n\r\n    NodeTest.isElementOrAttribute = NodeTest.isNodeType([1, 2]);\r\n    NodeTest.nameSpaceMatches = function (prefix, xpc, n) {\r\n        var nNamespace = (n.namespaceURI || '');\r\n\r\n        if (!prefix) {\r\n            return !nNamespace || (xpc.allowAnyNamespaceForNoPrefix && !NodeTest.hasPrefix(n));\r\n        }\r\n\r\n        var ns = xpc.namespaceResolver.getNamespace(prefix, xpc.expressionContextNode);\r\n\r\n        if (ns == null) {\r\n            throw new Error(\"Cannot resolve QName \" + prefix);\r\n        }\r\n\r\n        return ns === nNamespace;\r\n    };\r\n    NodeTest.localNameMatches = function (localName, xpc, n) {\r\n        var nLocalName = (n.localName || n.nodeName);\r\n\r\n        return xpc.caseInsensitive\r\n            ? localName.toLowerCase() === nLocalName.toLowerCase()\r\n            : localName === nLocalName;\r\n    };\r\n\r\n    NodeTest.NameTestPrefixAny = NodeTest.makeNodeTestType(\r\n        NodeTest.NAMETESTPREFIXANY,\r\n        {\r\n            matches: function (n, xpc) {\r\n                return NodeTest.isElementOrAttribute(n) &&\r\n                    NodeTest.nameSpaceMatches(this.prefix, xpc, n);\r\n            },\r\n            toString: function () {\r\n                return this.prefix + \":*\";\r\n            }\r\n        },\r\n        function NameTestPrefixAny(prefix) { this.prefix = prefix; }\r\n    );\r\n\r\n    NodeTest.NameTestQName = NodeTest.makeNodeTestType(\r\n        NodeTest.NAMETESTQNAME,\r\n        {\r\n            matches: function (n, xpc) {\r\n                return NodeTest.isNodeType(\r\n                    [\r\n                        NodeTypes.ELEMENT_NODE,\r\n                        NodeTypes.ATTRIBUTE_NODE,\r\n                        XPathNamespace.XPATH_NAMESPACE_NODE,\r\n                    ]\r\n                )(n) &&\r\n                    NodeTest.nameSpaceMatches(this.prefix, xpc, n) &&\r\n                    NodeTest.localNameMatches(this.localName, xpc, n);\r\n            },\r\n            toString: function () {\r\n                return this.name;\r\n            }\r\n        },\r\n        function NameTestQName(name) {\r\n            var nameParts = name.split(':');\r\n\r\n            this.name = name;\r\n            this.prefix = nameParts.length > 1 ? nameParts[0] : null;\r\n            this.localName = nameParts[nameParts.length > 1 ? 1 : 0];\r\n        }\r\n    );\r\n\r\n    NodeTest.PITest = NodeTest.makeNodeTestType(NodeTest.PI, {\r\n        matches: function (n, xpc) {\r\n            return NodeTest.isNodeType(\r\n                [NodeTypes.PROCESSING_INSTRUCTION_NODE]\r\n            )(n) &&\r\n                (n.target || n.nodeName) === this.name;\r\n        },\r\n        toString: function () {\r\n            return wrap('processing-instruction(\"', '\")', this.name);\r\n        }\r\n    }, function (name) { this.name = name; })\r\n\r\n    // singletons\r\n\r\n    // elements, attributes, namespaces\r\n    NodeTest.nameTestAny = NodeTest.makeNodeTypeTest(\r\n        NodeTest.NAMETESTANY,\r\n        [\r\n            NodeTypes.ELEMENT_NODE,\r\n            NodeTypes.ATTRIBUTE_NODE,\r\n            XPathNamespace.XPATH_NAMESPACE_NODE,\r\n        ],\r\n        '*'\r\n    );\r\n    // text, cdata\r\n    NodeTest.textTest = NodeTest.makeNodeTypeTest(\r\n        NodeTest.TEXT,\r\n        [\r\n            NodeTypes.TEXT_NODE,\r\n            NodeTypes.CDATA_SECTION_NODE,\r\n        ],\r\n        'text()'\r\n    );\r\n    NodeTest.commentTest = NodeTest.makeNodeTypeTest(\r\n        NodeTest.COMMENT,\r\n        [NodeTypes.COMMENT_NODE],\r\n        'comment()'\r\n    );\r\n    // elements, attributes, text, cdata, PIs, comments, document nodes\r\n    NodeTest.nodeTest = NodeTest.makeNodeTypeTest(\r\n        NodeTest.NODE,\r\n        [\r\n            NodeTypes.ELEMENT_NODE,\r\n            NodeTypes.ATTRIBUTE_NODE, \r\n            NodeTypes.TEXT_NODE, \r\n            NodeTypes.CDATA_SECTION_NODE,\r\n            NodeTypes.PROCESSING_INSTRUCTION_NODE,\r\n            NodeTypes.COMMENT_NODE,\r\n            NodeTypes.DOCUMENT_NODE,\r\n        ],\r\n        'node()'\r\n    );\r\n    NodeTest.anyPiTest = NodeTest.makeNodeTypeTest(\r\n        NodeTest.PI,\r\n        [NodeTypes.PROCESSING_INSTRUCTION_NODE],\r\n        'processing-instruction()'\r\n    );\r\n\r\n    // VariableReference /////////////////////////////////////////////////////////\r\n\r\n    VariableReference.prototype = new Expression();\r\n    VariableReference.prototype.constructor = VariableReference;\r\n    VariableReference.superclass = Expression.prototype;\r\n\r\n    function VariableReference(v) {\r\n        if (arguments.length > 0) {\r\n            this.init(v);\r\n        }\r\n    }\r\n\r\n    VariableReference.prototype.init = function (v) {\r\n        this.variable = v;\r\n    };\r\n\r\n    VariableReference.prototype.toString = function () {\r\n        return \"$\" + this.variable;\r\n    };\r\n\r\n    VariableReference.prototype.evaluate = function (c) {\r\n        var parts = Utilities.resolveQName(this.variable, c.namespaceResolver, c.contextNode, false);\r\n\r\n        if (parts[0] == null) {\r\n            throw new Error(\"Cannot resolve QName \" + fn);\r\n        }\r\n        var result = c.variableResolver.getVariable(parts[1], parts[0]);\r\n        if (!result) {\r\n            throw XPathException.fromMessage(\"Undeclared variable: \" + this.toString());\r\n        }\r\n        return result;\r\n    };\r\n\r\n    // FunctionCall //////////////////////////////////////////////////////////////\r\n\r\n    FunctionCall.prototype = new Expression();\r\n    FunctionCall.prototype.constructor = FunctionCall;\r\n    FunctionCall.superclass = Expression.prototype;\r\n\r\n    function FunctionCall(fn, args) {\r\n        if (arguments.length > 0) {\r\n            this.init(fn, args);\r\n        }\r\n    }\r\n\r\n    FunctionCall.prototype.init = function (fn, args) {\r\n        this.functionName = fn;\r\n        this.arguments = args;\r\n    };\r\n\r\n    FunctionCall.prototype.toString = function () {\r\n        var s = this.functionName + \"(\";\r\n        for (var i = 0; i < this.arguments.length; i++) {\r\n            if (i > 0) {\r\n                s += \", \";\r\n            }\r\n            s += this.arguments[i].toString();\r\n        }\r\n        return s + \")\";\r\n    };\r\n\r\n    FunctionCall.prototype.evaluate = function (c) {\r\n        var f = FunctionResolver.getFunctionFromContext(this.functionName, c);\r\n\r\n        if (!f) {\r\n            throw new Error(\"Unknown function \" + this.functionName);\r\n        }\r\n\r\n        var a = [c].concat(this.arguments);\r\n        return f.apply(c.functionResolver.thisArg, a);\r\n    };\r\n\r\n    // Operators /////////////////////////////////////////////////////////////////\r\n\r\n    var Operators = new Object();\r\n\r\n    Operators.equals = function (l, r) {\r\n        return l.equals(r);\r\n    };\r\n\r\n    Operators.notequal = function (l, r) {\r\n        return l.notequal(r);\r\n    };\r\n\r\n    Operators.lessthan = function (l, r) {\r\n        return l.lessthan(r);\r\n    };\r\n\r\n    Operators.greaterthan = function (l, r) {\r\n        return l.greaterthan(r);\r\n    };\r\n\r\n    Operators.lessthanorequal = function (l, r) {\r\n        return l.lessthanorequal(r);\r\n    };\r\n\r\n    Operators.greaterthanorequal = function (l, r) {\r\n        return l.greaterthanorequal(r);\r\n    };\r\n\r\n    // XString ///////////////////////////////////////////////////////////////////\r\n\r\n    XString.prototype = new Expression();\r\n    XString.prototype.constructor = XString;\r\n    XString.superclass = Expression.prototype;\r\n\r\n    function XString(s) {\r\n        if (arguments.length > 0) {\r\n            this.init(s);\r\n        }\r\n    }\r\n\r\n    XString.prototype.init = function (s) {\r\n        this.str = String(s);\r\n    };\r\n\r\n    XString.prototype.toString = function () {\r\n        return this.str;\r\n    };\r\n\r\n    XString.prototype.evaluate = function (c) {\r\n        return this;\r\n    };\r\n\r\n    XString.prototype.string = function () {\r\n        return this;\r\n    };\r\n\r\n    XString.prototype.number = function () {\r\n        return new XNumber(this.str);\r\n    };\r\n\r\n    XString.prototype.bool = function () {\r\n        return new XBoolean(this.str);\r\n    };\r\n\r\n    XString.prototype.nodeset = function () {\r\n        throw new Error(\"Cannot convert string to nodeset\");\r\n    };\r\n\r\n    XString.prototype.stringValue = function () {\r\n        return this.str;\r\n    };\r\n\r\n    XString.prototype.numberValue = function () {\r\n        return this.number().numberValue();\r\n    };\r\n\r\n    XString.prototype.booleanValue = function () {\r\n        return this.bool().booleanValue();\r\n    };\r\n\r\n    XString.prototype.equals = function (r) {\r\n        if (Utilities.instance_of(r, XBoolean)) {\r\n            return this.bool().equals(r);\r\n        }\r\n        if (Utilities.instance_of(r, XNumber)) {\r\n            return this.number().equals(r);\r\n        }\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithString(this, Operators.equals);\r\n        }\r\n        return new XBoolean(this.str == r.str);\r\n    };\r\n\r\n    XString.prototype.notequal = function (r) {\r\n        if (Utilities.instance_of(r, XBoolean)) {\r\n            return this.bool().notequal(r);\r\n        }\r\n        if (Utilities.instance_of(r, XNumber)) {\r\n            return this.number().notequal(r);\r\n        }\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithString(this, Operators.notequal);\r\n        }\r\n        return new XBoolean(this.str != r.str);\r\n    };\r\n\r\n    XString.prototype.lessthan = function (r) {\r\n        return this.number().lessthan(r);\r\n    };\r\n\r\n    XString.prototype.greaterthan = function (r) {\r\n        return this.number().greaterthan(r);\r\n    };\r\n\r\n    XString.prototype.lessthanorequal = function (r) {\r\n        return this.number().lessthanorequal(r);\r\n    };\r\n\r\n    XString.prototype.greaterthanorequal = function (r) {\r\n        return this.number().greaterthanorequal(r);\r\n    };\r\n\r\n    // XNumber ///////////////////////////////////////////////////////////////////\r\n\r\n    XNumber.prototype = new Expression();\r\n    XNumber.prototype.constructor = XNumber;\r\n    XNumber.superclass = Expression.prototype;\r\n\r\n    function XNumber(n) {\r\n        if (arguments.length > 0) {\r\n            this.init(n);\r\n        }\r\n    }\r\n\r\n    XNumber.prototype.init = function (n) {\r\n        this.num = typeof n === \"string\" ? this.parse(n) : Number(n);\r\n    };\r\n\r\n    XNumber.prototype.numberFormat = /^\\s*-?[0-9]*\\.?[0-9]+\\s*$/;\r\n\r\n    XNumber.prototype.parse = function (s) {\r\n        // XPath representation of numbers is more restrictive than what Number() or parseFloat() allow\r\n        return this.numberFormat.test(s) ? parseFloat(s) : Number.NaN;\r\n    };\r\n\r\n    function padSmallNumber(numberStr) {\r\n        var parts = numberStr.split('e-');\r\n        var base = parts[0].replace('.', '');\r\n        var exponent = Number(parts[1]);\r\n\r\n        for (var i = 0; i < exponent - 1; i += 1) {\r\n            base = '0' + base;\r\n        }\r\n\r\n        return '0.' + base;\r\n    }\r\n\r\n    function padLargeNumber(numberStr) {\r\n        var parts = numberStr.split('e');\r\n        var base = parts[0].replace('.', '');\r\n        var exponent = Number(parts[1]);\r\n        var zerosToAppend = exponent + 1 - base.length;\r\n\r\n        for (var i = 0; i < zerosToAppend; i += 1) {\r\n            base += '0';\r\n        }\r\n\r\n        return base;\r\n    }\r\n\r\n    XNumber.prototype.toString = function () {\r\n        var strValue = this.num.toString();\r\n\r\n        if (strValue.indexOf('e-') !== -1) {\r\n            return padSmallNumber(strValue);\r\n        }\r\n\r\n        if (strValue.indexOf('e') !== -1) {\r\n            return padLargeNumber(strValue);\r\n        }\r\n\r\n        return strValue;\r\n    };\r\n\r\n    XNumber.prototype.evaluate = function (c) {\r\n        return this;\r\n    };\r\n\r\n    XNumber.prototype.string = function () {\r\n\r\n\r\n        return new XString(this.toString());\r\n    };\r\n\r\n    XNumber.prototype.number = function () {\r\n        return this;\r\n    };\r\n\r\n    XNumber.prototype.bool = function () {\r\n        return new XBoolean(this.num);\r\n    };\r\n\r\n    XNumber.prototype.nodeset = function () {\r\n        throw new Error(\"Cannot convert number to nodeset\");\r\n    };\r\n\r\n    XNumber.prototype.stringValue = function () {\r\n        return this.string().stringValue();\r\n    };\r\n\r\n    XNumber.prototype.numberValue = function () {\r\n        return this.num;\r\n    };\r\n\r\n    XNumber.prototype.booleanValue = function () {\r\n        return this.bool().booleanValue();\r\n    };\r\n\r\n    XNumber.prototype.negate = function () {\r\n        return new XNumber(-this.num);\r\n    };\r\n\r\n    XNumber.prototype.equals = function (r) {\r\n        if (Utilities.instance_of(r, XBoolean)) {\r\n            return this.bool().equals(r);\r\n        }\r\n        if (Utilities.instance_of(r, XString)) {\r\n            return this.equals(r.number());\r\n        }\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithNumber(this, Operators.equals);\r\n        }\r\n        return new XBoolean(this.num == r.num);\r\n    };\r\n\r\n    XNumber.prototype.notequal = function (r) {\r\n        if (Utilities.instance_of(r, XBoolean)) {\r\n            return this.bool().notequal(r);\r\n        }\r\n        if (Utilities.instance_of(r, XString)) {\r\n            return this.notequal(r.number());\r\n        }\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithNumber(this, Operators.notequal);\r\n        }\r\n        return new XBoolean(this.num != r.num);\r\n    };\r\n\r\n    XNumber.prototype.lessthan = function (r) {\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithNumber(this, Operators.greaterthan);\r\n        }\r\n        if (Utilities.instance_of(r, XBoolean) || Utilities.instance_of(r, XString)) {\r\n            return this.lessthan(r.number());\r\n        }\r\n        return new XBoolean(this.num < r.num);\r\n    };\r\n\r\n    XNumber.prototype.greaterthan = function (r) {\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithNumber(this, Operators.lessthan);\r\n        }\r\n        if (Utilities.instance_of(r, XBoolean) || Utilities.instance_of(r, XString)) {\r\n            return this.greaterthan(r.number());\r\n        }\r\n        return new XBoolean(this.num > r.num);\r\n    };\r\n\r\n    XNumber.prototype.lessthanorequal = function (r) {\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithNumber(this, Operators.greaterthanorequal);\r\n        }\r\n        if (Utilities.instance_of(r, XBoolean) || Utilities.instance_of(r, XString)) {\r\n            return this.lessthanorequal(r.number());\r\n        }\r\n        return new XBoolean(this.num <= r.num);\r\n    };\r\n\r\n    XNumber.prototype.greaterthanorequal = function (r) {\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithNumber(this, Operators.lessthanorequal);\r\n        }\r\n        if (Utilities.instance_of(r, XBoolean) || Utilities.instance_of(r, XString)) {\r\n            return this.greaterthanorequal(r.number());\r\n        }\r\n        return new XBoolean(this.num >= r.num);\r\n    };\r\n\r\n    XNumber.prototype.plus = function (r) {\r\n        return new XNumber(this.num + r.num);\r\n    };\r\n\r\n    XNumber.prototype.minus = function (r) {\r\n        return new XNumber(this.num - r.num);\r\n    };\r\n\r\n    XNumber.prototype.multiply = function (r) {\r\n        return new XNumber(this.num * r.num);\r\n    };\r\n\r\n    XNumber.prototype.div = function (r) {\r\n        return new XNumber(this.num / r.num);\r\n    };\r\n\r\n    XNumber.prototype.mod = function (r) {\r\n        return new XNumber(this.num % r.num);\r\n    };\r\n\r\n    // XBoolean //////////////////////////////////////////////////////////////////\r\n\r\n    XBoolean.prototype = new Expression();\r\n    XBoolean.prototype.constructor = XBoolean;\r\n    XBoolean.superclass = Expression.prototype;\r\n\r\n    function XBoolean(b) {\r\n        if (arguments.length > 0) {\r\n            this.init(b);\r\n        }\r\n    }\r\n\r\n    XBoolean.prototype.init = function (b) {\r\n        this.b = Boolean(b);\r\n    };\r\n\r\n    XBoolean.prototype.toString = function () {\r\n        return this.b.toString();\r\n    };\r\n\r\n    XBoolean.prototype.evaluate = function (c) {\r\n        return this;\r\n    };\r\n\r\n    XBoolean.prototype.string = function () {\r\n        return new XString(this.b);\r\n    };\r\n\r\n    XBoolean.prototype.number = function () {\r\n        return new XNumber(this.b);\r\n    };\r\n\r\n    XBoolean.prototype.bool = function () {\r\n        return this;\r\n    };\r\n\r\n    XBoolean.prototype.nodeset = function () {\r\n        throw new Error(\"Cannot convert boolean to nodeset\");\r\n    };\r\n\r\n    XBoolean.prototype.stringValue = function () {\r\n        return this.string().stringValue();\r\n    };\r\n\r\n    XBoolean.prototype.numberValue = function () {\r\n        return this.number().numberValue();\r\n    };\r\n\r\n    XBoolean.prototype.booleanValue = function () {\r\n        return this.b;\r\n    };\r\n\r\n    XBoolean.prototype.not = function () {\r\n        return new XBoolean(!this.b);\r\n    };\r\n\r\n    XBoolean.prototype.equals = function (r) {\r\n        if (Utilities.instance_of(r, XString) || Utilities.instance_of(r, XNumber)) {\r\n            return this.equals(r.bool());\r\n        }\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithBoolean(this, Operators.equals);\r\n        }\r\n        return new XBoolean(this.b == r.b);\r\n    };\r\n\r\n    XBoolean.prototype.notequal = function (r) {\r\n        if (Utilities.instance_of(r, XString) || Utilities.instance_of(r, XNumber)) {\r\n            return this.notequal(r.bool());\r\n        }\r\n        if (Utilities.instance_of(r, XNodeSet)) {\r\n            return r.compareWithBoolean(this, Operators.notequal);\r\n        }\r\n        return new XBoolean(this.b != r.b);\r\n    };\r\n\r\n    XBoolean.prototype.lessthan = function (r) {\r\n        return this.number().lessthan(r);\r\n    };\r\n\r\n    XBoolean.prototype.greaterthan = function (r) {\r\n        return this.number().greaterthan(r);\r\n    };\r\n\r\n    XBoolean.prototype.lessthanorequal = function (r) {\r\n        return this.number().lessthanorequal(r);\r\n    };\r\n\r\n    XBoolean.prototype.greaterthanorequal = function (r) {\r\n        return this.number().greaterthanorequal(r);\r\n    };\r\n\r\n    XBoolean.true_ = new XBoolean(true);\r\n    XBoolean.false_ = new XBoolean(false);\r\n\r\n    // AVLTree ///////////////////////////////////////////////////////////////////\r\n\r\n    AVLTree.prototype = new Object();\r\n    AVLTree.prototype.constructor = AVLTree;\r\n    AVLTree.superclass = Object.prototype;\r\n\r\n    function AVLTree(n) {\r\n        this.init(n);\r\n    }\r\n\r\n    AVLTree.prototype.init = function (n) {\r\n        this.left = null;\r\n        this.right = null;\r\n        this.node = n;\r\n        this.depth = 1;\r\n    };\r\n\r\n    AVLTree.prototype.balance = function () {\r\n        var ldepth = this.left == null ? 0 : this.left.depth;\r\n        var rdepth = this.right == null ? 0 : this.right.depth;\r\n\r\n        if (ldepth > rdepth + 1) {\r\n            // LR or LL rotation\r\n            var lldepth = this.left.left == null ? 0 : this.left.left.depth;\r\n            var lrdepth = this.left.right == null ? 0 : this.left.right.depth;\r\n\r\n            if (lldepth < lrdepth) {\r\n                // LR rotation consists of a RR rotation of the left child\r\n                this.left.rotateRR();\r\n                // plus a LL rotation of this node, which happens anyway\r\n            }\r\n            this.rotateLL();\r\n        } else if (ldepth + 1 < rdepth) {\r\n            // RR or RL rorarion\r\n            var rrdepth = this.right.right == null ? 0 : this.right.right.depth;\r\n            var rldepth = this.right.left == null ? 0 : this.right.left.depth;\r\n\r\n            if (rldepth > rrdepth) {\r\n                // RR rotation consists of a LL rotation of the right child\r\n                this.right.rotateLL();\r\n                // plus a RR rotation of this node, which happens anyway\r\n            }\r\n            this.rotateRR();\r\n        }\r\n    };\r\n\r\n    AVLTree.prototype.rotateLL = function () {\r\n        // the left side is too long => rotate from the left (_not_ leftwards)\r\n        var nodeBefore = this.node;\r\n        var rightBefore = this.right;\r\n        this.node = this.left.node;\r\n        this.right = this.left;\r\n        this.left = this.left.left;\r\n        this.right.left = this.right.right;\r\n        this.right.right = rightBefore;\r\n        this.right.node = nodeBefore;\r\n        this.right.updateInNewLocation();\r\n        this.updateInNewLocation();\r\n    };\r\n\r\n    AVLTree.prototype.rotateRR = function () {\r\n        // the right side is too long => rotate from the right (_not_ rightwards)\r\n        var nodeBefore = this.node;\r\n        var leftBefore = this.left;\r\n        this.node = this.right.node;\r\n        this.left = this.right;\r\n        this.right = this.right.right;\r\n        this.left.right = this.left.left;\r\n        this.left.left = leftBefore;\r\n        this.left.node = nodeBefore;\r\n        this.left.updateInNewLocation();\r\n        this.updateInNewLocation();\r\n    };\r\n\r\n    AVLTree.prototype.updateInNewLocation = function () {\r\n        this.getDepthFromChildren();\r\n    };\r\n\r\n    AVLTree.prototype.getDepthFromChildren = function () {\r\n        this.depth = this.node == null ? 0 : 1;\r\n        if (this.left != null) {\r\n            this.depth = this.left.depth + 1;\r\n        }\r\n        if (this.right != null && this.depth <= this.right.depth) {\r\n            this.depth = this.right.depth + 1;\r\n        }\r\n    };\r\n\r\n    function nodeOrder(n1, n2) {\r\n        if (n1 === n2) {\r\n            return 0;\r\n        }\r\n\r\n        if (n1.compareDocumentPosition) {\r\n            var cpos = n1.compareDocumentPosition(n2);\r\n\r\n            if (cpos & 0x01) {\r\n                // not in the same document; return an arbitrary result (is there a better way to do this)\r\n                return 1;\r\n            }\r\n            if (cpos & 0x0A) {\r\n                // n2 precedes or contains n1\r\n                return 1;\r\n            }\r\n            if (cpos & 0x14) {\r\n                // n2 follows or is contained by n1\r\n                return -1;\r\n            }\r\n\r\n            return 0;\r\n        }\r\n\r\n        var d1 = 0,\r\n            d2 = 0;\r\n        for (var m1 = n1; m1 != null; m1 = m1.parentNode || m1.ownerElement) {\r\n            d1++;\r\n        }\r\n        for (var m2 = n2; m2 != null; m2 = m2.parentNode || m2.ownerElement) {\r\n            d2++;\r\n        }\r\n\r\n        // step up to same depth\r\n        if (d1 > d2) {\r\n            while (d1 > d2) {\r\n                n1 = n1.parentNode || n1.ownerElement;\r\n                d1--;\r\n            }\r\n            if (n1 === n2) {\r\n                return 1;\r\n            }\r\n        } else if (d2 > d1) {\r\n            while (d2 > d1) {\r\n                n2 = n2.parentNode || n2.ownerElement;\r\n                d2--;\r\n            }\r\n            if (n1 === n2) {\r\n                return -1;\r\n            }\r\n        }\r\n\r\n        var n1Par = n1.parentNode || n1.ownerElement,\r\n            n2Par = n2.parentNode || n2.ownerElement;\r\n\r\n        // find common parent\r\n        while (n1Par !== n2Par) {\r\n            n1 = n1Par;\r\n            n2 = n2Par;\r\n            n1Par = n1.parentNode || n1.ownerElement;\r\n            n2Par = n2.parentNode || n2.ownerElement;\r\n        }\r\n\r\n        var n1isAttr = Utilities.isAttribute(n1);\r\n        var n2isAttr = Utilities.isAttribute(n2);\r\n\r\n        if (n1isAttr && !n2isAttr) {\r\n            return -1;\r\n        }\r\n        if (!n1isAttr && n2isAttr) {\r\n            return 1;\r\n        }\r\n\r\n        if (n1Par) {\r\n            var cn = n1isAttr ? n1Par.attributes : n1Par.childNodes,\r\n                len = cn.length;\r\n            for (var i = 0; i < len; i += 1) {\r\n                var n = cn[i];\r\n                if (n === n1) {\r\n                    return -1;\r\n                }\r\n                if (n === n2) {\r\n                    return 1;\r\n                }\r\n            }\r\n        }\r\n\r\n        throw new Error('Unexpected: could not determine node order');\r\n    }\r\n\r\n    AVLTree.prototype.add = function (n) {\r\n        if (n === this.node) {\r\n            return false;\r\n        }\r\n\r\n        var o = nodeOrder(n, this.node);\r\n\r\n        var ret = false;\r\n        if (o == -1) {\r\n            if (this.left == null) {\r\n                this.left = new AVLTree(n);\r\n                ret = true;\r\n            } else {\r\n                ret = this.left.add(n);\r\n                if (ret) {\r\n                    this.balance();\r\n                }\r\n            }\r\n        } else if (o == 1) {\r\n            if (this.right == null) {\r\n                this.right = new AVLTree(n);\r\n                ret = true;\r\n            } else {\r\n                ret = this.right.add(n);\r\n                if (ret) {\r\n                    this.balance();\r\n                }\r\n            }\r\n        }\r\n\r\n        if (ret) {\r\n            this.getDepthFromChildren();\r\n        }\r\n        return ret;\r\n    };\r\n\r\n    // XNodeSet //////////////////////////////////////////////////////////////////\r\n\r\n    XNodeSet.prototype = new Expression();\r\n    XNodeSet.prototype.constructor = XNodeSet;\r\n    XNodeSet.superclass = Expression.prototype;\r\n\r\n    function XNodeSet() {\r\n        this.init();\r\n    }\r\n\r\n    XNodeSet.prototype.init = function () {\r\n        this.tree = null;\r\n        this.nodes = [];\r\n        this.size = 0;\r\n    };\r\n\r\n    XNodeSet.prototype.toString = function () {\r\n        var p = this.first();\r\n        if (p == null) {\r\n            return \"\";\r\n        }\r\n        return this.stringForNode(p);\r\n    };\r\n\r\n    XNodeSet.prototype.evaluate = function (c) {\r\n        return this;\r\n    };\r\n\r\n    XNodeSet.prototype.string = function () {\r\n        return new XString(this.toString());\r\n    };\r\n\r\n    XNodeSet.prototype.stringValue = function () {\r\n        return this.toString();\r\n    };\r\n\r\n    XNodeSet.prototype.number = function () {\r\n        return new XNumber(this.string());\r\n    };\r\n\r\n    XNodeSet.prototype.numberValue = function () {\r\n        return Number(this.string());\r\n    };\r\n\r\n    XNodeSet.prototype.bool = function () {\r\n        return new XBoolean(this.booleanValue());\r\n    };\r\n\r\n    XNodeSet.prototype.booleanValue = function () {\r\n        return !!this.size;\r\n    };\r\n\r\n    XNodeSet.prototype.nodeset = function () {\r\n        return this;\r\n    };\r\n\r\n    XNodeSet.prototype.stringForNode = function (n) {\r\n        if (n.nodeType == NodeTypes.DOCUMENT_NODE ||\r\n            n.nodeType == NodeTypes.ELEMENT_NODE ||\r\n            n.nodeType === NodeTypes.DOCUMENT_FRAGMENT_NODE) {\r\n            return this.stringForContainerNode(n);\r\n        }\r\n        if (n.nodeType === NodeTypes.ATTRIBUTE_NODE) {\r\n            return n.value || n.nodeValue;\r\n        }\r\n        if (n.isNamespaceNode) {\r\n            return n.namespace;\r\n        }\r\n        return n.nodeValue;\r\n    };\r\n\r\n    XNodeSet.prototype.stringForContainerNode = function (n) {\r\n        var s = \"\";\r\n        for (var n2 = n.firstChild; n2 != null; n2 = n2.nextSibling) {\r\n            var nt = n2.nodeType;\r\n            //  Element,    Text,       CDATA,      Document,   Document Fragment\r\n            if (nt === 1 || nt === 3 || nt === 4 || nt === 9 || nt === 11) {\r\n                s += this.stringForNode(n2);\r\n            }\r\n        }\r\n        return s;\r\n    };\r\n\r\n    XNodeSet.prototype.buildTree = function () {\r\n        if (!this.tree && this.nodes.length) {\r\n            this.tree = new AVLTree(this.nodes[0]);\r\n            for (var i = 1; i < this.nodes.length; i += 1) {\r\n                this.tree.add(this.nodes[i]);\r\n            }\r\n        }\r\n\r\n        return this.tree;\r\n    };\r\n\r\n    XNodeSet.prototype.first = function () {\r\n        var p = this.buildTree();\r\n        if (p == null) {\r\n            return null;\r\n        }\r\n        while (p.left != null) {\r\n            p = p.left;\r\n        }\r\n        return p.node;\r\n    };\r\n\r\n    XNodeSet.prototype.add = function (n) {\r\n        for (var i = 0; i < this.nodes.length; i += 1) {\r\n            if (n === this.nodes[i]) {\r\n                return;\r\n            }\r\n        }\r\n\r\n        this.tree = null;\r\n        this.nodes.push(n);\r\n        this.size += 1;\r\n    };\r\n\r\n    XNodeSet.prototype.addArray = function (ns) {\r\n        var self = this;\r\n\r\n        forEach(function (x) { self.add(x); }, ns);\r\n    };\r\n\r\n    /**\r\n     * Returns an array of the node set's contents in document order\r\n     */\r\n    XNodeSet.prototype.toArray = function () {\r\n        var a = [];\r\n        this.toArrayRec(this.buildTree(), a);\r\n        return a;\r\n    };\r\n\r\n    XNodeSet.prototype.toArrayRec = function (t, a) {\r\n        if (t != null) {\r\n            this.toArrayRec(t.left, a);\r\n            a.push(t.node);\r\n            this.toArrayRec(t.right, a);\r\n        }\r\n    };\r\n\r\n    /**\r\n     * Returns an array of the node set's contents in arbitrary order\r\n     */\r\n    XNodeSet.prototype.toUnsortedArray = function () {\r\n        return this.nodes.slice();\r\n    };\r\n\r\n    XNodeSet.prototype.compareWithString = function (r, o) {\r\n        var a = this.toUnsortedArray();\r\n        for (var i = 0; i < a.length; i++) {\r\n            var n = a[i];\r\n            var l = new XString(this.stringForNode(n));\r\n            var res = o(l, r);\r\n            if (res.booleanValue()) {\r\n                return res;\r\n            }\r\n        }\r\n        return new XBoolean(false);\r\n    };\r\n\r\n    XNodeSet.prototype.compareWithNumber = function (r, o) {\r\n        var a = this.toUnsortedArray();\r\n        for (var i = 0; i < a.length; i++) {\r\n            var n = a[i];\r\n            var l = new XNumber(this.stringForNode(n));\r\n            var res = o(l, r);\r\n            if (res.booleanValue()) {\r\n                return res;\r\n            }\r\n        }\r\n        return new XBoolean(false);\r\n    };\r\n\r\n    XNodeSet.prototype.compareWithBoolean = function (r, o) {\r\n        return o(this.bool(), r);\r\n    };\r\n\r\n    XNodeSet.prototype.compareWithNodeSet = function (r, o) {\r\n        var arr = this.toUnsortedArray();\r\n        var oInvert = function (lop, rop) { return o(rop, lop); };\r\n\r\n        for (var i = 0; i < arr.length; i++) {\r\n            var l = new XString(this.stringForNode(arr[i]));\r\n\r\n            var res = r.compareWithString(l, oInvert);\r\n            if (res.booleanValue()) {\r\n                return res;\r\n            }\r\n        }\r\n\r\n        return new XBoolean(false);\r\n    };\r\n\r\n    XNodeSet.compareWith = curry(function (o, r) {\r\n        if (Utilities.instance_of(r, XString)) {\r\n            return this.compareWithString(r, o);\r\n        }\r\n        if (Utilities.instance_of(r, XNumber)) {\r\n            return this.compareWithNumber(r, o);\r\n        }\r\n        if (Utilities.instance_of(r, XBoolean)) {\r\n            return this.compareWithBoolean(r, o);\r\n        }\r\n        return this.compareWithNodeSet(r, o);\r\n    });\r\n\r\n    XNodeSet.prototype.equals = XNodeSet.compareWith(Operators.equals);\r\n    XNodeSet.prototype.notequal = XNodeSet.compareWith(Operators.notequal);\r\n    XNodeSet.prototype.lessthan = XNodeSet.compareWith(Operators.lessthan);\r\n    XNodeSet.prototype.greaterthan = XNodeSet.compareWith(Operators.greaterthan);\r\n    XNodeSet.prototype.lessthanorequal = XNodeSet.compareWith(Operators.lessthanorequal);\r\n    XNodeSet.prototype.greaterthanorequal = XNodeSet.compareWith(Operators.greaterthanorequal);\r\n\r\n    XNodeSet.prototype.union = function (r) {\r\n        var ns = new XNodeSet();\r\n        ns.addArray(this.toUnsortedArray());\r\n        ns.addArray(r.toUnsortedArray());\r\n        return ns;\r\n    };\r\n\r\n    // XPathNamespace ////////////////////////////////////////////////////////////\r\n\r\n    XPathNamespace.prototype = new Object();\r\n    XPathNamespace.prototype.constructor = XPathNamespace;\r\n    XPathNamespace.superclass = Object.prototype;\r\n\r\n    function XPathNamespace(pre, ns, p) {\r\n        this.isXPathNamespace = true;\r\n        this.ownerDocument = p.ownerDocument;\r\n        this.nodeName = \"#namespace\";\r\n        this.prefix = pre;\r\n        this.localName = pre;\r\n        this.namespaceURI = ns;\r\n        this.nodeValue = ns;\r\n        this.ownerElement = p;\r\n        this.nodeType = XPathNamespace.XPATH_NAMESPACE_NODE;\r\n    }\r\n\r\n    XPathNamespace.prototype.toString = function () {\r\n        return \"{ \\\"\" + this.prefix + \"\\\", \\\"\" + this.namespaceURI + \"\\\" }\";\r\n    };\r\n\r\n    // XPathContext //////////////////////////////////////////////////////////////\r\n\r\n    XPathContext.prototype = new Object();\r\n    XPathContext.prototype.constructor = XPathContext;\r\n    XPathContext.superclass = Object.prototype;\r\n\r\n    function XPathContext(vr, nr, fr) {\r\n        this.variableResolver = vr != null ? vr : new VariableResolver();\r\n        this.namespaceResolver = nr != null ? nr : new NamespaceResolver();\r\n        this.functionResolver = fr != null ? fr : new FunctionResolver();\r\n    }\r\n\r\n    XPathContext.prototype.extend = function (newProps) {\r\n        return assign(new XPathContext(), this, newProps);\r\n    };\r\n\r\n    // VariableResolver //////////////////////////////////////////////////////////\r\n\r\n    VariableResolver.prototype = new Object();\r\n    VariableResolver.prototype.constructor = VariableResolver;\r\n    VariableResolver.superclass = Object.prototype;\r\n\r\n    function VariableResolver() {\r\n    }\r\n\r\n    VariableResolver.prototype.getVariable = function (ln, ns) {\r\n        return null;\r\n    };\r\n\r\n    // FunctionResolver //////////////////////////////////////////////////////////\r\n\r\n    FunctionResolver.prototype = new Object();\r\n    FunctionResolver.prototype.constructor = FunctionResolver;\r\n    FunctionResolver.superclass = Object.prototype;\r\n\r\n    function FunctionResolver(thisArg) {\r\n        this.thisArg = thisArg != null ? thisArg : Functions;\r\n        this.functions = new Object();\r\n        this.addStandardFunctions();\r\n    }\r\n\r\n    FunctionResolver.prototype.addStandardFunctions = function () {\r\n        this.functions[\"{}last\"] = Functions.last;\r\n        this.functions[\"{}position\"] = Functions.position;\r\n        this.functions[\"{}count\"] = Functions.count;\r\n        this.functions[\"{}id\"] = Functions.id;\r\n        this.functions[\"{}local-name\"] = Functions.localName;\r\n        this.functions[\"{}namespace-uri\"] = Functions.namespaceURI;\r\n        this.functions[\"{}name\"] = Functions.name;\r\n        this.functions[\"{}string\"] = Functions.string;\r\n        this.functions[\"{}concat\"] = Functions.concat;\r\n        this.functions[\"{}starts-with\"] = Functions.startsWith;\r\n        this.functions[\"{}contains\"] = Functions.contains;\r\n        this.functions[\"{}substring-before\"] = Functions.substringBefore;\r\n        this.functions[\"{}substring-after\"] = Functions.substringAfter;\r\n        this.functions[\"{}substring\"] = Functions.substring;\r\n        this.functions[\"{}string-length\"] = Functions.stringLength;\r\n        this.functions[\"{}normalize-space\"] = Functions.normalizeSpace;\r\n        this.functions[\"{}translate\"] = Functions.translate;\r\n        this.functions[\"{}boolean\"] = Functions.boolean_;\r\n        this.functions[\"{}not\"] = Functions.not;\r\n        this.functions[\"{}true\"] = Functions.true_;\r\n        this.functions[\"{}false\"] = Functions.false_;\r\n        this.functions[\"{}lang\"] = Functions.lang;\r\n        this.functions[\"{}number\"] = Functions.number;\r\n        this.functions[\"{}sum\"] = Functions.sum;\r\n        this.functions[\"{}floor\"] = Functions.floor;\r\n        this.functions[\"{}ceiling\"] = Functions.ceiling;\r\n        this.functions[\"{}round\"] = Functions.round;\r\n    };\r\n\r\n    FunctionResolver.prototype.addFunction = function (ns, ln, f) {\r\n        this.functions[\"{\" + ns + \"}\" + ln] = f;\r\n    };\r\n\r\n    FunctionResolver.getFunctionFromContext = function (qName, context) {\r\n        var parts = Utilities.resolveQName(qName, context.namespaceResolver, context.contextNode, false);\r\n\r\n        if (parts[0] === null) {\r\n            throw new Error(\"Cannot resolve QName \" + name);\r\n        }\r\n\r\n        return context.functionResolver.getFunction(parts[1], parts[0]);\r\n    };\r\n\r\n    FunctionResolver.prototype.getFunction = function (localName, namespace) {\r\n        return this.functions[\"{\" + namespace + \"}\" + localName];\r\n    };\r\n\r\n    // NamespaceResolver /////////////////////////////////////////////////////////\r\n\r\n    NamespaceResolver.prototype = new Object();\r\n    NamespaceResolver.prototype.constructor = NamespaceResolver;\r\n    NamespaceResolver.superclass = Object.prototype;\r\n\r\n    function NamespaceResolver() {\r\n    }\r\n\r\n    NamespaceResolver.prototype.getNamespace = function (prefix, n) {\r\n        if (prefix == \"xml\") {\r\n            return XPath.XML_NAMESPACE_URI;\r\n        } else if (prefix == \"xmlns\") {\r\n            return XPath.XMLNS_NAMESPACE_URI;\r\n        }\r\n        if (n.nodeType == NodeTypes.DOCUMENT_NODE) {\r\n            n = n.documentElement;\r\n        } else if (n.nodeType == NodeTypes.ATTRIBUTE_NODE) {\r\n            n = PathExpr.getOwnerElement(n);\r\n        } else if (n.nodeType != NodeTypes.ELEMENT_NODE) {\r\n            n = n.parentNode;\r\n        }\r\n        while (n != null && n.nodeType == NodeTypes.ELEMENT_NODE) {\r\n            var nnm = n.attributes;\r\n            for (var i = 0; i < nnm.length; i++) {\r\n                var a = nnm.item(i);\r\n                var aname = a.name || a.nodeName;\r\n                if ((aname === \"xmlns\" && prefix === \"\")\r\n                    || aname === \"xmlns:\" + prefix) {\r\n                    return String(a.value || a.nodeValue);\r\n                }\r\n            }\r\n            n = n.parentNode;\r\n        }\r\n        return null;\r\n    };\r\n\r\n    // Functions /////////////////////////////////////////////////////////////////\r\n\r\n    var Functions = new Object();\r\n\r\n    Functions.last = function (c) {\r\n        if (arguments.length != 1) {\r\n            throw new Error(\"Function last expects ()\");\r\n        }\r\n\r\n        return new XNumber(c.contextSize);\r\n    };\r\n\r\n    Functions.position = function (c) {\r\n        if (arguments.length != 1) {\r\n            throw new Error(\"Function position expects ()\");\r\n        }\r\n\r\n        return new XNumber(c.contextPosition);\r\n    };\r\n\r\n    Functions.count = function () {\r\n        var c = arguments[0];\r\n        var ns;\r\n        if (arguments.length != 2 || !Utilities.instance_of(ns = arguments[1].evaluate(c), XNodeSet)) {\r\n            throw new Error(\"Function count expects (node-set)\");\r\n        }\r\n        return new XNumber(ns.size);\r\n    };\r\n\r\n    Functions.id = function () {\r\n        var c = arguments[0];\r\n        var id;\r\n        if (arguments.length != 2) {\r\n            throw new Error(\"Function id expects (object)\");\r\n        }\r\n        id = arguments[1].evaluate(c);\r\n        if (Utilities.instance_of(id, XNodeSet)) {\r\n            id = id.toArray().join(\" \");\r\n        } else {\r\n            id = id.stringValue();\r\n        }\r\n        var ids = id.split(/[\\x0d\\x0a\\x09\\x20]+/);\r\n        var count = 0;\r\n        var ns = new XNodeSet();\r\n        var doc = c.contextNode.nodeType == NodeTypes.DOCUMENT_NODE\r\n            ? c.contextNode\r\n            : c.contextNode.ownerDocument;\r\n        for (var i = 0; i < ids.length; i++) {\r\n            var n;\r\n            if (doc.getElementById) {\r\n                n = doc.getElementById(ids[i]);\r\n            } else {\r\n                n = Utilities.getElementById(doc, ids[i]);\r\n            }\r\n            if (n != null) {\r\n                ns.add(n);\r\n                count++;\r\n            }\r\n        }\r\n        return ns;\r\n    };\r\n\r\n    Functions.localName = function (c, eNode) {\r\n        var n;\r\n\r\n        if (arguments.length == 1) {\r\n            n = c.contextNode;\r\n        } else if (arguments.length == 2) {\r\n            n = eNode.evaluate(c).first();\r\n        } else {\r\n            throw new Error(\"Function local-name expects (node-set?)\");\r\n        }\r\n\r\n        if (n == null) {\r\n            return new XString(\"\");\r\n        }\r\n\r\n        return new XString(\r\n            n.localName ||     //  standard elements and attributes\r\n            n.baseName ||     //  IE\r\n            n.target ||     //  processing instructions\r\n            n.nodeName ||     //  DOM1 elements\r\n            \"\"                 //  fallback\r\n        );\r\n    };\r\n\r\n    Functions.namespaceURI = function () {\r\n        var c = arguments[0];\r\n        var n;\r\n        if (arguments.length == 1) {\r\n            n = c.contextNode;\r\n        } else if (arguments.length == 2) {\r\n            n = arguments[1].evaluate(c).first();\r\n        } else {\r\n            throw new Error(\"Function namespace-uri expects (node-set?)\");\r\n        }\r\n        if (n == null) {\r\n            return new XString(\"\");\r\n        }\r\n        return new XString(n.namespaceURI);\r\n    };\r\n\r\n    Functions.name = function () {\r\n        var c = arguments[0];\r\n        var n;\r\n        if (arguments.length == 1) {\r\n            n = c.contextNode;\r\n        } else if (arguments.length == 2) {\r\n            n = arguments[1].evaluate(c).first();\r\n        } else {\r\n            throw new Error(\"Function name expects (node-set?)\");\r\n        }\r\n        if (n == null) {\r\n            return new XString(\"\");\r\n        }\r\n        if (n.nodeType == NodeTypes.ELEMENT_NODE) {\r\n            return new XString(n.nodeName);\r\n        } else if (n.nodeType == NodeTypes.ATTRIBUTE_NODE) {\r\n            return new XString(n.name || n.nodeName);\r\n        } else if (n.nodeType === NodeTypes.PROCESSING_INSTRUCTION_NODE) {\r\n            return new XString(n.target || n.nodeName);\r\n        } else if (n.localName == null) {\r\n            return new XString(\"\");\r\n        } else {\r\n            return new XString(n.localName);\r\n        }\r\n    };\r\n\r\n    Functions.string = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length == 1) {\r\n            return new XString(XNodeSet.prototype.stringForNode(c.contextNode));\r\n        } else if (arguments.length == 2) {\r\n            return arguments[1].evaluate(c).string();\r\n        }\r\n        throw new Error(\"Function string expects (object?)\");\r\n    };\r\n\r\n    Functions.concat = function (c) {\r\n        if (arguments.length < 3) {\r\n            throw new Error(\"Function concat expects (string, string[, string]*)\");\r\n        }\r\n        var s = \"\";\r\n        for (var i = 1; i < arguments.length; i++) {\r\n            s += arguments[i].evaluate(c).stringValue();\r\n        }\r\n        return new XString(s);\r\n    };\r\n\r\n    Functions.startsWith = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length != 3) {\r\n            throw new Error(\"Function startsWith expects (string, string)\");\r\n        }\r\n        var s1 = arguments[1].evaluate(c).stringValue();\r\n        var s2 = arguments[2].evaluate(c).stringValue();\r\n        return new XBoolean(s1.substring(0, s2.length) == s2);\r\n    };\r\n\r\n    Functions.contains = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length != 3) {\r\n            throw new Error(\"Function contains expects (string, string)\");\r\n        }\r\n        var s1 = arguments[1].evaluate(c).stringValue();\r\n        var s2 = arguments[2].evaluate(c).stringValue();\r\n        return new XBoolean(s1.indexOf(s2) !== -1);\r\n    };\r\n\r\n    Functions.substringBefore = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length != 3) {\r\n            throw new Error(\"Function substring-before expects (string, string)\");\r\n        }\r\n        var s1 = arguments[1].evaluate(c).stringValue();\r\n        var s2 = arguments[2].evaluate(c).stringValue();\r\n        return new XString(s1.substring(0, s1.indexOf(s2)));\r\n    };\r\n\r\n    Functions.substringAfter = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length != 3) {\r\n            throw new Error(\"Function substring-after expects (string, string)\");\r\n        }\r\n        var s1 = arguments[1].evaluate(c).stringValue();\r\n        var s2 = arguments[2].evaluate(c).stringValue();\r\n        if (s2.length == 0) {\r\n            return new XString(s1);\r\n        }\r\n        var i = s1.indexOf(s2);\r\n        if (i == -1) {\r\n            return new XString(\"\");\r\n        }\r\n        return new XString(s1.substring(i + s2.length));\r\n    };\r\n\r\n    Functions.substring = function () {\r\n        var c = arguments[0];\r\n        if (!(arguments.length == 3 || arguments.length == 4)) {\r\n            throw new Error(\"Function substring expects (string, number, number?)\");\r\n        }\r\n        var s = arguments[1].evaluate(c).stringValue();\r\n        var n1 = Math.round(arguments[2].evaluate(c).numberValue()) - 1;\r\n        var n2 = arguments.length == 4 ? n1 + Math.round(arguments[3].evaluate(c).numberValue()) : undefined;\r\n        return new XString(s.substring(n1, n2));\r\n    };\r\n\r\n    Functions.stringLength = function () {\r\n        var c = arguments[0];\r\n        var s;\r\n        if (arguments.length == 1) {\r\n            s = XNodeSet.prototype.stringForNode(c.contextNode);\r\n        } else if (arguments.length == 2) {\r\n            s = arguments[1].evaluate(c).stringValue();\r\n        } else {\r\n            throw new Error(\"Function string-length expects (string?)\");\r\n        }\r\n        return new XNumber(s.length);\r\n    };\r\n\r\n    Functions.normalizeSpace = function () {\r\n        var c = arguments[0];\r\n        var s;\r\n        if (arguments.length == 1) {\r\n            s = XNodeSet.prototype.stringForNode(c.contextNode);\r\n        } else if (arguments.length == 2) {\r\n            s = arguments[1].evaluate(c).stringValue();\r\n        } else {\r\n            throw new Error(\"Function normalize-space expects (string?)\");\r\n        }\r\n        var i = 0;\r\n        var j = s.length - 1;\r\n        while (Utilities.isSpace(s.charCodeAt(j))) {\r\n            j--;\r\n        }\r\n        var t = \"\";\r\n        while (i <= j && Utilities.isSpace(s.charCodeAt(i))) {\r\n            i++;\r\n        }\r\n        while (i <= j) {\r\n            if (Utilities.isSpace(s.charCodeAt(i))) {\r\n                t += \" \";\r\n                while (i <= j && Utilities.isSpace(s.charCodeAt(i))) {\r\n                    i++;\r\n                }\r\n            } else {\r\n                t += s.charAt(i);\r\n                i++;\r\n            }\r\n        }\r\n        return new XString(t);\r\n    };\r\n\r\n    Functions.translate = function (c, eValue, eFrom, eTo) {\r\n        if (arguments.length != 4) {\r\n            throw new Error(\"Function translate expects (string, string, string)\");\r\n        }\r\n\r\n        var value = eValue.evaluate(c).stringValue();\r\n        var from = eFrom.evaluate(c).stringValue();\r\n        var to = eTo.evaluate(c).stringValue();\r\n\r\n        var cMap = reduce(function (acc, ch, i) {\r\n            if (!(ch in acc)) {\r\n                acc[ch] = i > to.length ? '' : to[i];\r\n            }\r\n            return acc;\r\n        }, {}, from);\r\n\r\n        var t = join(\r\n            '',\r\n            map(function (ch) {\r\n                return ch in cMap ? cMap[ch] : ch;\r\n            }, value)\r\n        );\r\n\r\n        return new XString(t);\r\n    };\r\n\r\n    Functions.boolean_ = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length != 2) {\r\n            throw new Error(\"Function boolean expects (object)\");\r\n        }\r\n        return arguments[1].evaluate(c).bool();\r\n    };\r\n\r\n    Functions.not = function (c, eValue) {\r\n        if (arguments.length != 2) {\r\n            throw new Error(\"Function not expects (object)\");\r\n        }\r\n        return eValue.evaluate(c).bool().not();\r\n    };\r\n\r\n    Functions.true_ = function () {\r\n        if (arguments.length != 1) {\r\n            throw new Error(\"Function true expects ()\");\r\n        }\r\n        return XBoolean.true_;\r\n    };\r\n\r\n    Functions.false_ = function () {\r\n        if (arguments.length != 1) {\r\n            throw new Error(\"Function false expects ()\");\r\n        }\r\n        return XBoolean.false_;\r\n    };\r\n\r\n    Functions.lang = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length != 2) {\r\n            throw new Error(\"Function lang expects (string)\");\r\n        }\r\n        var lang;\r\n        for (var n = c.contextNode; n != null && n.nodeType != NodeTypes.DOCUMENT_NODE; n = n.parentNode) {\r\n            var a = n.getAttributeNS(XPath.XML_NAMESPACE_URI, \"lang\");\r\n            if (a != null) {\r\n                lang = String(a);\r\n                break;\r\n            }\r\n        }\r\n        if (lang == null) {\r\n            return XBoolean.false_;\r\n        }\r\n        var s = arguments[1].evaluate(c).stringValue();\r\n        return new XBoolean(lang.substring(0, s.length) == s\r\n            && (lang.length == s.length || lang.charAt(s.length) == '-'));\r\n    };\r\n\r\n    Functions.number = function () {\r\n        var c = arguments[0];\r\n        if (!(arguments.length == 1 || arguments.length == 2)) {\r\n            throw new Error(\"Function number expects (object?)\");\r\n        }\r\n        if (arguments.length == 1) {\r\n            return new XNumber(XNodeSet.prototype.stringForNode(c.contextNode));\r\n        }\r\n        return arguments[1].evaluate(c).number();\r\n    };\r\n\r\n    Functions.sum = function () {\r\n        var c = arguments[0];\r\n        var ns;\r\n        if (arguments.length != 2 || !Utilities.instance_of((ns = arguments[1].evaluate(c)), XNodeSet)) {\r\n            throw new Error(\"Function sum expects (node-set)\");\r\n        }\r\n        ns = ns.toUnsortedArray();\r\n        var n = 0;\r\n        for (var i = 0; i < ns.length; i++) {\r\n            n += new XNumber(XNodeSet.prototype.stringForNode(ns[i])).numberValue();\r\n        }\r\n        return new XNumber(n);\r\n    };\r\n\r\n    Functions.floor = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length != 2) {\r\n            throw new Error(\"Function floor expects (number)\");\r\n        }\r\n        return new XNumber(Math.floor(arguments[1].evaluate(c).numberValue()));\r\n    };\r\n\r\n    Functions.ceiling = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length != 2) {\r\n            throw new Error(\"Function ceiling expects (number)\");\r\n        }\r\n        return new XNumber(Math.ceil(arguments[1].evaluate(c).numberValue()));\r\n    };\r\n\r\n    Functions.round = function () {\r\n        var c = arguments[0];\r\n        if (arguments.length != 2) {\r\n            throw new Error(\"Function round expects (number)\");\r\n        }\r\n        return new XNumber(Math.round(arguments[1].evaluate(c).numberValue()));\r\n    };\r\n\r\n    // Utilities /////////////////////////////////////////////////////////////////\r\n\r\n    var Utilities = new Object();\r\n\r\n    Utilities.isAttribute = function (val) {\r\n        return val && (val.nodeType === NodeTypes.ATTRIBUTE_NODE || val.ownerElement);\r\n    }\r\n\r\n    Utilities.splitQName = function (qn) {\r\n        var i = qn.indexOf(\":\");\r\n        if (i == -1) {\r\n            return [null, qn];\r\n        }\r\n        return [qn.substring(0, i), qn.substring(i + 1)];\r\n    };\r\n\r\n    Utilities.resolveQName = function (qn, nr, n, useDefault) {\r\n        var parts = Utilities.splitQName(qn);\r\n        if (parts[0] != null) {\r\n            parts[0] = nr.getNamespace(parts[0], n);\r\n        } else {\r\n            if (useDefault) {\r\n                parts[0] = nr.getNamespace(\"\", n);\r\n                if (parts[0] == null) {\r\n                    parts[0] = \"\";\r\n                }\r\n            } else {\r\n                parts[0] = \"\";\r\n            }\r\n        }\r\n        return parts;\r\n    };\r\n\r\n    Utilities.isSpace = function (c) {\r\n        return c == 0x9 || c == 0xd || c == 0xa || c == 0x20;\r\n    };\r\n\r\n    Utilities.isLetter = function (c) {\r\n        return c >= 0x0041 && c <= 0x005A ||\r\n            c >= 0x0061 && c <= 0x007A ||\r\n            c >= 0x00C0 && c <= 0x00D6 ||\r\n            c >= 0x00D8 && c <= 0x00F6 ||\r\n            c >= 0x00F8 && c <= 0x00FF ||\r\n            c >= 0x0100 && c <= 0x0131 ||\r\n            c >= 0x0134 && c <= 0x013E ||\r\n            c >= 0x0141 && c <= 0x0148 ||\r\n            c >= 0x014A && c <= 0x017E ||\r\n            c >= 0x0180 && c <= 0x01C3 ||\r\n            c >= 0x01CD && c <= 0x01F0 ||\r\n            c >= 0x01F4 && c <= 0x01F5 ||\r\n            c >= 0x01FA && c <= 0x0217 ||\r\n            c >= 0x0250 && c <= 0x02A8 ||\r\n            c >= 0x02BB && c <= 0x02C1 ||\r\n            c == 0x0386 ||\r\n            c >= 0x0388 && c <= 0x038A ||\r\n            c == 0x038C ||\r\n            c >= 0x038E && c <= 0x03A1 ||\r\n            c >= 0x03A3 && c <= 0x03CE ||\r\n            c >= 0x03D0 && c <= 0x03D6 ||\r\n            c == 0x03DA ||\r\n            c == 0x03DC ||\r\n            c == 0x03DE ||\r\n            c == 0x03E0 ||\r\n            c >= 0x03E2 && c <= 0x03F3 ||\r\n            c >= 0x0401 && c <= 0x040C ||\r\n            c >= 0x040E && c <= 0x044F ||\r\n            c >= 0x0451 && c <= 0x045C ||\r\n            c >= 0x045E && c <= 0x0481 ||\r\n            c >= 0x0490 && c <= 0x04C4 ||\r\n            c >= 0x04C7 && c <= 0x04C8 ||\r\n            c >= 0x04CB && c <= 0x04CC ||\r\n            c >= 0x04D0 && c <= 0x04EB ||\r\n            c >= 0x04EE && c <= 0x04F5 ||\r\n            c >= 0x04F8 && c <= 0x04F9 ||\r\n            c >= 0x0531 && c <= 0x0556 ||\r\n            c == 0x0559 ||\r\n            c >= 0x0561 && c <= 0x0586 ||\r\n            c >= 0x05D0 && c <= 0x05EA ||\r\n            c >= 0x05F0 && c <= 0x05F2 ||\r\n            c >= 0x0621 && c <= 0x063A ||\r\n            c >= 0x0641 && c <= 0x064A ||\r\n            c >= 0x0671 && c <= 0x06B7 ||\r\n            c >= 0x06BA && c <= 0x06BE ||\r\n            c >= 0x06C0 && c <= 0x06CE ||\r\n            c >= 0x06D0 && c <= 0x06D3 ||\r\n            c == 0x06D5 ||\r\n            c >= 0x06E5 && c <= 0x06E6 ||\r\n            c >= 0x0905 && c <= 0x0939 ||\r\n            c == 0x093D ||\r\n            c >= 0x0958 && c <= 0x0961 ||\r\n            c >= 0x0985 && c <= 0x098C ||\r\n            c >= 0x098F && c <= 0x0990 ||\r\n            c >= 0x0993 && c <= 0x09A8 ||\r\n            c >= 0x09AA && c <= 0x09B0 ||\r\n            c == 0x09B2 ||\r\n            c >= 0x09B6 && c <= 0x09B9 ||\r\n            c >= 0x09DC && c <= 0x09DD ||\r\n            c >= 0x09DF && c <= 0x09E1 ||\r\n            c >= 0x09F0 && c <= 0x09F1 ||\r\n            c >= 0x0A05 && c <= 0x0A0A ||\r\n            c >= 0x0A0F && c <= 0x0A10 ||\r\n            c >= 0x0A13 && c <= 0x0A28 ||\r\n            c >= 0x0A2A && c <= 0x0A30 ||\r\n            c >= 0x0A32 && c <= 0x0A33 ||\r\n            c >= 0x0A35 && c <= 0x0A36 ||\r\n            c >= 0x0A38 && c <= 0x0A39 ||\r\n            c >= 0x0A59 && c <= 0x0A5C ||\r\n            c == 0x0A5E ||\r\n            c >= 0x0A72 && c <= 0x0A74 ||\r\n            c >= 0x0A85 && c <= 0x0A8B ||\r\n            c == 0x0A8D ||\r\n            c >= 0x0A8F && c <= 0x0A91 ||\r\n            c >= 0x0A93 && c <= 0x0AA8 ||\r\n            c >= 0x0AAA && c <= 0x0AB0 ||\r\n            c >= 0x0AB2 && c <= 0x0AB3 ||\r\n            c >= 0x0AB5 && c <= 0x0AB9 ||\r\n            c == 0x0ABD ||\r\n            c == 0x0AE0 ||\r\n            c >= 0x0B05 && c <= 0x0B0C ||\r\n            c >= 0x0B0F && c <= 0x0B10 ||\r\n            c >= 0x0B13 && c <= 0x0B28 ||\r\n            c >= 0x0B2A && c <= 0x0B30 ||\r\n            c >= 0x0B32 && c <= 0x0B33 ||\r\n            c >= 0x0B36 && c <= 0x0B39 ||\r\n            c == 0x0B3D ||\r\n            c >= 0x0B5C && c <= 0x0B5D ||\r\n            c >= 0x0B5F && c <= 0x0B61 ||\r\n            c >= 0x0B85 && c <= 0x0B8A ||\r\n            c >= 0x0B8E && c <= 0x0B90 ||\r\n            c >= 0x0B92 && c <= 0x0B95 ||\r\n            c >= 0x0B99 && c <= 0x0B9A ||\r\n            c == 0x0B9C ||\r\n            c >= 0x0B9E && c <= 0x0B9F ||\r\n            c >= 0x0BA3 && c <= 0x0BA4 ||\r\n            c >= 0x0BA8 && c <= 0x0BAA ||\r\n            c >= 0x0BAE && c <= 0x0BB5 ||\r\n            c >= 0x0BB7 && c <= 0x0BB9 ||\r\n            c >= 0x0C05 && c <= 0x0C0C ||\r\n            c >= 0x0C0E && c <= 0x0C10 ||\r\n            c >= 0x0C12 && c <= 0x0C28 ||\r\n            c >= 0x0C2A && c <= 0x0C33 ||\r\n            c >= 0x0C35 && c <= 0x0C39 ||\r\n            c >= 0x0C60 && c <= 0x0C61 ||\r\n            c >= 0x0C85 && c <= 0x0C8C ||\r\n            c >= 0x0C8E && c <= 0x0C90 ||\r\n            c >= 0x0C92 && c <= 0x0CA8 ||\r\n            c >= 0x0CAA && c <= 0x0CB3 ||\r\n            c >= 0x0CB5 && c <= 0x0CB9 ||\r\n            c == 0x0CDE ||\r\n            c >= 0x0CE0 && c <= 0x0CE1 ||\r\n            c >= 0x0D05 && c <= 0x0D0C ||\r\n            c >= 0x0D0E && c <= 0x0D10 ||\r\n            c >= 0x0D12 && c <= 0x0D28 ||\r\n            c >= 0x0D2A && c <= 0x0D39 ||\r\n            c >= 0x0D60 && c <= 0x0D61 ||\r\n            c >= 0x0E01 && c <= 0x0E2E ||\r\n            c == 0x0E30 ||\r\n            c >= 0x0E32 && c <= 0x0E33 ||\r\n            c >= 0x0E40 && c <= 0x0E45 ||\r\n            c >= 0x0E81 && c <= 0x0E82 ||\r\n            c == 0x0E84 ||\r\n            c >= 0x0E87 && c <= 0x0E88 ||\r\n            c == 0x0E8A ||\r\n            c == 0x0E8D ||\r\n            c >= 0x0E94 && c <= 0x0E97 ||\r\n            c >= 0x0E99 && c <= 0x0E9F ||\r\n            c >= 0x0EA1 && c <= 0x0EA3 ||\r\n            c == 0x0EA5 ||\r\n            c == 0x0EA7 ||\r\n            c >= 0x0EAA && c <= 0x0EAB ||\r\n            c >= 0x0EAD && c <= 0x0EAE ||\r\n            c == 0x0EB0 ||\r\n            c >= 0x0EB2 && c <= 0x0EB3 ||\r\n            c == 0x0EBD ||\r\n            c >= 0x0EC0 && c <= 0x0EC4 ||\r\n            c >= 0x0F40 && c <= 0x0F47 ||\r\n            c >= 0x0F49 && c <= 0x0F69 ||\r\n            c >= 0x10A0 && c <= 0x10C5 ||\r\n            c >= 0x10D0 && c <= 0x10F6 ||\r\n            c == 0x1100 ||\r\n            c >= 0x1102 && c <= 0x1103 ||\r\n            c >= 0x1105 && c <= 0x1107 ||\r\n            c == 0x1109 ||\r\n            c >= 0x110B && c <= 0x110C ||\r\n            c >= 0x110E && c <= 0x1112 ||\r\n            c == 0x113C ||\r\n            c == 0x113E ||\r\n            c == 0x1140 ||\r\n            c == 0x114C ||\r\n            c == 0x114E ||\r\n            c == 0x1150 ||\r\n            c >= 0x1154 && c <= 0x1155 ||\r\n            c == 0x1159 ||\r\n            c >= 0x115F && c <= 0x1161 ||\r\n            c == 0x1163 ||\r\n            c == 0x1165 ||\r\n            c == 0x1167 ||\r\n            c == 0x1169 ||\r\n            c >= 0x116D && c <= 0x116E ||\r\n            c >= 0x1172 && c <= 0x1173 ||\r\n            c == 0x1175 ||\r\n            c == 0x119E ||\r\n            c == 0x11A8 ||\r\n            c == 0x11AB ||\r\n            c >= 0x11AE && c <= 0x11AF ||\r\n            c >= 0x11B7 && c <= 0x11B8 ||\r\n            c == 0x11BA ||\r\n            c >= 0x11BC && c <= 0x11C2 ||\r\n            c == 0x11EB ||\r\n            c == 0x11F0 ||\r\n            c == 0x11F9 ||\r\n            c >= 0x1E00 && c <= 0x1E9B ||\r\n            c >= 0x1EA0 && c <= 0x1EF9 ||\r\n            c >= 0x1F00 && c <= 0x1F15 ||\r\n            c >= 0x1F18 && c <= 0x1F1D ||\r\n            c >= 0x1F20 && c <= 0x1F45 ||\r\n            c >= 0x1F48 && c <= 0x1F4D ||\r\n            c >= 0x1F50 && c <= 0x1F57 ||\r\n            c == 0x1F59 ||\r\n            c == 0x1F5B ||\r\n            c == 0x1F5D ||\r\n            c >= 0x1F5F && c <= 0x1F7D ||\r\n            c >= 0x1F80 && c <= 0x1FB4 ||\r\n            c >= 0x1FB6 && c <= 0x1FBC ||\r\n            c == 0x1FBE ||\r\n            c >= 0x1FC2 && c <= 0x1FC4 ||\r\n            c >= 0x1FC6 && c <= 0x1FCC ||\r\n            c >= 0x1FD0 && c <= 0x1FD3 ||\r\n            c >= 0x1FD6 && c <= 0x1FDB ||\r\n            c >= 0x1FE0 && c <= 0x1FEC ||\r\n            c >= 0x1FF2 && c <= 0x1FF4 ||\r\n            c >= 0x1FF6 && c <= 0x1FFC ||\r\n            c == 0x2126 ||\r\n            c >= 0x212A && c <= 0x212B ||\r\n            c == 0x212E ||\r\n            c >= 0x2180 && c <= 0x2182 ||\r\n            c >= 0x3041 && c <= 0x3094 ||\r\n            c >= 0x30A1 && c <= 0x30FA ||\r\n            c >= 0x3105 && c <= 0x312C ||\r\n            c >= 0xAC00 && c <= 0xD7A3 ||\r\n            c >= 0x4E00 && c <= 0x9FA5 ||\r\n            c == 0x3007 ||\r\n            c >= 0x3021 && c <= 0x3029;\r\n    };\r\n\r\n    Utilities.isNCNameChar = function (c) {\r\n        return c >= 0x0030 && c <= 0x0039\r\n            || c >= 0x0660 && c <= 0x0669\r\n            || c >= 0x06F0 && c <= 0x06F9\r\n            || c >= 0x0966 && c <= 0x096F\r\n            || c >= 0x09E6 && c <= 0x09EF\r\n            || c >= 0x0A66 && c <= 0x0A6F\r\n            || c >= 0x0AE6 && c <= 0x0AEF\r\n            || c >= 0x0B66 && c <= 0x0B6F\r\n            || c >= 0x0BE7 && c <= 0x0BEF\r\n            || c >= 0x0C66 && c <= 0x0C6F\r\n            || c >= 0x0CE6 && c <= 0x0CEF\r\n            || c >= 0x0D66 && c <= 0x0D6F\r\n            || c >= 0x0E50 && c <= 0x0E59\r\n            || c >= 0x0ED0 && c <= 0x0ED9\r\n            || c >= 0x0F20 && c <= 0x0F29\r\n            || c == 0x002E\r\n            || c == 0x002D\r\n            || c == 0x005F\r\n            || Utilities.isLetter(c)\r\n            || c >= 0x0300 && c <= 0x0345\r\n            || c >= 0x0360 && c <= 0x0361\r\n            || c >= 0x0483 && c <= 0x0486\r\n            || c >= 0x0591 && c <= 0x05A1\r\n            || c >= 0x05A3 && c <= 0x05B9\r\n            || c >= 0x05BB && c <= 0x05BD\r\n            || c == 0x05BF\r\n            || c >= 0x05C1 && c <= 0x05C2\r\n            || c == 0x05C4\r\n            || c >= 0x064B && c <= 0x0652\r\n            || c == 0x0670\r\n            || c >= 0x06D6 && c <= 0x06DC\r\n            || c >= 0x06DD && c <= 0x06DF\r\n            || c >= 0x06E0 && c <= 0x06E4\r\n            || c >= 0x06E7 && c <= 0x06E8\r\n            || c >= 0x06EA && c <= 0x06ED\r\n            || c >= 0x0901 && c <= 0x0903\r\n            || c == 0x093C\r\n            || c >= 0x093E && c <= 0x094C\r\n            || c == 0x094D\r\n            || c >= 0x0951 && c <= 0x0954\r\n            || c >= 0x0962 && c <= 0x0963\r\n            || c >= 0x0981 && c <= 0x0983\r\n            || c == 0x09BC\r\n            || c == 0x09BE\r\n            || c == 0x09BF\r\n            || c >= 0x09C0 && c <= 0x09C4\r\n            || c >= 0x09C7 && c <= 0x09C8\r\n            || c >= 0x09CB && c <= 0x09CD\r\n            || c == 0x09D7\r\n            || c >= 0x09E2 && c <= 0x09E3\r\n            || c == 0x0A02\r\n            || c == 0x0A3C\r\n            || c == 0x0A3E\r\n            || c == 0x0A3F\r\n            || c >= 0x0A40 && c <= 0x0A42\r\n            || c >= 0x0A47 && c <= 0x0A48\r\n            || c >= 0x0A4B && c <= 0x0A4D\r\n            || c >= 0x0A70 && c <= 0x0A71\r\n            || c >= 0x0A81 && c <= 0x0A83\r\n            || c == 0x0ABC\r\n            || c >= 0x0ABE && c <= 0x0AC5\r\n            || c >= 0x0AC7 && c <= 0x0AC9\r\n            || c >= 0x0ACB && c <= 0x0ACD\r\n            || c >= 0x0B01 && c <= 0x0B03\r\n            || c == 0x0B3C\r\n            || c >= 0x0B3E && c <= 0x0B43\r\n            || c >= 0x0B47 && c <= 0x0B48\r\n            || c >= 0x0B4B && c <= 0x0B4D\r\n            || c >= 0x0B56 && c <= 0x0B57\r\n            || c >= 0x0B82 && c <= 0x0B83\r\n            || c >= 0x0BBE && c <= 0x0BC2\r\n            || c >= 0x0BC6 && c <= 0x0BC8\r\n            || c >= 0x0BCA && c <= 0x0BCD\r\n            || c == 0x0BD7\r\n            || c >= 0x0C01 && c <= 0x0C03\r\n            || c >= 0x0C3E && c <= 0x0C44\r\n            || c >= 0x0C46 && c <= 0x0C48\r\n            || c >= 0x0C4A && c <= 0x0C4D\r\n            || c >= 0x0C55 && c <= 0x0C56\r\n            || c >= 0x0C82 && c <= 0x0C83\r\n            || c >= 0x0CBE && c <= 0x0CC4\r\n            || c >= 0x0CC6 && c <= 0x0CC8\r\n            || c >= 0x0CCA && c <= 0x0CCD\r\n            || c >= 0x0CD5 && c <= 0x0CD6\r\n            || c >= 0x0D02 && c <= 0x0D03\r\n            || c >= 0x0D3E && c <= 0x0D43\r\n            || c >= 0x0D46 && c <= 0x0D48\r\n            || c >= 0x0D4A && c <= 0x0D4D\r\n            || c == 0x0D57\r\n            || c == 0x0E31\r\n            || c >= 0x0E34 && c <= 0x0E3A\r\n            || c >= 0x0E47 && c <= 0x0E4E\r\n            || c == 0x0EB1\r\n            || c >= 0x0EB4 && c <= 0x0EB9\r\n            || c >= 0x0EBB && c <= 0x0EBC\r\n            || c >= 0x0EC8 && c <= 0x0ECD\r\n            || c >= 0x0F18 && c <= 0x0F19\r\n            || c == 0x0F35\r\n            || c == 0x0F37\r\n            || c == 0x0F39\r\n            || c == 0x0F3E\r\n            || c == 0x0F3F\r\n            || c >= 0x0F71 && c <= 0x0F84\r\n            || c >= 0x0F86 && c <= 0x0F8B\r\n            || c >= 0x0F90 && c <= 0x0F95\r\n            || c == 0x0F97\r\n            || c >= 0x0F99 && c <= 0x0FAD\r\n            || c >= 0x0FB1 && c <= 0x0FB7\r\n            || c == 0x0FB9\r\n            || c >= 0x20D0 && c <= 0x20DC\r\n            || c == 0x20E1\r\n            || c >= 0x302A && c <= 0x302F\r\n            || c == 0x3099\r\n            || c == 0x309A\r\n            || c == 0x00B7\r\n            || c == 0x02D0\r\n            || c == 0x02D1\r\n            || c == 0x0387\r\n            || c == 0x0640\r\n            || c == 0x0E46\r\n            || c == 0x0EC6\r\n            || c == 0x3005\r\n            || c >= 0x3031 && c <= 0x3035\r\n            || c >= 0x309D && c <= 0x309E\r\n            || c >= 0x30FC && c <= 0x30FE;\r\n    };\r\n\r\n    Utilities.coalesceText = function (n) {\r\n        for (var m = n.firstChild; m != null; m = m.nextSibling) {\r\n            if (m.nodeType == NodeTypes.TEXT_NODE || m.nodeType == NodeTypes.CDATA_SECTION_NODE) {\r\n                var s = m.nodeValue;\r\n                var first = m;\r\n                m = m.nextSibling;\r\n                while (m != null && (m.nodeType == NodeTypes.TEXT_NODE || m.nodeType == NodeTypes.CDATA_SECTION_NODE)) {\r\n                    s += m.nodeValue;\r\n                    var del = m;\r\n                    m = m.nextSibling;\r\n                    del.parentNode.removeChild(del);\r\n                }\r\n                if (first.nodeType == NodeTypes.CDATA_SECTION_NODE) {\r\n                    var p = first.parentNode;\r\n                    if (first.nextSibling == null) {\r\n                        p.removeChild(first);\r\n                        p.appendChild(p.ownerDocument.createTextNode(s));\r\n                    } else {\r\n                        var next = first.nextSibling;\r\n                        p.removeChild(first);\r\n                        p.insertBefore(p.ownerDocument.createTextNode(s), next);\r\n                    }\r\n                } else {\r\n                    first.nodeValue = s;\r\n                }\r\n                if (m == null) {\r\n                    break;\r\n                }\r\n            } else if (m.nodeType == NodeTypes.ELEMENT_NODE) {\r\n                Utilities.coalesceText(m);\r\n            }\r\n        }\r\n    };\r\n\r\n    Utilities.instance_of = function (o, c) {\r\n        while (o != null) {\r\n            if (o.constructor === c) {\r\n                return true;\r\n            }\r\n            if (o === Object) {\r\n                return false;\r\n            }\r\n            o = o.constructor.superclass;\r\n        }\r\n        return false;\r\n    };\r\n\r\n    Utilities.getElementById = function (n, id) {\r\n        // Note that this does not check the DTD to check for actual\r\n        // attributes of type ID, so this may be a bit wrong.\r\n        if (n.nodeType == NodeTypes.ELEMENT_NODE) {\r\n            if (n.getAttribute(\"id\") == id\r\n                || n.getAttributeNS(null, \"id\") == id) {\r\n                return n;\r\n            }\r\n        }\r\n        for (var m = n.firstChild; m != null; m = m.nextSibling) {\r\n            var res = Utilities.getElementById(m, id);\r\n            if (res != null) {\r\n                return res;\r\n            }\r\n        }\r\n        return null;\r\n    };\r\n\r\n    // XPathException ////////////////////////////////////////////////////////////\r\n\r\n    var XPathException = (function () {\r\n        function getMessage(code, exception) {\r\n            var msg = exception ? \": \" + exception.toString() : \"\";\r\n            switch (code) {\r\n                case XPathException.INVALID_EXPRESSION_ERR:\r\n                    return \"Invalid expression\" + msg;\r\n                case XPathException.TYPE_ERR:\r\n                    return \"Type error\" + msg;\r\n            }\r\n            return null;\r\n        }\r\n\r\n        function XPathException(code, error, message) {\r\n            var err = Error.call(this, getMessage(code, error) || message);\r\n\r\n            err.code = code;\r\n            err.exception = error;\r\n\r\n            return err;\r\n        }\r\n\r\n        XPathException.prototype = Object.create(Error.prototype);\r\n        XPathException.prototype.constructor = XPathException;\r\n        XPathException.superclass = Error;\r\n\r\n        XPathException.prototype.toString = function () {\r\n            return this.message;\r\n        };\r\n\r\n        XPathException.fromMessage = function (message, error) {\r\n            return new XPathException(null, error, message);\r\n        };\r\n\r\n        XPathException.INVALID_EXPRESSION_ERR = 51;\r\n        XPathException.TYPE_ERR = 52;\r\n\r\n        return XPathException;\r\n    })();\r\n\r\n    // XPathExpression ///////////////////////////////////////////////////////////\r\n\r\n    XPathExpression.prototype = {};\r\n    XPathExpression.prototype.constructor = XPathExpression;\r\n    XPathExpression.superclass = Object.prototype;\r\n\r\n    function XPathExpression(e, r, p) {\r\n        this.xpath = p.parse(e);\r\n        this.context = new XPathContext();\r\n        this.context.namespaceResolver = new XPathNSResolverWrapper(r);\r\n    }\r\n\r\n    XPathExpression.getOwnerDocument = function (n) {\r\n        return n.nodeType === NodeTypes.DOCUMENT_NODE ? n : n.ownerDocument;\r\n    }\r\n\r\n    XPathExpression.detectHtmlDom = function (n) {\r\n        if (!n) { return false; }\r\n\r\n        var doc = XPathExpression.getOwnerDocument(n);\r\n\r\n        try {\r\n            return doc.implementation.hasFeature(\"HTML\", \"2.0\");\r\n        } catch (e) {\r\n            return true;\r\n        }\r\n    }\r\n\r\n    XPathExpression.prototype.evaluate = function (n, t, res) {\r\n        this.context.expressionContextNode = n;\r\n        // backward compatibility - no reliable way to detect whether the DOM is HTML, but\r\n        // this library has been using this method up until now, so we will continue to use it\r\n        // ONLY when using an XPathExpression\r\n        this.context.caseInsensitive = XPathExpression.detectHtmlDom(n);\r\n\r\n        var result = this.xpath.evaluate(this.context);\r\n        return new XPathResult(result, t);\r\n    }\r\n\r\n    // XPathNSResolverWrapper ////////////////////////////////////////////////////\r\n\r\n    XPathNSResolverWrapper.prototype = {};\r\n    XPathNSResolverWrapper.prototype.constructor = XPathNSResolverWrapper;\r\n    XPathNSResolverWrapper.superclass = Object.prototype;\r\n\r\n    function XPathNSResolverWrapper(r) {\r\n        this.xpathNSResolver = r;\r\n    }\r\n\r\n    XPathNSResolverWrapper.prototype.getNamespace = function (prefix, n) {\r\n        if (this.xpathNSResolver == null) {\r\n            return null;\r\n        }\r\n        return this.xpathNSResolver.lookupNamespaceURI(prefix);\r\n    };\r\n\r\n    // NodeXPathNSResolver ///////////////////////////////////////////////////////\r\n\r\n    NodeXPathNSResolver.prototype = {};\r\n    NodeXPathNSResolver.prototype.constructor = NodeXPathNSResolver;\r\n    NodeXPathNSResolver.superclass = Object.prototype;\r\n\r\n    function NodeXPathNSResolver(n) {\r\n        this.node = n;\r\n        this.namespaceResolver = new NamespaceResolver();\r\n    }\r\n\r\n    NodeXPathNSResolver.prototype.lookupNamespaceURI = function (prefix) {\r\n        return this.namespaceResolver.getNamespace(prefix, this.node);\r\n    };\r\n\r\n    // XPathResult ///////////////////////////////////////////////////////////////\r\n\r\n    XPathResult.prototype = {};\r\n    XPathResult.prototype.constructor = XPathResult;\r\n    XPathResult.superclass = Object.prototype;\r\n\r\n    function XPathResult(v, t) {\r\n        if (t == XPathResult.ANY_TYPE) {\r\n            if (v.constructor === XString) {\r\n                t = XPathResult.STRING_TYPE;\r\n            } else if (v.constructor === XNumber) {\r\n                t = XPathResult.NUMBER_TYPE;\r\n            } else if (v.constructor === XBoolean) {\r\n                t = XPathResult.BOOLEAN_TYPE;\r\n            } else if (v.constructor === XNodeSet) {\r\n                t = XPathResult.UNORDERED_NODE_ITERATOR_TYPE;\r\n            }\r\n        }\r\n        this.resultType = t;\r\n        switch (t) {\r\n            case XPathResult.NUMBER_TYPE:\r\n                this.numberValue = v.numberValue();\r\n                return;\r\n            case XPathResult.STRING_TYPE:\r\n                this.stringValue = v.stringValue();\r\n                return;\r\n            case XPathResult.BOOLEAN_TYPE:\r\n                this.booleanValue = v.booleanValue();\r\n                return;\r\n            case XPathResult.ANY_UNORDERED_NODE_TYPE:\r\n            case XPathResult.FIRST_ORDERED_NODE_TYPE:\r\n                if (v.constructor === XNodeSet) {\r\n                    this.singleNodeValue = v.first();\r\n                    return;\r\n                }\r\n                break;\r\n            case XPathResult.UNORDERED_NODE_ITERATOR_TYPE:\r\n            case XPathResult.ORDERED_NODE_ITERATOR_TYPE:\r\n                if (v.constructor === XNodeSet) {\r\n                    this.invalidIteratorState = false;\r\n                    this.nodes = v.toArray();\r\n                    this.iteratorIndex = 0;\r\n                    return;\r\n                }\r\n                break;\r\n            case XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE:\r\n            case XPathResult.ORDERED_NODE_SNAPSHOT_TYPE:\r\n                if (v.constructor === XNodeSet) {\r\n                    this.nodes = v.toArray();\r\n                    this.snapshotLength = this.nodes.length;\r\n                    return;\r\n                }\r\n                break;\r\n        }\r\n        throw new XPathException(XPathException.TYPE_ERR);\r\n    };\r\n\r\n    XPathResult.prototype.iterateNext = function () {\r\n        if (this.resultType != XPathResult.UNORDERED_NODE_ITERATOR_TYPE\r\n            && this.resultType != XPathResult.ORDERED_NODE_ITERATOR_TYPE) {\r\n            throw new XPathException(XPathException.TYPE_ERR);\r\n        }\r\n        return this.nodes[this.iteratorIndex++];\r\n    };\r\n\r\n    XPathResult.prototype.snapshotItem = function (i) {\r\n        if (this.resultType != XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE\r\n            && this.resultType != XPathResult.ORDERED_NODE_SNAPSHOT_TYPE) {\r\n            throw new XPathException(XPathException.TYPE_ERR);\r\n        }\r\n        return this.nodes[i];\r\n    };\r\n\r\n    XPathResult.ANY_TYPE = 0;\r\n    XPathResult.NUMBER_TYPE = 1;\r\n    XPathResult.STRING_TYPE = 2;\r\n    XPathResult.BOOLEAN_TYPE = 3;\r\n    XPathResult.UNORDERED_NODE_ITERATOR_TYPE = 4;\r\n    XPathResult.ORDERED_NODE_ITERATOR_TYPE = 5;\r\n    XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE = 6;\r\n    XPathResult.ORDERED_NODE_SNAPSHOT_TYPE = 7;\r\n    XPathResult.ANY_UNORDERED_NODE_TYPE = 8;\r\n    XPathResult.FIRST_ORDERED_NODE_TYPE = 9;\r\n\r\n    // DOM 3 XPath support ///////////////////////////////////////////////////////\r\n\r\n    function installDOM3XPathSupport(doc, p) {\r\n        doc.createExpression = function (e, r) {\r\n            try {\r\n                return new XPathExpression(e, r, p);\r\n            } catch (e) {\r\n                throw new XPathException(XPathException.INVALID_EXPRESSION_ERR, e);\r\n            }\r\n        };\r\n        doc.createNSResolver = function (n) {\r\n            return new NodeXPathNSResolver(n);\r\n        };\r\n        doc.evaluate = function (e, cn, r, t, res) {\r\n            if (t < 0 || t > 9) {\r\n                throw { code: 0, toString: function () { return \"Request type not supported\"; } };\r\n            }\r\n            return doc.createExpression(e, r, p).evaluate(cn, t, res);\r\n        };\r\n    };\r\n\r\n    // ---------------------------------------------------------------------------\r\n\r\n    // Install DOM 3 XPath support for the current document.\r\n    try {\r\n        var shouldInstall = true;\r\n        try {\r\n            if (document.implementation\r\n                && document.implementation.hasFeature\r\n                && document.implementation.hasFeature(\"XPath\", null)) {\r\n                shouldInstall = false;\r\n            }\r\n        } catch (e) {\r\n        }\r\n        if (shouldInstall) {\r\n            installDOM3XPathSupport(document, new XPathParser());\r\n        }\r\n    } catch (e) {\r\n    }\r\n\r\n    // ---------------------------------------------------------------------------\r\n    // exports for node.js\r\n\r\n    installDOM3XPathSupport(exports, new XPathParser());\r\n\r\n    (function () {\r\n        var parser = new XPathParser();\r\n\r\n        var defaultNSResolver = new NamespaceResolver();\r\n        var defaultFunctionResolver = new FunctionResolver();\r\n        var defaultVariableResolver = new VariableResolver();\r\n\r\n        function makeNSResolverFromFunction(func) {\r\n            return {\r\n                getNamespace: function (prefix, node) {\r\n                    var ns = func(prefix, node);\r\n\r\n                    return ns || defaultNSResolver.getNamespace(prefix, node);\r\n                }\r\n            };\r\n        }\r\n\r\n        function makeNSResolverFromObject(obj) {\r\n            return makeNSResolverFromFunction(obj.getNamespace.bind(obj));\r\n        }\r\n\r\n        function makeNSResolverFromMap(map) {\r\n            return makeNSResolverFromFunction(function (prefix) {\r\n                return map[prefix];\r\n            });\r\n        }\r\n\r\n        function makeNSResolver(resolver) {\r\n            if (resolver && typeof resolver.getNamespace === \"function\") {\r\n                return makeNSResolverFromObject(resolver);\r\n            }\r\n\r\n            if (typeof resolver === \"function\") {\r\n                return makeNSResolverFromFunction(resolver);\r\n            }\r\n\r\n            // assume prefix -> uri mapping\r\n            if (typeof resolver === \"object\") {\r\n                return makeNSResolverFromMap(resolver);\r\n            }\r\n\r\n            return defaultNSResolver;\r\n        }\r\n\r\n        /** Converts native JavaScript types to their XPath library equivalent */\r\n        function convertValue(value) {\r\n            if (value === null ||\r\n                typeof value === \"undefined\" ||\r\n                value instanceof XString ||\r\n                value instanceof XBoolean ||\r\n                value instanceof XNumber ||\r\n                value instanceof XNodeSet) {\r\n                return value;\r\n            }\r\n\r\n            switch (typeof value) {\r\n                case \"string\": return new XString(value);\r\n                case \"boolean\": return new XBoolean(value);\r\n                case \"number\": return new XNumber(value);\r\n            }\r\n\r\n            // assume node(s)\r\n            var ns = new XNodeSet();\r\n            ns.addArray([].concat(value));\r\n            return ns;\r\n        }\r\n\r\n        function makeEvaluator(func) {\r\n            return function (context) {\r\n                var args = Array.prototype.slice.call(arguments, 1).map(function (arg) {\r\n                    return arg.evaluate(context);\r\n                });\r\n                var result = func.apply(this, [].concat(context, args));\r\n                return convertValue(result);\r\n            };\r\n        }\r\n\r\n        function makeFunctionResolverFromFunction(func) {\r\n            return {\r\n                getFunction: function (name, namespace) {\r\n                    var found = func(name, namespace);\r\n                    if (found) {\r\n                        return makeEvaluator(found);\r\n                    }\r\n                    return defaultFunctionResolver.getFunction(name, namespace);\r\n                }\r\n            };\r\n        }\r\n\r\n        function makeFunctionResolverFromObject(obj) {\r\n            return makeFunctionResolverFromFunction(obj.getFunction.bind(obj));\r\n        }\r\n\r\n        function makeFunctionResolverFromMap(map) {\r\n            return makeFunctionResolverFromFunction(function (name) {\r\n                return map[name];\r\n            });\r\n        }\r\n\r\n        function makeFunctionResolver(resolver) {\r\n            if (resolver && typeof resolver.getFunction === \"function\") {\r\n                return makeFunctionResolverFromObject(resolver);\r\n            }\r\n\r\n            if (typeof resolver === \"function\") {\r\n                return makeFunctionResolverFromFunction(resolver);\r\n            }\r\n\r\n            // assume map\r\n            if (typeof resolver === \"object\") {\r\n                return makeFunctionResolverFromMap(resolver);\r\n            }\r\n\r\n            return defaultFunctionResolver;\r\n        }\r\n\r\n        function makeVariableResolverFromFunction(func) {\r\n            return {\r\n                getVariable: function (name, namespace) {\r\n                    var value = func(name, namespace);\r\n                    return convertValue(value);\r\n                }\r\n            };\r\n        }\r\n\r\n        function makeVariableResolver(resolver) {\r\n            if (resolver) {\r\n                if (typeof resolver.getVariable === \"function\") {\r\n                    return makeVariableResolverFromFunction(resolver.getVariable.bind(resolver));\r\n                }\r\n\r\n                if (typeof resolver === \"function\") {\r\n                    return makeVariableResolverFromFunction(resolver);\r\n                }\r\n\r\n                // assume map\r\n                if (typeof resolver === \"object\") {\r\n                    return makeVariableResolverFromFunction(function (name) {\r\n                        return resolver[name];\r\n                    });\r\n                }\r\n            }\r\n\r\n            return defaultVariableResolver;\r\n        }\r\n\r\n        function copyIfPresent(prop, dest, source) {\r\n            if (prop in source) { dest[prop] = source[prop]; }\r\n        }\r\n\r\n        function makeContext(options) {\r\n            var context = new XPathContext();\r\n\r\n            if (options) {\r\n                context.namespaceResolver = makeNSResolver(options.namespaces);\r\n                context.functionResolver = makeFunctionResolver(options.functions);\r\n                context.variableResolver = makeVariableResolver(options.variables);\r\n                context.expressionContextNode = options.node;\r\n                copyIfPresent('allowAnyNamespaceForNoPrefix', context, options);\r\n                copyIfPresent('isHtml', context, options);\r\n            } else {\r\n                context.namespaceResolver = defaultNSResolver;\r\n            }\r\n\r\n            return context;\r\n        }\r\n\r\n        function evaluate(parsedExpression, options) {\r\n            var context = makeContext(options);\r\n\r\n            return parsedExpression.evaluate(context);\r\n        }\r\n\r\n        var evaluatorPrototype = {\r\n            evaluate: function (options) {\r\n                return evaluate(this.expression, options);\r\n            }\r\n\r\n            , evaluateNumber: function (options) {\r\n                return this.evaluate(options).numberValue();\r\n            }\r\n\r\n            , evaluateString: function (options) {\r\n                return this.evaluate(options).stringValue();\r\n            }\r\n\r\n            , evaluateBoolean: function (options) {\r\n                return this.evaluate(options).booleanValue();\r\n            }\r\n\r\n            , evaluateNodeSet: function (options) {\r\n                return this.evaluate(options).nodeset();\r\n            }\r\n\r\n            , select: function (options) {\r\n                return this.evaluateNodeSet(options).toArray()\r\n            }\r\n\r\n            , select1: function (options) {\r\n                return this.select(options)[0];\r\n            }\r\n        };\r\n\r\n        function parse(xpath) {\r\n            var parsed = parser.parse(xpath);\r\n\r\n            return Object.create(evaluatorPrototype, {\r\n                expression: {\r\n                    value: parsed\r\n                }\r\n            });\r\n        }\r\n\r\n        exports.parse = parse;\r\n    })();\r\n\r\n    assign(\r\n        exports,\r\n        {\r\n            XPath: XPath,\r\n            XPathParser: XPathParser,\r\n            XPathResult: XPathResult,\r\n\r\n            Step: Step,\r\n            PathExpr: PathExpr,\r\n            NodeTest: NodeTest,\r\n            LocationPath: LocationPath,\r\n\r\n            OrOperation: OrOperation,\r\n            AndOperation: AndOperation,\r\n\r\n            BarOperation: BarOperation,\r\n\r\n            EqualsOperation: EqualsOperation,\r\n            NotEqualOperation: NotEqualOperation,\r\n            LessThanOperation: LessThanOperation,\r\n            GreaterThanOperation: GreaterThanOperation,\r\n            LessThanOrEqualOperation: LessThanOrEqualOperation,\r\n            GreaterThanOrEqualOperation: GreaterThanOrEqualOperation,\r\n\r\n            PlusOperation: PlusOperation,\r\n            MinusOperation: MinusOperation,\r\n            MultiplyOperation: MultiplyOperation,\r\n            DivOperation: DivOperation,\r\n            ModOperation: ModOperation,\r\n            UnaryMinusOperation: UnaryMinusOperation,\r\n          \r\n            FunctionCall: FunctionCall,\r\n            VariableReference: VariableReference,\r\n          \r\n            XPathContext: XPathContext,\r\n          \r\n            XNodeSet: XNodeSet,\r\n            XBoolean: XBoolean,\r\n            XString: XString,\r\n            XNumber: XNumber,\r\n          \r\n            NamespaceResolver: NamespaceResolver,\r\n            FunctionResolver: FunctionResolver,\r\n            VariableResolver: VariableResolver,\r\n          \r\n            Utilities: Utilities,\r\n        }\r\n    );\r\n\r\n    // helper\r\n    exports.select = function (e, doc, single) {\r\n        return exports.selectWithResolver(e, doc, null, single);\r\n    };\r\n\r\n    exports.useNamespaces = function (mappings) {\r\n        var resolver = {\r\n            mappings: mappings || {},\r\n            lookupNamespaceURI: function (prefix) {\r\n                return this.mappings[prefix];\r\n            }\r\n        };\r\n\r\n        return function (e, doc, single) {\r\n            return exports.selectWithResolver(e, doc, resolver, single);\r\n        };\r\n    };\r\n\r\n    exports.selectWithResolver = function (e, doc, resolver, single) {\r\n        var expression = new XPathExpression(e, resolver, new XPathParser());\r\n        var type = XPathResult.ANY_TYPE;\r\n\r\n        var result = expression.evaluate(doc, type, null);\r\n\r\n        if (result.resultType == XPathResult.STRING_TYPE) {\r\n            result = result.stringValue;\r\n        }\r\n        else if (result.resultType == XPathResult.NUMBER_TYPE) {\r\n            result = result.numberValue;\r\n        }\r\n        else if (result.resultType == XPathResult.BOOLEAN_TYPE) {\r\n            result = result.booleanValue;\r\n        }\r\n        else {\r\n            result = result.nodes;\r\n            if (single) {\r\n                result = result[0];\r\n            }\r\n        }\r\n\r\n        return result;\r\n    };\r\n\r\n    exports.select1 = function (e, doc) {\r\n        return exports.select(e, doc, true);\r\n    };\r\n\r\n    var isNodeLike = function (value) {\r\n        return value \r\n            && typeof value.nodeType === \"number\" \r\n            && Number.isInteger(value.nodeType)\r\n            && value.nodeType >= 1\r\n            && value.nodeType <= 11\r\n            && typeof value.nodeName === \"string\";\r\n    };\r\n\r\n    var isArrayOfNodes = function (value) {\r\n        return Array.isArray(value) && value.every(isNodeLike);\r\n    };\r\n\r\n    var isNodeOfType = function (type) {\r\n        return function (value) {\r\n            return isNodeLike(value) && value.nodeType === type;\r\n        };\r\n    };\r\n\r\n    assign(\r\n        exports,\r\n        {\r\n            isNodeLike: isNodeLike,\r\n            isArrayOfNodes: isArrayOfNodes,\r\n            isElement: isNodeOfType(NodeTypes.ELEMENT_NODE),\r\n            isAttribute: isNodeOfType(NodeTypes.ATTRIBUTE_NODE),\r\n            isTextNode: isNodeOfType(NodeTypes.TEXT_NODE),\r\n            isCDATASection: isNodeOfType(NodeTypes.CDATA_SECTION_NODE),\r\n            isProcessingInstruction: isNodeOfType(NodeTypes.PROCESSING_INSTRUCTION_NODE),\r\n            isComment: isNodeOfType(NodeTypes.COMMENT_NODE),\r\n            isDocumentNode: isNodeOfType(NodeTypes.DOCUMENT_NODE),\r\n            isDocumentTypeNode: isNodeOfType(NodeTypes.DOCUMENT_TYPE_NODE),\r\n            isDocumentFragment: isNodeOfType(NodeTypes.DOCUMENT_FRAGMENT_NODE),\r\n        }\r\n    );\r\n    // end non-node wrapper\r\n})(xpath);\r\n","'use strict'\n\n/**\n * Ponyfill for `Array.prototype.find` which is only available in ES6 runtimes.\n *\n * Works with anything that has a `length` property and index access properties, including NodeList.\n *\n * @template {unknown} T\n * @param {Array<T> | ({length:number, [number]: T})} list\n * @param {function (item: T, index: number, list:Array<T> | ({length:number, [number]: T})):boolean} predicate\n * @param {Partial<Pick<ArrayConstructor['prototype'], 'find'>>?} ac `Array.prototype` by default,\n * \t\t\t\tallows injecting a custom implementation in tests\n * @returns {T | undefined}\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find\n * @see https://tc39.es/ecma262/multipage/indexed-collections.html#sec-array.prototype.find\n */\nfunction find(list, predicate, ac) {\n\tif (ac === undefined) {\n\t\tac = Array.prototype;\n\t}\n\tif (list && typeof ac.find === 'function') {\n\t\treturn ac.find.call(list, predicate);\n\t}\n\tfor (var i = 0; i < list.length; i++) {\n\t\tif (Object.prototype.hasOwnProperty.call(list, i)) {\n\t\t\tvar item = list[i];\n\t\t\tif (predicate.call(undefined, item, i, list)) {\n\t\t\t\treturn item;\n\t\t\t}\n\t\t}\n\t}\n}\n\n/**\n * \"Shallow freezes\" an object to render it immutable.\n * Uses `Object.freeze` if available,\n * otherwise the immutability is only in the type.\n *\n * Is used to create \"enum like\" objects.\n *\n * @template T\n * @param {T} object the object to freeze\n * @param {Pick<ObjectConstructor, 'freeze'> = Object} oc `Object` by default,\n * \t\t\t\tallows to inject custom object constructor for tests\n * @returns {Readonly<T>}\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/freeze\n */\nfunction freeze(object, oc) {\n\tif (oc === undefined) {\n\t\toc = Object\n\t}\n\treturn oc && typeof oc.freeze === 'function' ? oc.freeze(object) : object\n}\n\n/**\n * Since we can not rely on `Object.assign` we provide a simplified version\n * that is sufficient for our needs.\n *\n * @param {Object} target\n * @param {Object | null | undefined} source\n *\n * @returns {Object} target\n * @throws TypeError if target is not an object\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/assign\n * @see https://tc39.es/ecma262/multipage/fundamental-objects.html#sec-object.assign\n */\nfunction assign(target, source) {\n\tif (target === null || typeof target !== 'object') {\n\t\tthrow new TypeError('target is not an object')\n\t}\n\tfor (var key in source) {\n\t\tif (Object.prototype.hasOwnProperty.call(source, key)) {\n\t\t\ttarget[key] = source[key]\n\t\t}\n\t}\n\treturn target\n}\n\n/**\n * All mime types that are allowed as input to `DOMParser.parseFromString`\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMParser/parseFromString#Argument02 MDN\n * @see https://html.spec.whatwg.org/multipage/dynamic-markup-insertion.html#domparsersupportedtype WHATWG HTML Spec\n * @see DOMParser.prototype.parseFromString\n */\nvar MIME_TYPE = freeze({\n\t/**\n\t * `text/html`, the only mime type that triggers treating an XML document as HTML.\n\t *\n\t * @see DOMParser.SupportedType.isHTML\n\t * @see https://www.iana.org/assignments/media-types/text/html IANA MimeType registration\n\t * @see https://en.wikipedia.org/wiki/HTML Wikipedia\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMParser/parseFromString MDN\n\t * @see https://html.spec.whatwg.org/multipage/dynamic-markup-insertion.html#dom-domparser-parsefromstring WHATWG HTML Spec\n\t */\n\tHTML: 'text/html',\n\n\t/**\n\t * Helper method to check a mime type if it indicates an HTML document\n\t *\n\t * @param {string} [value]\n\t * @returns {boolean}\n\t *\n\t * @see https://www.iana.org/assignments/media-types/text/html IANA MimeType registration\n\t * @see https://en.wikipedia.org/wiki/HTML Wikipedia\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMParser/parseFromString MDN\n\t * @see https://html.spec.whatwg.org/multipage/dynamic-markup-insertion.html#dom-domparser-parsefromstring \t */\n\tisHTML: function (value) {\n\t\treturn value === MIME_TYPE.HTML\n\t},\n\n\t/**\n\t * `application/xml`, the standard mime type for XML documents.\n\t *\n\t * @see https://www.iana.org/assignments/media-types/application/xml IANA MimeType registration\n\t * @see https://tools.ietf.org/html/rfc7303#section-9.1 RFC 7303\n\t * @see https://en.wikipedia.org/wiki/XML_and_MIME Wikipedia\n\t */\n\tXML_APPLICATION: 'application/xml',\n\n\t/**\n\t * `text/html`, an alias for `application/xml`.\n\t *\n\t * @see https://tools.ietf.org/html/rfc7303#section-9.2 RFC 7303\n\t * @see https://www.iana.org/assignments/media-types/text/xml IANA MimeType registration\n\t * @see https://en.wikipedia.org/wiki/XML_and_MIME Wikipedia\n\t */\n\tXML_TEXT: 'text/xml',\n\n\t/**\n\t * `application/xhtml+xml`, indicates an XML document that has the default HTML namespace,\n\t * but is parsed as an XML document.\n\t *\n\t * @see https://www.iana.org/assignments/media-types/application/xhtml+xml IANA MimeType registration\n\t * @see https://dom.spec.whatwg.org/#dom-domimplementation-createdocument WHATWG DOM Spec\n\t * @see https://en.wikipedia.org/wiki/XHTML Wikipedia\n\t */\n\tXML_XHTML_APPLICATION: 'application/xhtml+xml',\n\n\t/**\n\t * `image/svg+xml`,\n\t *\n\t * @see https://www.iana.org/assignments/media-types/image/svg+xml IANA MimeType registration\n\t * @see https://www.w3.org/TR/SVG11/ W3C SVG 1.1\n\t * @see https://en.wikipedia.org/wiki/Scalable_Vector_Graphics Wikipedia\n\t */\n\tXML_SVG_IMAGE: 'image/svg+xml',\n})\n\n/**\n * Namespaces that are used in this code base.\n *\n * @see http://www.w3.org/TR/REC-xml-names\n */\nvar NAMESPACE = freeze({\n\t/**\n\t * The XHTML namespace.\n\t *\n\t * @see http://www.w3.org/1999/xhtml\n\t */\n\tHTML: 'http://www.w3.org/1999/xhtml',\n\n\t/**\n\t * Checks if `uri` equals `NAMESPACE.HTML`.\n\t *\n\t * @param {string} [uri]\n\t *\n\t * @see NAMESPACE.HTML\n\t */\n\tisHTML: function (uri) {\n\t\treturn uri === NAMESPACE.HTML\n\t},\n\n\t/**\n\t * The SVG namespace.\n\t *\n\t * @see http://www.w3.org/2000/svg\n\t */\n\tSVG: 'http://www.w3.org/2000/svg',\n\n\t/**\n\t * The `xml:` namespace.\n\t *\n\t * @see http://www.w3.org/XML/1998/namespace\n\t */\n\tXML: 'http://www.w3.org/XML/1998/namespace',\n\n\t/**\n\t * The `xmlns:` namespace\n\t *\n\t * @see https://www.w3.org/2000/xmlns/\n\t */\n\tXMLNS: 'http://www.w3.org/2000/xmlns/',\n})\n\nexports.assign = assign;\nexports.find = find;\nexports.freeze = freeze;\nexports.MIME_TYPE = MIME_TYPE;\nexports.NAMESPACE = NAMESPACE;\n","var conventions = require(\"./conventions\");\n\nvar find = conventions.find;\nvar NAMESPACE = conventions.NAMESPACE;\n\n/**\n * A prerequisite for `[].filter`, to drop elements that are empty\n * @param {string} input\n * @returns {boolean}\n */\nfunction notEmptyString (input) {\n\treturn input !== ''\n}\n/**\n * @see https://infra.spec.whatwg.org/#split-on-ascii-whitespace\n * @see https://infra.spec.whatwg.org/#ascii-whitespace\n *\n * @param {string} input\n * @returns {string[]} (can be empty)\n */\nfunction splitOnASCIIWhitespace(input) {\n\t// U+0009 TAB, U+000A LF, U+000C FF, U+000D CR, U+0020 SPACE\n\treturn input ? input.split(/[\\t\\n\\f\\r ]+/).filter(notEmptyString) : []\n}\n\n/**\n * Adds element as a key to current if it is not already present.\n *\n * @param {Record<string, boolean | undefined>} current\n * @param {string} element\n * @returns {Record<string, boolean | undefined>}\n */\nfunction orderedSetReducer (current, element) {\n\tif (!current.hasOwnProperty(element)) {\n\t\tcurrent[element] = true;\n\t}\n\treturn current;\n}\n\n/**\n * @see https://infra.spec.whatwg.org/#ordered-set\n * @param {string} input\n * @returns {string[]}\n */\nfunction toOrderedSet(input) {\n\tif (!input) return [];\n\tvar list = splitOnASCIIWhitespace(input);\n\treturn Object.keys(list.reduce(orderedSetReducer, {}))\n}\n\n/**\n * Uses `list.indexOf` to implement something like `Array.prototype.includes`,\n * which we can not rely on being available.\n *\n * @param {any[]} list\n * @returns {function(any): boolean}\n */\nfunction arrayIncludes (list) {\n\treturn function(element) {\n\t\treturn list && list.indexOf(element) !== -1;\n\t}\n}\n\nfunction copy(src,dest){\n\tfor(var p in src){\n\t\tif (Object.prototype.hasOwnProperty.call(src, p)) {\n\t\t\tdest[p] = src[p];\n\t\t}\n\t}\n}\n\n/**\n^\\w+\\.prototype\\.([_\\w]+)\\s*=\\s*((?:.*\\{\\s*?[\\r\\n][\\s\\S]*?^})|\\S.*?(?=[;\\r\\n]));?\n^\\w+\\.prototype\\.([_\\w]+)\\s*=\\s*(\\S.*?(?=[;\\r\\n]));?\n */\nfunction _extends(Class,Super){\n\tvar pt = Class.prototype;\n\tif(!(pt instanceof Super)){\n\t\tfunction t(){};\n\t\tt.prototype = Super.prototype;\n\t\tt = new t();\n\t\tcopy(pt,t);\n\t\tClass.prototype = pt = t;\n\t}\n\tif(pt.constructor != Class){\n\t\tif(typeof Class != 'function'){\n\t\t\tconsole.error(\"unknown Class:\"+Class)\n\t\t}\n\t\tpt.constructor = Class\n\t}\n}\n\n// Node Types\nvar NodeType = {}\nvar ELEMENT_NODE                = NodeType.ELEMENT_NODE                = 1;\nvar ATTRIBUTE_NODE              = NodeType.ATTRIBUTE_NODE              = 2;\nvar TEXT_NODE                   = NodeType.TEXT_NODE                   = 3;\nvar CDATA_SECTION_NODE          = NodeType.CDATA_SECTION_NODE          = 4;\nvar ENTITY_REFERENCE_NODE       = NodeType.ENTITY_REFERENCE_NODE       = 5;\nvar ENTITY_NODE                 = NodeType.ENTITY_NODE                 = 6;\nvar PROCESSING_INSTRUCTION_NODE = NodeType.PROCESSING_INSTRUCTION_NODE = 7;\nvar COMMENT_NODE                = NodeType.COMMENT_NODE                = 8;\nvar DOCUMENT_NODE               = NodeType.DOCUMENT_NODE               = 9;\nvar DOCUMENT_TYPE_NODE          = NodeType.DOCUMENT_TYPE_NODE          = 10;\nvar DOCUMENT_FRAGMENT_NODE      = NodeType.DOCUMENT_FRAGMENT_NODE      = 11;\nvar NOTATION_NODE               = NodeType.NOTATION_NODE               = 12;\n\n// ExceptionCode\nvar ExceptionCode = {}\nvar ExceptionMessage = {};\nvar INDEX_SIZE_ERR              = ExceptionCode.INDEX_SIZE_ERR              = ((ExceptionMessage[1]=\"Index size error\"),1);\nvar DOMSTRING_SIZE_ERR          = ExceptionCode.DOMSTRING_SIZE_ERR          = ((ExceptionMessage[2]=\"DOMString size error\"),2);\nvar HIERARCHY_REQUEST_ERR       = ExceptionCode.HIERARCHY_REQUEST_ERR       = ((ExceptionMessage[3]=\"Hierarchy request error\"),3);\nvar WRONG_DOCUMENT_ERR          = ExceptionCode.WRONG_DOCUMENT_ERR          = ((ExceptionMessage[4]=\"Wrong document\"),4);\nvar INVALID_CHARACTER_ERR       = ExceptionCode.INVALID_CHARACTER_ERR       = ((ExceptionMessage[5]=\"Invalid character\"),5);\nvar NO_DATA_ALLOWED_ERR         = ExceptionCode.NO_DATA_ALLOWED_ERR         = ((ExceptionMessage[6]=\"No data allowed\"),6);\nvar NO_MODIFICATION_ALLOWED_ERR = ExceptionCode.NO_MODIFICATION_ALLOWED_ERR = ((ExceptionMessage[7]=\"No modification allowed\"),7);\nvar NOT_FOUND_ERR               = ExceptionCode.NOT_FOUND_ERR               = ((ExceptionMessage[8]=\"Not found\"),8);\nvar NOT_SUPPORTED_ERR           = ExceptionCode.NOT_SUPPORTED_ERR           = ((ExceptionMessage[9]=\"Not supported\"),9);\nvar INUSE_ATTRIBUTE_ERR         = ExceptionCode.INUSE_ATTRIBUTE_ERR         = ((ExceptionMessage[10]=\"Attribute in use\"),10);\n//level2\nvar INVALID_STATE_ERR        \t= ExceptionCode.INVALID_STATE_ERR        \t= ((ExceptionMessage[11]=\"Invalid state\"),11);\nvar SYNTAX_ERR               \t= ExceptionCode.SYNTAX_ERR               \t= ((ExceptionMessage[12]=\"Syntax error\"),12);\nvar INVALID_MODIFICATION_ERR \t= ExceptionCode.INVALID_MODIFICATION_ERR \t= ((ExceptionMessage[13]=\"Invalid modification\"),13);\nvar NAMESPACE_ERR            \t= ExceptionCode.NAMESPACE_ERR           \t= ((ExceptionMessage[14]=\"Invalid namespace\"),14);\nvar INVALID_ACCESS_ERR       \t= ExceptionCode.INVALID_ACCESS_ERR      \t= ((ExceptionMessage[15]=\"Invalid access\"),15);\n\n/**\n * DOM Level 2\n * Object DOMException\n * @see http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/ecma-script-binding.html\n * @see http://www.w3.org/TR/REC-DOM-Level-1/ecma-script-language-binding.html\n */\nfunction DOMException(code, message) {\n\tif(message instanceof Error){\n\t\tvar error = message;\n\t}else{\n\t\terror = this;\n\t\tError.call(this, ExceptionMessage[code]);\n\t\tthis.message = ExceptionMessage[code];\n\t\tif(Error.captureStackTrace) Error.captureStackTrace(this, DOMException);\n\t}\n\terror.code = code;\n\tif(message) this.message = this.message + \": \" + message;\n\treturn error;\n};\nDOMException.prototype = Error.prototype;\ncopy(ExceptionCode,DOMException)\n\n/**\n * @see http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/core.html#ID-536297177\n * The NodeList interface provides the abstraction of an ordered collection of nodes, without defining or constraining how this collection is implemented. NodeList objects in the DOM are live.\n * The items in the NodeList are accessible via an integral index, starting from 0.\n */\nfunction NodeList() {\n};\nNodeList.prototype = {\n\t/**\n\t * The number of nodes in the list. The range of valid child node indices is 0 to length-1 inclusive.\n\t * @standard level1\n\t */\n\tlength:0,\n\t/**\n\t * Returns the indexth item in the collection. If index is greater than or equal to the number of nodes in the list, this returns null.\n\t * @standard level1\n\t * @param index  unsigned long\n\t *   Index into the collection.\n\t * @return Node\n\t * \tThe node at the indexth position in the NodeList, or null if that is not a valid index.\n\t */\n\titem: function(index) {\n\t\treturn index >= 0 && index < this.length ? this[index] : null;\n\t},\n\ttoString:function(isHTML,nodeFilter){\n\t\tfor(var buf = [], i = 0;i<this.length;i++){\n\t\t\tserializeToString(this[i],buf,isHTML,nodeFilter);\n\t\t}\n\t\treturn buf.join('');\n\t},\n\t/**\n\t * @private\n\t * @param {function (Node):boolean} predicate\n\t * @returns {Node[]}\n\t */\n\tfilter: function (predicate) {\n\t\treturn Array.prototype.filter.call(this, predicate);\n\t},\n\t/**\n\t * @private\n\t * @param {Node} item\n\t * @returns {number}\n\t */\n\tindexOf: function (item) {\n\t\treturn Array.prototype.indexOf.call(this, item);\n\t},\n};\n\nfunction LiveNodeList(node,refresh){\n\tthis._node = node;\n\tthis._refresh = refresh\n\t_updateLiveList(this);\n}\nfunction _updateLiveList(list){\n\tvar inc = list._node._inc || list._node.ownerDocument._inc;\n\tif (list._inc !== inc) {\n\t\tvar ls = list._refresh(list._node);\n\t\t__set__(list,'length',ls.length);\n\t\tif (!list.$$length || ls.length < list.$$length) {\n\t\t\tfor (var i = ls.length; i in list; i++) {\n\t\t\t\tif (Object.prototype.hasOwnProperty.call(list, i)) {\n\t\t\t\t\tdelete list[i];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tcopy(ls,list);\n\t\tlist._inc = inc;\n\t}\n}\nLiveNodeList.prototype.item = function(i){\n\t_updateLiveList(this);\n\treturn this[i] || null;\n}\n\n_extends(LiveNodeList,NodeList);\n\n/**\n * Objects implementing the NamedNodeMap interface are used\n * to represent collections of nodes that can be accessed by name.\n * Note that NamedNodeMap does not inherit from NodeList;\n * NamedNodeMaps are not maintained in any particular order.\n * Objects contained in an object implementing NamedNodeMap may also be accessed by an ordinal index,\n * but this is simply to allow convenient enumeration of the contents of a NamedNodeMap,\n * and does not imply that the DOM specifies an order to these Nodes.\n * NamedNodeMap objects in the DOM are live.\n * used for attributes or DocumentType entities\n */\nfunction NamedNodeMap() {\n};\n\nfunction _findNodeIndex(list,node){\n\tvar i = list.length;\n\twhile(i--){\n\t\tif(list[i] === node){return i}\n\t}\n}\n\nfunction _addNamedNode(el,list,newAttr,oldAttr){\n\tif(oldAttr){\n\t\tlist[_findNodeIndex(list,oldAttr)] = newAttr;\n\t}else{\n\t\tlist[list.length++] = newAttr;\n\t}\n\tif(el){\n\t\tnewAttr.ownerElement = el;\n\t\tvar doc = el.ownerDocument;\n\t\tif(doc){\n\t\t\toldAttr && _onRemoveAttribute(doc,el,oldAttr);\n\t\t\t_onAddAttribute(doc,el,newAttr);\n\t\t}\n\t}\n}\nfunction _removeNamedNode(el,list,attr){\n\t//console.log('remove attr:'+attr)\n\tvar i = _findNodeIndex(list,attr);\n\tif(i>=0){\n\t\tvar lastIndex = list.length-1\n\t\twhile(i<lastIndex){\n\t\t\tlist[i] = list[++i]\n\t\t}\n\t\tlist.length = lastIndex;\n\t\tif(el){\n\t\t\tvar doc = el.ownerDocument;\n\t\t\tif(doc){\n\t\t\t\t_onRemoveAttribute(doc,el,attr);\n\t\t\t\tattr.ownerElement = null;\n\t\t\t}\n\t\t}\n\t}else{\n\t\tthrow new DOMException(NOT_FOUND_ERR,new Error(el.tagName+'@'+attr))\n\t}\n}\nNamedNodeMap.prototype = {\n\tlength:0,\n\titem:NodeList.prototype.item,\n\tgetNamedItem: function(key) {\n//\t\tif(key.indexOf(':')>0 || key == 'xmlns'){\n//\t\t\treturn null;\n//\t\t}\n\t\t//console.log()\n\t\tvar i = this.length;\n\t\twhile(i--){\n\t\t\tvar attr = this[i];\n\t\t\t//console.log(attr.nodeName,key)\n\t\t\tif(attr.nodeName == key){\n\t\t\t\treturn attr;\n\t\t\t}\n\t\t}\n\t},\n\tsetNamedItem: function(attr) {\n\t\tvar el = attr.ownerElement;\n\t\tif(el && el!=this._ownerElement){\n\t\t\tthrow new DOMException(INUSE_ATTRIBUTE_ERR);\n\t\t}\n\t\tvar oldAttr = this.getNamedItem(attr.nodeName);\n\t\t_addNamedNode(this._ownerElement,this,attr,oldAttr);\n\t\treturn oldAttr;\n\t},\n\t/* returns Node */\n\tsetNamedItemNS: function(attr) {// raises: WRONG_DOCUMENT_ERR,NO_MODIFICATION_ALLOWED_ERR,INUSE_ATTRIBUTE_ERR\n\t\tvar el = attr.ownerElement, oldAttr;\n\t\tif(el && el!=this._ownerElement){\n\t\t\tthrow new DOMException(INUSE_ATTRIBUTE_ERR);\n\t\t}\n\t\toldAttr = this.getNamedItemNS(attr.namespaceURI,attr.localName);\n\t\t_addNamedNode(this._ownerElement,this,attr,oldAttr);\n\t\treturn oldAttr;\n\t},\n\n\t/* returns Node */\n\tremoveNamedItem: function(key) {\n\t\tvar attr = this.getNamedItem(key);\n\t\t_removeNamedNode(this._ownerElement,this,attr);\n\t\treturn attr;\n\n\n\t},// raises: NOT_FOUND_ERR,NO_MODIFICATION_ALLOWED_ERR\n\n\t//for level2\n\tremoveNamedItemNS:function(namespaceURI,localName){\n\t\tvar attr = this.getNamedItemNS(namespaceURI,localName);\n\t\t_removeNamedNode(this._ownerElement,this,attr);\n\t\treturn attr;\n\t},\n\tgetNamedItemNS: function(namespaceURI, localName) {\n\t\tvar i = this.length;\n\t\twhile(i--){\n\t\t\tvar node = this[i];\n\t\t\tif(node.localName == localName && node.namespaceURI == namespaceURI){\n\t\t\t\treturn node;\n\t\t\t}\n\t\t}\n\t\treturn null;\n\t}\n};\n\n/**\n * The DOMImplementation interface represents an object providing methods\n * which are not dependent on any particular document.\n * Such an object is returned by the `Document.implementation` property.\n *\n * __The individual methods describe the differences compared to the specs.__\n *\n * @constructor\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMImplementation MDN\n * @see https://www.w3.org/TR/REC-DOM-Level-1/level-one-core.html#ID-102161490 DOM Level 1 Core (Initial)\n * @see https://www.w3.org/TR/DOM-Level-2-Core/core.html#ID-102161490 DOM Level 2 Core\n * @see https://www.w3.org/TR/DOM-Level-3-Core/core.html#ID-102161490 DOM Level 3 Core\n * @see https://dom.spec.whatwg.org/#domimplementation DOM Living Standard\n */\nfunction DOMImplementation() {\n}\n\nDOMImplementation.prototype = {\n\t/**\n\t * The DOMImplementation.hasFeature() method returns a Boolean flag indicating if a given feature is supported.\n\t * The different implementations fairly diverged in what kind of features were reported.\n\t * The latest version of the spec settled to force this method to always return true, where the functionality was accurate and in use.\n\t *\n\t * @deprecated It is deprecated and modern browsers return true in all cases.\n\t *\n\t * @param {string} feature\n\t * @param {string} [version]\n\t * @returns {boolean} always true\n\t *\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMImplementation/hasFeature MDN\n\t * @see https://www.w3.org/TR/REC-DOM-Level-1/level-one-core.html#ID-5CED94D7 DOM Level 1 Core\n\t * @see https://dom.spec.whatwg.org/#dom-domimplementation-hasfeature DOM Living Standard\n\t */\n\thasFeature: function(feature, version) {\n\t\t\treturn true;\n\t},\n\t/**\n\t * Creates an XML Document object of the specified type with its document element.\n\t *\n\t * __It behaves slightly different from the description in the living standard__:\n\t * - There is no interface/class `XMLDocument`, it returns a `Document` instance.\n\t * - `contentType`, `encoding`, `mode`, `origin`, `url` fields are currently not declared.\n\t * - this implementation is not validating names or qualified names\n\t *   (when parsing XML strings, the SAX parser takes care of that)\n\t *\n\t * @param {string|null} namespaceURI\n\t * @param {string} qualifiedName\n\t * @param {DocumentType=null} doctype\n\t * @returns {Document}\n\t *\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMImplementation/createDocument MDN\n\t * @see https://www.w3.org/TR/DOM-Level-2-Core/core.html#Level-2-Core-DOM-createDocument DOM Level 2 Core (initial)\n\t * @see https://dom.spec.whatwg.org/#dom-domimplementation-createdocument  DOM Level 2 Core\n\t *\n\t * @see https://dom.spec.whatwg.org/#validate-and-extract DOM: Validate and extract\n\t * @see https://www.w3.org/TR/xml/#NT-NameStartChar XML Spec: Names\n\t * @see https://www.w3.org/TR/xml-names/#ns-qualnames XML Namespaces: Qualified names\n\t */\n\tcreateDocument: function(namespaceURI,  qualifiedName, doctype){\n\t\tvar doc = new Document();\n\t\tdoc.implementation = this;\n\t\tdoc.childNodes = new NodeList();\n\t\tdoc.doctype = doctype || null;\n\t\tif (doctype){\n\t\t\tdoc.appendChild(doctype);\n\t\t}\n\t\tif (qualifiedName){\n\t\t\tvar root = doc.createElementNS(namespaceURI, qualifiedName);\n\t\t\tdoc.appendChild(root);\n\t\t}\n\t\treturn doc;\n\t},\n\t/**\n\t * Returns a doctype, with the given `qualifiedName`, `publicId`, and `systemId`.\n\t *\n\t * __This behavior is slightly different from the in the specs__:\n\t * - this implementation is not validating names or qualified names\n\t *   (when parsing XML strings, the SAX parser takes care of that)\n\t *\n\t * @param {string} qualifiedName\n\t * @param {string} [publicId]\n\t * @param {string} [systemId]\n\t * @returns {DocumentType} which can either be used with `DOMImplementation.createDocument` upon document creation\n\t * \t\t\t\t  or can be put into the document via methods like `Node.insertBefore()` or `Node.replaceChild()`\n\t *\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMImplementation/createDocumentType MDN\n\t * @see https://www.w3.org/TR/DOM-Level-2-Core/core.html#Level-2-Core-DOM-createDocType DOM Level 2 Core\n\t * @see https://dom.spec.whatwg.org/#dom-domimplementation-createdocumenttype DOM Living Standard\n\t *\n\t * @see https://dom.spec.whatwg.org/#validate-and-extract DOM: Validate and extract\n\t * @see https://www.w3.org/TR/xml/#NT-NameStartChar XML Spec: Names\n\t * @see https://www.w3.org/TR/xml-names/#ns-qualnames XML Namespaces: Qualified names\n\t */\n\tcreateDocumentType: function(qualifiedName, publicId, systemId){\n\t\tvar node = new DocumentType();\n\t\tnode.name = qualifiedName;\n\t\tnode.nodeName = qualifiedName;\n\t\tnode.publicId = publicId || '';\n\t\tnode.systemId = systemId || '';\n\n\t\treturn node;\n\t}\n};\n\n\n/**\n * @see http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/core.html#ID-1950641247\n */\n\nfunction Node() {\n};\n\nNode.prototype = {\n\tfirstChild : null,\n\tlastChild : null,\n\tpreviousSibling : null,\n\tnextSibling : null,\n\tattributes : null,\n\tparentNode : null,\n\tchildNodes : null,\n\townerDocument : null,\n\tnodeValue : null,\n\tnamespaceURI : null,\n\tprefix : null,\n\tlocalName : null,\n\t// Modified in DOM Level 2:\n\tinsertBefore:function(newChild, refChild){//raises\n\t\treturn _insertBefore(this,newChild,refChild);\n\t},\n\treplaceChild:function(newChild, oldChild){//raises\n\t\t_insertBefore(this, newChild,oldChild, assertPreReplacementValidityInDocument);\n\t\tif(oldChild){\n\t\t\tthis.removeChild(oldChild);\n\t\t}\n\t},\n\tremoveChild:function(oldChild){\n\t\treturn _removeChild(this,oldChild);\n\t},\n\tappendChild:function(newChild){\n\t\treturn this.insertBefore(newChild,null);\n\t},\n\thasChildNodes:function(){\n\t\treturn this.firstChild != null;\n\t},\n\tcloneNode:function(deep){\n\t\treturn cloneNode(this.ownerDocument||this,this,deep);\n\t},\n\t// Modified in DOM Level 2:\n\tnormalize:function(){\n\t\tvar child = this.firstChild;\n\t\twhile(child){\n\t\t\tvar next = child.nextSibling;\n\t\t\tif(next && next.nodeType == TEXT_NODE && child.nodeType == TEXT_NODE){\n\t\t\t\tthis.removeChild(next);\n\t\t\t\tchild.appendData(next.data);\n\t\t\t}else{\n\t\t\t\tchild.normalize();\n\t\t\t\tchild = next;\n\t\t\t}\n\t\t}\n\t},\n  \t// Introduced in DOM Level 2:\n\tisSupported:function(feature, version){\n\t\treturn this.ownerDocument.implementation.hasFeature(feature,version);\n\t},\n    // Introduced in DOM Level 2:\n    hasAttributes:function(){\n    \treturn this.attributes.length>0;\n    },\n\t/**\n\t * Look up the prefix associated to the given namespace URI, starting from this node.\n\t * **The default namespace declarations are ignored by this method.**\n\t * See Namespace Prefix Lookup for details on the algorithm used by this method.\n\t *\n\t * _Note: The implementation seems to be incomplete when compared to the algorithm described in the specs._\n\t *\n\t * @param {string | null} namespaceURI\n\t * @returns {string | null}\n\t * @see https://www.w3.org/TR/DOM-Level-3-Core/core.html#Node3-lookupNamespacePrefix\n\t * @see https://www.w3.org/TR/DOM-Level-3-Core/namespaces-algorithms.html#lookupNamespacePrefixAlgo\n\t * @see https://dom.spec.whatwg.org/#dom-node-lookupprefix\n\t * @see https://github.com/xmldom/xmldom/issues/322\n\t */\n    lookupPrefix:function(namespaceURI){\n    \tvar el = this;\n    \twhile(el){\n    \t\tvar map = el._nsMap;\n    \t\t//console.dir(map)\n    \t\tif(map){\n    \t\t\tfor(var n in map){\n\t\t\t\t\t\tif (Object.prototype.hasOwnProperty.call(map, n) && map[n] === namespaceURI) {\n\t\t\t\t\t\t\treturn n;\n\t\t\t\t\t\t}\n    \t\t\t}\n    \t\t}\n    \t\tel = el.nodeType == ATTRIBUTE_NODE?el.ownerDocument : el.parentNode;\n    \t}\n    \treturn null;\n    },\n    // Introduced in DOM Level 3:\n    lookupNamespaceURI:function(prefix){\n    \tvar el = this;\n    \twhile(el){\n    \t\tvar map = el._nsMap;\n    \t\t//console.dir(map)\n    \t\tif(map){\n    \t\t\tif(Object.prototype.hasOwnProperty.call(map, prefix)){\n    \t\t\t\treturn map[prefix] ;\n    \t\t\t}\n    \t\t}\n    \t\tel = el.nodeType == ATTRIBUTE_NODE?el.ownerDocument : el.parentNode;\n    \t}\n    \treturn null;\n    },\n    // Introduced in DOM Level 3:\n    isDefaultNamespace:function(namespaceURI){\n    \tvar prefix = this.lookupPrefix(namespaceURI);\n    \treturn prefix == null;\n    }\n};\n\n\nfunction _xmlEncoder(c){\n\treturn c == '<' && '&lt;' ||\n         c == '>' && '&gt;' ||\n         c == '&' && '&amp;' ||\n         c == '\"' && '&quot;' ||\n         '&#'+c.charCodeAt()+';'\n}\n\n\ncopy(NodeType,Node);\ncopy(NodeType,Node.prototype);\n\n/**\n * @param callback return true for continue,false for break\n * @return boolean true: break visit;\n */\nfunction _visitNode(node,callback){\n\tif(callback(node)){\n\t\treturn true;\n\t}\n\tif(node = node.firstChild){\n\t\tdo{\n\t\t\tif(_visitNode(node,callback)){return true}\n        }while(node=node.nextSibling)\n    }\n}\n\n\n\nfunction Document(){\n\tthis.ownerDocument = this;\n}\n\nfunction _onAddAttribute(doc,el,newAttr){\n\tdoc && doc._inc++;\n\tvar ns = newAttr.namespaceURI ;\n\tif(ns === NAMESPACE.XMLNS){\n\t\t//update namespace\n\t\tel._nsMap[newAttr.prefix?newAttr.localName:''] = newAttr.value\n\t}\n}\n\nfunction _onRemoveAttribute(doc,el,newAttr,remove){\n\tdoc && doc._inc++;\n\tvar ns = newAttr.namespaceURI ;\n\tif(ns === NAMESPACE.XMLNS){\n\t\t//update namespace\n\t\tdelete el._nsMap[newAttr.prefix?newAttr.localName:'']\n\t}\n}\n\n/**\n * Updates `el.childNodes`, updating the indexed items and it's `length`.\n * Passing `newChild` means it will be appended.\n * Otherwise it's assumed that an item has been removed,\n * and `el.firstNode` and it's `.nextSibling` are used\n * to walk the current list of child nodes.\n *\n * @param {Document} doc\n * @param {Node} el\n * @param {Node} [newChild]\n * @private\n */\nfunction _onUpdateChild (doc, el, newChild) {\n\tif(doc && doc._inc){\n\t\tdoc._inc++;\n\t\t//update childNodes\n\t\tvar cs = el.childNodes;\n\t\tif (newChild) {\n\t\t\tcs[cs.length++] = newChild;\n\t\t} else {\n\t\t\tvar child = el.firstChild;\n\t\t\tvar i = 0;\n\t\t\twhile (child) {\n\t\t\t\tcs[i++] = child;\n\t\t\t\tchild = child.nextSibling;\n\t\t\t}\n\t\t\tcs.length = i;\n\t\t\tdelete cs[cs.length];\n\t\t}\n\t}\n}\n\n/**\n * Removes the connections between `parentNode` and `child`\n * and any existing `child.previousSibling` or `child.nextSibling`.\n *\n * @see https://github.com/xmldom/xmldom/issues/135\n * @see https://github.com/xmldom/xmldom/issues/145\n *\n * @param {Node} parentNode\n * @param {Node} child\n * @returns {Node} the child that was removed.\n * @private\n */\nfunction _removeChild (parentNode, child) {\n\tvar previous = child.previousSibling;\n\tvar next = child.nextSibling;\n\tif (previous) {\n\t\tprevious.nextSibling = next;\n\t} else {\n\t\tparentNode.firstChild = next;\n\t}\n\tif (next) {\n\t\tnext.previousSibling = previous;\n\t} else {\n\t\tparentNode.lastChild = previous;\n\t}\n\tchild.parentNode = null;\n\tchild.previousSibling = null;\n\tchild.nextSibling = null;\n\t_onUpdateChild(parentNode.ownerDocument, parentNode);\n\treturn child;\n}\n\n/**\n * Returns `true` if `node` can be a parent for insertion.\n * @param {Node} node\n * @returns {boolean}\n */\nfunction hasValidParentNodeType(node) {\n\treturn (\n\t\tnode &&\n\t\t(node.nodeType === Node.DOCUMENT_NODE || node.nodeType === Node.DOCUMENT_FRAGMENT_NODE || node.nodeType === Node.ELEMENT_NODE)\n\t);\n}\n\n/**\n * Returns `true` if `node` can be inserted according to it's `nodeType`.\n * @param {Node} node\n * @returns {boolean}\n */\nfunction hasInsertableNodeType(node) {\n\treturn (\n\t\tnode &&\n\t\t(isElementNode(node) ||\n\t\t\tisTextNode(node) ||\n\t\t\tisDocTypeNode(node) ||\n\t\t\tnode.nodeType === Node.DOCUMENT_FRAGMENT_NODE ||\n\t\t\tnode.nodeType === Node.COMMENT_NODE ||\n\t\t\tnode.nodeType === Node.PROCESSING_INSTRUCTION_NODE)\n\t);\n}\n\n/**\n * Returns true if `node` is a DOCTYPE node\n * @param {Node} node\n * @returns {boolean}\n */\nfunction isDocTypeNode(node) {\n\treturn node && node.nodeType === Node.DOCUMENT_TYPE_NODE;\n}\n\n/**\n * Returns true if the node is an element\n * @param {Node} node\n * @returns {boolean}\n */\nfunction isElementNode(node) {\n\treturn node && node.nodeType === Node.ELEMENT_NODE;\n}\n/**\n * Returns true if `node` is a text node\n * @param {Node} node\n * @returns {boolean}\n */\nfunction isTextNode(node) {\n\treturn node && node.nodeType === Node.TEXT_NODE;\n}\n\n/**\n * Check if en element node can be inserted before `child`, or at the end if child is falsy,\n * according to the presence and position of a doctype node on the same level.\n *\n * @param {Document} doc The document node\n * @param {Node} child the node that would become the nextSibling if the element would be inserted\n * @returns {boolean} `true` if an element can be inserted before child\n * @private\n * https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n */\nfunction isElementInsertionPossible(doc, child) {\n\tvar parentChildNodes = doc.childNodes || [];\n\tif (find(parentChildNodes, isElementNode) || isDocTypeNode(child)) {\n\t\treturn false;\n\t}\n\tvar docTypeNode = find(parentChildNodes, isDocTypeNode);\n\treturn !(child && docTypeNode && parentChildNodes.indexOf(docTypeNode) > parentChildNodes.indexOf(child));\n}\n\n/**\n * Check if en element node can be inserted before `child`, or at the end if child is falsy,\n * according to the presence and position of a doctype node on the same level.\n *\n * @param {Node} doc The document node\n * @param {Node} child the node that would become the nextSibling if the element would be inserted\n * @returns {boolean} `true` if an element can be inserted before child\n * @private\n * https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n */\nfunction isElementReplacementPossible(doc, child) {\n\tvar parentChildNodes = doc.childNodes || [];\n\n\tfunction hasElementChildThatIsNotChild(node) {\n\t\treturn isElementNode(node) && node !== child;\n\t}\n\n\tif (find(parentChildNodes, hasElementChildThatIsNotChild)) {\n\t\treturn false;\n\t}\n\tvar docTypeNode = find(parentChildNodes, isDocTypeNode);\n\treturn !(child && docTypeNode && parentChildNodes.indexOf(docTypeNode) > parentChildNodes.indexOf(child));\n}\n\n/**\n * @private\n * Steps 1-5 of the checks before inserting and before replacing a child are the same.\n *\n * @param {Node} parent the parent node to insert `node` into\n * @param {Node} node the node to insert\n * @param {Node=} child the node that should become the `nextSibling` of `node`\n * @returns {Node}\n * @throws DOMException for several node combinations that would create a DOM that is not well-formed.\n * @throws DOMException if `child` is provided but is not a child of `parent`.\n * @see https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n * @see https://dom.spec.whatwg.org/#concept-node-replace\n */\nfunction assertPreInsertionValidity1to5(parent, node, child) {\n\t// 1. If `parent` is not a Document, DocumentFragment, or Element node, then throw a \"HierarchyRequestError\" DOMException.\n\tif (!hasValidParentNodeType(parent)) {\n\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Unexpected parent node type ' + parent.nodeType);\n\t}\n\t// 2. If `node` is a host-including inclusive ancestor of `parent`, then throw a \"HierarchyRequestError\" DOMException.\n\t// not implemented!\n\t// 3. If `child` is non-null and its parent is not `parent`, then throw a \"NotFoundError\" DOMException.\n\tif (child && child.parentNode !== parent) {\n\t\tthrow new DOMException(NOT_FOUND_ERR, 'child not in parent');\n\t}\n\tif (\n\t\t// 4. If `node` is not a DocumentFragment, DocumentType, Element, or CharacterData node, then throw a \"HierarchyRequestError\" DOMException.\n\t\t!hasInsertableNodeType(node) ||\n\t\t// 5. If either `node` is a Text node and `parent` is a document,\n\t\t// the sax parser currently adds top level text nodes, this will be fixed in 0.9.0\n\t\t// || (node.nodeType === Node.TEXT_NODE && parent.nodeType === Node.DOCUMENT_NODE)\n\t\t// or `node` is a doctype and `parent` is not a document, then throw a \"HierarchyRequestError\" DOMException.\n\t\t(isDocTypeNode(node) && parent.nodeType !== Node.DOCUMENT_NODE)\n\t) {\n\t\tthrow new DOMException(\n\t\t\tHIERARCHY_REQUEST_ERR,\n\t\t\t'Unexpected node type ' + node.nodeType + ' for parent node type ' + parent.nodeType\n\t\t);\n\t}\n}\n\n/**\n * @private\n * Step 6 of the checks before inserting and before replacing a child are different.\n *\n * @param {Document} parent the parent node to insert `node` into\n * @param {Node} node the node to insert\n * @param {Node | undefined} child the node that should become the `nextSibling` of `node`\n * @returns {Node}\n * @throws DOMException for several node combinations that would create a DOM that is not well-formed.\n * @throws DOMException if `child` is provided but is not a child of `parent`.\n * @see https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n * @see https://dom.spec.whatwg.org/#concept-node-replace\n */\nfunction assertPreInsertionValidityInDocument(parent, node, child) {\n\tvar parentChildNodes = parent.childNodes || [];\n\tvar nodeChildNodes = node.childNodes || [];\n\n\t// DocumentFragment\n\tif (node.nodeType === Node.DOCUMENT_FRAGMENT_NODE) {\n\t\tvar nodeChildElements = nodeChildNodes.filter(isElementNode);\n\t\t// If node has more than one element child or has a Text node child.\n\t\tif (nodeChildElements.length > 1 || find(nodeChildNodes, isTextNode)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'More than one element or text in fragment');\n\t\t}\n\t\t// Otherwise, if `node` has one element child and either `parent` has an element child,\n\t\t// `child` is a doctype, or `child` is non-null and a doctype is following `child`.\n\t\tif (nodeChildElements.length === 1 && !isElementInsertionPossible(parent, child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Element in fragment can not be inserted before doctype');\n\t\t}\n\t}\n\t// Element\n\tif (isElementNode(node)) {\n\t\t// `parent` has an element child, `child` is a doctype,\n\t\t// or `child` is non-null and a doctype is following `child`.\n\t\tif (!isElementInsertionPossible(parent, child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Only one element can be added and only after doctype');\n\t\t}\n\t}\n\t// DocumentType\n\tif (isDocTypeNode(node)) {\n\t\t// `parent` has a doctype child,\n\t\tif (find(parentChildNodes, isDocTypeNode)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Only one doctype is allowed');\n\t\t}\n\t\tvar parentElementChild = find(parentChildNodes, isElementNode);\n\t\t// `child` is non-null and an element is preceding `child`,\n\t\tif (child && parentChildNodes.indexOf(parentElementChild) < parentChildNodes.indexOf(child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Doctype can only be inserted before an element');\n\t\t}\n\t\t// or `child` is null and `parent` has an element child.\n\t\tif (!child && parentElementChild) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Doctype can not be appended since element is present');\n\t\t}\n\t}\n}\n\n/**\n * @private\n * Step 6 of the checks before inserting and before replacing a child are different.\n *\n * @param {Document} parent the parent node to insert `node` into\n * @param {Node} node the node to insert\n * @param {Node | undefined} child the node that should become the `nextSibling` of `node`\n * @returns {Node}\n * @throws DOMException for several node combinations that would create a DOM that is not well-formed.\n * @throws DOMException if `child` is provided but is not a child of `parent`.\n * @see https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n * @see https://dom.spec.whatwg.org/#concept-node-replace\n */\nfunction assertPreReplacementValidityInDocument(parent, node, child) {\n\tvar parentChildNodes = parent.childNodes || [];\n\tvar nodeChildNodes = node.childNodes || [];\n\n\t// DocumentFragment\n\tif (node.nodeType === Node.DOCUMENT_FRAGMENT_NODE) {\n\t\tvar nodeChildElements = nodeChildNodes.filter(isElementNode);\n\t\t// If `node` has more than one element child or has a Text node child.\n\t\tif (nodeChildElements.length > 1 || find(nodeChildNodes, isTextNode)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'More than one element or text in fragment');\n\t\t}\n\t\t// Otherwise, if `node` has one element child and either `parent` has an element child that is not `child` or a doctype is following `child`.\n\t\tif (nodeChildElements.length === 1 && !isElementReplacementPossible(parent, child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Element in fragment can not be inserted before doctype');\n\t\t}\n\t}\n\t// Element\n\tif (isElementNode(node)) {\n\t\t// `parent` has an element child that is not `child` or a doctype is following `child`.\n\t\tif (!isElementReplacementPossible(parent, child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Only one element can be added and only after doctype');\n\t\t}\n\t}\n\t// DocumentType\n\tif (isDocTypeNode(node)) {\n\t\tfunction hasDoctypeChildThatIsNotChild(node) {\n\t\t\treturn isDocTypeNode(node) && node !== child;\n\t\t}\n\n\t\t// `parent` has a doctype child that is not `child`,\n\t\tif (find(parentChildNodes, hasDoctypeChildThatIsNotChild)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Only one doctype is allowed');\n\t\t}\n\t\tvar parentElementChild = find(parentChildNodes, isElementNode);\n\t\t// or an element is preceding `child`.\n\t\tif (child && parentChildNodes.indexOf(parentElementChild) < parentChildNodes.indexOf(child)) {\n\t\t\tthrow new DOMException(HIERARCHY_REQUEST_ERR, 'Doctype can only be inserted before an element');\n\t\t}\n\t}\n}\n\n/**\n * @private\n * @param {Node} parent the parent node to insert `node` into\n * @param {Node} node the node to insert\n * @param {Node=} child the node that should become the `nextSibling` of `node`\n * @returns {Node}\n * @throws DOMException for several node combinations that would create a DOM that is not well-formed.\n * @throws DOMException if `child` is provided but is not a child of `parent`.\n * @see https://dom.spec.whatwg.org/#concept-node-ensure-pre-insertion-validity\n */\nfunction _insertBefore(parent, node, child, _inDocumentAssertion) {\n\t// To ensure pre-insertion validity of a node into a parent before a child, run these steps:\n\tassertPreInsertionValidity1to5(parent, node, child);\n\n\t// If parent is a document, and any of the statements below, switched on the interface node implements,\n\t// are true, then throw a \"HierarchyRequestError\" DOMException.\n\tif (parent.nodeType === Node.DOCUMENT_NODE) {\n\t\t(_inDocumentAssertion || assertPreInsertionValidityInDocument)(parent, node, child);\n\t}\n\n\tvar cp = node.parentNode;\n\tif(cp){\n\t\tcp.removeChild(node);//remove and update\n\t}\n\tif(node.nodeType === DOCUMENT_FRAGMENT_NODE){\n\t\tvar newFirst = node.firstChild;\n\t\tif (newFirst == null) {\n\t\t\treturn node;\n\t\t}\n\t\tvar newLast = node.lastChild;\n\t}else{\n\t\tnewFirst = newLast = node;\n\t}\n\tvar pre = child ? child.previousSibling : parent.lastChild;\n\n\tnewFirst.previousSibling = pre;\n\tnewLast.nextSibling = child;\n\n\n\tif(pre){\n\t\tpre.nextSibling = newFirst;\n\t}else{\n\t\tparent.firstChild = newFirst;\n\t}\n\tif(child == null){\n\t\tparent.lastChild = newLast;\n\t}else{\n\t\tchild.previousSibling = newLast;\n\t}\n\tdo{\n\t\tnewFirst.parentNode = parent;\n\t}while(newFirst !== newLast && (newFirst= newFirst.nextSibling))\n\t_onUpdateChild(parent.ownerDocument||parent, parent);\n\t//console.log(parent.lastChild.nextSibling == null)\n\tif (node.nodeType == DOCUMENT_FRAGMENT_NODE) {\n\t\tnode.firstChild = node.lastChild = null;\n\t}\n\treturn node;\n}\n\n/**\n * Appends `newChild` to `parentNode`.\n * If `newChild` is already connected to a `parentNode` it is first removed from it.\n *\n * @see https://github.com/xmldom/xmldom/issues/135\n * @see https://github.com/xmldom/xmldom/issues/145\n * @param {Node} parentNode\n * @param {Node} newChild\n * @returns {Node}\n * @private\n */\nfunction _appendSingleChild (parentNode, newChild) {\n\tif (newChild.parentNode) {\n\t\tnewChild.parentNode.removeChild(newChild);\n\t}\n\tnewChild.parentNode = parentNode;\n\tnewChild.previousSibling = parentNode.lastChild;\n\tnewChild.nextSibling = null;\n\tif (newChild.previousSibling) {\n\t\tnewChild.previousSibling.nextSibling = newChild;\n\t} else {\n\t\tparentNode.firstChild = newChild;\n\t}\n\tparentNode.lastChild = newChild;\n\t_onUpdateChild(parentNode.ownerDocument, parentNode, newChild);\n\treturn newChild;\n}\n\nDocument.prototype = {\n\t//implementation : null,\n\tnodeName :  '#document',\n\tnodeType :  DOCUMENT_NODE,\n\t/**\n\t * The DocumentType node of the document.\n\t *\n\t * @readonly\n\t * @type DocumentType\n\t */\n\tdoctype :  null,\n\tdocumentElement :  null,\n\t_inc : 1,\n\n\tinsertBefore :  function(newChild, refChild){//raises\n\t\tif(newChild.nodeType == DOCUMENT_FRAGMENT_NODE){\n\t\t\tvar child = newChild.firstChild;\n\t\t\twhile(child){\n\t\t\t\tvar next = child.nextSibling;\n\t\t\t\tthis.insertBefore(child,refChild);\n\t\t\t\tchild = next;\n\t\t\t}\n\t\t\treturn newChild;\n\t\t}\n\t\t_insertBefore(this, newChild, refChild);\n\t\tnewChild.ownerDocument = this;\n\t\tif (this.documentElement === null && newChild.nodeType === ELEMENT_NODE) {\n\t\t\tthis.documentElement = newChild;\n\t\t}\n\n\t\treturn newChild;\n\t},\n\tremoveChild :  function(oldChild){\n\t\tif(this.documentElement == oldChild){\n\t\t\tthis.documentElement = null;\n\t\t}\n\t\treturn _removeChild(this,oldChild);\n\t},\n\treplaceChild: function (newChild, oldChild) {\n\t\t//raises\n\t\t_insertBefore(this, newChild, oldChild, assertPreReplacementValidityInDocument);\n\t\tnewChild.ownerDocument = this;\n\t\tif (oldChild) {\n\t\t\tthis.removeChild(oldChild);\n\t\t}\n\t\tif (isElementNode(newChild)) {\n\t\t\tthis.documentElement = newChild;\n\t\t}\n\t},\n\t// Introduced in DOM Level 2:\n\timportNode : function(importedNode,deep){\n\t\treturn importNode(this,importedNode,deep);\n\t},\n\t// Introduced in DOM Level 2:\n\tgetElementById :\tfunction(id){\n\t\tvar rtv = null;\n\t\t_visitNode(this.documentElement,function(node){\n\t\t\tif(node.nodeType == ELEMENT_NODE){\n\t\t\t\tif(node.getAttribute('id') == id){\n\t\t\t\t\trtv = node;\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t}\n\t\t})\n\t\treturn rtv;\n\t},\n\n\t/**\n\t * The `getElementsByClassName` method of `Document` interface returns an array-like object\n\t * of all child elements which have **all** of the given class name(s).\n\t *\n\t * Returns an empty list if `classeNames` is an empty string or only contains HTML white space characters.\n\t *\n\t *\n\t * Warning: This is a live LiveNodeList.\n\t * Changes in the DOM will reflect in the array as the changes occur.\n\t * If an element selected by this array no longer qualifies for the selector,\n\t * it will automatically be removed. Be aware of this for iteration purposes.\n\t *\n\t * @param {string} classNames is a string representing the class name(s) to match; multiple class names are separated by (ASCII-)whitespace\n\t *\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/Document/getElementsByClassName\n\t * @see https://dom.spec.whatwg.org/#concept-getelementsbyclassname\n\t */\n\tgetElementsByClassName: function(classNames) {\n\t\tvar classNamesSet = toOrderedSet(classNames)\n\t\treturn new LiveNodeList(this, function(base) {\n\t\t\tvar ls = [];\n\t\t\tif (classNamesSet.length > 0) {\n\t\t\t\t_visitNode(base.documentElement, function(node) {\n\t\t\t\t\tif(node !== base && node.nodeType === ELEMENT_NODE) {\n\t\t\t\t\t\tvar nodeClassNames = node.getAttribute('class')\n\t\t\t\t\t\t// can be null if the attribute does not exist\n\t\t\t\t\t\tif (nodeClassNames) {\n\t\t\t\t\t\t\t// before splitting and iterating just compare them for the most common case\n\t\t\t\t\t\t\tvar matches = classNames === nodeClassNames;\n\t\t\t\t\t\t\tif (!matches) {\n\t\t\t\t\t\t\t\tvar nodeClassNamesSet = toOrderedSet(nodeClassNames)\n\t\t\t\t\t\t\t\tmatches = classNamesSet.every(arrayIncludes(nodeClassNamesSet))\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tif(matches) {\n\t\t\t\t\t\t\t\tls.push(node);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\t\t\treturn ls;\n\t\t});\n\t},\n\n\t//document factory method:\n\tcreateElement :\tfunction(tagName){\n\t\tvar node = new Element();\n\t\tnode.ownerDocument = this;\n\t\tnode.nodeName = tagName;\n\t\tnode.tagName = tagName;\n\t\tnode.localName = tagName;\n\t\tnode.childNodes = new NodeList();\n\t\tvar attrs\t= node.attributes = new NamedNodeMap();\n\t\tattrs._ownerElement = node;\n\t\treturn node;\n\t},\n\tcreateDocumentFragment :\tfunction(){\n\t\tvar node = new DocumentFragment();\n\t\tnode.ownerDocument = this;\n\t\tnode.childNodes = new NodeList();\n\t\treturn node;\n\t},\n\tcreateTextNode :\tfunction(data){\n\t\tvar node = new Text();\n\t\tnode.ownerDocument = this;\n\t\tnode.appendData(data)\n\t\treturn node;\n\t},\n\tcreateComment :\tfunction(data){\n\t\tvar node = new Comment();\n\t\tnode.ownerDocument = this;\n\t\tnode.appendData(data)\n\t\treturn node;\n\t},\n\tcreateCDATASection :\tfunction(data){\n\t\tvar node = new CDATASection();\n\t\tnode.ownerDocument = this;\n\t\tnode.appendData(data)\n\t\treturn node;\n\t},\n\tcreateProcessingInstruction :\tfunction(target,data){\n\t\tvar node = new ProcessingInstruction();\n\t\tnode.ownerDocument = this;\n\t\tnode.tagName = node.nodeName = node.target = target;\n\t\tnode.nodeValue = node.data = data;\n\t\treturn node;\n\t},\n\tcreateAttribute :\tfunction(name){\n\t\tvar node = new Attr();\n\t\tnode.ownerDocument\t= this;\n\t\tnode.name = name;\n\t\tnode.nodeName\t= name;\n\t\tnode.localName = name;\n\t\tnode.specified = true;\n\t\treturn node;\n\t},\n\tcreateEntityReference :\tfunction(name){\n\t\tvar node = new EntityReference();\n\t\tnode.ownerDocument\t= this;\n\t\tnode.nodeName\t= name;\n\t\treturn node;\n\t},\n\t// Introduced in DOM Level 2:\n\tcreateElementNS :\tfunction(namespaceURI,qualifiedName){\n\t\tvar node = new Element();\n\t\tvar pl = qualifiedName.split(':');\n\t\tvar attrs\t= node.attributes = new NamedNodeMap();\n\t\tnode.childNodes = new NodeList();\n\t\tnode.ownerDocument = this;\n\t\tnode.nodeName = qualifiedName;\n\t\tnode.tagName = qualifiedName;\n\t\tnode.namespaceURI = namespaceURI;\n\t\tif(pl.length == 2){\n\t\t\tnode.prefix = pl[0];\n\t\t\tnode.localName = pl[1];\n\t\t}else{\n\t\t\t//el.prefix = null;\n\t\t\tnode.localName = qualifiedName;\n\t\t}\n\t\tattrs._ownerElement = node;\n\t\treturn node;\n\t},\n\t// Introduced in DOM Level 2:\n\tcreateAttributeNS :\tfunction(namespaceURI,qualifiedName){\n\t\tvar node = new Attr();\n\t\tvar pl = qualifiedName.split(':');\n\t\tnode.ownerDocument = this;\n\t\tnode.nodeName = qualifiedName;\n\t\tnode.name = qualifiedName;\n\t\tnode.namespaceURI = namespaceURI;\n\t\tnode.specified = true;\n\t\tif(pl.length == 2){\n\t\t\tnode.prefix = pl[0];\n\t\t\tnode.localName = pl[1];\n\t\t}else{\n\t\t\t//el.prefix = null;\n\t\t\tnode.localName = qualifiedName;\n\t\t}\n\t\treturn node;\n\t}\n};\n_extends(Document,Node);\n\n\nfunction Element() {\n\tthis._nsMap = {};\n};\nElement.prototype = {\n\tnodeType : ELEMENT_NODE,\n\thasAttribute : function(name){\n\t\treturn this.getAttributeNode(name)!=null;\n\t},\n\tgetAttribute : function(name){\n\t\tvar attr = this.getAttributeNode(name);\n\t\treturn attr && attr.value || '';\n\t},\n\tgetAttributeNode : function(name){\n\t\treturn this.attributes.getNamedItem(name);\n\t},\n\tsetAttribute : function(name, value){\n\t\tvar attr = this.ownerDocument.createAttribute(name);\n\t\tattr.value = attr.nodeValue = \"\" + value;\n\t\tthis.setAttributeNode(attr)\n\t},\n\tremoveAttribute : function(name){\n\t\tvar attr = this.getAttributeNode(name)\n\t\tattr && this.removeAttributeNode(attr);\n\t},\n\n\t//four real opeartion method\n\tappendChild:function(newChild){\n\t\tif(newChild.nodeType === DOCUMENT_FRAGMENT_NODE){\n\t\t\treturn this.insertBefore(newChild,null);\n\t\t}else{\n\t\t\treturn _appendSingleChild(this,newChild);\n\t\t}\n\t},\n\tsetAttributeNode : function(newAttr){\n\t\treturn this.attributes.setNamedItem(newAttr);\n\t},\n\tsetAttributeNodeNS : function(newAttr){\n\t\treturn this.attributes.setNamedItemNS(newAttr);\n\t},\n\tremoveAttributeNode : function(oldAttr){\n\t\t//console.log(this == oldAttr.ownerElement)\n\t\treturn this.attributes.removeNamedItem(oldAttr.nodeName);\n\t},\n\t//get real attribute name,and remove it by removeAttributeNode\n\tremoveAttributeNS : function(namespaceURI, localName){\n\t\tvar old = this.getAttributeNodeNS(namespaceURI, localName);\n\t\told && this.removeAttributeNode(old);\n\t},\n\n\thasAttributeNS : function(namespaceURI, localName){\n\t\treturn this.getAttributeNodeNS(namespaceURI, localName)!=null;\n\t},\n\tgetAttributeNS : function(namespaceURI, localName){\n\t\tvar attr = this.getAttributeNodeNS(namespaceURI, localName);\n\t\treturn attr && attr.value || '';\n\t},\n\tsetAttributeNS : function(namespaceURI, qualifiedName, value){\n\t\tvar attr = this.ownerDocument.createAttributeNS(namespaceURI, qualifiedName);\n\t\tattr.value = attr.nodeValue = \"\" + value;\n\t\tthis.setAttributeNode(attr)\n\t},\n\tgetAttributeNodeNS : function(namespaceURI, localName){\n\t\treturn this.attributes.getNamedItemNS(namespaceURI, localName);\n\t},\n\n\tgetElementsByTagName : function(tagName){\n\t\treturn new LiveNodeList(this,function(base){\n\t\t\tvar ls = [];\n\t\t\t_visitNode(base,function(node){\n\t\t\t\tif(node !== base && node.nodeType == ELEMENT_NODE && (tagName === '*' || node.tagName == tagName)){\n\t\t\t\t\tls.push(node);\n\t\t\t\t}\n\t\t\t});\n\t\t\treturn ls;\n\t\t});\n\t},\n\tgetElementsByTagNameNS : function(namespaceURI, localName){\n\t\treturn new LiveNodeList(this,function(base){\n\t\t\tvar ls = [];\n\t\t\t_visitNode(base,function(node){\n\t\t\t\tif(node !== base && node.nodeType === ELEMENT_NODE && (namespaceURI === '*' || node.namespaceURI === namespaceURI) && (localName === '*' || node.localName == localName)){\n\t\t\t\t\tls.push(node);\n\t\t\t\t}\n\t\t\t});\n\t\t\treturn ls;\n\n\t\t});\n\t}\n};\nDocument.prototype.getElementsByTagName = Element.prototype.getElementsByTagName;\nDocument.prototype.getElementsByTagNameNS = Element.prototype.getElementsByTagNameNS;\n\n\n_extends(Element,Node);\nfunction Attr() {\n};\nAttr.prototype.nodeType = ATTRIBUTE_NODE;\n_extends(Attr,Node);\n\n\nfunction CharacterData() {\n};\nCharacterData.prototype = {\n\tdata : '',\n\tsubstringData : function(offset, count) {\n\t\treturn this.data.substring(offset, offset+count);\n\t},\n\tappendData: function(text) {\n\t\ttext = this.data+text;\n\t\tthis.nodeValue = this.data = text;\n\t\tthis.length = text.length;\n\t},\n\tinsertData: function(offset,text) {\n\t\tthis.replaceData(offset,0,text);\n\n\t},\n\tappendChild:function(newChild){\n\t\tthrow new Error(ExceptionMessage[HIERARCHY_REQUEST_ERR])\n\t},\n\tdeleteData: function(offset, count) {\n\t\tthis.replaceData(offset,count,\"\");\n\t},\n\treplaceData: function(offset, count, text) {\n\t\tvar start = this.data.substring(0,offset);\n\t\tvar end = this.data.substring(offset+count);\n\t\ttext = start + text + end;\n\t\tthis.nodeValue = this.data = text;\n\t\tthis.length = text.length;\n\t}\n}\n_extends(CharacterData,Node);\nfunction Text() {\n};\nText.prototype = {\n\tnodeName : \"#text\",\n\tnodeType : TEXT_NODE,\n\tsplitText : function(offset) {\n\t\tvar text = this.data;\n\t\tvar newText = text.substring(offset);\n\t\ttext = text.substring(0, offset);\n\t\tthis.data = this.nodeValue = text;\n\t\tthis.length = text.length;\n\t\tvar newNode = this.ownerDocument.createTextNode(newText);\n\t\tif(this.parentNode){\n\t\t\tthis.parentNode.insertBefore(newNode, this.nextSibling);\n\t\t}\n\t\treturn newNode;\n\t}\n}\n_extends(Text,CharacterData);\nfunction Comment() {\n};\nComment.prototype = {\n\tnodeName : \"#comment\",\n\tnodeType : COMMENT_NODE\n}\n_extends(Comment,CharacterData);\n\nfunction CDATASection() {\n};\nCDATASection.prototype = {\n\tnodeName : \"#cdata-section\",\n\tnodeType : CDATA_SECTION_NODE\n}\n_extends(CDATASection,CharacterData);\n\n\nfunction DocumentType() {\n};\nDocumentType.prototype.nodeType = DOCUMENT_TYPE_NODE;\n_extends(DocumentType,Node);\n\nfunction Notation() {\n};\nNotation.prototype.nodeType = NOTATION_NODE;\n_extends(Notation,Node);\n\nfunction Entity() {\n};\nEntity.prototype.nodeType = ENTITY_NODE;\n_extends(Entity,Node);\n\nfunction EntityReference() {\n};\nEntityReference.prototype.nodeType = ENTITY_REFERENCE_NODE;\n_extends(EntityReference,Node);\n\nfunction DocumentFragment() {\n};\nDocumentFragment.prototype.nodeName =\t\"#document-fragment\";\nDocumentFragment.prototype.nodeType =\tDOCUMENT_FRAGMENT_NODE;\n_extends(DocumentFragment,Node);\n\n\nfunction ProcessingInstruction() {\n}\nProcessingInstruction.prototype.nodeType = PROCESSING_INSTRUCTION_NODE;\n_extends(ProcessingInstruction,Node);\nfunction XMLSerializer(){}\nXMLSerializer.prototype.serializeToString = function(node,isHtml,nodeFilter){\n\treturn nodeSerializeToString.call(node,isHtml,nodeFilter);\n}\nNode.prototype.toString = nodeSerializeToString;\nfunction nodeSerializeToString(isHtml,nodeFilter){\n\tvar buf = [];\n\tvar refNode = this.nodeType == 9 && this.documentElement || this;\n\tvar prefix = refNode.prefix;\n\tvar uri = refNode.namespaceURI;\n\n\tif(uri && prefix == null){\n\t\t//console.log(prefix)\n\t\tvar prefix = refNode.lookupPrefix(uri);\n\t\tif(prefix == null){\n\t\t\t//isHTML = true;\n\t\t\tvar visibleNamespaces=[\n\t\t\t{namespace:uri,prefix:null}\n\t\t\t//{namespace:uri,prefix:''}\n\t\t\t]\n\t\t}\n\t}\n\tserializeToString(this,buf,isHtml,nodeFilter,visibleNamespaces);\n\t//console.log('###',this.nodeType,uri,prefix,buf.join(''))\n\treturn buf.join('');\n}\n\nfunction needNamespaceDefine(node, isHTML, visibleNamespaces) {\n\tvar prefix = node.prefix || '';\n\tvar uri = node.namespaceURI;\n\t// According to [Namespaces in XML 1.0](https://www.w3.org/TR/REC-xml-names/#ns-using) ,\n\t// and more specifically https://www.w3.org/TR/REC-xml-names/#nsc-NoPrefixUndecl :\n\t// > In a namespace declaration for a prefix [...], the attribute value MUST NOT be empty.\n\t// in a similar manner [Namespaces in XML 1.1](https://www.w3.org/TR/xml-names11/#ns-using)\n\t// and more specifically https://www.w3.org/TR/xml-names11/#nsc-NSDeclared :\n\t// > [...] Furthermore, the attribute value [...] must not be an empty string.\n\t// so serializing empty namespace value like xmlns:ds=\"\" would produce an invalid XML document.\n\tif (!uri) {\n\t\treturn false;\n\t}\n\tif (prefix === \"xml\" && uri === NAMESPACE.XML || uri === NAMESPACE.XMLNS) {\n\t\treturn false;\n\t}\n\n\tvar i = visibleNamespaces.length\n\twhile (i--) {\n\t\tvar ns = visibleNamespaces[i];\n\t\t// get namespace prefix\n\t\tif (ns.prefix === prefix) {\n\t\t\treturn ns.namespace !== uri;\n\t\t}\n\t}\n\treturn true;\n}\n/**\n * Well-formed constraint: No < in Attribute Values\n * > The replacement text of any entity referred to directly or indirectly\n * > in an attribute value must not contain a <.\n * @see https://www.w3.org/TR/xml11/#CleanAttrVals\n * @see https://www.w3.org/TR/xml11/#NT-AttValue\n *\n * Literal whitespace other than space that appear in attribute values\n * are serialized as their entity references, so they will be preserved.\n * (In contrast to whitespace literals in the input which are normalized to spaces)\n * @see https://www.w3.org/TR/xml11/#AVNormalize\n * @see https://w3c.github.io/DOM-Parsing/#serializing-an-element-s-attributes\n */\nfunction addSerializedAttribute(buf, qualifiedName, value) {\n\tbuf.push(' ', qualifiedName, '=\"', value.replace(/[<>&\"\\t\\n\\r]/g, _xmlEncoder), '\"')\n}\n\nfunction serializeToString(node,buf,isHTML,nodeFilter,visibleNamespaces){\n\tif (!visibleNamespaces) {\n\t\tvisibleNamespaces = [];\n\t}\n\n\tif(nodeFilter){\n\t\tnode = nodeFilter(node);\n\t\tif(node){\n\t\t\tif(typeof node == 'string'){\n\t\t\t\tbuf.push(node);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}else{\n\t\t\treturn;\n\t\t}\n\t\t//buf.sort.apply(attrs, attributeSorter);\n\t}\n\n\tswitch(node.nodeType){\n\tcase ELEMENT_NODE:\n\t\tvar attrs = node.attributes;\n\t\tvar len = attrs.length;\n\t\tvar child = node.firstChild;\n\t\tvar nodeName = node.tagName;\n\n\t\tisHTML = NAMESPACE.isHTML(node.namespaceURI) || isHTML\n\n\t\tvar prefixedNodeName = nodeName\n\t\tif (!isHTML && !node.prefix && node.namespaceURI) {\n\t\t\tvar defaultNS\n\t\t\t// lookup current default ns from `xmlns` attribute\n\t\t\tfor (var ai = 0; ai < attrs.length; ai++) {\n\t\t\t\tif (attrs.item(ai).name === 'xmlns') {\n\t\t\t\t\tdefaultNS = attrs.item(ai).value\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!defaultNS) {\n\t\t\t\t// lookup current default ns in visibleNamespaces\n\t\t\t\tfor (var nsi = visibleNamespaces.length - 1; nsi >= 0; nsi--) {\n\t\t\t\t\tvar namespace = visibleNamespaces[nsi]\n\t\t\t\t\tif (namespace.prefix === '' && namespace.namespace === node.namespaceURI) {\n\t\t\t\t\t\tdefaultNS = namespace.namespace\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (defaultNS !== node.namespaceURI) {\n\t\t\t\tfor (var nsi = visibleNamespaces.length - 1; nsi >= 0; nsi--) {\n\t\t\t\t\tvar namespace = visibleNamespaces[nsi]\n\t\t\t\t\tif (namespace.namespace === node.namespaceURI) {\n\t\t\t\t\t\tif (namespace.prefix) {\n\t\t\t\t\t\t\tprefixedNodeName = namespace.prefix + ':' + nodeName\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tbuf.push('<', prefixedNodeName);\n\n\t\tfor(var i=0;i<len;i++){\n\t\t\t// add namespaces for attributes\n\t\t\tvar attr = attrs.item(i);\n\t\t\tif (attr.prefix == 'xmlns') {\n\t\t\t\tvisibleNamespaces.push({ prefix: attr.localName, namespace: attr.value });\n\t\t\t}else if(attr.nodeName == 'xmlns'){\n\t\t\t\tvisibleNamespaces.push({ prefix: '', namespace: attr.value });\n\t\t\t}\n\t\t}\n\n\t\tfor(var i=0;i<len;i++){\n\t\t\tvar attr = attrs.item(i);\n\t\t\tif (needNamespaceDefine(attr,isHTML, visibleNamespaces)) {\n\t\t\t\tvar prefix = attr.prefix||'';\n\t\t\t\tvar uri = attr.namespaceURI;\n\t\t\t\taddSerializedAttribute(buf, prefix ? 'xmlns:' + prefix : \"xmlns\", uri);\n\t\t\t\tvisibleNamespaces.push({ prefix: prefix, namespace:uri });\n\t\t\t}\n\t\t\tserializeToString(attr,buf,isHTML,nodeFilter,visibleNamespaces);\n\t\t}\n\n\t\t// add namespace for current node\n\t\tif (nodeName === prefixedNodeName && needNamespaceDefine(node, isHTML, visibleNamespaces)) {\n\t\t\tvar prefix = node.prefix||'';\n\t\t\tvar uri = node.namespaceURI;\n\t\t\taddSerializedAttribute(buf, prefix ? 'xmlns:' + prefix : \"xmlns\", uri);\n\t\t\tvisibleNamespaces.push({ prefix: prefix, namespace:uri });\n\t\t}\n\n\t\tif(child || isHTML && !/^(?:meta|link|img|br|hr|input)$/i.test(nodeName)){\n\t\t\tbuf.push('>');\n\t\t\t//if is cdata child node\n\t\t\tif(isHTML && /^script$/i.test(nodeName)){\n\t\t\t\twhile(child){\n\t\t\t\t\tif(child.data){\n\t\t\t\t\t\tbuf.push(child.data);\n\t\t\t\t\t}else{\n\t\t\t\t\t\tserializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces.slice());\n\t\t\t\t\t}\n\t\t\t\t\tchild = child.nextSibling;\n\t\t\t\t}\n\t\t\t}else\n\t\t\t{\n\t\t\t\twhile(child){\n\t\t\t\t\tserializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces.slice());\n\t\t\t\t\tchild = child.nextSibling;\n\t\t\t\t}\n\t\t\t}\n\t\t\tbuf.push('</',prefixedNodeName,'>');\n\t\t}else{\n\t\t\tbuf.push('/>');\n\t\t}\n\t\t// remove added visible namespaces\n\t\t//visibleNamespaces.length = startVisibleNamespaces;\n\t\treturn;\n\tcase DOCUMENT_NODE:\n\tcase DOCUMENT_FRAGMENT_NODE:\n\t\tvar child = node.firstChild;\n\t\twhile(child){\n\t\t\tserializeToString(child, buf, isHTML, nodeFilter, visibleNamespaces.slice());\n\t\t\tchild = child.nextSibling;\n\t\t}\n\t\treturn;\n\tcase ATTRIBUTE_NODE:\n\t\treturn addSerializedAttribute(buf, node.name, node.value);\n\tcase TEXT_NODE:\n\t\t/**\n\t\t * The ampersand character (&) and the left angle bracket (<) must not appear in their literal form,\n\t\t * except when used as markup delimiters, or within a comment, a processing instruction, or a CDATA section.\n\t\t * If they are needed elsewhere, they must be escaped using either numeric character references or the strings\n\t\t * `&amp;` and `&lt;` respectively.\n\t\t * The right angle bracket (>) may be represented using the string \" &gt; \", and must, for compatibility,\n\t\t * be escaped using either `&gt;` or a character reference when it appears in the string `]]>` in content,\n\t\t * when that string is not marking the end of a CDATA section.\n\t\t *\n\t\t * In the content of elements, character data is any string of characters\n\t\t * which does not contain the start-delimiter of any markup\n\t\t * and does not include the CDATA-section-close delimiter, `]]>`.\n\t\t *\n\t\t * @see https://www.w3.org/TR/xml/#NT-CharData\n\t\t * @see https://w3c.github.io/DOM-Parsing/#xml-serializing-a-text-node\n\t\t */\n\t\treturn buf.push(node.data\n\t\t\t.replace(/[<&>]/g,_xmlEncoder)\n\t\t);\n\tcase CDATA_SECTION_NODE:\n\t\treturn buf.push( '<![CDATA[',node.data,']]>');\n\tcase COMMENT_NODE:\n\t\treturn buf.push( \"<!--\",node.data,\"-->\");\n\tcase DOCUMENT_TYPE_NODE:\n\t\tvar pubid = node.publicId;\n\t\tvar sysid = node.systemId;\n\t\tbuf.push('<!DOCTYPE ',node.name);\n\t\tif(pubid){\n\t\t\tbuf.push(' PUBLIC ', pubid);\n\t\t\tif (sysid && sysid!='.') {\n\t\t\t\tbuf.push(' ', sysid);\n\t\t\t}\n\t\t\tbuf.push('>');\n\t\t}else if(sysid && sysid!='.'){\n\t\t\tbuf.push(' SYSTEM ', sysid, '>');\n\t\t}else{\n\t\t\tvar sub = node.internalSubset;\n\t\t\tif(sub){\n\t\t\t\tbuf.push(\" [\",sub,\"]\");\n\t\t\t}\n\t\t\tbuf.push(\">\");\n\t\t}\n\t\treturn;\n\tcase PROCESSING_INSTRUCTION_NODE:\n\t\treturn buf.push( \"<?\",node.target,\" \",node.data,\"?>\");\n\tcase ENTITY_REFERENCE_NODE:\n\t\treturn buf.push( '&',node.nodeName,';');\n\t//case ENTITY_NODE:\n\t//case NOTATION_NODE:\n\tdefault:\n\t\tbuf.push('??',node.nodeName);\n\t}\n}\nfunction importNode(doc,node,deep){\n\tvar node2;\n\tswitch (node.nodeType) {\n\tcase ELEMENT_NODE:\n\t\tnode2 = node.cloneNode(false);\n\t\tnode2.ownerDocument = doc;\n\t\t//var attrs = node2.attributes;\n\t\t//var len = attrs.length;\n\t\t//for(var i=0;i<len;i++){\n\t\t\t//node2.setAttributeNodeNS(importNode(doc,attrs.item(i),deep));\n\t\t//}\n\tcase DOCUMENT_FRAGMENT_NODE:\n\t\tbreak;\n\tcase ATTRIBUTE_NODE:\n\t\tdeep = true;\n\t\tbreak;\n\t//case ENTITY_REFERENCE_NODE:\n\t//case PROCESSING_INSTRUCTION_NODE:\n\t////case TEXT_NODE:\n\t//case CDATA_SECTION_NODE:\n\t//case COMMENT_NODE:\n\t//\tdeep = false;\n\t//\tbreak;\n\t//case DOCUMENT_NODE:\n\t//case DOCUMENT_TYPE_NODE:\n\t//cannot be imported.\n\t//case ENTITY_NODE:\n\t//case NOTATION_NODE：\n\t//can not hit in level3\n\t//default:throw e;\n\t}\n\tif(!node2){\n\t\tnode2 = node.cloneNode(false);//false\n\t}\n\tnode2.ownerDocument = doc;\n\tnode2.parentNode = null;\n\tif(deep){\n\t\tvar child = node.firstChild;\n\t\twhile(child){\n\t\t\tnode2.appendChild(importNode(doc,child,deep));\n\t\t\tchild = child.nextSibling;\n\t\t}\n\t}\n\treturn node2;\n}\n//\n//var _relationMap = {firstChild:1,lastChild:1,previousSibling:1,nextSibling:1,\n//\t\t\t\t\tattributes:1,childNodes:1,parentNode:1,documentElement:1,doctype,};\nfunction cloneNode(doc,node,deep){\n\tvar node2 = new node.constructor();\n\tfor (var n in node) {\n\t\tif (Object.prototype.hasOwnProperty.call(node, n)) {\n\t\t\tvar v = node[n];\n\t\t\tif (typeof v != \"object\") {\n\t\t\t\tif (v != node2[n]) {\n\t\t\t\t\tnode2[n] = v;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\tif(node.childNodes){\n\t\tnode2.childNodes = new NodeList();\n\t}\n\tnode2.ownerDocument = doc;\n\tswitch (node2.nodeType) {\n\tcase ELEMENT_NODE:\n\t\tvar attrs\t= node.attributes;\n\t\tvar attrs2\t= node2.attributes = new NamedNodeMap();\n\t\tvar len = attrs.length\n\t\tattrs2._ownerElement = node2;\n\t\tfor(var i=0;i<len;i++){\n\t\t\tnode2.setAttributeNode(cloneNode(doc,attrs.item(i),true));\n\t\t}\n\t\tbreak;;\n\tcase ATTRIBUTE_NODE:\n\t\tdeep = true;\n\t}\n\tif(deep){\n\t\tvar child = node.firstChild;\n\t\twhile(child){\n\t\t\tnode2.appendChild(cloneNode(doc,child,deep));\n\t\t\tchild = child.nextSibling;\n\t\t}\n\t}\n\treturn node2;\n}\n\nfunction __set__(object,key,value){\n\tobject[key] = value\n}\n//do dynamic\ntry{\n\tif(Object.defineProperty){\n\t\tObject.defineProperty(LiveNodeList.prototype,'length',{\n\t\t\tget:function(){\n\t\t\t\t_updateLiveList(this);\n\t\t\t\treturn this.$$length;\n\t\t\t}\n\t\t});\n\n\t\tObject.defineProperty(Node.prototype,'textContent',{\n\t\t\tget:function(){\n\t\t\t\treturn getTextContent(this);\n\t\t\t},\n\n\t\t\tset:function(data){\n\t\t\t\tswitch(this.nodeType){\n\t\t\t\tcase ELEMENT_NODE:\n\t\t\t\tcase DOCUMENT_FRAGMENT_NODE:\n\t\t\t\t\twhile(this.firstChild){\n\t\t\t\t\t\tthis.removeChild(this.firstChild);\n\t\t\t\t\t}\n\t\t\t\t\tif(data || String(data)){\n\t\t\t\t\t\tthis.appendChild(this.ownerDocument.createTextNode(data));\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\n\t\t\t\tdefault:\n\t\t\t\t\tthis.data = data;\n\t\t\t\t\tthis.value = data;\n\t\t\t\t\tthis.nodeValue = data;\n\t\t\t\t}\n\t\t\t}\n\t\t})\n\n\t\tfunction getTextContent(node){\n\t\t\tswitch(node.nodeType){\n\t\t\tcase ELEMENT_NODE:\n\t\t\tcase DOCUMENT_FRAGMENT_NODE:\n\t\t\t\tvar buf = [];\n\t\t\t\tnode = node.firstChild;\n\t\t\t\twhile(node){\n\t\t\t\t\tif(node.nodeType!==7 && node.nodeType !==8){\n\t\t\t\t\t\tbuf.push(getTextContent(node));\n\t\t\t\t\t}\n\t\t\t\t\tnode = node.nextSibling;\n\t\t\t\t}\n\t\t\t\treturn buf.join('');\n\t\t\tdefault:\n\t\t\t\treturn node.nodeValue;\n\t\t\t}\n\t\t}\n\n\t\t__set__ = function(object,key,value){\n\t\t\t//console.log(value)\n\t\t\tobject['$$'+key] = value\n\t\t}\n\t}\n}catch(e){//ie8\n}\n\n//if(typeof require == 'function'){\n\texports.DocumentType = DocumentType;\n\texports.DOMException = DOMException;\n\texports.DOMImplementation = DOMImplementation;\n\texports.Element = Element;\n\texports.Node = Node;\n\texports.NodeList = NodeList;\n\texports.XMLSerializer = XMLSerializer;\n//}\n","'use strict';\n\nvar freeze = require('./conventions').freeze;\n\n/**\n * The entities that are predefined in every XML document.\n *\n * @see https://www.w3.org/TR/2006/REC-xml11-20060816/#sec-predefined-ent W3C XML 1.1\n * @see https://www.w3.org/TR/2008/REC-xml-20081126/#sec-predefined-ent W3C XML 1.0\n * @see https://en.wikipedia.org/wiki/List_of_XML_and_HTML_character_entity_references#Predefined_entities_in_XML Wikipedia\n */\nexports.XML_ENTITIES = freeze({\n\tamp: '&',\n\tapos: \"'\",\n\tgt: '>',\n\tlt: '<',\n\tquot: '\"',\n});\n\n/**\n * A map of all entities that are detected in an HTML document.\n * They contain all entries from `XML_ENTITIES`.\n *\n * @see XML_ENTITIES\n * @see DOMParser.parseFromString\n * @see DOMImplementation.prototype.createHTMLDocument\n * @see https://html.spec.whatwg.org/#named-character-references WHATWG HTML(5) Spec\n * @see https://html.spec.whatwg.org/entities.json JSON\n * @see https://www.w3.org/TR/xml-entity-names/ W3C XML Entity Names\n * @see https://www.w3.org/TR/html4/sgml/entities.html W3C HTML4/SGML\n * @see https://en.wikipedia.org/wiki/List_of_XML_and_HTML_character_entity_references#Character_entity_references_in_HTML Wikipedia (HTML)\n * @see https://en.wikipedia.org/wiki/List_of_XML_and_HTML_character_entity_references#Entities_representing_special_characters_in_XHTML Wikpedia (XHTML)\n */\nexports.HTML_ENTITIES = freeze({\n\tAacute: '\\u00C1',\n\taacute: '\\u00E1',\n\tAbreve: '\\u0102',\n\tabreve: '\\u0103',\n\tac: '\\u223E',\n\tacd: '\\u223F',\n\tacE: '\\u223E\\u0333',\n\tAcirc: '\\u00C2',\n\tacirc: '\\u00E2',\n\tacute: '\\u00B4',\n\tAcy: '\\u0410',\n\tacy: '\\u0430',\n\tAElig: '\\u00C6',\n\taelig: '\\u00E6',\n\taf: '\\u2061',\n\tAfr: '\\uD835\\uDD04',\n\tafr: '\\uD835\\uDD1E',\n\tAgrave: '\\u00C0',\n\tagrave: '\\u00E0',\n\talefsym: '\\u2135',\n\taleph: '\\u2135',\n\tAlpha: '\\u0391',\n\talpha: '\\u03B1',\n\tAmacr: '\\u0100',\n\tamacr: '\\u0101',\n\tamalg: '\\u2A3F',\n\tAMP: '\\u0026',\n\tamp: '\\u0026',\n\tAnd: '\\u2A53',\n\tand: '\\u2227',\n\tandand: '\\u2A55',\n\tandd: '\\u2A5C',\n\tandslope: '\\u2A58',\n\tandv: '\\u2A5A',\n\tang: '\\u2220',\n\tange: '\\u29A4',\n\tangle: '\\u2220',\n\tangmsd: '\\u2221',\n\tangmsdaa: '\\u29A8',\n\tangmsdab: '\\u29A9',\n\tangmsdac: '\\u29AA',\n\tangmsdad: '\\u29AB',\n\tangmsdae: '\\u29AC',\n\tangmsdaf: '\\u29AD',\n\tangmsdag: '\\u29AE',\n\tangmsdah: '\\u29AF',\n\tangrt: '\\u221F',\n\tangrtvb: '\\u22BE',\n\tangrtvbd: '\\u299D',\n\tangsph: '\\u2222',\n\tangst: '\\u00C5',\n\tangzarr: '\\u237C',\n\tAogon: '\\u0104',\n\taogon: '\\u0105',\n\tAopf: '\\uD835\\uDD38',\n\taopf: '\\uD835\\uDD52',\n\tap: '\\u2248',\n\tapacir: '\\u2A6F',\n\tapE: '\\u2A70',\n\tape: '\\u224A',\n\tapid: '\\u224B',\n\tapos: '\\u0027',\n\tApplyFunction: '\\u2061',\n\tapprox: '\\u2248',\n\tapproxeq: '\\u224A',\n\tAring: '\\u00C5',\n\taring: '\\u00E5',\n\tAscr: '\\uD835\\uDC9C',\n\tascr: '\\uD835\\uDCB6',\n\tAssign: '\\u2254',\n\tast: '\\u002A',\n\tasymp: '\\u2248',\n\tasympeq: '\\u224D',\n\tAtilde: '\\u00C3',\n\tatilde: '\\u00E3',\n\tAuml: '\\u00C4',\n\tauml: '\\u00E4',\n\tawconint: '\\u2233',\n\tawint: '\\u2A11',\n\tbackcong: '\\u224C',\n\tbackepsilon: '\\u03F6',\n\tbackprime: '\\u2035',\n\tbacksim: '\\u223D',\n\tbacksimeq: '\\u22CD',\n\tBackslash: '\\u2216',\n\tBarv: '\\u2AE7',\n\tbarvee: '\\u22BD',\n\tBarwed: '\\u2306',\n\tbarwed: '\\u2305',\n\tbarwedge: '\\u2305',\n\tbbrk: '\\u23B5',\n\tbbrktbrk: '\\u23B6',\n\tbcong: '\\u224C',\n\tBcy: '\\u0411',\n\tbcy: '\\u0431',\n\tbdquo: '\\u201E',\n\tbecaus: '\\u2235',\n\tBecause: '\\u2235',\n\tbecause: '\\u2235',\n\tbemptyv: '\\u29B0',\n\tbepsi: '\\u03F6',\n\tbernou: '\\u212C',\n\tBernoullis: '\\u212C',\n\tBeta: '\\u0392',\n\tbeta: '\\u03B2',\n\tbeth: '\\u2136',\n\tbetween: '\\u226C',\n\tBfr: '\\uD835\\uDD05',\n\tbfr: '\\uD835\\uDD1F',\n\tbigcap: '\\u22C2',\n\tbigcirc: '\\u25EF',\n\tbigcup: '\\u22C3',\n\tbigodot: '\\u2A00',\n\tbigoplus: '\\u2A01',\n\tbigotimes: '\\u2A02',\n\tbigsqcup: '\\u2A06',\n\tbigstar: '\\u2605',\n\tbigtriangledown: '\\u25BD',\n\tbigtriangleup: '\\u25B3',\n\tbiguplus: '\\u2A04',\n\tbigvee: '\\u22C1',\n\tbigwedge: '\\u22C0',\n\tbkarow: '\\u290D',\n\tblacklozenge: '\\u29EB',\n\tblacksquare: '\\u25AA',\n\tblacktriangle: '\\u25B4',\n\tblacktriangledown: '\\u25BE',\n\tblacktriangleleft: '\\u25C2',\n\tblacktriangleright: '\\u25B8',\n\tblank: '\\u2423',\n\tblk12: '\\u2592',\n\tblk14: '\\u2591',\n\tblk34: '\\u2593',\n\tblock: '\\u2588',\n\tbne: '\\u003D\\u20E5',\n\tbnequiv: '\\u2261\\u20E5',\n\tbNot: '\\u2AED',\n\tbnot: '\\u2310',\n\tBopf: '\\uD835\\uDD39',\n\tbopf: '\\uD835\\uDD53',\n\tbot: '\\u22A5',\n\tbottom: '\\u22A5',\n\tbowtie: '\\u22C8',\n\tboxbox: '\\u29C9',\n\tboxDL: '\\u2557',\n\tboxDl: '\\u2556',\n\tboxdL: '\\u2555',\n\tboxdl: '\\u2510',\n\tboxDR: '\\u2554',\n\tboxDr: '\\u2553',\n\tboxdR: '\\u2552',\n\tboxdr: '\\u250C',\n\tboxH: '\\u2550',\n\tboxh: '\\u2500',\n\tboxHD: '\\u2566',\n\tboxHd: '\\u2564',\n\tboxhD: '\\u2565',\n\tboxhd: '\\u252C',\n\tboxHU: '\\u2569',\n\tboxHu: '\\u2567',\n\tboxhU: '\\u2568',\n\tboxhu: '\\u2534',\n\tboxminus: '\\u229F',\n\tboxplus: '\\u229E',\n\tboxtimes: '\\u22A0',\n\tboxUL: '\\u255D',\n\tboxUl: '\\u255C',\n\tboxuL: '\\u255B',\n\tboxul: '\\u2518',\n\tboxUR: '\\u255A',\n\tboxUr: '\\u2559',\n\tboxuR: '\\u2558',\n\tboxur: '\\u2514',\n\tboxV: '\\u2551',\n\tboxv: '\\u2502',\n\tboxVH: '\\u256C',\n\tboxVh: '\\u256B',\n\tboxvH: '\\u256A',\n\tboxvh: '\\u253C',\n\tboxVL: '\\u2563',\n\tboxVl: '\\u2562',\n\tboxvL: '\\u2561',\n\tboxvl: '\\u2524',\n\tboxVR: '\\u2560',\n\tboxVr: '\\u255F',\n\tboxvR: '\\u255E',\n\tboxvr: '\\u251C',\n\tbprime: '\\u2035',\n\tBreve: '\\u02D8',\n\tbreve: '\\u02D8',\n\tbrvbar: '\\u00A6',\n\tBscr: '\\u212C',\n\tbscr: '\\uD835\\uDCB7',\n\tbsemi: '\\u204F',\n\tbsim: '\\u223D',\n\tbsime: '\\u22CD',\n\tbsol: '\\u005C',\n\tbsolb: '\\u29C5',\n\tbsolhsub: '\\u27C8',\n\tbull: '\\u2022',\n\tbullet: '\\u2022',\n\tbump: '\\u224E',\n\tbumpE: '\\u2AAE',\n\tbumpe: '\\u224F',\n\tBumpeq: '\\u224E',\n\tbumpeq: '\\u224F',\n\tCacute: '\\u0106',\n\tcacute: '\\u0107',\n\tCap: '\\u22D2',\n\tcap: '\\u2229',\n\tcapand: '\\u2A44',\n\tcapbrcup: '\\u2A49',\n\tcapcap: '\\u2A4B',\n\tcapcup: '\\u2A47',\n\tcapdot: '\\u2A40',\n\tCapitalDifferentialD: '\\u2145',\n\tcaps: '\\u2229\\uFE00',\n\tcaret: '\\u2041',\n\tcaron: '\\u02C7',\n\tCayleys: '\\u212D',\n\tccaps: '\\u2A4D',\n\tCcaron: '\\u010C',\n\tccaron: '\\u010D',\n\tCcedil: '\\u00C7',\n\tccedil: '\\u00E7',\n\tCcirc: '\\u0108',\n\tccirc: '\\u0109',\n\tCconint: '\\u2230',\n\tccups: '\\u2A4C',\n\tccupssm: '\\u2A50',\n\tCdot: '\\u010A',\n\tcdot: '\\u010B',\n\tcedil: '\\u00B8',\n\tCedilla: '\\u00B8',\n\tcemptyv: '\\u29B2',\n\tcent: '\\u00A2',\n\tCenterDot: '\\u00B7',\n\tcenterdot: '\\u00B7',\n\tCfr: '\\u212D',\n\tcfr: '\\uD835\\uDD20',\n\tCHcy: '\\u0427',\n\tchcy: '\\u0447',\n\tcheck: '\\u2713',\n\tcheckmark: '\\u2713',\n\tChi: '\\u03A7',\n\tchi: '\\u03C7',\n\tcir: '\\u25CB',\n\tcirc: '\\u02C6',\n\tcirceq: '\\u2257',\n\tcirclearrowleft: '\\u21BA',\n\tcirclearrowright: '\\u21BB',\n\tcircledast: '\\u229B',\n\tcircledcirc: '\\u229A',\n\tcircleddash: '\\u229D',\n\tCircleDot: '\\u2299',\n\tcircledR: '\\u00AE',\n\tcircledS: '\\u24C8',\n\tCircleMinus: '\\u2296',\n\tCirclePlus: '\\u2295',\n\tCircleTimes: '\\u2297',\n\tcirE: '\\u29C3',\n\tcire: '\\u2257',\n\tcirfnint: '\\u2A10',\n\tcirmid: '\\u2AEF',\n\tcirscir: '\\u29C2',\n\tClockwiseContourIntegral: '\\u2232',\n\tCloseCurlyDoubleQuote: '\\u201D',\n\tCloseCurlyQuote: '\\u2019',\n\tclubs: '\\u2663',\n\tclubsuit: '\\u2663',\n\tColon: '\\u2237',\n\tcolon: '\\u003A',\n\tColone: '\\u2A74',\n\tcolone: '\\u2254',\n\tcoloneq: '\\u2254',\n\tcomma: '\\u002C',\n\tcommat: '\\u0040',\n\tcomp: '\\u2201',\n\tcompfn: '\\u2218',\n\tcomplement: '\\u2201',\n\tcomplexes: '\\u2102',\n\tcong: '\\u2245',\n\tcongdot: '\\u2A6D',\n\tCongruent: '\\u2261',\n\tConint: '\\u222F',\n\tconint: '\\u222E',\n\tContourIntegral: '\\u222E',\n\tCopf: '\\u2102',\n\tcopf: '\\uD835\\uDD54',\n\tcoprod: '\\u2210',\n\tCoproduct: '\\u2210',\n\tCOPY: '\\u00A9',\n\tcopy: '\\u00A9',\n\tcopysr: '\\u2117',\n\tCounterClockwiseContourIntegral: '\\u2233',\n\tcrarr: '\\u21B5',\n\tCross: '\\u2A2F',\n\tcross: '\\u2717',\n\tCscr: '\\uD835\\uDC9E',\n\tcscr: '\\uD835\\uDCB8',\n\tcsub: '\\u2ACF',\n\tcsube: '\\u2AD1',\n\tcsup: '\\u2AD0',\n\tcsupe: '\\u2AD2',\n\tctdot: '\\u22EF',\n\tcudarrl: '\\u2938',\n\tcudarrr: '\\u2935',\n\tcuepr: '\\u22DE',\n\tcuesc: '\\u22DF',\n\tcularr: '\\u21B6',\n\tcularrp: '\\u293D',\n\tCup: '\\u22D3',\n\tcup: '\\u222A',\n\tcupbrcap: '\\u2A48',\n\tCupCap: '\\u224D',\n\tcupcap: '\\u2A46',\n\tcupcup: '\\u2A4A',\n\tcupdot: '\\u228D',\n\tcupor: '\\u2A45',\n\tcups: '\\u222A\\uFE00',\n\tcurarr: '\\u21B7',\n\tcurarrm: '\\u293C',\n\tcurlyeqprec: '\\u22DE',\n\tcurlyeqsucc: '\\u22DF',\n\tcurlyvee: '\\u22CE',\n\tcurlywedge: '\\u22CF',\n\tcurren: '\\u00A4',\n\tcurvearrowleft: '\\u21B6',\n\tcurvearrowright: '\\u21B7',\n\tcuvee: '\\u22CE',\n\tcuwed: '\\u22CF',\n\tcwconint: '\\u2232',\n\tcwint: '\\u2231',\n\tcylcty: '\\u232D',\n\tDagger: '\\u2021',\n\tdagger: '\\u2020',\n\tdaleth: '\\u2138',\n\tDarr: '\\u21A1',\n\tdArr: '\\u21D3',\n\tdarr: '\\u2193',\n\tdash: '\\u2010',\n\tDashv: '\\u2AE4',\n\tdashv: '\\u22A3',\n\tdbkarow: '\\u290F',\n\tdblac: '\\u02DD',\n\tDcaron: '\\u010E',\n\tdcaron: '\\u010F',\n\tDcy: '\\u0414',\n\tdcy: '\\u0434',\n\tDD: '\\u2145',\n\tdd: '\\u2146',\n\tddagger: '\\u2021',\n\tddarr: '\\u21CA',\n\tDDotrahd: '\\u2911',\n\tddotseq: '\\u2A77',\n\tdeg: '\\u00B0',\n\tDel: '\\u2207',\n\tDelta: '\\u0394',\n\tdelta: '\\u03B4',\n\tdemptyv: '\\u29B1',\n\tdfisht: '\\u297F',\n\tDfr: '\\uD835\\uDD07',\n\tdfr: '\\uD835\\uDD21',\n\tdHar: '\\u2965',\n\tdharl: '\\u21C3',\n\tdharr: '\\u21C2',\n\tDiacriticalAcute: '\\u00B4',\n\tDiacriticalDot: '\\u02D9',\n\tDiacriticalDoubleAcute: '\\u02DD',\n\tDiacriticalGrave: '\\u0060',\n\tDiacriticalTilde: '\\u02DC',\n\tdiam: '\\u22C4',\n\tDiamond: '\\u22C4',\n\tdiamond: '\\u22C4',\n\tdiamondsuit: '\\u2666',\n\tdiams: '\\u2666',\n\tdie: '\\u00A8',\n\tDifferentialD: '\\u2146',\n\tdigamma: '\\u03DD',\n\tdisin: '\\u22F2',\n\tdiv: '\\u00F7',\n\tdivide: '\\u00F7',\n\tdivideontimes: '\\u22C7',\n\tdivonx: '\\u22C7',\n\tDJcy: '\\u0402',\n\tdjcy: '\\u0452',\n\tdlcorn: '\\u231E',\n\tdlcrop: '\\u230D',\n\tdollar: '\\u0024',\n\tDopf: '\\uD835\\uDD3B',\n\tdopf: '\\uD835\\uDD55',\n\tDot: '\\u00A8',\n\tdot: '\\u02D9',\n\tDotDot: '\\u20DC',\n\tdoteq: '\\u2250',\n\tdoteqdot: '\\u2251',\n\tDotEqual: '\\u2250',\n\tdotminus: '\\u2238',\n\tdotplus: '\\u2214',\n\tdotsquare: '\\u22A1',\n\tdoublebarwedge: '\\u2306',\n\tDoubleContourIntegral: '\\u222F',\n\tDoubleDot: '\\u00A8',\n\tDoubleDownArrow: '\\u21D3',\n\tDoubleLeftArrow: '\\u21D0',\n\tDoubleLeftRightArrow: '\\u21D4',\n\tDoubleLeftTee: '\\u2AE4',\n\tDoubleLongLeftArrow: '\\u27F8',\n\tDoubleLongLeftRightArrow: '\\u27FA',\n\tDoubleLongRightArrow: '\\u27F9',\n\tDoubleRightArrow: '\\u21D2',\n\tDoubleRightTee: '\\u22A8',\n\tDoubleUpArrow: '\\u21D1',\n\tDoubleUpDownArrow: '\\u21D5',\n\tDoubleVerticalBar: '\\u2225',\n\tDownArrow: '\\u2193',\n\tDownarrow: '\\u21D3',\n\tdownarrow: '\\u2193',\n\tDownArrowBar: '\\u2913',\n\tDownArrowUpArrow: '\\u21F5',\n\tDownBreve: '\\u0311',\n\tdowndownarrows: '\\u21CA',\n\tdownharpoonleft: '\\u21C3',\n\tdownharpoonright: '\\u21C2',\n\tDownLeftRightVector: '\\u2950',\n\tDownLeftTeeVector: '\\u295E',\n\tDownLeftVector: '\\u21BD',\n\tDownLeftVectorBar: '\\u2956',\n\tDownRightTeeVector: '\\u295F',\n\tDownRightVector: '\\u21C1',\n\tDownRightVectorBar: '\\u2957',\n\tDownTee: '\\u22A4',\n\tDownTeeArrow: '\\u21A7',\n\tdrbkarow: '\\u2910',\n\tdrcorn: '\\u231F',\n\tdrcrop: '\\u230C',\n\tDscr: '\\uD835\\uDC9F',\n\tdscr: '\\uD835\\uDCB9',\n\tDScy: '\\u0405',\n\tdscy: '\\u0455',\n\tdsol: '\\u29F6',\n\tDstrok: '\\u0110',\n\tdstrok: '\\u0111',\n\tdtdot: '\\u22F1',\n\tdtri: '\\u25BF',\n\tdtrif: '\\u25BE',\n\tduarr: '\\u21F5',\n\tduhar: '\\u296F',\n\tdwangle: '\\u29A6',\n\tDZcy: '\\u040F',\n\tdzcy: '\\u045F',\n\tdzigrarr: '\\u27FF',\n\tEacute: '\\u00C9',\n\teacute: '\\u00E9',\n\teaster: '\\u2A6E',\n\tEcaron: '\\u011A',\n\tecaron: '\\u011B',\n\tecir: '\\u2256',\n\tEcirc: '\\u00CA',\n\tecirc: '\\u00EA',\n\tecolon: '\\u2255',\n\tEcy: '\\u042D',\n\tecy: '\\u044D',\n\teDDot: '\\u2A77',\n\tEdot: '\\u0116',\n\teDot: '\\u2251',\n\tedot: '\\u0117',\n\tee: '\\u2147',\n\tefDot: '\\u2252',\n\tEfr: '\\uD835\\uDD08',\n\tefr: '\\uD835\\uDD22',\n\teg: '\\u2A9A',\n\tEgrave: '\\u00C8',\n\tegrave: '\\u00E8',\n\tegs: '\\u2A96',\n\tegsdot: '\\u2A98',\n\tel: '\\u2A99',\n\tElement: '\\u2208',\n\telinters: '\\u23E7',\n\tell: '\\u2113',\n\tels: '\\u2A95',\n\telsdot: '\\u2A97',\n\tEmacr: '\\u0112',\n\temacr: '\\u0113',\n\tempty: '\\u2205',\n\temptyset: '\\u2205',\n\tEmptySmallSquare: '\\u25FB',\n\temptyv: '\\u2205',\n\tEmptyVerySmallSquare: '\\u25AB',\n\temsp: '\\u2003',\n\temsp13: '\\u2004',\n\temsp14: '\\u2005',\n\tENG: '\\u014A',\n\teng: '\\u014B',\n\tensp: '\\u2002',\n\tEogon: '\\u0118',\n\teogon: '\\u0119',\n\tEopf: '\\uD835\\uDD3C',\n\teopf: '\\uD835\\uDD56',\n\tepar: '\\u22D5',\n\teparsl: '\\u29E3',\n\teplus: '\\u2A71',\n\tepsi: '\\u03B5',\n\tEpsilon: '\\u0395',\n\tepsilon: '\\u03B5',\n\tepsiv: '\\u03F5',\n\teqcirc: '\\u2256',\n\teqcolon: '\\u2255',\n\teqsim: '\\u2242',\n\teqslantgtr: '\\u2A96',\n\teqslantless: '\\u2A95',\n\tEqual: '\\u2A75',\n\tequals: '\\u003D',\n\tEqualTilde: '\\u2242',\n\tequest: '\\u225F',\n\tEquilibrium: '\\u21CC',\n\tequiv: '\\u2261',\n\tequivDD: '\\u2A78',\n\teqvparsl: '\\u29E5',\n\terarr: '\\u2971',\n\terDot: '\\u2253',\n\tEscr: '\\u2130',\n\tescr: '\\u212F',\n\tesdot: '\\u2250',\n\tEsim: '\\u2A73',\n\tesim: '\\u2242',\n\tEta: '\\u0397',\n\teta: '\\u03B7',\n\tETH: '\\u00D0',\n\teth: '\\u00F0',\n\tEuml: '\\u00CB',\n\teuml: '\\u00EB',\n\teuro: '\\u20AC',\n\texcl: '\\u0021',\n\texist: '\\u2203',\n\tExists: '\\u2203',\n\texpectation: '\\u2130',\n\tExponentialE: '\\u2147',\n\texponentiale: '\\u2147',\n\tfallingdotseq: '\\u2252',\n\tFcy: '\\u0424',\n\tfcy: '\\u0444',\n\tfemale: '\\u2640',\n\tffilig: '\\uFB03',\n\tfflig: '\\uFB00',\n\tffllig: '\\uFB04',\n\tFfr: '\\uD835\\uDD09',\n\tffr: '\\uD835\\uDD23',\n\tfilig: '\\uFB01',\n\tFilledSmallSquare: '\\u25FC',\n\tFilledVerySmallSquare: '\\u25AA',\n\tfjlig: '\\u0066\\u006A',\n\tflat: '\\u266D',\n\tfllig: '\\uFB02',\n\tfltns: '\\u25B1',\n\tfnof: '\\u0192',\n\tFopf: '\\uD835\\uDD3D',\n\tfopf: '\\uD835\\uDD57',\n\tForAll: '\\u2200',\n\tforall: '\\u2200',\n\tfork: '\\u22D4',\n\tforkv: '\\u2AD9',\n\tFouriertrf: '\\u2131',\n\tfpartint: '\\u2A0D',\n\tfrac12: '\\u00BD',\n\tfrac13: '\\u2153',\n\tfrac14: '\\u00BC',\n\tfrac15: '\\u2155',\n\tfrac16: '\\u2159',\n\tfrac18: '\\u215B',\n\tfrac23: '\\u2154',\n\tfrac25: '\\u2156',\n\tfrac34: '\\u00BE',\n\tfrac35: '\\u2157',\n\tfrac38: '\\u215C',\n\tfrac45: '\\u2158',\n\tfrac56: '\\u215A',\n\tfrac58: '\\u215D',\n\tfrac78: '\\u215E',\n\tfrasl: '\\u2044',\n\tfrown: '\\u2322',\n\tFscr: '\\u2131',\n\tfscr: '\\uD835\\uDCBB',\n\tgacute: '\\u01F5',\n\tGamma: '\\u0393',\n\tgamma: '\\u03B3',\n\tGammad: '\\u03DC',\n\tgammad: '\\u03DD',\n\tgap: '\\u2A86',\n\tGbreve: '\\u011E',\n\tgbreve: '\\u011F',\n\tGcedil: '\\u0122',\n\tGcirc: '\\u011C',\n\tgcirc: '\\u011D',\n\tGcy: '\\u0413',\n\tgcy: '\\u0433',\n\tGdot: '\\u0120',\n\tgdot: '\\u0121',\n\tgE: '\\u2267',\n\tge: '\\u2265',\n\tgEl: '\\u2A8C',\n\tgel: '\\u22DB',\n\tgeq: '\\u2265',\n\tgeqq: '\\u2267',\n\tgeqslant: '\\u2A7E',\n\tges: '\\u2A7E',\n\tgescc: '\\u2AA9',\n\tgesdot: '\\u2A80',\n\tgesdoto: '\\u2A82',\n\tgesdotol: '\\u2A84',\n\tgesl: '\\u22DB\\uFE00',\n\tgesles: '\\u2A94',\n\tGfr: '\\uD835\\uDD0A',\n\tgfr: '\\uD835\\uDD24',\n\tGg: '\\u22D9',\n\tgg: '\\u226B',\n\tggg: '\\u22D9',\n\tgimel: '\\u2137',\n\tGJcy: '\\u0403',\n\tgjcy: '\\u0453',\n\tgl: '\\u2277',\n\tgla: '\\u2AA5',\n\tglE: '\\u2A92',\n\tglj: '\\u2AA4',\n\tgnap: '\\u2A8A',\n\tgnapprox: '\\u2A8A',\n\tgnE: '\\u2269',\n\tgne: '\\u2A88',\n\tgneq: '\\u2A88',\n\tgneqq: '\\u2269',\n\tgnsim: '\\u22E7',\n\tGopf: '\\uD835\\uDD3E',\n\tgopf: '\\uD835\\uDD58',\n\tgrave: '\\u0060',\n\tGreaterEqual: '\\u2265',\n\tGreaterEqualLess: '\\u22DB',\n\tGreaterFullEqual: '\\u2267',\n\tGreaterGreater: '\\u2AA2',\n\tGreaterLess: '\\u2277',\n\tGreaterSlantEqual: '\\u2A7E',\n\tGreaterTilde: '\\u2273',\n\tGscr: '\\uD835\\uDCA2',\n\tgscr: '\\u210A',\n\tgsim: '\\u2273',\n\tgsime: '\\u2A8E',\n\tgsiml: '\\u2A90',\n\tGt: '\\u226B',\n\tGT: '\\u003E',\n\tgt: '\\u003E',\n\tgtcc: '\\u2AA7',\n\tgtcir: '\\u2A7A',\n\tgtdot: '\\u22D7',\n\tgtlPar: '\\u2995',\n\tgtquest: '\\u2A7C',\n\tgtrapprox: '\\u2A86',\n\tgtrarr: '\\u2978',\n\tgtrdot: '\\u22D7',\n\tgtreqless: '\\u22DB',\n\tgtreqqless: '\\u2A8C',\n\tgtrless: '\\u2277',\n\tgtrsim: '\\u2273',\n\tgvertneqq: '\\u2269\\uFE00',\n\tgvnE: '\\u2269\\uFE00',\n\tHacek: '\\u02C7',\n\thairsp: '\\u200A',\n\thalf: '\\u00BD',\n\thamilt: '\\u210B',\n\tHARDcy: '\\u042A',\n\thardcy: '\\u044A',\n\thArr: '\\u21D4',\n\tharr: '\\u2194',\n\tharrcir: '\\u2948',\n\tharrw: '\\u21AD',\n\tHat: '\\u005E',\n\thbar: '\\u210F',\n\tHcirc: '\\u0124',\n\thcirc: '\\u0125',\n\thearts: '\\u2665',\n\theartsuit: '\\u2665',\n\thellip: '\\u2026',\n\thercon: '\\u22B9',\n\tHfr: '\\u210C',\n\thfr: '\\uD835\\uDD25',\n\tHilbertSpace: '\\u210B',\n\thksearow: '\\u2925',\n\thkswarow: '\\u2926',\n\thoarr: '\\u21FF',\n\thomtht: '\\u223B',\n\thookleftarrow: '\\u21A9',\n\thookrightarrow: '\\u21AA',\n\tHopf: '\\u210D',\n\thopf: '\\uD835\\uDD59',\n\thorbar: '\\u2015',\n\tHorizontalLine: '\\u2500',\n\tHscr: '\\u210B',\n\thscr: '\\uD835\\uDCBD',\n\thslash: '\\u210F',\n\tHstrok: '\\u0126',\n\thstrok: '\\u0127',\n\tHumpDownHump: '\\u224E',\n\tHumpEqual: '\\u224F',\n\thybull: '\\u2043',\n\thyphen: '\\u2010',\n\tIacute: '\\u00CD',\n\tiacute: '\\u00ED',\n\tic: '\\u2063',\n\tIcirc: '\\u00CE',\n\ticirc: '\\u00EE',\n\tIcy: '\\u0418',\n\ticy: '\\u0438',\n\tIdot: '\\u0130',\n\tIEcy: '\\u0415',\n\tiecy: '\\u0435',\n\tiexcl: '\\u00A1',\n\tiff: '\\u21D4',\n\tIfr: '\\u2111',\n\tifr: '\\uD835\\uDD26',\n\tIgrave: '\\u00CC',\n\tigrave: '\\u00EC',\n\tii: '\\u2148',\n\tiiiint: '\\u2A0C',\n\tiiint: '\\u222D',\n\tiinfin: '\\u29DC',\n\tiiota: '\\u2129',\n\tIJlig: '\\u0132',\n\tijlig: '\\u0133',\n\tIm: '\\u2111',\n\tImacr: '\\u012A',\n\timacr: '\\u012B',\n\timage: '\\u2111',\n\tImaginaryI: '\\u2148',\n\timagline: '\\u2110',\n\timagpart: '\\u2111',\n\timath: '\\u0131',\n\timof: '\\u22B7',\n\timped: '\\u01B5',\n\tImplies: '\\u21D2',\n\tin: '\\u2208',\n\tincare: '\\u2105',\n\tinfin: '\\u221E',\n\tinfintie: '\\u29DD',\n\tinodot: '\\u0131',\n\tInt: '\\u222C',\n\tint: '\\u222B',\n\tintcal: '\\u22BA',\n\tintegers: '\\u2124',\n\tIntegral: '\\u222B',\n\tintercal: '\\u22BA',\n\tIntersection: '\\u22C2',\n\tintlarhk: '\\u2A17',\n\tintprod: '\\u2A3C',\n\tInvisibleComma: '\\u2063',\n\tInvisibleTimes: '\\u2062',\n\tIOcy: '\\u0401',\n\tiocy: '\\u0451',\n\tIogon: '\\u012E',\n\tiogon: '\\u012F',\n\tIopf: '\\uD835\\uDD40',\n\tiopf: '\\uD835\\uDD5A',\n\tIota: '\\u0399',\n\tiota: '\\u03B9',\n\tiprod: '\\u2A3C',\n\tiquest: '\\u00BF',\n\tIscr: '\\u2110',\n\tiscr: '\\uD835\\uDCBE',\n\tisin: '\\u2208',\n\tisindot: '\\u22F5',\n\tisinE: '\\u22F9',\n\tisins: '\\u22F4',\n\tisinsv: '\\u22F3',\n\tisinv: '\\u2208',\n\tit: '\\u2062',\n\tItilde: '\\u0128',\n\titilde: '\\u0129',\n\tIukcy: '\\u0406',\n\tiukcy: '\\u0456',\n\tIuml: '\\u00CF',\n\tiuml: '\\u00EF',\n\tJcirc: '\\u0134',\n\tjcirc: '\\u0135',\n\tJcy: '\\u0419',\n\tjcy: '\\u0439',\n\tJfr: '\\uD835\\uDD0D',\n\tjfr: '\\uD835\\uDD27',\n\tjmath: '\\u0237',\n\tJopf: '\\uD835\\uDD41',\n\tjopf: '\\uD835\\uDD5B',\n\tJscr: '\\uD835\\uDCA5',\n\tjscr: '\\uD835\\uDCBF',\n\tJsercy: '\\u0408',\n\tjsercy: '\\u0458',\n\tJukcy: '\\u0404',\n\tjukcy: '\\u0454',\n\tKappa: '\\u039A',\n\tkappa: '\\u03BA',\n\tkappav: '\\u03F0',\n\tKcedil: '\\u0136',\n\tkcedil: '\\u0137',\n\tKcy: '\\u041A',\n\tkcy: '\\u043A',\n\tKfr: '\\uD835\\uDD0E',\n\tkfr: '\\uD835\\uDD28',\n\tkgreen: '\\u0138',\n\tKHcy: '\\u0425',\n\tkhcy: '\\u0445',\n\tKJcy: '\\u040C',\n\tkjcy: '\\u045C',\n\tKopf: '\\uD835\\uDD42',\n\tkopf: '\\uD835\\uDD5C',\n\tKscr: '\\uD835\\uDCA6',\n\tkscr: '\\uD835\\uDCC0',\n\tlAarr: '\\u21DA',\n\tLacute: '\\u0139',\n\tlacute: '\\u013A',\n\tlaemptyv: '\\u29B4',\n\tlagran: '\\u2112',\n\tLambda: '\\u039B',\n\tlambda: '\\u03BB',\n\tLang: '\\u27EA',\n\tlang: '\\u27E8',\n\tlangd: '\\u2991',\n\tlangle: '\\u27E8',\n\tlap: '\\u2A85',\n\tLaplacetrf: '\\u2112',\n\tlaquo: '\\u00AB',\n\tLarr: '\\u219E',\n\tlArr: '\\u21D0',\n\tlarr: '\\u2190',\n\tlarrb: '\\u21E4',\n\tlarrbfs: '\\u291F',\n\tlarrfs: '\\u291D',\n\tlarrhk: '\\u21A9',\n\tlarrlp: '\\u21AB',\n\tlarrpl: '\\u2939',\n\tlarrsim: '\\u2973',\n\tlarrtl: '\\u21A2',\n\tlat: '\\u2AAB',\n\tlAtail: '\\u291B',\n\tlatail: '\\u2919',\n\tlate: '\\u2AAD',\n\tlates: '\\u2AAD\\uFE00',\n\tlBarr: '\\u290E',\n\tlbarr: '\\u290C',\n\tlbbrk: '\\u2772',\n\tlbrace: '\\u007B',\n\tlbrack: '\\u005B',\n\tlbrke: '\\u298B',\n\tlbrksld: '\\u298F',\n\tlbrkslu: '\\u298D',\n\tLcaron: '\\u013D',\n\tlcaron: '\\u013E',\n\tLcedil: '\\u013B',\n\tlcedil: '\\u013C',\n\tlceil: '\\u2308',\n\tlcub: '\\u007B',\n\tLcy: '\\u041B',\n\tlcy: '\\u043B',\n\tldca: '\\u2936',\n\tldquo: '\\u201C',\n\tldquor: '\\u201E',\n\tldrdhar: '\\u2967',\n\tldrushar: '\\u294B',\n\tldsh: '\\u21B2',\n\tlE: '\\u2266',\n\tle: '\\u2264',\n\tLeftAngleBracket: '\\u27E8',\n\tLeftArrow: '\\u2190',\n\tLeftarrow: '\\u21D0',\n\tleftarrow: '\\u2190',\n\tLeftArrowBar: '\\u21E4',\n\tLeftArrowRightArrow: '\\u21C6',\n\tleftarrowtail: '\\u21A2',\n\tLeftCeiling: '\\u2308',\n\tLeftDoubleBracket: '\\u27E6',\n\tLeftDownTeeVector: '\\u2961',\n\tLeftDownVector: '\\u21C3',\n\tLeftDownVectorBar: '\\u2959',\n\tLeftFloor: '\\u230A',\n\tleftharpoondown: '\\u21BD',\n\tleftharpoonup: '\\u21BC',\n\tleftleftarrows: '\\u21C7',\n\tLeftRightArrow: '\\u2194',\n\tLeftrightarrow: '\\u21D4',\n\tleftrightarrow: '\\u2194',\n\tleftrightarrows: '\\u21C6',\n\tleftrightharpoons: '\\u21CB',\n\tleftrightsquigarrow: '\\u21AD',\n\tLeftRightVector: '\\u294E',\n\tLeftTee: '\\u22A3',\n\tLeftTeeArrow: '\\u21A4',\n\tLeftTeeVector: '\\u295A',\n\tleftthreetimes: '\\u22CB',\n\tLeftTriangle: '\\u22B2',\n\tLeftTriangleBar: '\\u29CF',\n\tLeftTriangleEqual: '\\u22B4',\n\tLeftUpDownVector: '\\u2951',\n\tLeftUpTeeVector: '\\u2960',\n\tLeftUpVector: '\\u21BF',\n\tLeftUpVectorBar: '\\u2958',\n\tLeftVector: '\\u21BC',\n\tLeftVectorBar: '\\u2952',\n\tlEg: '\\u2A8B',\n\tleg: '\\u22DA',\n\tleq: '\\u2264',\n\tleqq: '\\u2266',\n\tleqslant: '\\u2A7D',\n\tles: '\\u2A7D',\n\tlescc: '\\u2AA8',\n\tlesdot: '\\u2A7F',\n\tlesdoto: '\\u2A81',\n\tlesdotor: '\\u2A83',\n\tlesg: '\\u22DA\\uFE00',\n\tlesges: '\\u2A93',\n\tlessapprox: '\\u2A85',\n\tlessdot: '\\u22D6',\n\tlesseqgtr: '\\u22DA',\n\tlesseqqgtr: '\\u2A8B',\n\tLessEqualGreater: '\\u22DA',\n\tLessFullEqual: '\\u2266',\n\tLessGreater: '\\u2276',\n\tlessgtr: '\\u2276',\n\tLessLess: '\\u2AA1',\n\tlesssim: '\\u2272',\n\tLessSlantEqual: '\\u2A7D',\n\tLessTilde: '\\u2272',\n\tlfisht: '\\u297C',\n\tlfloor: '\\u230A',\n\tLfr: '\\uD835\\uDD0F',\n\tlfr: '\\uD835\\uDD29',\n\tlg: '\\u2276',\n\tlgE: '\\u2A91',\n\tlHar: '\\u2962',\n\tlhard: '\\u21BD',\n\tlharu: '\\u21BC',\n\tlharul: '\\u296A',\n\tlhblk: '\\u2584',\n\tLJcy: '\\u0409',\n\tljcy: '\\u0459',\n\tLl: '\\u22D8',\n\tll: '\\u226A',\n\tllarr: '\\u21C7',\n\tllcorner: '\\u231E',\n\tLleftarrow: '\\u21DA',\n\tllhard: '\\u296B',\n\tlltri: '\\u25FA',\n\tLmidot: '\\u013F',\n\tlmidot: '\\u0140',\n\tlmoust: '\\u23B0',\n\tlmoustache: '\\u23B0',\n\tlnap: '\\u2A89',\n\tlnapprox: '\\u2A89',\n\tlnE: '\\u2268',\n\tlne: '\\u2A87',\n\tlneq: '\\u2A87',\n\tlneqq: '\\u2268',\n\tlnsim: '\\u22E6',\n\tloang: '\\u27EC',\n\tloarr: '\\u21FD',\n\tlobrk: '\\u27E6',\n\tLongLeftArrow: '\\u27F5',\n\tLongleftarrow: '\\u27F8',\n\tlongleftarrow: '\\u27F5',\n\tLongLeftRightArrow: '\\u27F7',\n\tLongleftrightarrow: '\\u27FA',\n\tlongleftrightarrow: '\\u27F7',\n\tlongmapsto: '\\u27FC',\n\tLongRightArrow: '\\u27F6',\n\tLongrightarrow: '\\u27F9',\n\tlongrightarrow: '\\u27F6',\n\tlooparrowleft: '\\u21AB',\n\tlooparrowright: '\\u21AC',\n\tlopar: '\\u2985',\n\tLopf: '\\uD835\\uDD43',\n\tlopf: '\\uD835\\uDD5D',\n\tloplus: '\\u2A2D',\n\tlotimes: '\\u2A34',\n\tlowast: '\\u2217',\n\tlowbar: '\\u005F',\n\tLowerLeftArrow: '\\u2199',\n\tLowerRightArrow: '\\u2198',\n\tloz: '\\u25CA',\n\tlozenge: '\\u25CA',\n\tlozf: '\\u29EB',\n\tlpar: '\\u0028',\n\tlparlt: '\\u2993',\n\tlrarr: '\\u21C6',\n\tlrcorner: '\\u231F',\n\tlrhar: '\\u21CB',\n\tlrhard: '\\u296D',\n\tlrm: '\\u200E',\n\tlrtri: '\\u22BF',\n\tlsaquo: '\\u2039',\n\tLscr: '\\u2112',\n\tlscr: '\\uD835\\uDCC1',\n\tLsh: '\\u21B0',\n\tlsh: '\\u21B0',\n\tlsim: '\\u2272',\n\tlsime: '\\u2A8D',\n\tlsimg: '\\u2A8F',\n\tlsqb: '\\u005B',\n\tlsquo: '\\u2018',\n\tlsquor: '\\u201A',\n\tLstrok: '\\u0141',\n\tlstrok: '\\u0142',\n\tLt: '\\u226A',\n\tLT: '\\u003C',\n\tlt: '\\u003C',\n\tltcc: '\\u2AA6',\n\tltcir: '\\u2A79',\n\tltdot: '\\u22D6',\n\tlthree: '\\u22CB',\n\tltimes: '\\u22C9',\n\tltlarr: '\\u2976',\n\tltquest: '\\u2A7B',\n\tltri: '\\u25C3',\n\tltrie: '\\u22B4',\n\tltrif: '\\u25C2',\n\tltrPar: '\\u2996',\n\tlurdshar: '\\u294A',\n\tluruhar: '\\u2966',\n\tlvertneqq: '\\u2268\\uFE00',\n\tlvnE: '\\u2268\\uFE00',\n\tmacr: '\\u00AF',\n\tmale: '\\u2642',\n\tmalt: '\\u2720',\n\tmaltese: '\\u2720',\n\tMap: '\\u2905',\n\tmap: '\\u21A6',\n\tmapsto: '\\u21A6',\n\tmapstodown: '\\u21A7',\n\tmapstoleft: '\\u21A4',\n\tmapstoup: '\\u21A5',\n\tmarker: '\\u25AE',\n\tmcomma: '\\u2A29',\n\tMcy: '\\u041C',\n\tmcy: '\\u043C',\n\tmdash: '\\u2014',\n\tmDDot: '\\u223A',\n\tmeasuredangle: '\\u2221',\n\tMediumSpace: '\\u205F',\n\tMellintrf: '\\u2133',\n\tMfr: '\\uD835\\uDD10',\n\tmfr: '\\uD835\\uDD2A',\n\tmho: '\\u2127',\n\tmicro: '\\u00B5',\n\tmid: '\\u2223',\n\tmidast: '\\u002A',\n\tmidcir: '\\u2AF0',\n\tmiddot: '\\u00B7',\n\tminus: '\\u2212',\n\tminusb: '\\u229F',\n\tminusd: '\\u2238',\n\tminusdu: '\\u2A2A',\n\tMinusPlus: '\\u2213',\n\tmlcp: '\\u2ADB',\n\tmldr: '\\u2026',\n\tmnplus: '\\u2213',\n\tmodels: '\\u22A7',\n\tMopf: '\\uD835\\uDD44',\n\tmopf: '\\uD835\\uDD5E',\n\tmp: '\\u2213',\n\tMscr: '\\u2133',\n\tmscr: '\\uD835\\uDCC2',\n\tmstpos: '\\u223E',\n\tMu: '\\u039C',\n\tmu: '\\u03BC',\n\tmultimap: '\\u22B8',\n\tmumap: '\\u22B8',\n\tnabla: '\\u2207',\n\tNacute: '\\u0143',\n\tnacute: '\\u0144',\n\tnang: '\\u2220\\u20D2',\n\tnap: '\\u2249',\n\tnapE: '\\u2A70\\u0338',\n\tnapid: '\\u224B\\u0338',\n\tnapos: '\\u0149',\n\tnapprox: '\\u2249',\n\tnatur: '\\u266E',\n\tnatural: '\\u266E',\n\tnaturals: '\\u2115',\n\tnbsp: '\\u00A0',\n\tnbump: '\\u224E\\u0338',\n\tnbumpe: '\\u224F\\u0338',\n\tncap: '\\u2A43',\n\tNcaron: '\\u0147',\n\tncaron: '\\u0148',\n\tNcedil: '\\u0145',\n\tncedil: '\\u0146',\n\tncong: '\\u2247',\n\tncongdot: '\\u2A6D\\u0338',\n\tncup: '\\u2A42',\n\tNcy: '\\u041D',\n\tncy: '\\u043D',\n\tndash: '\\u2013',\n\tne: '\\u2260',\n\tnearhk: '\\u2924',\n\tneArr: '\\u21D7',\n\tnearr: '\\u2197',\n\tnearrow: '\\u2197',\n\tnedot: '\\u2250\\u0338',\n\tNegativeMediumSpace: '\\u200B',\n\tNegativeThickSpace: '\\u200B',\n\tNegativeThinSpace: '\\u200B',\n\tNegativeVeryThinSpace: '\\u200B',\n\tnequiv: '\\u2262',\n\tnesear: '\\u2928',\n\tnesim: '\\u2242\\u0338',\n\tNestedGreaterGreater: '\\u226B',\n\tNestedLessLess: '\\u226A',\n\tNewLine: '\\u000A',\n\tnexist: '\\u2204',\n\tnexists: '\\u2204',\n\tNfr: '\\uD835\\uDD11',\n\tnfr: '\\uD835\\uDD2B',\n\tngE: '\\u2267\\u0338',\n\tnge: '\\u2271',\n\tngeq: '\\u2271',\n\tngeqq: '\\u2267\\u0338',\n\tngeqslant: '\\u2A7E\\u0338',\n\tnges: '\\u2A7E\\u0338',\n\tnGg: '\\u22D9\\u0338',\n\tngsim: '\\u2275',\n\tnGt: '\\u226B\\u20D2',\n\tngt: '\\u226F',\n\tngtr: '\\u226F',\n\tnGtv: '\\u226B\\u0338',\n\tnhArr: '\\u21CE',\n\tnharr: '\\u21AE',\n\tnhpar: '\\u2AF2',\n\tni: '\\u220B',\n\tnis: '\\u22FC',\n\tnisd: '\\u22FA',\n\tniv: '\\u220B',\n\tNJcy: '\\u040A',\n\tnjcy: '\\u045A',\n\tnlArr: '\\u21CD',\n\tnlarr: '\\u219A',\n\tnldr: '\\u2025',\n\tnlE: '\\u2266\\u0338',\n\tnle: '\\u2270',\n\tnLeftarrow: '\\u21CD',\n\tnleftarrow: '\\u219A',\n\tnLeftrightarrow: '\\u21CE',\n\tnleftrightarrow: '\\u21AE',\n\tnleq: '\\u2270',\n\tnleqq: '\\u2266\\u0338',\n\tnleqslant: '\\u2A7D\\u0338',\n\tnles: '\\u2A7D\\u0338',\n\tnless: '\\u226E',\n\tnLl: '\\u22D8\\u0338',\n\tnlsim: '\\u2274',\n\tnLt: '\\u226A\\u20D2',\n\tnlt: '\\u226E',\n\tnltri: '\\u22EA',\n\tnltrie: '\\u22EC',\n\tnLtv: '\\u226A\\u0338',\n\tnmid: '\\u2224',\n\tNoBreak: '\\u2060',\n\tNonBreakingSpace: '\\u00A0',\n\tNopf: '\\u2115',\n\tnopf: '\\uD835\\uDD5F',\n\tNot: '\\u2AEC',\n\tnot: '\\u00AC',\n\tNotCongruent: '\\u2262',\n\tNotCupCap: '\\u226D',\n\tNotDoubleVerticalBar: '\\u2226',\n\tNotElement: '\\u2209',\n\tNotEqual: '\\u2260',\n\tNotEqualTilde: '\\u2242\\u0338',\n\tNotExists: '\\u2204',\n\tNotGreater: '\\u226F',\n\tNotGreaterEqual: '\\u2271',\n\tNotGreaterFullEqual: '\\u2267\\u0338',\n\tNotGreaterGreater: '\\u226B\\u0338',\n\tNotGreaterLess: '\\u2279',\n\tNotGreaterSlantEqual: '\\u2A7E\\u0338',\n\tNotGreaterTilde: '\\u2275',\n\tNotHumpDownHump: '\\u224E\\u0338',\n\tNotHumpEqual: '\\u224F\\u0338',\n\tnotin: '\\u2209',\n\tnotindot: '\\u22F5\\u0338',\n\tnotinE: '\\u22F9\\u0338',\n\tnotinva: '\\u2209',\n\tnotinvb: '\\u22F7',\n\tnotinvc: '\\u22F6',\n\tNotLeftTriangle: '\\u22EA',\n\tNotLeftTriangleBar: '\\u29CF\\u0338',\n\tNotLeftTriangleEqual: '\\u22EC',\n\tNotLess: '\\u226E',\n\tNotLessEqual: '\\u2270',\n\tNotLessGreater: '\\u2278',\n\tNotLessLess: '\\u226A\\u0338',\n\tNotLessSlantEqual: '\\u2A7D\\u0338',\n\tNotLessTilde: '\\u2274',\n\tNotNestedGreaterGreater: '\\u2AA2\\u0338',\n\tNotNestedLessLess: '\\u2AA1\\u0338',\n\tnotni: '\\u220C',\n\tnotniva: '\\u220C',\n\tnotnivb: '\\u22FE',\n\tnotnivc: '\\u22FD',\n\tNotPrecedes: '\\u2280',\n\tNotPrecedesEqual: '\\u2AAF\\u0338',\n\tNotPrecedesSlantEqual: '\\u22E0',\n\tNotReverseElement: '\\u220C',\n\tNotRightTriangle: '\\u22EB',\n\tNotRightTriangleBar: '\\u29D0\\u0338',\n\tNotRightTriangleEqual: '\\u22ED',\n\tNotSquareSubset: '\\u228F\\u0338',\n\tNotSquareSubsetEqual: '\\u22E2',\n\tNotSquareSuperset: '\\u2290\\u0338',\n\tNotSquareSupersetEqual: '\\u22E3',\n\tNotSubset: '\\u2282\\u20D2',\n\tNotSubsetEqual: '\\u2288',\n\tNotSucceeds: '\\u2281',\n\tNotSucceedsEqual: '\\u2AB0\\u0338',\n\tNotSucceedsSlantEqual: '\\u22E1',\n\tNotSucceedsTilde: '\\u227F\\u0338',\n\tNotSuperset: '\\u2283\\u20D2',\n\tNotSupersetEqual: '\\u2289',\n\tNotTilde: '\\u2241',\n\tNotTildeEqual: '\\u2244',\n\tNotTildeFullEqual: '\\u2247',\n\tNotTildeTilde: '\\u2249',\n\tNotVerticalBar: '\\u2224',\n\tnpar: '\\u2226',\n\tnparallel: '\\u2226',\n\tnparsl: '\\u2AFD\\u20E5',\n\tnpart: '\\u2202\\u0338',\n\tnpolint: '\\u2A14',\n\tnpr: '\\u2280',\n\tnprcue: '\\u22E0',\n\tnpre: '\\u2AAF\\u0338',\n\tnprec: '\\u2280',\n\tnpreceq: '\\u2AAF\\u0338',\n\tnrArr: '\\u21CF',\n\tnrarr: '\\u219B',\n\tnrarrc: '\\u2933\\u0338',\n\tnrarrw: '\\u219D\\u0338',\n\tnRightarrow: '\\u21CF',\n\tnrightarrow: '\\u219B',\n\tnrtri: '\\u22EB',\n\tnrtrie: '\\u22ED',\n\tnsc: '\\u2281',\n\tnsccue: '\\u22E1',\n\tnsce: '\\u2AB0\\u0338',\n\tNscr: '\\uD835\\uDCA9',\n\tnscr: '\\uD835\\uDCC3',\n\tnshortmid: '\\u2224',\n\tnshortparallel: '\\u2226',\n\tnsim: '\\u2241',\n\tnsime: '\\u2244',\n\tnsimeq: '\\u2244',\n\tnsmid: '\\u2224',\n\tnspar: '\\u2226',\n\tnsqsube: '\\u22E2',\n\tnsqsupe: '\\u22E3',\n\tnsub: '\\u2284',\n\tnsubE: '\\u2AC5\\u0338',\n\tnsube: '\\u2288',\n\tnsubset: '\\u2282\\u20D2',\n\tnsubseteq: '\\u2288',\n\tnsubseteqq: '\\u2AC5\\u0338',\n\tnsucc: '\\u2281',\n\tnsucceq: '\\u2AB0\\u0338',\n\tnsup: '\\u2285',\n\tnsupE: '\\u2AC6\\u0338',\n\tnsupe: '\\u2289',\n\tnsupset: '\\u2283\\u20D2',\n\tnsupseteq: '\\u2289',\n\tnsupseteqq: '\\u2AC6\\u0338',\n\tntgl: '\\u2279',\n\tNtilde: '\\u00D1',\n\tntilde: '\\u00F1',\n\tntlg: '\\u2278',\n\tntriangleleft: '\\u22EA',\n\tntrianglelefteq: '\\u22EC',\n\tntriangleright: '\\u22EB',\n\tntrianglerighteq: '\\u22ED',\n\tNu: '\\u039D',\n\tnu: '\\u03BD',\n\tnum: '\\u0023',\n\tnumero: '\\u2116',\n\tnumsp: '\\u2007',\n\tnvap: '\\u224D\\u20D2',\n\tnVDash: '\\u22AF',\n\tnVdash: '\\u22AE',\n\tnvDash: '\\u22AD',\n\tnvdash: '\\u22AC',\n\tnvge: '\\u2265\\u20D2',\n\tnvgt: '\\u003E\\u20D2',\n\tnvHarr: '\\u2904',\n\tnvinfin: '\\u29DE',\n\tnvlArr: '\\u2902',\n\tnvle: '\\u2264\\u20D2',\n\tnvlt: '\\u003C\\u20D2',\n\tnvltrie: '\\u22B4\\u20D2',\n\tnvrArr: '\\u2903',\n\tnvrtrie: '\\u22B5\\u20D2',\n\tnvsim: '\\u223C\\u20D2',\n\tnwarhk: '\\u2923',\n\tnwArr: '\\u21D6',\n\tnwarr: '\\u2196',\n\tnwarrow: '\\u2196',\n\tnwnear: '\\u2927',\n\tOacute: '\\u00D3',\n\toacute: '\\u00F3',\n\toast: '\\u229B',\n\tocir: '\\u229A',\n\tOcirc: '\\u00D4',\n\tocirc: '\\u00F4',\n\tOcy: '\\u041E',\n\tocy: '\\u043E',\n\todash: '\\u229D',\n\tOdblac: '\\u0150',\n\todblac: '\\u0151',\n\todiv: '\\u2A38',\n\todot: '\\u2299',\n\todsold: '\\u29BC',\n\tOElig: '\\u0152',\n\toelig: '\\u0153',\n\tofcir: '\\u29BF',\n\tOfr: '\\uD835\\uDD12',\n\tofr: '\\uD835\\uDD2C',\n\togon: '\\u02DB',\n\tOgrave: '\\u00D2',\n\tograve: '\\u00F2',\n\togt: '\\u29C1',\n\tohbar: '\\u29B5',\n\tohm: '\\u03A9',\n\toint: '\\u222E',\n\tolarr: '\\u21BA',\n\tolcir: '\\u29BE',\n\tolcross: '\\u29BB',\n\toline: '\\u203E',\n\tolt: '\\u29C0',\n\tOmacr: '\\u014C',\n\tomacr: '\\u014D',\n\tOmega: '\\u03A9',\n\tomega: '\\u03C9',\n\tOmicron: '\\u039F',\n\tomicron: '\\u03BF',\n\tomid: '\\u29B6',\n\tominus: '\\u2296',\n\tOopf: '\\uD835\\uDD46',\n\toopf: '\\uD835\\uDD60',\n\topar: '\\u29B7',\n\tOpenCurlyDoubleQuote: '\\u201C',\n\tOpenCurlyQuote: '\\u2018',\n\toperp: '\\u29B9',\n\toplus: '\\u2295',\n\tOr: '\\u2A54',\n\tor: '\\u2228',\n\torarr: '\\u21BB',\n\tord: '\\u2A5D',\n\torder: '\\u2134',\n\torderof: '\\u2134',\n\tordf: '\\u00AA',\n\tordm: '\\u00BA',\n\torigof: '\\u22B6',\n\toror: '\\u2A56',\n\torslope: '\\u2A57',\n\torv: '\\u2A5B',\n\toS: '\\u24C8',\n\tOscr: '\\uD835\\uDCAA',\n\toscr: '\\u2134',\n\tOslash: '\\u00D8',\n\toslash: '\\u00F8',\n\tosol: '\\u2298',\n\tOtilde: '\\u00D5',\n\totilde: '\\u00F5',\n\tOtimes: '\\u2A37',\n\totimes: '\\u2297',\n\totimesas: '\\u2A36',\n\tOuml: '\\u00D6',\n\touml: '\\u00F6',\n\tovbar: '\\u233D',\n\tOverBar: '\\u203E',\n\tOverBrace: '\\u23DE',\n\tOverBracket: '\\u23B4',\n\tOverParenthesis: '\\u23DC',\n\tpar: '\\u2225',\n\tpara: '\\u00B6',\n\tparallel: '\\u2225',\n\tparsim: '\\u2AF3',\n\tparsl: '\\u2AFD',\n\tpart: '\\u2202',\n\tPartialD: '\\u2202',\n\tPcy: '\\u041F',\n\tpcy: '\\u043F',\n\tpercnt: '\\u0025',\n\tperiod: '\\u002E',\n\tpermil: '\\u2030',\n\tperp: '\\u22A5',\n\tpertenk: '\\u2031',\n\tPfr: '\\uD835\\uDD13',\n\tpfr: '\\uD835\\uDD2D',\n\tPhi: '\\u03A6',\n\tphi: '\\u03C6',\n\tphiv: '\\u03D5',\n\tphmmat: '\\u2133',\n\tphone: '\\u260E',\n\tPi: '\\u03A0',\n\tpi: '\\u03C0',\n\tpitchfork: '\\u22D4',\n\tpiv: '\\u03D6',\n\tplanck: '\\u210F',\n\tplanckh: '\\u210E',\n\tplankv: '\\u210F',\n\tplus: '\\u002B',\n\tplusacir: '\\u2A23',\n\tplusb: '\\u229E',\n\tpluscir: '\\u2A22',\n\tplusdo: '\\u2214',\n\tplusdu: '\\u2A25',\n\tpluse: '\\u2A72',\n\tPlusMinus: '\\u00B1',\n\tplusmn: '\\u00B1',\n\tplussim: '\\u2A26',\n\tplustwo: '\\u2A27',\n\tpm: '\\u00B1',\n\tPoincareplane: '\\u210C',\n\tpointint: '\\u2A15',\n\tPopf: '\\u2119',\n\tpopf: '\\uD835\\uDD61',\n\tpound: '\\u00A3',\n\tPr: '\\u2ABB',\n\tpr: '\\u227A',\n\tprap: '\\u2AB7',\n\tprcue: '\\u227C',\n\tprE: '\\u2AB3',\n\tpre: '\\u2AAF',\n\tprec: '\\u227A',\n\tprecapprox: '\\u2AB7',\n\tpreccurlyeq: '\\u227C',\n\tPrecedes: '\\u227A',\n\tPrecedesEqual: '\\u2AAF',\n\tPrecedesSlantEqual: '\\u227C',\n\tPrecedesTilde: '\\u227E',\n\tpreceq: '\\u2AAF',\n\tprecnapprox: '\\u2AB9',\n\tprecneqq: '\\u2AB5',\n\tprecnsim: '\\u22E8',\n\tprecsim: '\\u227E',\n\tPrime: '\\u2033',\n\tprime: '\\u2032',\n\tprimes: '\\u2119',\n\tprnap: '\\u2AB9',\n\tprnE: '\\u2AB5',\n\tprnsim: '\\u22E8',\n\tprod: '\\u220F',\n\tProduct: '\\u220F',\n\tprofalar: '\\u232E',\n\tprofline: '\\u2312',\n\tprofsurf: '\\u2313',\n\tprop: '\\u221D',\n\tProportion: '\\u2237',\n\tProportional: '\\u221D',\n\tpropto: '\\u221D',\n\tprsim: '\\u227E',\n\tprurel: '\\u22B0',\n\tPscr: '\\uD835\\uDCAB',\n\tpscr: '\\uD835\\uDCC5',\n\tPsi: '\\u03A8',\n\tpsi: '\\u03C8',\n\tpuncsp: '\\u2008',\n\tQfr: '\\uD835\\uDD14',\n\tqfr: '\\uD835\\uDD2E',\n\tqint: '\\u2A0C',\n\tQopf: '\\u211A',\n\tqopf: '\\uD835\\uDD62',\n\tqprime: '\\u2057',\n\tQscr: '\\uD835\\uDCAC',\n\tqscr: '\\uD835\\uDCC6',\n\tquaternions: '\\u210D',\n\tquatint: '\\u2A16',\n\tquest: '\\u003F',\n\tquesteq: '\\u225F',\n\tQUOT: '\\u0022',\n\tquot: '\\u0022',\n\trAarr: '\\u21DB',\n\trace: '\\u223D\\u0331',\n\tRacute: '\\u0154',\n\tracute: '\\u0155',\n\tradic: '\\u221A',\n\traemptyv: '\\u29B3',\n\tRang: '\\u27EB',\n\trang: '\\u27E9',\n\trangd: '\\u2992',\n\trange: '\\u29A5',\n\trangle: '\\u27E9',\n\traquo: '\\u00BB',\n\tRarr: '\\u21A0',\n\trArr: '\\u21D2',\n\trarr: '\\u2192',\n\trarrap: '\\u2975',\n\trarrb: '\\u21E5',\n\trarrbfs: '\\u2920',\n\trarrc: '\\u2933',\n\trarrfs: '\\u291E',\n\trarrhk: '\\u21AA',\n\trarrlp: '\\u21AC',\n\trarrpl: '\\u2945',\n\trarrsim: '\\u2974',\n\tRarrtl: '\\u2916',\n\trarrtl: '\\u21A3',\n\trarrw: '\\u219D',\n\trAtail: '\\u291C',\n\tratail: '\\u291A',\n\tratio: '\\u2236',\n\trationals: '\\u211A',\n\tRBarr: '\\u2910',\n\trBarr: '\\u290F',\n\trbarr: '\\u290D',\n\trbbrk: '\\u2773',\n\trbrace: '\\u007D',\n\trbrack: '\\u005D',\n\trbrke: '\\u298C',\n\trbrksld: '\\u298E',\n\trbrkslu: '\\u2990',\n\tRcaron: '\\u0158',\n\trcaron: '\\u0159',\n\tRcedil: '\\u0156',\n\trcedil: '\\u0157',\n\trceil: '\\u2309',\n\trcub: '\\u007D',\n\tRcy: '\\u0420',\n\trcy: '\\u0440',\n\trdca: '\\u2937',\n\trdldhar: '\\u2969',\n\trdquo: '\\u201D',\n\trdquor: '\\u201D',\n\trdsh: '\\u21B3',\n\tRe: '\\u211C',\n\treal: '\\u211C',\n\trealine: '\\u211B',\n\trealpart: '\\u211C',\n\treals: '\\u211D',\n\trect: '\\u25AD',\n\tREG: '\\u00AE',\n\treg: '\\u00AE',\n\tReverseElement: '\\u220B',\n\tReverseEquilibrium: '\\u21CB',\n\tReverseUpEquilibrium: '\\u296F',\n\trfisht: '\\u297D',\n\trfloor: '\\u230B',\n\tRfr: '\\u211C',\n\trfr: '\\uD835\\uDD2F',\n\trHar: '\\u2964',\n\trhard: '\\u21C1',\n\trharu: '\\u21C0',\n\trharul: '\\u296C',\n\tRho: '\\u03A1',\n\trho: '\\u03C1',\n\trhov: '\\u03F1',\n\tRightAngleBracket: '\\u27E9',\n\tRightArrow: '\\u2192',\n\tRightarrow: '\\u21D2',\n\trightarrow: '\\u2192',\n\tRightArrowBar: '\\u21E5',\n\tRightArrowLeftArrow: '\\u21C4',\n\trightarrowtail: '\\u21A3',\n\tRightCeiling: '\\u2309',\n\tRightDoubleBracket: '\\u27E7',\n\tRightDownTeeVector: '\\u295D',\n\tRightDownVector: '\\u21C2',\n\tRightDownVectorBar: '\\u2955',\n\tRightFloor: '\\u230B',\n\trightharpoondown: '\\u21C1',\n\trightharpoonup: '\\u21C0',\n\trightleftarrows: '\\u21C4',\n\trightleftharpoons: '\\u21CC',\n\trightrightarrows: '\\u21C9',\n\trightsquigarrow: '\\u219D',\n\tRightTee: '\\u22A2',\n\tRightTeeArrow: '\\u21A6',\n\tRightTeeVector: '\\u295B',\n\trightthreetimes: '\\u22CC',\n\tRightTriangle: '\\u22B3',\n\tRightTriangleBar: '\\u29D0',\n\tRightTriangleEqual: '\\u22B5',\n\tRightUpDownVector: '\\u294F',\n\tRightUpTeeVector: '\\u295C',\n\tRightUpVector: '\\u21BE',\n\tRightUpVectorBar: '\\u2954',\n\tRightVector: '\\u21C0',\n\tRightVectorBar: '\\u2953',\n\tring: '\\u02DA',\n\trisingdotseq: '\\u2253',\n\trlarr: '\\u21C4',\n\trlhar: '\\u21CC',\n\trlm: '\\u200F',\n\trmoust: '\\u23B1',\n\trmoustache: '\\u23B1',\n\trnmid: '\\u2AEE',\n\troang: '\\u27ED',\n\troarr: '\\u21FE',\n\trobrk: '\\u27E7',\n\tropar: '\\u2986',\n\tRopf: '\\u211D',\n\tropf: '\\uD835\\uDD63',\n\troplus: '\\u2A2E',\n\trotimes: '\\u2A35',\n\tRoundImplies: '\\u2970',\n\trpar: '\\u0029',\n\trpargt: '\\u2994',\n\trppolint: '\\u2A12',\n\trrarr: '\\u21C9',\n\tRrightarrow: '\\u21DB',\n\trsaquo: '\\u203A',\n\tRscr: '\\u211B',\n\trscr: '\\uD835\\uDCC7',\n\tRsh: '\\u21B1',\n\trsh: '\\u21B1',\n\trsqb: '\\u005D',\n\trsquo: '\\u2019',\n\trsquor: '\\u2019',\n\trthree: '\\u22CC',\n\trtimes: '\\u22CA',\n\trtri: '\\u25B9',\n\trtrie: '\\u22B5',\n\trtrif: '\\u25B8',\n\trtriltri: '\\u29CE',\n\tRuleDelayed: '\\u29F4',\n\truluhar: '\\u2968',\n\trx: '\\u211E',\n\tSacute: '\\u015A',\n\tsacute: '\\u015B',\n\tsbquo: '\\u201A',\n\tSc: '\\u2ABC',\n\tsc: '\\u227B',\n\tscap: '\\u2AB8',\n\tScaron: '\\u0160',\n\tscaron: '\\u0161',\n\tsccue: '\\u227D',\n\tscE: '\\u2AB4',\n\tsce: '\\u2AB0',\n\tScedil: '\\u015E',\n\tscedil: '\\u015F',\n\tScirc: '\\u015C',\n\tscirc: '\\u015D',\n\tscnap: '\\u2ABA',\n\tscnE: '\\u2AB6',\n\tscnsim: '\\u22E9',\n\tscpolint: '\\u2A13',\n\tscsim: '\\u227F',\n\tScy: '\\u0421',\n\tscy: '\\u0441',\n\tsdot: '\\u22C5',\n\tsdotb: '\\u22A1',\n\tsdote: '\\u2A66',\n\tsearhk: '\\u2925',\n\tseArr: '\\u21D8',\n\tsearr: '\\u2198',\n\tsearrow: '\\u2198',\n\tsect: '\\u00A7',\n\tsemi: '\\u003B',\n\tseswar: '\\u2929',\n\tsetminus: '\\u2216',\n\tsetmn: '\\u2216',\n\tsext: '\\u2736',\n\tSfr: '\\uD835\\uDD16',\n\tsfr: '\\uD835\\uDD30',\n\tsfrown: '\\u2322',\n\tsharp: '\\u266F',\n\tSHCHcy: '\\u0429',\n\tshchcy: '\\u0449',\n\tSHcy: '\\u0428',\n\tshcy: '\\u0448',\n\tShortDownArrow: '\\u2193',\n\tShortLeftArrow: '\\u2190',\n\tshortmid: '\\u2223',\n\tshortparallel: '\\u2225',\n\tShortRightArrow: '\\u2192',\n\tShortUpArrow: '\\u2191',\n\tshy: '\\u00AD',\n\tSigma: '\\u03A3',\n\tsigma: '\\u03C3',\n\tsigmaf: '\\u03C2',\n\tsigmav: '\\u03C2',\n\tsim: '\\u223C',\n\tsimdot: '\\u2A6A',\n\tsime: '\\u2243',\n\tsimeq: '\\u2243',\n\tsimg: '\\u2A9E',\n\tsimgE: '\\u2AA0',\n\tsiml: '\\u2A9D',\n\tsimlE: '\\u2A9F',\n\tsimne: '\\u2246',\n\tsimplus: '\\u2A24',\n\tsimrarr: '\\u2972',\n\tslarr: '\\u2190',\n\tSmallCircle: '\\u2218',\n\tsmallsetminus: '\\u2216',\n\tsmashp: '\\u2A33',\n\tsmeparsl: '\\u29E4',\n\tsmid: '\\u2223',\n\tsmile: '\\u2323',\n\tsmt: '\\u2AAA',\n\tsmte: '\\u2AAC',\n\tsmtes: '\\u2AAC\\uFE00',\n\tSOFTcy: '\\u042C',\n\tsoftcy: '\\u044C',\n\tsol: '\\u002F',\n\tsolb: '\\u29C4',\n\tsolbar: '\\u233F',\n\tSopf: '\\uD835\\uDD4A',\n\tsopf: '\\uD835\\uDD64',\n\tspades: '\\u2660',\n\tspadesuit: '\\u2660',\n\tspar: '\\u2225',\n\tsqcap: '\\u2293',\n\tsqcaps: '\\u2293\\uFE00',\n\tsqcup: '\\u2294',\n\tsqcups: '\\u2294\\uFE00',\n\tSqrt: '\\u221A',\n\tsqsub: '\\u228F',\n\tsqsube: '\\u2291',\n\tsqsubset: '\\u228F',\n\tsqsubseteq: '\\u2291',\n\tsqsup: '\\u2290',\n\tsqsupe: '\\u2292',\n\tsqsupset: '\\u2290',\n\tsqsupseteq: '\\u2292',\n\tsqu: '\\u25A1',\n\tSquare: '\\u25A1',\n\tsquare: '\\u25A1',\n\tSquareIntersection: '\\u2293',\n\tSquareSubset: '\\u228F',\n\tSquareSubsetEqual: '\\u2291',\n\tSquareSuperset: '\\u2290',\n\tSquareSupersetEqual: '\\u2292',\n\tSquareUnion: '\\u2294',\n\tsquarf: '\\u25AA',\n\tsquf: '\\u25AA',\n\tsrarr: '\\u2192',\n\tSscr: '\\uD835\\uDCAE',\n\tsscr: '\\uD835\\uDCC8',\n\tssetmn: '\\u2216',\n\tssmile: '\\u2323',\n\tsstarf: '\\u22C6',\n\tStar: '\\u22C6',\n\tstar: '\\u2606',\n\tstarf: '\\u2605',\n\tstraightepsilon: '\\u03F5',\n\tstraightphi: '\\u03D5',\n\tstrns: '\\u00AF',\n\tSub: '\\u22D0',\n\tsub: '\\u2282',\n\tsubdot: '\\u2ABD',\n\tsubE: '\\u2AC5',\n\tsube: '\\u2286',\n\tsubedot: '\\u2AC3',\n\tsubmult: '\\u2AC1',\n\tsubnE: '\\u2ACB',\n\tsubne: '\\u228A',\n\tsubplus: '\\u2ABF',\n\tsubrarr: '\\u2979',\n\tSubset: '\\u22D0',\n\tsubset: '\\u2282',\n\tsubseteq: '\\u2286',\n\tsubseteqq: '\\u2AC5',\n\tSubsetEqual: '\\u2286',\n\tsubsetneq: '\\u228A',\n\tsubsetneqq: '\\u2ACB',\n\tsubsim: '\\u2AC7',\n\tsubsub: '\\u2AD5',\n\tsubsup: '\\u2AD3',\n\tsucc: '\\u227B',\n\tsuccapprox: '\\u2AB8',\n\tsucccurlyeq: '\\u227D',\n\tSucceeds: '\\u227B',\n\tSucceedsEqual: '\\u2AB0',\n\tSucceedsSlantEqual: '\\u227D',\n\tSucceedsTilde: '\\u227F',\n\tsucceq: '\\u2AB0',\n\tsuccnapprox: '\\u2ABA',\n\tsuccneqq: '\\u2AB6',\n\tsuccnsim: '\\u22E9',\n\tsuccsim: '\\u227F',\n\tSuchThat: '\\u220B',\n\tSum: '\\u2211',\n\tsum: '\\u2211',\n\tsung: '\\u266A',\n\tSup: '\\u22D1',\n\tsup: '\\u2283',\n\tsup1: '\\u00B9',\n\tsup2: '\\u00B2',\n\tsup3: '\\u00B3',\n\tsupdot: '\\u2ABE',\n\tsupdsub: '\\u2AD8',\n\tsupE: '\\u2AC6',\n\tsupe: '\\u2287',\n\tsupedot: '\\u2AC4',\n\tSuperset: '\\u2283',\n\tSupersetEqual: '\\u2287',\n\tsuphsol: '\\u27C9',\n\tsuphsub: '\\u2AD7',\n\tsuplarr: '\\u297B',\n\tsupmult: '\\u2AC2',\n\tsupnE: '\\u2ACC',\n\tsupne: '\\u228B',\n\tsupplus: '\\u2AC0',\n\tSupset: '\\u22D1',\n\tsupset: '\\u2283',\n\tsupseteq: '\\u2287',\n\tsupseteqq: '\\u2AC6',\n\tsupsetneq: '\\u228B',\n\tsupsetneqq: '\\u2ACC',\n\tsupsim: '\\u2AC8',\n\tsupsub: '\\u2AD4',\n\tsupsup: '\\u2AD6',\n\tswarhk: '\\u2926',\n\tswArr: '\\u21D9',\n\tswarr: '\\u2199',\n\tswarrow: '\\u2199',\n\tswnwar: '\\u292A',\n\tszlig: '\\u00DF',\n\tTab: '\\u0009',\n\ttarget: '\\u2316',\n\tTau: '\\u03A4',\n\ttau: '\\u03C4',\n\ttbrk: '\\u23B4',\n\tTcaron: '\\u0164',\n\ttcaron: '\\u0165',\n\tTcedil: '\\u0162',\n\ttcedil: '\\u0163',\n\tTcy: '\\u0422',\n\ttcy: '\\u0442',\n\ttdot: '\\u20DB',\n\ttelrec: '\\u2315',\n\tTfr: '\\uD835\\uDD17',\n\ttfr: '\\uD835\\uDD31',\n\tthere4: '\\u2234',\n\tTherefore: '\\u2234',\n\ttherefore: '\\u2234',\n\tTheta: '\\u0398',\n\ttheta: '\\u03B8',\n\tthetasym: '\\u03D1',\n\tthetav: '\\u03D1',\n\tthickapprox: '\\u2248',\n\tthicksim: '\\u223C',\n\tThickSpace: '\\u205F\\u200A',\n\tthinsp: '\\u2009',\n\tThinSpace: '\\u2009',\n\tthkap: '\\u2248',\n\tthksim: '\\u223C',\n\tTHORN: '\\u00DE',\n\tthorn: '\\u00FE',\n\tTilde: '\\u223C',\n\ttilde: '\\u02DC',\n\tTildeEqual: '\\u2243',\n\tTildeFullEqual: '\\u2245',\n\tTildeTilde: '\\u2248',\n\ttimes: '\\u00D7',\n\ttimesb: '\\u22A0',\n\ttimesbar: '\\u2A31',\n\ttimesd: '\\u2A30',\n\ttint: '\\u222D',\n\ttoea: '\\u2928',\n\ttop: '\\u22A4',\n\ttopbot: '\\u2336',\n\ttopcir: '\\u2AF1',\n\tTopf: '\\uD835\\uDD4B',\n\ttopf: '\\uD835\\uDD65',\n\ttopfork: '\\u2ADA',\n\ttosa: '\\u2929',\n\ttprime: '\\u2034',\n\tTRADE: '\\u2122',\n\ttrade: '\\u2122',\n\ttriangle: '\\u25B5',\n\ttriangledown: '\\u25BF',\n\ttriangleleft: '\\u25C3',\n\ttrianglelefteq: '\\u22B4',\n\ttriangleq: '\\u225C',\n\ttriangleright: '\\u25B9',\n\ttrianglerighteq: '\\u22B5',\n\ttridot: '\\u25EC',\n\ttrie: '\\u225C',\n\ttriminus: '\\u2A3A',\n\tTripleDot: '\\u20DB',\n\ttriplus: '\\u2A39',\n\ttrisb: '\\u29CD',\n\ttritime: '\\u2A3B',\n\ttrpezium: '\\u23E2',\n\tTscr: '\\uD835\\uDCAF',\n\ttscr: '\\uD835\\uDCC9',\n\tTScy: '\\u0426',\n\ttscy: '\\u0446',\n\tTSHcy: '\\u040B',\n\ttshcy: '\\u045B',\n\tTstrok: '\\u0166',\n\ttstrok: '\\u0167',\n\ttwixt: '\\u226C',\n\ttwoheadleftarrow: '\\u219E',\n\ttwoheadrightarrow: '\\u21A0',\n\tUacute: '\\u00DA',\n\tuacute: '\\u00FA',\n\tUarr: '\\u219F',\n\tuArr: '\\u21D1',\n\tuarr: '\\u2191',\n\tUarrocir: '\\u2949',\n\tUbrcy: '\\u040E',\n\tubrcy: '\\u045E',\n\tUbreve: '\\u016C',\n\tubreve: '\\u016D',\n\tUcirc: '\\u00DB',\n\tucirc: '\\u00FB',\n\tUcy: '\\u0423',\n\tucy: '\\u0443',\n\tudarr: '\\u21C5',\n\tUdblac: '\\u0170',\n\tudblac: '\\u0171',\n\tudhar: '\\u296E',\n\tufisht: '\\u297E',\n\tUfr: '\\uD835\\uDD18',\n\tufr: '\\uD835\\uDD32',\n\tUgrave: '\\u00D9',\n\tugrave: '\\u00F9',\n\tuHar: '\\u2963',\n\tuharl: '\\u21BF',\n\tuharr: '\\u21BE',\n\tuhblk: '\\u2580',\n\tulcorn: '\\u231C',\n\tulcorner: '\\u231C',\n\tulcrop: '\\u230F',\n\tultri: '\\u25F8',\n\tUmacr: '\\u016A',\n\tumacr: '\\u016B',\n\tuml: '\\u00A8',\n\tUnderBar: '\\u005F',\n\tUnderBrace: '\\u23DF',\n\tUnderBracket: '\\u23B5',\n\tUnderParenthesis: '\\u23DD',\n\tUnion: '\\u22C3',\n\tUnionPlus: '\\u228E',\n\tUogon: '\\u0172',\n\tuogon: '\\u0173',\n\tUopf: '\\uD835\\uDD4C',\n\tuopf: '\\uD835\\uDD66',\n\tUpArrow: '\\u2191',\n\tUparrow: '\\u21D1',\n\tuparrow: '\\u2191',\n\tUpArrowBar: '\\u2912',\n\tUpArrowDownArrow: '\\u21C5',\n\tUpDownArrow: '\\u2195',\n\tUpdownarrow: '\\u21D5',\n\tupdownarrow: '\\u2195',\n\tUpEquilibrium: '\\u296E',\n\tupharpoonleft: '\\u21BF',\n\tupharpoonright: '\\u21BE',\n\tuplus: '\\u228E',\n\tUpperLeftArrow: '\\u2196',\n\tUpperRightArrow: '\\u2197',\n\tUpsi: '\\u03D2',\n\tupsi: '\\u03C5',\n\tupsih: '\\u03D2',\n\tUpsilon: '\\u03A5',\n\tupsilon: '\\u03C5',\n\tUpTee: '\\u22A5',\n\tUpTeeArrow: '\\u21A5',\n\tupuparrows: '\\u21C8',\n\turcorn: '\\u231D',\n\turcorner: '\\u231D',\n\turcrop: '\\u230E',\n\tUring: '\\u016E',\n\turing: '\\u016F',\n\turtri: '\\u25F9',\n\tUscr: '\\uD835\\uDCB0',\n\tuscr: '\\uD835\\uDCCA',\n\tutdot: '\\u22F0',\n\tUtilde: '\\u0168',\n\tutilde: '\\u0169',\n\tutri: '\\u25B5',\n\tutrif: '\\u25B4',\n\tuuarr: '\\u21C8',\n\tUuml: '\\u00DC',\n\tuuml: '\\u00FC',\n\tuwangle: '\\u29A7',\n\tvangrt: '\\u299C',\n\tvarepsilon: '\\u03F5',\n\tvarkappa: '\\u03F0',\n\tvarnothing: '\\u2205',\n\tvarphi: '\\u03D5',\n\tvarpi: '\\u03D6',\n\tvarpropto: '\\u221D',\n\tvArr: '\\u21D5',\n\tvarr: '\\u2195',\n\tvarrho: '\\u03F1',\n\tvarsigma: '\\u03C2',\n\tvarsubsetneq: '\\u228A\\uFE00',\n\tvarsubsetneqq: '\\u2ACB\\uFE00',\n\tvarsupsetneq: '\\u228B\\uFE00',\n\tvarsupsetneqq: '\\u2ACC\\uFE00',\n\tvartheta: '\\u03D1',\n\tvartriangleleft: '\\u22B2',\n\tvartriangleright: '\\u22B3',\n\tVbar: '\\u2AEB',\n\tvBar: '\\u2AE8',\n\tvBarv: '\\u2AE9',\n\tVcy: '\\u0412',\n\tvcy: '\\u0432',\n\tVDash: '\\u22AB',\n\tVdash: '\\u22A9',\n\tvDash: '\\u22A8',\n\tvdash: '\\u22A2',\n\tVdashl: '\\u2AE6',\n\tVee: '\\u22C1',\n\tvee: '\\u2228',\n\tveebar: '\\u22BB',\n\tveeeq: '\\u225A',\n\tvellip: '\\u22EE',\n\tVerbar: '\\u2016',\n\tverbar: '\\u007C',\n\tVert: '\\u2016',\n\tvert: '\\u007C',\n\tVerticalBar: '\\u2223',\n\tVerticalLine: '\\u007C',\n\tVerticalSeparator: '\\u2758',\n\tVerticalTilde: '\\u2240',\n\tVeryThinSpace: '\\u200A',\n\tVfr: '\\uD835\\uDD19',\n\tvfr: '\\uD835\\uDD33',\n\tvltri: '\\u22B2',\n\tvnsub: '\\u2282\\u20D2',\n\tvnsup: '\\u2283\\u20D2',\n\tVopf: '\\uD835\\uDD4D',\n\tvopf: '\\uD835\\uDD67',\n\tvprop: '\\u221D',\n\tvrtri: '\\u22B3',\n\tVscr: '\\uD835\\uDCB1',\n\tvscr: '\\uD835\\uDCCB',\n\tvsubnE: '\\u2ACB\\uFE00',\n\tvsubne: '\\u228A\\uFE00',\n\tvsupnE: '\\u2ACC\\uFE00',\n\tvsupne: '\\u228B\\uFE00',\n\tVvdash: '\\u22AA',\n\tvzigzag: '\\u299A',\n\tWcirc: '\\u0174',\n\twcirc: '\\u0175',\n\twedbar: '\\u2A5F',\n\tWedge: '\\u22C0',\n\twedge: '\\u2227',\n\twedgeq: '\\u2259',\n\tweierp: '\\u2118',\n\tWfr: '\\uD835\\uDD1A',\n\twfr: '\\uD835\\uDD34',\n\tWopf: '\\uD835\\uDD4E',\n\twopf: '\\uD835\\uDD68',\n\twp: '\\u2118',\n\twr: '\\u2240',\n\twreath: '\\u2240',\n\tWscr: '\\uD835\\uDCB2',\n\twscr: '\\uD835\\uDCCC',\n\txcap: '\\u22C2',\n\txcirc: '\\u25EF',\n\txcup: '\\u22C3',\n\txdtri: '\\u25BD',\n\tXfr: '\\uD835\\uDD1B',\n\txfr: '\\uD835\\uDD35',\n\txhArr: '\\u27FA',\n\txharr: '\\u27F7',\n\tXi: '\\u039E',\n\txi: '\\u03BE',\n\txlArr: '\\u27F8',\n\txlarr: '\\u27F5',\n\txmap: '\\u27FC',\n\txnis: '\\u22FB',\n\txodot: '\\u2A00',\n\tXopf: '\\uD835\\uDD4F',\n\txopf: '\\uD835\\uDD69',\n\txoplus: '\\u2A01',\n\txotime: '\\u2A02',\n\txrArr: '\\u27F9',\n\txrarr: '\\u27F6',\n\tXscr: '\\uD835\\uDCB3',\n\txscr: '\\uD835\\uDCCD',\n\txsqcup: '\\u2A06',\n\txuplus: '\\u2A04',\n\txutri: '\\u25B3',\n\txvee: '\\u22C1',\n\txwedge: '\\u22C0',\n\tYacute: '\\u00DD',\n\tyacute: '\\u00FD',\n\tYAcy: '\\u042F',\n\tyacy: '\\u044F',\n\tYcirc: '\\u0176',\n\tycirc: '\\u0177',\n\tYcy: '\\u042B',\n\tycy: '\\u044B',\n\tyen: '\\u00A5',\n\tYfr: '\\uD835\\uDD1C',\n\tyfr: '\\uD835\\uDD36',\n\tYIcy: '\\u0407',\n\tyicy: '\\u0457',\n\tYopf: '\\uD835\\uDD50',\n\tyopf: '\\uD835\\uDD6A',\n\tYscr: '\\uD835\\uDCB4',\n\tyscr: '\\uD835\\uDCCE',\n\tYUcy: '\\u042E',\n\tyucy: '\\u044E',\n\tYuml: '\\u0178',\n\tyuml: '\\u00FF',\n\tZacute: '\\u0179',\n\tzacute: '\\u017A',\n\tZcaron: '\\u017D',\n\tzcaron: '\\u017E',\n\tZcy: '\\u0417',\n\tzcy: '\\u0437',\n\tZdot: '\\u017B',\n\tzdot: '\\u017C',\n\tzeetrf: '\\u2128',\n\tZeroWidthSpace: '\\u200B',\n\tZeta: '\\u0396',\n\tzeta: '\\u03B6',\n\tZfr: '\\u2128',\n\tzfr: '\\uD835\\uDD37',\n\tZHcy: '\\u0416',\n\tzhcy: '\\u0436',\n\tzigrarr: '\\u21DD',\n\tZopf: '\\u2124',\n\tzopf: '\\uD835\\uDD6B',\n\tZscr: '\\uD835\\uDCB5',\n\tzscr: '\\uD835\\uDCCF',\n\tzwj: '\\u200D',\n\tzwnj: '\\u200C',\n});\n\n/**\n * @deprecated use `HTML_ENTITIES` instead\n * @see HTML_ENTITIES\n */\nexports.entityMap = exports.HTML_ENTITIES;\n","var NAMESPACE = require(\"./conventions\").NAMESPACE;\n\n//[4]   \tNameStartChar\t   ::=   \t\":\" | [A-Z] | \"_\" | [a-z] | [#xC0-#xD6] | [#xD8-#xF6] | [#xF8-#x2FF] | [#x370-#x37D] | [#x37F-#x1FFF] | [#x200C-#x200D] | [#x2070-#x218F] | [#x2C00-#x2FEF] | [#x3001-#xD7FF] | [#xF900-#xFDCF] | [#xFDF0-#xFFFD] | [#x10000-#xEFFFF]\n//[4a]   \tNameChar\t   ::=   \tNameStartChar | \"-\" | \".\" | [0-9] | #xB7 | [#x0300-#x036F] | [#x203F-#x2040]\n//[5]   \tName\t   ::=   \tNameStartChar (NameChar)*\nvar nameStartChar = /[A-Z_a-z\\xC0-\\xD6\\xD8-\\xF6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD]///\\u10000-\\uEFFFF\nvar nameChar = new RegExp(\"[\\\\-\\\\.0-9\"+nameStartChar.source.slice(1,-1)+\"\\\\u00B7\\\\u0300-\\\\u036F\\\\u203F-\\\\u2040]\");\nvar tagNamePattern = new RegExp('^'+nameStartChar.source+nameChar.source+'*(?:\\:'+nameStartChar.source+nameChar.source+'*)?$');\n//var tagNamePattern = /^[a-zA-Z_][\\w\\-\\.]*(?:\\:[a-zA-Z_][\\w\\-\\.]*)?$/\n//var handlers = 'resolveEntity,getExternalSubset,characters,endDocument,endElement,endPrefixMapping,ignorableWhitespace,processingInstruction,setDocumentLocator,skippedEntity,startDocument,startElement,startPrefixMapping,notationDecl,unparsedEntityDecl,error,fatalError,warning,attributeDecl,elementDecl,externalEntityDecl,internalEntityDecl,comment,endCDATA,endDTD,endEntity,startCDATA,startDTD,startEntity'.split(',')\n\n//S_TAG,\tS_ATTR,\tS_EQ,\tS_ATTR_NOQUOT_VALUE\n//S_ATTR_SPACE,\tS_ATTR_END,\tS_TAG_SPACE, S_TAG_CLOSE\nvar S_TAG = 0;//tag name offerring\nvar S_ATTR = 1;//attr name offerring\nvar S_ATTR_SPACE=2;//attr name end and space offer\nvar S_EQ = 3;//=space?\nvar S_ATTR_NOQUOT_VALUE = 4;//attr value(no quot value only)\nvar S_ATTR_END = 5;//attr value end and no space(quot end)\nvar S_TAG_SPACE = 6;//(attr value end || tag end ) && (space offer)\nvar S_TAG_CLOSE = 7;//closed el<el />\n\n/**\n * Creates an error that will not be caught by XMLReader aka the SAX parser.\n *\n * @param {string} message\n * @param {any?} locator Optional, can provide details about the location in the source\n * @constructor\n */\nfunction ParseError(message, locator) {\n\tthis.message = message\n\tthis.locator = locator\n\tif(Error.captureStackTrace) Error.captureStackTrace(this, ParseError);\n}\nParseError.prototype = new Error();\nParseError.prototype.name = ParseError.name\n\nfunction XMLReader(){\n\n}\n\nXMLReader.prototype = {\n\tparse:function(source,defaultNSMap,entityMap){\n\t\tvar domBuilder = this.domBuilder;\n\t\tdomBuilder.startDocument();\n\t\t_copy(defaultNSMap ,defaultNSMap = {})\n\t\tparse(source,defaultNSMap,entityMap,\n\t\t\t\tdomBuilder,this.errorHandler);\n\t\tdomBuilder.endDocument();\n\t}\n}\nfunction parse(source,defaultNSMapCopy,entityMap,domBuilder,errorHandler){\n\tfunction fixedFromCharCode(code) {\n\t\t// String.prototype.fromCharCode does not supports\n\t\t// > 2 bytes unicode chars directly\n\t\tif (code > 0xffff) {\n\t\t\tcode -= 0x10000;\n\t\t\tvar surrogate1 = 0xd800 + (code >> 10)\n\t\t\t\t, surrogate2 = 0xdc00 + (code & 0x3ff);\n\n\t\t\treturn String.fromCharCode(surrogate1, surrogate2);\n\t\t} else {\n\t\t\treturn String.fromCharCode(code);\n\t\t}\n\t}\n\tfunction entityReplacer(a){\n\t\tvar k = a.slice(1,-1);\n\t\tif (Object.hasOwnProperty.call(entityMap, k)) {\n\t\t\treturn entityMap[k];\n\t\t}else if(k.charAt(0) === '#'){\n\t\t\treturn fixedFromCharCode(parseInt(k.substr(1).replace('x','0x')))\n\t\t}else{\n\t\t\terrorHandler.error('entity not found:'+a);\n\t\t\treturn a;\n\t\t}\n\t}\n\tfunction appendText(end){//has some bugs\n\t\tif(end>start){\n\t\t\tvar xt = source.substring(start,end).replace(/&#?\\w+;/g,entityReplacer);\n\t\t\tlocator&&position(start);\n\t\t\tdomBuilder.characters(xt,0,end-start);\n\t\t\tstart = end\n\t\t}\n\t}\n\tfunction position(p,m){\n\t\twhile(p>=lineEnd && (m = linePattern.exec(source))){\n\t\t\tlineStart = m.index;\n\t\t\tlineEnd = lineStart + m[0].length;\n\t\t\tlocator.lineNumber++;\n\t\t\t//console.log('line++:',locator,startPos,endPos)\n\t\t}\n\t\tlocator.columnNumber = p-lineStart+1;\n\t}\n\tvar lineStart = 0;\n\tvar lineEnd = 0;\n\tvar linePattern = /.*(?:\\r\\n?|\\n)|.*$/g\n\tvar locator = domBuilder.locator;\n\n\tvar parseStack = [{currentNSMap:defaultNSMapCopy}]\n\tvar closeMap = {};\n\tvar start = 0;\n\twhile(true){\n\t\ttry{\n\t\t\tvar tagStart = source.indexOf('<',start);\n\t\t\tif(tagStart<0){\n\t\t\t\tif(!source.substr(start).match(/^\\s*$/)){\n\t\t\t\t\tvar doc = domBuilder.doc;\n\t    \t\t\tvar text = doc.createTextNode(source.substr(start));\n\t    \t\t\tdoc.appendChild(text);\n\t    \t\t\tdomBuilder.currentElement = text;\n\t\t\t\t}\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif(tagStart>start){\n\t\t\t\tappendText(tagStart);\n\t\t\t}\n\t\t\tswitch(source.charAt(tagStart+1)){\n\t\t\tcase '/':\n\t\t\t\tvar end = source.indexOf('>',tagStart+3);\n\t\t\t\tvar tagName = source.substring(tagStart + 2, end).replace(/[ \\t\\n\\r]+$/g, '');\n\t\t\t\tvar config = parseStack.pop();\n\t\t\t\tif(end<0){\n\n\t        \t\ttagName = source.substring(tagStart+2).replace(/[\\s<].*/,'');\n\t        \t\terrorHandler.error(\"end tag name: \"+tagName+' is not complete:'+config.tagName);\n\t        \t\tend = tagStart+1+tagName.length;\n\t        \t}else if(tagName.match(/\\s</)){\n\t        \t\ttagName = tagName.replace(/[\\s<].*/,'');\n\t        \t\terrorHandler.error(\"end tag name: \"+tagName+' maybe not complete');\n\t        \t\tend = tagStart+1+tagName.length;\n\t\t\t\t}\n\t\t\t\tvar localNSMap = config.localNSMap;\n\t\t\t\tvar endMatch = config.tagName == tagName;\n\t\t\t\tvar endIgnoreCaseMach = endMatch || config.tagName&&config.tagName.toLowerCase() == tagName.toLowerCase()\n\t\t        if(endIgnoreCaseMach){\n\t\t        \tdomBuilder.endElement(config.uri,config.localName,tagName);\n\t\t\t\t\tif(localNSMap){\n\t\t\t\t\t\tfor (var prefix in localNSMap) {\n\t\t\t\t\t\t\tif (Object.prototype.hasOwnProperty.call(localNSMap, prefix)) {\n\t\t\t\t\t\t\t\tdomBuilder.endPrefixMapping(prefix);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif(!endMatch){\n\t\t            \terrorHandler.fatalError(\"end tag name: \"+tagName+' is not match the current start tagName:'+config.tagName ); // No known test case\n\t\t\t\t\t}\n\t\t        }else{\n\t\t        \tparseStack.push(config)\n\t\t        }\n\n\t\t\t\tend++;\n\t\t\t\tbreak;\n\t\t\t\t// end elment\n\t\t\tcase '?':// <?...?>\n\t\t\t\tlocator&&position(tagStart);\n\t\t\t\tend = parseInstruction(source,tagStart,domBuilder);\n\t\t\t\tbreak;\n\t\t\tcase '!':// <!doctype,<![CDATA,<!--\n\t\t\t\tlocator&&position(tagStart);\n\t\t\t\tend = parseDCC(source,tagStart,domBuilder,errorHandler);\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tlocator&&position(tagStart);\n\t\t\t\tvar el = new ElementAttributes();\n\t\t\t\tvar currentNSMap = parseStack[parseStack.length-1].currentNSMap;\n\t\t\t\t//elStartEnd\n\t\t\t\tvar end = parseElementStartPart(source,tagStart,el,currentNSMap,entityReplacer,errorHandler);\n\t\t\t\tvar len = el.length;\n\n\n\t\t\t\tif(!el.closed && fixSelfClosed(source,end,el.tagName,closeMap)){\n\t\t\t\t\tel.closed = true;\n\t\t\t\t\tif(!entityMap.nbsp){\n\t\t\t\t\t\terrorHandler.warning('unclosed xml attribute');\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif(locator && len){\n\t\t\t\t\tvar locator2 = copyLocator(locator,{});\n\t\t\t\t\t//try{//attribute position fixed\n\t\t\t\t\tfor(var i = 0;i<len;i++){\n\t\t\t\t\t\tvar a = el[i];\n\t\t\t\t\t\tposition(a.offset);\n\t\t\t\t\t\ta.locator = copyLocator(locator,{});\n\t\t\t\t\t}\n\t\t\t\t\tdomBuilder.locator = locator2\n\t\t\t\t\tif(appendElement(el,domBuilder,currentNSMap)){\n\t\t\t\t\t\tparseStack.push(el)\n\t\t\t\t\t}\n\t\t\t\t\tdomBuilder.locator = locator;\n\t\t\t\t}else{\n\t\t\t\t\tif(appendElement(el,domBuilder,currentNSMap)){\n\t\t\t\t\t\tparseStack.push(el)\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (NAMESPACE.isHTML(el.uri) && !el.closed) {\n\t\t\t\t\tend = parseHtmlSpecialContent(source,end,el.tagName,entityReplacer,domBuilder)\n\t\t\t\t} else {\n\t\t\t\t\tend++;\n\t\t\t\t}\n\t\t\t}\n\t\t}catch(e){\n\t\t\tif (e instanceof ParseError) {\n\t\t\t\tthrow e;\n\t\t\t}\n\t\t\terrorHandler.error('element parse error: '+e)\n\t\t\tend = -1;\n\t\t}\n\t\tif(end>start){\n\t\t\tstart = end;\n\t\t}else{\n\t\t\t//TODO: 这里有可能sax回退，有位置错误风险\n\t\t\tappendText(Math.max(tagStart,start)+1);\n\t\t}\n\t}\n}\nfunction copyLocator(f,t){\n\tt.lineNumber = f.lineNumber;\n\tt.columnNumber = f.columnNumber;\n\treturn t;\n}\n\n/**\n * @see #appendElement(source,elStartEnd,el,selfClosed,entityReplacer,domBuilder,parseStack);\n * @return end of the elementStartPart(end of elementEndPart for selfClosed el)\n */\nfunction parseElementStartPart(source,start,el,currentNSMap,entityReplacer,errorHandler){\n\n\t/**\n\t * @param {string} qname\n\t * @param {string} value\n\t * @param {number} startIndex\n\t */\n\tfunction addAttribute(qname, value, startIndex) {\n\t\tif (el.attributeNames.hasOwnProperty(qname)) {\n\t\t\terrorHandler.fatalError('Attribute ' + qname + ' redefined')\n\t\t}\n\t\tel.addValue(\n\t\t\tqname,\n\t\t\t// @see https://www.w3.org/TR/xml/#AVNormalize\n\t\t\t// since the xmldom sax parser does not \"interpret\" DTD the following is not implemented:\n\t\t\t// - recursive replacement of (DTD) entity references\n\t\t\t// - trimming and collapsing multiple spaces into a single one for attributes that are not of type CDATA\n\t\t\tvalue.replace(/[\\t\\n\\r]/g, ' ').replace(/&#?\\w+;/g, entityReplacer),\n\t\t\tstartIndex\n\t\t)\n\t}\n\tvar attrName;\n\tvar value;\n\tvar p = ++start;\n\tvar s = S_TAG;//status\n\twhile(true){\n\t\tvar c = source.charAt(p);\n\t\tswitch(c){\n\t\tcase '=':\n\t\t\tif(s === S_ATTR){//attrName\n\t\t\t\tattrName = source.slice(start,p);\n\t\t\t\ts = S_EQ;\n\t\t\t}else if(s === S_ATTR_SPACE){\n\t\t\t\ts = S_EQ;\n\t\t\t}else{\n\t\t\t\t//fatalError: equal must after attrName or space after attrName\n\t\t\t\tthrow new Error('attribute equal must after attrName'); // No known test case\n\t\t\t}\n\t\t\tbreak;\n\t\tcase '\\'':\n\t\tcase '\"':\n\t\t\tif(s === S_EQ || s === S_ATTR //|| s == S_ATTR_SPACE\n\t\t\t\t){//equal\n\t\t\t\tif(s === S_ATTR){\n\t\t\t\t\terrorHandler.warning('attribute value must after \"=\"')\n\t\t\t\t\tattrName = source.slice(start,p)\n\t\t\t\t}\n\t\t\t\tstart = p+1;\n\t\t\t\tp = source.indexOf(c,start)\n\t\t\t\tif(p>0){\n\t\t\t\t\tvalue = source.slice(start, p);\n\t\t\t\t\taddAttribute(attrName, value, start-1);\n\t\t\t\t\ts = S_ATTR_END;\n\t\t\t\t}else{\n\t\t\t\t\t//fatalError: no end quot match\n\t\t\t\t\tthrow new Error('attribute value no end \\''+c+'\\' match');\n\t\t\t\t}\n\t\t\t}else if(s == S_ATTR_NOQUOT_VALUE){\n\t\t\t\tvalue = source.slice(start, p);\n\t\t\t\taddAttribute(attrName, value, start);\n\t\t\t\terrorHandler.warning('attribute \"'+attrName+'\" missed start quot('+c+')!!');\n\t\t\t\tstart = p+1;\n\t\t\t\ts = S_ATTR_END\n\t\t\t}else{\n\t\t\t\t//fatalError: no equal before\n\t\t\t\tthrow new Error('attribute value must after \"=\"'); // No known test case\n\t\t\t}\n\t\t\tbreak;\n\t\tcase '/':\n\t\t\tswitch(s){\n\t\t\tcase S_TAG:\n\t\t\t\tel.setTagName(source.slice(start,p));\n\t\t\tcase S_ATTR_END:\n\t\t\tcase S_TAG_SPACE:\n\t\t\tcase S_TAG_CLOSE:\n\t\t\t\ts =S_TAG_CLOSE;\n\t\t\t\tel.closed = true;\n\t\t\tcase S_ATTR_NOQUOT_VALUE:\n\t\t\tcase S_ATTR:\n\t\t\t\tbreak;\n\t\t\t\tcase S_ATTR_SPACE:\n\t\t\t\t\tel.closed = true;\n\t\t\t\tbreak;\n\t\t\t//case S_EQ:\n\t\t\tdefault:\n\t\t\t\tthrow new Error(\"attribute invalid close char('/')\") // No known test case\n\t\t\t}\n\t\t\tbreak;\n\t\tcase ''://end document\n\t\t\terrorHandler.error('unexpected end of input');\n\t\t\tif(s == S_TAG){\n\t\t\t\tel.setTagName(source.slice(start,p));\n\t\t\t}\n\t\t\treturn p;\n\t\tcase '>':\n\t\t\tswitch(s){\n\t\t\tcase S_TAG:\n\t\t\t\tel.setTagName(source.slice(start,p));\n\t\t\tcase S_ATTR_END:\n\t\t\tcase S_TAG_SPACE:\n\t\t\tcase S_TAG_CLOSE:\n\t\t\t\tbreak;//normal\n\t\t\tcase S_ATTR_NOQUOT_VALUE://Compatible state\n\t\t\tcase S_ATTR:\n\t\t\t\tvalue = source.slice(start,p);\n\t\t\t\tif(value.slice(-1) === '/'){\n\t\t\t\t\tel.closed  = true;\n\t\t\t\t\tvalue = value.slice(0,-1)\n\t\t\t\t}\n\t\t\tcase S_ATTR_SPACE:\n\t\t\t\tif(s === S_ATTR_SPACE){\n\t\t\t\t\tvalue = attrName;\n\t\t\t\t}\n\t\t\t\tif(s == S_ATTR_NOQUOT_VALUE){\n\t\t\t\t\terrorHandler.warning('attribute \"'+value+'\" missed quot(\")!');\n\t\t\t\t\taddAttribute(attrName, value, start)\n\t\t\t\t}else{\n\t\t\t\t\tif(!NAMESPACE.isHTML(currentNSMap['']) || !value.match(/^(?:disabled|checked|selected)$/i)){\n\t\t\t\t\t\terrorHandler.warning('attribute \"'+value+'\" missed value!! \"'+value+'\" instead!!')\n\t\t\t\t\t}\n\t\t\t\t\taddAttribute(value, value, start)\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase S_EQ:\n\t\t\t\tthrow new Error('attribute value missed!!');\n\t\t\t}\n//\t\t\tconsole.log(tagName,tagNamePattern,tagNamePattern.test(tagName))\n\t\t\treturn p;\n\t\t/*xml space '\\x20' | #x9 | #xD | #xA; */\n\t\tcase '\\u0080':\n\t\t\tc = ' ';\n\t\tdefault:\n\t\t\tif(c<= ' '){//space\n\t\t\t\tswitch(s){\n\t\t\t\tcase S_TAG:\n\t\t\t\t\tel.setTagName(source.slice(start,p));//tagName\n\t\t\t\t\ts = S_TAG_SPACE;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_ATTR:\n\t\t\t\t\tattrName = source.slice(start,p)\n\t\t\t\t\ts = S_ATTR_SPACE;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_ATTR_NOQUOT_VALUE:\n\t\t\t\t\tvar value = source.slice(start, p);\n\t\t\t\t\terrorHandler.warning('attribute \"'+value+'\" missed quot(\")!!');\n\t\t\t\t\taddAttribute(attrName, value, start)\n\t\t\t\tcase S_ATTR_END:\n\t\t\t\t\ts = S_TAG_SPACE;\n\t\t\t\t\tbreak;\n\t\t\t\t//case S_TAG_SPACE:\n\t\t\t\t//case S_EQ:\n\t\t\t\t//case S_ATTR_SPACE:\n\t\t\t\t//\tvoid();break;\n\t\t\t\t//case S_TAG_CLOSE:\n\t\t\t\t\t//ignore warning\n\t\t\t\t}\n\t\t\t}else{//not space\n//S_TAG,\tS_ATTR,\tS_EQ,\tS_ATTR_NOQUOT_VALUE\n//S_ATTR_SPACE,\tS_ATTR_END,\tS_TAG_SPACE, S_TAG_CLOSE\n\t\t\t\tswitch(s){\n\t\t\t\t//case S_TAG:void();break;\n\t\t\t\t//case S_ATTR:void();break;\n\t\t\t\t//case S_ATTR_NOQUOT_VALUE:void();break;\n\t\t\t\tcase S_ATTR_SPACE:\n\t\t\t\t\tvar tagName =  el.tagName;\n\t\t\t\t\tif (!NAMESPACE.isHTML(currentNSMap['']) || !attrName.match(/^(?:disabled|checked|selected)$/i)) {\n\t\t\t\t\t\terrorHandler.warning('attribute \"'+attrName+'\" missed value!! \"'+attrName+'\" instead2!!')\n\t\t\t\t\t}\n\t\t\t\t\taddAttribute(attrName, attrName, start);\n\t\t\t\t\tstart = p;\n\t\t\t\t\ts = S_ATTR;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_ATTR_END:\n\t\t\t\t\terrorHandler.warning('attribute space is required\"'+attrName+'\"!!')\n\t\t\t\tcase S_TAG_SPACE:\n\t\t\t\t\ts = S_ATTR;\n\t\t\t\t\tstart = p;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_EQ:\n\t\t\t\t\ts = S_ATTR_NOQUOT_VALUE;\n\t\t\t\t\tstart = p;\n\t\t\t\t\tbreak;\n\t\t\t\tcase S_TAG_CLOSE:\n\t\t\t\t\tthrow new Error(\"elements closed character '/' and '>' must be connected to\");\n\t\t\t\t}\n\t\t\t}\n\t\t}//end outer switch\n\t\t//console.log('p++',p)\n\t\tp++;\n\t}\n}\n/**\n * @return true if has new namespace define\n */\nfunction appendElement(el,domBuilder,currentNSMap){\n\tvar tagName = el.tagName;\n\tvar localNSMap = null;\n\t//var currentNSMap = parseStack[parseStack.length-1].currentNSMap;\n\tvar i = el.length;\n\twhile(i--){\n\t\tvar a = el[i];\n\t\tvar qName = a.qName;\n\t\tvar value = a.value;\n\t\tvar nsp = qName.indexOf(':');\n\t\tif(nsp>0){\n\t\t\tvar prefix = a.prefix = qName.slice(0,nsp);\n\t\t\tvar localName = qName.slice(nsp+1);\n\t\t\tvar nsPrefix = prefix === 'xmlns' && localName\n\t\t}else{\n\t\t\tlocalName = qName;\n\t\t\tprefix = null\n\t\t\tnsPrefix = qName === 'xmlns' && ''\n\t\t}\n\t\t//can not set prefix,because prefix !== ''\n\t\ta.localName = localName ;\n\t\t//prefix == null for no ns prefix attribute\n\t\tif(nsPrefix !== false){//hack!!\n\t\t\tif(localNSMap == null){\n\t\t\t\tlocalNSMap = {}\n\t\t\t\t//console.log(currentNSMap,0)\n\t\t\t\t_copy(currentNSMap,currentNSMap={})\n\t\t\t\t//console.log(currentNSMap,1)\n\t\t\t}\n\t\t\tcurrentNSMap[nsPrefix] = localNSMap[nsPrefix] = value;\n\t\t\ta.uri = NAMESPACE.XMLNS\n\t\t\tdomBuilder.startPrefixMapping(nsPrefix, value)\n\t\t}\n\t}\n\tvar i = el.length;\n\twhile(i--){\n\t\ta = el[i];\n\t\tvar prefix = a.prefix;\n\t\tif(prefix){//no prefix attribute has no namespace\n\t\t\tif(prefix === 'xml'){\n\t\t\t\ta.uri = NAMESPACE.XML;\n\t\t\t}if(prefix !== 'xmlns'){\n\t\t\t\ta.uri = currentNSMap[prefix || '']\n\n\t\t\t\t//{console.log('###'+a.qName,domBuilder.locator.systemId+'',currentNSMap,a.uri)}\n\t\t\t}\n\t\t}\n\t}\n\tvar nsp = tagName.indexOf(':');\n\tif(nsp>0){\n\t\tprefix = el.prefix = tagName.slice(0,nsp);\n\t\tlocalName = el.localName = tagName.slice(nsp+1);\n\t}else{\n\t\tprefix = null;//important!!\n\t\tlocalName = el.localName = tagName;\n\t}\n\t//no prefix element has default namespace\n\tvar ns = el.uri = currentNSMap[prefix || ''];\n\tdomBuilder.startElement(ns,localName,tagName,el);\n\t//endPrefixMapping and startPrefixMapping have not any help for dom builder\n\t//localNSMap = null\n\tif(el.closed){\n\t\tdomBuilder.endElement(ns,localName,tagName);\n\t\tif(localNSMap){\n\t\t\tfor (prefix in localNSMap) {\n\t\t\t\tif (Object.prototype.hasOwnProperty.call(localNSMap, prefix)) {\n\t\t\t\t\tdomBuilder.endPrefixMapping(prefix);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}else{\n\t\tel.currentNSMap = currentNSMap;\n\t\tel.localNSMap = localNSMap;\n\t\t//parseStack.push(el);\n\t\treturn true;\n\t}\n}\nfunction parseHtmlSpecialContent(source,elStartEnd,tagName,entityReplacer,domBuilder){\n\tif(/^(?:script|textarea)$/i.test(tagName)){\n\t\tvar elEndStart =  source.indexOf('</'+tagName+'>',elStartEnd);\n\t\tvar text = source.substring(elStartEnd+1,elEndStart);\n\t\tif(/[&<]/.test(text)){\n\t\t\tif(/^script$/i.test(tagName)){\n\t\t\t\t//if(!/\\]\\]>/.test(text)){\n\t\t\t\t\t//lexHandler.startCDATA();\n\t\t\t\t\tdomBuilder.characters(text,0,text.length);\n\t\t\t\t\t//lexHandler.endCDATA();\n\t\t\t\t\treturn elEndStart;\n\t\t\t\t//}\n\t\t\t}//}else{//text area\n\t\t\t\ttext = text.replace(/&#?\\w+;/g,entityReplacer);\n\t\t\t\tdomBuilder.characters(text,0,text.length);\n\t\t\t\treturn elEndStart;\n\t\t\t//}\n\n\t\t}\n\t}\n\treturn elStartEnd+1;\n}\nfunction fixSelfClosed(source,elStartEnd,tagName,closeMap){\n\t//if(tagName in closeMap){\n\tvar pos = closeMap[tagName];\n\tif(pos == null){\n\t\t//console.log(tagName)\n\t\tpos =  source.lastIndexOf('</'+tagName+'>')\n\t\tif(pos<elStartEnd){//忘记闭合\n\t\t\tpos = source.lastIndexOf('</'+tagName)\n\t\t}\n\t\tcloseMap[tagName] =pos\n\t}\n\treturn pos<elStartEnd;\n\t//}\n}\n\nfunction _copy (source, target) {\n\tfor (var n in source) {\n\t\tif (Object.prototype.hasOwnProperty.call(source, n)) {\n\t\t\ttarget[n] = source[n];\n\t\t}\n\t}\n}\n\nfunction parseDCC(source,start,domBuilder,errorHandler){//sure start with '<!'\n\tvar next= source.charAt(start+2)\n\tswitch(next){\n\tcase '-':\n\t\tif(source.charAt(start + 3) === '-'){\n\t\t\tvar end = source.indexOf('-->',start+4);\n\t\t\t//append comment source.substring(4,end)//<!--\n\t\t\tif(end>start){\n\t\t\t\tdomBuilder.comment(source,start+4,end-start-4);\n\t\t\t\treturn end+3;\n\t\t\t}else{\n\t\t\t\terrorHandler.error(\"Unclosed comment\");\n\t\t\t\treturn -1;\n\t\t\t}\n\t\t}else{\n\t\t\t//error\n\t\t\treturn -1;\n\t\t}\n\tdefault:\n\t\tif(source.substr(start+3,6) == 'CDATA['){\n\t\t\tvar end = source.indexOf(']]>',start+9);\n\t\t\tdomBuilder.startCDATA();\n\t\t\tdomBuilder.characters(source,start+9,end-start-9);\n\t\t\tdomBuilder.endCDATA()\n\t\t\treturn end+3;\n\t\t}\n\t\t//<!DOCTYPE\n\t\t//startDTD(java.lang.String name, java.lang.String publicId, java.lang.String systemId)\n\t\tvar matchs = split(source,start);\n\t\tvar len = matchs.length;\n\t\tif(len>1 && /!doctype/i.test(matchs[0][0])){\n\t\t\tvar name = matchs[1][0];\n\t\t\tvar pubid = false;\n\t\t\tvar sysid = false;\n\t\t\tif(len>3){\n\t\t\t\tif(/^public$/i.test(matchs[2][0])){\n\t\t\t\t\tpubid = matchs[3][0];\n\t\t\t\t\tsysid = len>4 && matchs[4][0];\n\t\t\t\t}else if(/^system$/i.test(matchs[2][0])){\n\t\t\t\t\tsysid = matchs[3][0];\n\t\t\t\t}\n\t\t\t}\n\t\t\tvar lastMatch = matchs[len-1]\n\t\t\tdomBuilder.startDTD(name, pubid, sysid);\n\t\t\tdomBuilder.endDTD();\n\n\t\t\treturn lastMatch.index+lastMatch[0].length\n\t\t}\n\t}\n\treturn -1;\n}\n\n\n\nfunction parseInstruction(source,start,domBuilder){\n\tvar end = source.indexOf('?>',start);\n\tif(end){\n\t\tvar match = source.substring(start,end).match(/^<\\?(\\S*)\\s*([\\s\\S]*?)\\s*$/);\n\t\tif(match){\n\t\t\tvar len = match[0].length;\n\t\t\tdomBuilder.processingInstruction(match[1], match[2]) ;\n\t\t\treturn end+2;\n\t\t}else{//error\n\t\t\treturn -1;\n\t\t}\n\t}\n\treturn -1;\n}\n\nfunction ElementAttributes(){\n\tthis.attributeNames = {}\n}\nElementAttributes.prototype = {\n\tsetTagName:function(tagName){\n\t\tif(!tagNamePattern.test(tagName)){\n\t\t\tthrow new Error('invalid tagName:'+tagName)\n\t\t}\n\t\tthis.tagName = tagName\n\t},\n\taddValue:function(qName, value, offset) {\n\t\tif(!tagNamePattern.test(qName)){\n\t\t\tthrow new Error('invalid attribute:'+qName)\n\t\t}\n\t\tthis.attributeNames[qName] = this.length;\n\t\tthis[this.length++] = {qName:qName,value:value,offset:offset}\n\t},\n\tlength:0,\n\tgetLocalName:function(i){return this[i].localName},\n\tgetLocator:function(i){return this[i].locator},\n\tgetQName:function(i){return this[i].qName},\n\tgetURI:function(i){return this[i].uri},\n\tgetValue:function(i){return this[i].value}\n//\t,getIndex:function(uri, localName)){\n//\t\tif(localName){\n//\n//\t\t}else{\n//\t\t\tvar qName = uri\n//\t\t}\n//\t},\n//\tgetValue:function(){return this.getValue(this.getIndex.apply(this,arguments))},\n//\tgetType:function(uri,localName){}\n//\tgetType:function(i){},\n}\n\n\n\nfunction split(source,start){\n\tvar match;\n\tvar buf = [];\n\tvar reg = /'[^']+'|\"[^\"]+\"|[^\\s<>\\/=]+=?|(\\/?\\s*>|<)/g;\n\treg.lastIndex = start;\n\treg.exec(source);//skip <\n\twhile(match = reg.exec(source)){\n\t\tbuf.push(match);\n\t\tif(match[1])return buf;\n\t}\n}\n\nexports.XMLReader = XMLReader;\nexports.ParseError = ParseError;\n","var conventions = require(\"./conventions\");\nvar dom = require('./dom')\nvar entities = require('./entities');\nvar sax = require('./sax');\n\nvar DOMImplementation = dom.DOMImplementation;\n\nvar NAMESPACE = conventions.NAMESPACE;\n\nvar ParseError = sax.ParseError;\nvar XMLReader = sax.XMLReader;\n\n/**\n * Normalizes line ending according to https://www.w3.org/TR/xml11/#sec-line-ends:\n *\n * > XML parsed entities are often stored in computer files which,\n * > for editing convenience, are organized into lines.\n * > These lines are typically separated by some combination\n * > of the characters CARRIAGE RETURN (#xD) and LINE FEED (#xA).\n * >\n * > To simplify the tasks of applications, the XML processor must behave\n * > as if it normalized all line breaks in external parsed entities (including the document entity)\n * > on input, before parsing, by translating all of the following to a single #xA character:\n * >\n * > 1. the two-character sequence #xD #xA\n * > 2. the two-character sequence #xD #x85\n * > 3. the single character #x85\n * > 4. the single character #x2028\n * > 5. any #xD character that is not immediately followed by #xA or #x85.\n *\n * @param {string} input\n * @returns {string}\n */\nfunction normalizeLineEndings(input) {\n\treturn input\n\t\t.replace(/\\r[\\n\\u0085]/g, '\\n')\n\t\t.replace(/[\\r\\u0085\\u2028]/g, '\\n')\n}\n\n/**\n * @typedef Locator\n * @property {number} [columnNumber]\n * @property {number} [lineNumber]\n */\n\n/**\n * @typedef DOMParserOptions\n * @property {DOMHandler} [domBuilder]\n * @property {Function} [errorHandler]\n * @property {(string) => string} [normalizeLineEndings] used to replace line endings before parsing\n * \t\t\t\t\t\tdefaults to `normalizeLineEndings`\n * @property {Locator} [locator]\n * @property {Record<string, string>} [xmlns]\n *\n * @see normalizeLineEndings\n */\n\n/**\n * The DOMParser interface provides the ability to parse XML or HTML source code\n * from a string into a DOM `Document`.\n *\n * _xmldom is different from the spec in that it allows an `options` parameter,\n * to override the default behavior._\n *\n * @param {DOMParserOptions} [options]\n * @constructor\n *\n * @see https://developer.mozilla.org/en-US/docs/Web/API/DOMParser\n * @see https://html.spec.whatwg.org/multipage/dynamic-markup-insertion.html#dom-parsing-and-serialization\n */\nfunction DOMParser(options){\n\tthis.options = options ||{locator:{}};\n}\n\nDOMParser.prototype.parseFromString = function(source,mimeType){\n\tvar options = this.options;\n\tvar sax =  new XMLReader();\n\tvar domBuilder = options.domBuilder || new DOMHandler();//contentHandler and LexicalHandler\n\tvar errorHandler = options.errorHandler;\n\tvar locator = options.locator;\n\tvar defaultNSMap = options.xmlns||{};\n\tvar isHTML = /\\/x?html?$/.test(mimeType);//mimeType.toLowerCase().indexOf('html') > -1;\n  \tvar entityMap = isHTML ? entities.HTML_ENTITIES : entities.XML_ENTITIES;\n\tif(locator){\n\t\tdomBuilder.setDocumentLocator(locator)\n\t}\n\n\tsax.errorHandler = buildErrorHandler(errorHandler,domBuilder,locator);\n\tsax.domBuilder = options.domBuilder || domBuilder;\n\tif(isHTML){\n\t\tdefaultNSMap[''] = NAMESPACE.HTML;\n\t}\n\tdefaultNSMap.xml = defaultNSMap.xml || NAMESPACE.XML;\n\tvar normalize = options.normalizeLineEndings || normalizeLineEndings;\n\tif (source && typeof source === 'string') {\n\t\tsax.parse(\n\t\t\tnormalize(source),\n\t\t\tdefaultNSMap,\n\t\t\tentityMap\n\t\t)\n\t} else {\n\t\tsax.errorHandler.error('invalid doc source')\n\t}\n\treturn domBuilder.doc;\n}\nfunction buildErrorHandler(errorImpl,domBuilder,locator){\n\tif(!errorImpl){\n\t\tif(domBuilder instanceof DOMHandler){\n\t\t\treturn domBuilder;\n\t\t}\n\t\terrorImpl = domBuilder ;\n\t}\n\tvar errorHandler = {}\n\tvar isCallback = errorImpl instanceof Function;\n\tlocator = locator||{}\n\tfunction build(key){\n\t\tvar fn = errorImpl[key];\n\t\tif(!fn && isCallback){\n\t\t\tfn = errorImpl.length == 2?function(msg){errorImpl(key,msg)}:errorImpl;\n\t\t}\n\t\terrorHandler[key] = fn && function(msg){\n\t\t\tfn('[xmldom '+key+']\\t'+msg+_locator(locator));\n\t\t}||function(){};\n\t}\n\tbuild('warning');\n\tbuild('error');\n\tbuild('fatalError');\n\treturn errorHandler;\n}\n\n//console.log('#\\n\\n\\n\\n\\n\\n\\n####')\n/**\n * +ContentHandler+ErrorHandler\n * +LexicalHandler+EntityResolver2\n * -DeclHandler-DTDHandler\n *\n * DefaultHandler:EntityResolver, DTDHandler, ContentHandler, ErrorHandler\n * DefaultHandler2:DefaultHandler,LexicalHandler, DeclHandler, EntityResolver2\n * @link http://www.saxproject.org/apidoc/org/xml/sax/helpers/DefaultHandler.html\n */\nfunction DOMHandler() {\n    this.cdata = false;\n}\nfunction position(locator,node){\n\tnode.lineNumber = locator.lineNumber;\n\tnode.columnNumber = locator.columnNumber;\n}\n/**\n * @see org.xml.sax.ContentHandler#startDocument\n * @link http://www.saxproject.org/apidoc/org/xml/sax/ContentHandler.html\n */\nDOMHandler.prototype = {\n\tstartDocument : function() {\n    \tthis.doc = new DOMImplementation().createDocument(null, null, null);\n    \tif (this.locator) {\n        \tthis.doc.documentURI = this.locator.systemId;\n    \t}\n\t},\n\tstartElement:function(namespaceURI, localName, qName, attrs) {\n\t\tvar doc = this.doc;\n\t    var el = doc.createElementNS(namespaceURI, qName||localName);\n\t    var len = attrs.length;\n\t    appendElement(this, el);\n\t    this.currentElement = el;\n\n\t\tthis.locator && position(this.locator,el)\n\t    for (var i = 0 ; i < len; i++) {\n\t        var namespaceURI = attrs.getURI(i);\n\t        var value = attrs.getValue(i);\n\t        var qName = attrs.getQName(i);\n\t\t\tvar attr = doc.createAttributeNS(namespaceURI, qName);\n\t\t\tthis.locator &&position(attrs.getLocator(i),attr);\n\t\t\tattr.value = attr.nodeValue = value;\n\t\t\tel.setAttributeNode(attr)\n\t    }\n\t},\n\tendElement:function(namespaceURI, localName, qName) {\n\t\tvar current = this.currentElement\n\t\tvar tagName = current.tagName;\n\t\tthis.currentElement = current.parentNode;\n\t},\n\tstartPrefixMapping:function(prefix, uri) {\n\t},\n\tendPrefixMapping:function(prefix) {\n\t},\n\tprocessingInstruction:function(target, data) {\n\t    var ins = this.doc.createProcessingInstruction(target, data);\n\t    this.locator && position(this.locator,ins)\n\t    appendElement(this, ins);\n\t},\n\tignorableWhitespace:function(ch, start, length) {\n\t},\n\tcharacters:function(chars, start, length) {\n\t\tchars = _toString.apply(this,arguments)\n\t\t//console.log(chars)\n\t\tif(chars){\n\t\t\tif (this.cdata) {\n\t\t\t\tvar charNode = this.doc.createCDATASection(chars);\n\t\t\t} else {\n\t\t\t\tvar charNode = this.doc.createTextNode(chars);\n\t\t\t}\n\t\t\tif(this.currentElement){\n\t\t\t\tthis.currentElement.appendChild(charNode);\n\t\t\t}else if(/^\\s*$/.test(chars)){\n\t\t\t\tthis.doc.appendChild(charNode);\n\t\t\t\t//process xml\n\t\t\t}\n\t\t\tthis.locator && position(this.locator,charNode)\n\t\t}\n\t},\n\tskippedEntity:function(name) {\n\t},\n\tendDocument:function() {\n\t\tthis.doc.normalize();\n\t},\n\tsetDocumentLocator:function (locator) {\n\t    if(this.locator = locator){// && !('lineNumber' in locator)){\n\t    \tlocator.lineNumber = 0;\n\t    }\n\t},\n\t//LexicalHandler\n\tcomment:function(chars, start, length) {\n\t\tchars = _toString.apply(this,arguments)\n\t    var comm = this.doc.createComment(chars);\n\t    this.locator && position(this.locator,comm)\n\t    appendElement(this, comm);\n\t},\n\n\tstartCDATA:function() {\n\t    //used in characters() methods\n\t    this.cdata = true;\n\t},\n\tendCDATA:function() {\n\t    this.cdata = false;\n\t},\n\n\tstartDTD:function(name, publicId, systemId) {\n\t\tvar impl = this.doc.implementation;\n\t    if (impl && impl.createDocumentType) {\n\t        var dt = impl.createDocumentType(name, publicId, systemId);\n\t        this.locator && position(this.locator,dt)\n\t        appendElement(this, dt);\n\t\t\t\t\tthis.doc.doctype = dt;\n\t    }\n\t},\n\t/**\n\t * @see org.xml.sax.ErrorHandler\n\t * @link http://www.saxproject.org/apidoc/org/xml/sax/ErrorHandler.html\n\t */\n\twarning:function(error) {\n\t\tconsole.warn('[xmldom warning]\\t'+error,_locator(this.locator));\n\t},\n\terror:function(error) {\n\t\tconsole.error('[xmldom error]\\t'+error,_locator(this.locator));\n\t},\n\tfatalError:function(error) {\n\t\tthrow new ParseError(error, this.locator);\n\t}\n}\nfunction _locator(l){\n\tif(l){\n\t\treturn '\\n@'+(l.systemId ||'')+'#[line:'+l.lineNumber+',col:'+l.columnNumber+']'\n\t}\n}\nfunction _toString(chars,start,length){\n\tif(typeof chars == 'string'){\n\t\treturn chars.substr(start,length)\n\t}else{//java sax connect width xmldom on rhino(what about: \"? && !(chars instanceof String)\")\n\t\tif(chars.length >= start+length || start){\n\t\t\treturn new java.lang.String(chars,start,length)+'';\n\t\t}\n\t\treturn chars;\n\t}\n}\n\n/*\n * @link http://www.saxproject.org/apidoc/org/xml/sax/ext/LexicalHandler.html\n * used method of org.xml.sax.ext.LexicalHandler:\n *  #comment(chars, start, length)\n *  #startCDATA()\n *  #endCDATA()\n *  #startDTD(name, publicId, systemId)\n *\n *\n * IGNORED method of org.xml.sax.ext.LexicalHandler:\n *  #endDTD()\n *  #startEntity(name)\n *  #endEntity(name)\n *\n *\n * @link http://www.saxproject.org/apidoc/org/xml/sax/ext/DeclHandler.html\n * IGNORED method of org.xml.sax.ext.DeclHandler\n * \t#attributeDecl(eName, aName, type, mode, value)\n *  #elementDecl(name, model)\n *  #externalEntityDecl(name, publicId, systemId)\n *  #internalEntityDecl(name, value)\n * @link http://www.saxproject.org/apidoc/org/xml/sax/ext/EntityResolver2.html\n * IGNORED method of org.xml.sax.EntityResolver2\n *  #resolveEntity(String name,String publicId,String baseURI,String systemId)\n *  #resolveEntity(publicId, systemId)\n *  #getExternalSubset(name, baseURI)\n * @link http://www.saxproject.org/apidoc/org/xml/sax/DTDHandler.html\n * IGNORED method of org.xml.sax.DTDHandler\n *  #notationDecl(name, publicId, systemId) {};\n *  #unparsedEntityDecl(name, publicId, systemId, notationName) {};\n */\n\"endDTD,startEntity,endEntity,attributeDecl,elementDecl,externalEntityDecl,internalEntityDecl,resolveEntity,getExternalSubset,notationDecl,unparsedEntityDecl\".replace(/\\w+/g,function(key){\n\tDOMHandler.prototype[key] = function(){return null}\n})\n\n/* Private static helpers treated below as private instance methods, so don't need to add these to the public API; we might use a Relator to also get rid of non-standard public properties */\nfunction appendElement (hander,node) {\n    if (!hander.currentElement) {\n        hander.doc.appendChild(node);\n    } else {\n        hander.currentElement.appendChild(node);\n    }\n}//appendChild and setAttributeNS are preformance key\n\nexports.__DOMHandler = DOMHandler;\nexports.normalizeLineEndings = normalizeLineEndings;\nexports.DOMParser = DOMParser;\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.assertIsDocumentFragmentNode = exports.assertIsDocumentTypeNode = exports.assertIsDocumentNode = exports.assertIsCommentNode = exports.assertIsProcessingInstructionNode = exports.assertIsCDATASectionNode = exports.assertIsTextNode = exports.assertIsAttributeNode = exports.assertIsElementNode = exports.isDocumentFragmentNode = exports.isDocumentTypeNode = exports.isDocumentNode = exports.isCommentNode = exports.isProcessingInstructionNode = exports.isCDATASectionNode = exports.isTextNode = exports.isAttributeNode = exports.isElementNode = exports.assertIsArrayOfNodes = exports.isArrayOfNodes = exports.assertIsNodeLike = exports.isNodeLike = exports.NodeTypes = void 0;\nvar NodeTypes;\n(function (NodeTypes) {\n    NodeTypes[NodeTypes[\"ELEMENT_NODE\"] = 1] = \"ELEMENT_NODE\";\n    NodeTypes[NodeTypes[\"ATTRIBUTE_NODE\"] = 2] = \"ATTRIBUTE_NODE\";\n    NodeTypes[NodeTypes[\"TEXT_NODE\"] = 3] = \"TEXT_NODE\";\n    NodeTypes[NodeTypes[\"CDATA_SECTION_NODE\"] = 4] = \"CDATA_SECTION_NODE\";\n    NodeTypes[NodeTypes[\"PROCESSING_INSTRUCTION_NODE\"] = 7] = \"PROCESSING_INSTRUCTION_NODE\";\n    NodeTypes[NodeTypes[\"COMMENT_NODE\"] = 8] = \"COMMENT_NODE\";\n    NodeTypes[NodeTypes[\"DOCUMENT_NODE\"] = 9] = \"DOCUMENT_NODE\";\n    NodeTypes[NodeTypes[\"DOCUMENT_TYPE_NODE\"] = 10] = \"DOCUMENT_TYPE_NODE\";\n    NodeTypes[NodeTypes[\"DOCUMENT_FRAGMENT_NODE\"] = 11] = \"DOCUMENT_FRAGMENT_NODE\";\n})(NodeTypes || (exports.NodeTypes = NodeTypes = {}));\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction isNodeLike(value) {\n    return (value &&\n        typeof value === \"object\" &&\n        Number.isInteger(value.nodeType) &&\n        value.nodeType >= 1 &&\n        value.nodeType <= 11 &&\n        typeof value.nodeName === \"string\" &&\n        typeof value.appendChild === \"function\" &&\n        typeof value.removeChild === \"function\");\n}\nexports.isNodeLike = isNodeLike;\nfunction assertIsNodeLike(value) {\n    if (!isNodeLike(value)) {\n        throw new Error(`Value is not a Node-like object. Received: ${value}`);\n    }\n}\nexports.assertIsNodeLike = assertIsNodeLike;\nfunction isArrayOfNodes(value) {\n    return Array.isArray(value) && value.every(isNodeLike);\n}\nexports.isArrayOfNodes = isArrayOfNodes;\nfunction assertIsArrayOfNodes(value) {\n    if (!isArrayOfNodes(value)) {\n        throw new Error(\"Value is not an array of Nodes\");\n    }\n}\nexports.assertIsArrayOfNodes = assertIsArrayOfNodes;\nfunction isNodeOfType(type, value) {\n    return isNodeLike(value) && value.nodeType === type;\n}\nfunction assertIsNodeOfType(type, value) {\n    const typeName = Object.keys(NodeTypes).find((key) => NodeTypes[key] === type);\n    if (!isNodeOfType(type, value)) {\n        throw new Error(`Value is not of type ${typeName}`);\n    }\n}\nconst isElementNode = (value) => isNodeOfType(NodeTypes.ELEMENT_NODE, value);\nexports.isElementNode = isElementNode;\nconst isAttributeNode = (value) => isNodeOfType(NodeTypes.ATTRIBUTE_NODE, value);\nexports.isAttributeNode = isAttributeNode;\nconst isTextNode = (value) => isNodeOfType(NodeTypes.TEXT_NODE, value);\nexports.isTextNode = isTextNode;\nconst isCDATASectionNode = (value) => isNodeOfType(NodeTypes.CDATA_SECTION_NODE, value);\nexports.isCDATASectionNode = isCDATASectionNode;\nconst isProcessingInstructionNode = (value) => isNodeOfType(NodeTypes.PROCESSING_INSTRUCTION_NODE, value);\nexports.isProcessingInstructionNode = isProcessingInstructionNode;\nconst isCommentNode = (value) => isNodeOfType(NodeTypes.COMMENT_NODE, value);\nexports.isCommentNode = isCommentNode;\nconst isDocumentNode = (value) => isNodeOfType(NodeTypes.DOCUMENT_NODE, value);\nexports.isDocumentNode = isDocumentNode;\nconst isDocumentTypeNode = (value) => isNodeOfType(NodeTypes.DOCUMENT_TYPE_NODE, value);\nexports.isDocumentTypeNode = isDocumentTypeNode;\nconst isDocumentFragmentNode = (value) => isNodeOfType(NodeTypes.DOCUMENT_FRAGMENT_NODE, value);\nexports.isDocumentFragmentNode = isDocumentFragmentNode;\nconst assertIsElementNode = (value) => {\n    assertIsNodeOfType(NodeTypes.ELEMENT_NODE, value);\n};\nexports.assertIsElementNode = assertIsElementNode;\nconst assertIsAttributeNode = (value) => assertIsNodeOfType(NodeTypes.ATTRIBUTE_NODE, value);\nexports.assertIsAttributeNode = assertIsAttributeNode;\nconst assertIsTextNode = (value) => assertIsNodeOfType(NodeTypes.TEXT_NODE, value);\nexports.assertIsTextNode = assertIsTextNode;\nconst assertIsCDATASectionNode = (value) => assertIsNodeOfType(NodeTypes.CDATA_SECTION_NODE, value);\nexports.assertIsCDATASectionNode = assertIsCDATASectionNode;\nconst assertIsProcessingInstructionNode = (value) => assertIsNodeOfType(NodeTypes.PROCESSING_INSTRUCTION_NODE, value);\nexports.assertIsProcessingInstructionNode = assertIsProcessingInstructionNode;\nconst assertIsCommentNode = (value) => assertIsNodeOfType(NodeTypes.COMMENT_NODE, value);\nexports.assertIsCommentNode = assertIsCommentNode;\nconst assertIsDocumentNode = (value) => assertIsNodeOfType(NodeTypes.DOCUMENT_NODE, value);\nexports.assertIsDocumentNode = assertIsDocumentNode;\nconst assertIsDocumentTypeNode = (value) => assertIsNodeOfType(NodeTypes.DOCUMENT_TYPE_NODE, value);\nexports.assertIsDocumentTypeNode = assertIsDocumentTypeNode;\nconst assertIsDocumentFragmentNode = (value) => assertIsNodeOfType(NodeTypes.DOCUMENT_FRAGMENT_NODE, value);\nexports.assertIsDocumentFragmentNode = assertIsDocumentFragmentNode;\n//# sourceMappingURL=index.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.validateDigestValue = exports.findAncestorNs = exports.derToPem = exports.pemToDer = exports.normalizePem = exports.BASE64_REGEX = exports.EXTRACT_X509_CERTS = exports.PEM_FORMAT_REGEX = exports.encodeSpecialCharactersInText = exports.encodeSpecialCharactersInAttribute = exports.findChilds = exports.findChildren = exports.findAttr = exports.isArrayHasLength = void 0;\nconst xpath = require(\"xpath\");\nconst isDomNode = require(\"@xmldom/is-dom-node\");\nfunction isArrayHasLength(array) {\n    return Array.isArray(array) && array.length > 0;\n}\nexports.isArrayHasLength = isArrayHasLength;\nfunction attrEqualsExplicitly(attr, localName, namespace) {\n    return attr.localName === localName && (attr.namespaceURI === namespace || namespace == null);\n}\nfunction attrEqualsImplicitly(attr, localName, namespace, node) {\n    return (attr.localName === localName &&\n        ((!attr.namespaceURI && node?.namespaceURI === namespace) || namespace == null));\n}\nfunction findAttr(element, localName, namespace) {\n    for (let i = 0; i < element.attributes.length; i++) {\n        const attr = element.attributes[i];\n        if (attrEqualsExplicitly(attr, localName, namespace) ||\n            attrEqualsImplicitly(attr, localName, namespace, element)) {\n            return attr;\n        }\n    }\n    return null;\n}\nexports.findAttr = findAttr;\nfunction findChildren(node, localName, namespace) {\n    const element = node.documentElement ?? node;\n    const res = [];\n    for (let i = 0; i < element.childNodes.length; i++) {\n        const child = element.childNodes[i];\n        if (isDomNode.isElementNode(child) &&\n            child.localName === localName &&\n            (child.namespaceURI === namespace || namespace == null)) {\n            res.push(child);\n        }\n    }\n    return res;\n}\nexports.findChildren = findChildren;\n/** @deprecated */\nfunction findChilds(node, localName, namespace) {\n    return findChildren(node, localName, namespace);\n}\nexports.findChilds = findChilds;\nconst xml_special_to_encoded_attribute = {\n    \"&\": \"&amp;\",\n    \"<\": \"&lt;\",\n    '\"': \"&quot;\",\n    \"\\r\": \"&#xD;\",\n    \"\\n\": \"&#xA;\",\n    \"\\t\": \"&#x9;\",\n};\nconst xml_special_to_encoded_text = {\n    \"&\": \"&amp;\",\n    \"<\": \"&lt;\",\n    \">\": \"&gt;\",\n    \"\\r\": \"&#xD;\",\n};\nfunction encodeSpecialCharactersInAttribute(attributeValue) {\n    return attributeValue.replace(/([&<\"\\r\\n\\t])/g, function (str, item) {\n        /** Special character normalization.\n         * @see:\n         * - https://www.w3.org/TR/xml-c14n#ProcessingModel (Attribute Nodes)\n         * - https://www.w3.org/TR/xml-c14n#Example-Chars\n         */\n        return xml_special_to_encoded_attribute[item];\n    });\n}\nexports.encodeSpecialCharactersInAttribute = encodeSpecialCharactersInAttribute;\nfunction encodeSpecialCharactersInText(text) {\n    return text.replace(/([&<>\\r])/g, function (str, item) {\n        /** Special character normalization.\n         * @see:\n         * - https://www.w3.org/TR/xml-c14n#ProcessingModel (Text Nodes)\n         * - https://www.w3.org/TR/xml-c14n#Example-Chars\n         */\n        return xml_special_to_encoded_text[item];\n    });\n}\nexports.encodeSpecialCharactersInText = encodeSpecialCharactersInText;\n/**\n * PEM format has wide range of usages, but this library\n * is enforcing RFC7468 which focuses on PKIX, PKCS and CMS.\n *\n * https://www.rfc-editor.org/rfc/rfc7468\n *\n * PEM_FORMAT_REGEX is validating given PEM file against RFC7468 'stricttextualmsg' definition.\n *\n * With few exceptions;\n *  - 'posteb' MAY have 'eol', but it is not mandatory.\n *  - 'preeb' and 'posteb' lines are limited to 64 characters, but\n *     should not cause any issues in context of PKIX, PKCS and CMS.\n */\nexports.PEM_FORMAT_REGEX = new RegExp(\"^-----BEGIN [A-Z\\x20]{1,48}-----([^-]*)-----END [A-Z\\x20]{1,48}-----$\", \"s\");\nexports.EXTRACT_X509_CERTS = new RegExp(\"-----BEGIN CERTIFICATE-----[^-]*-----END CERTIFICATE-----\", \"g\");\nexports.BASE64_REGEX = new RegExp(\"^(?:[A-Za-z0-9\\\\+\\\\/]{4}\\\\n{0,1})*(?:[A-Za-z0-9\\\\+\\\\/]{2}==|[A-Za-z0-9\\\\+\\\\/]{3}=)?$\", \"s\");\n/**\n * -----BEGIN [LABEL]-----\n * base64([DATA])\n * -----END [LABEL]-----\n *\n * Above is shown what PEM file looks like. As can be seen, base64 data\n * can be in single line or multiple lines.\n *\n * This function normalizes PEM presentation to;\n *  - contain PEM header and footer as they are given\n *  - normalize line endings to '\\n'\n *  - normalize line length to maximum of 64 characters\n *  - ensure that 'preeb' has line ending '\\n'\n *\n * With a couple of notes:\n *  - 'eol' is normalized to '\\n'\n *\n * @param pem The PEM string to normalize to RFC7468 'stricttextualmsg' definition\n */\nfunction normalizePem(pem) {\n    return `${(pem\n        .trim()\n        .replace(/(\\r\\n|\\r)/g, \"\\n\")\n        .match(/.{1,64}/g) ?? []).join(\"\\n\")}\\n`;\n}\nexports.normalizePem = normalizePem;\n/**\n * @param pem The PEM-encoded base64 certificate to strip headers from\n */\nfunction pemToDer(pem) {\n    if (!exports.PEM_FORMAT_REGEX.test(pem.trim())) {\n        throw new Error(\"Invalid PEM format.\");\n    }\n    return Buffer.from(pem\n        .replace(/(\\r\\n|\\r)/g, \"\")\n        .replace(/-----BEGIN [A-Z\\x20]{1,48}-----\\n?/, \"\")\n        .replace(/-----END [A-Z\\x20]{1,48}-----\\n?/, \"\"), \"base64\");\n}\nexports.pemToDer = pemToDer;\n/**\n * @param der The DER-encoded base64 certificate to add PEM headers too\n * @param pemLabel The label of the header and footer to add\n */\nfunction derToPem(der, pemLabel) {\n    const base64Der = Buffer.isBuffer(der)\n        ? der.toString(\"base64\").trim()\n        : der.replace(/(\\r\\n|\\r)/g, \"\").trim();\n    if (exports.PEM_FORMAT_REGEX.test(base64Der)) {\n        return normalizePem(base64Der);\n    }\n    if (exports.BASE64_REGEX.test(base64Der.replace(/ /g, \"\"))) {\n        if (pemLabel == null) {\n            throw new Error(\"PEM label is required when DER is given.\");\n        }\n        const pem = `-----BEGIN ${pemLabel}-----\\n${base64Der.replace(/ /g, \"\")}\\n-----END ${pemLabel}-----`;\n        return normalizePem(pem);\n    }\n    throw new Error(\"Unknown DER format.\");\n}\nexports.derToPem = derToPem;\nfunction collectAncestorNamespaces(node, nsArray = []) {\n    if (!isDomNode.isElementNode(node.parentNode)) {\n        return nsArray;\n    }\n    const parent = node.parentNode;\n    if (!parent) {\n        return nsArray;\n    }\n    if (parent.attributes && parent.attributes.length > 0) {\n        for (let i = 0; i < parent.attributes.length; i++) {\n            const attr = parent.attributes[i];\n            if (attr && attr.nodeName && attr.nodeName.search(/^xmlns:?/) !== -1) {\n                nsArray.push({\n                    prefix: attr.nodeName.replace(/^xmlns:?/, \"\"),\n                    namespaceURI: attr.nodeValue || \"\",\n                });\n            }\n        }\n    }\n    return collectAncestorNamespaces(parent, nsArray);\n}\nfunction findNSPrefix(subset) {\n    const subsetAttributes = subset.attributes;\n    for (let k = 0; k < subsetAttributes.length; k++) {\n        const nodeName = subsetAttributes[k].nodeName;\n        if (nodeName.search(/^xmlns:?/) !== -1) {\n            return nodeName.replace(/^xmlns:?/, \"\");\n        }\n    }\n    return subset.prefix || \"\";\n}\nfunction isElementSubset(docSubset) {\n    return docSubset.every((node) => isDomNode.isElementNode(node));\n}\n/**\n * Extract ancestor namespaces in order to import it to root of document subset\n * which is being canonicalized for non-exclusive c14n.\n *\n * @param doc - Usually a product from `new xmldom.DOMParser().parseFromString()`\n * @param docSubsetXpath - xpath query to get document subset being canonicalized\n * @param namespaceResolver - xpath namespace resolver\n * @returns i.e. [{prefix: \"saml\", namespaceURI: \"urn:oasis:names:tc:SAML:2.0:assertion\"}]\n */\nfunction findAncestorNs(doc, docSubsetXpath, namespaceResolver) {\n    if (docSubsetXpath == null) {\n        return [];\n    }\n    const docSubset = xpath.selectWithResolver(docSubsetXpath, doc, namespaceResolver);\n    if (!isArrayHasLength(docSubset)) {\n        return [];\n    }\n    if (!isElementSubset(docSubset)) {\n        throw new Error(\"Document subset must be list of elements\");\n    }\n    // Remove duplicate on ancestor namespace\n    const ancestorNs = collectAncestorNamespaces(docSubset[0]);\n    const ancestorNsWithoutDuplicate = [];\n    for (let i = 0; i < ancestorNs.length; i++) {\n        let notOnTheList = true;\n        for (const v in ancestorNsWithoutDuplicate) {\n            if (ancestorNsWithoutDuplicate[v].prefix === ancestorNs[i].prefix) {\n                notOnTheList = false;\n                break;\n            }\n        }\n        if (notOnTheList) {\n            ancestorNsWithoutDuplicate.push(ancestorNs[i]);\n        }\n    }\n    // Remove namespaces which are already declared in the subset with the same prefix\n    const returningNs = [];\n    const subsetNsPrefix = findNSPrefix(docSubset[0]);\n    for (const ancestorNs of ancestorNsWithoutDuplicate) {\n        if (ancestorNs.prefix !== subsetNsPrefix) {\n            returningNs.push(ancestorNs);\n        }\n    }\n    return returningNs;\n}\nexports.findAncestorNs = findAncestorNs;\nfunction validateDigestValue(digest, expectedDigest) {\n    const buffer = Buffer.from(digest, \"base64\");\n    const expectedBuffer = Buffer.from(expectedDigest, \"base64\");\n    if (typeof buffer.equals === \"function\") {\n        return buffer.equals(expectedBuffer);\n    }\n    if (buffer.length !== expectedBuffer.length) {\n        return false;\n    }\n    for (let i = 0; i < buffer.length; i++) {\n        if (buffer[i] !== expectedBuffer[i]) {\n            return false;\n        }\n    }\n    return true;\n}\nexports.validateDigestValue = validateDigestValue;\n//# sourceMappingURL=utils.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Sha512 = exports.Sha256 = exports.Sha1 = void 0;\nconst crypto = require(\"crypto\");\nclass Sha1 {\n    constructor() {\n        this.getHash = function (xml) {\n            const shasum = crypto.createHash(\"sha1\");\n            shasum.update(xml, \"utf8\");\n            const res = shasum.digest(\"base64\");\n            return res;\n        };\n        this.getAlgorithmName = function () {\n            return \"http://www.w3.org/2000/09/xmldsig#sha1\";\n        };\n    }\n}\nexports.Sha1 = Sha1;\nclass Sha256 {\n    constructor() {\n        this.getHash = function (xml) {\n            const shasum = crypto.createHash(\"sha256\");\n            shasum.update(xml, \"utf8\");\n            const res = shasum.digest(\"base64\");\n            return res;\n        };\n        this.getAlgorithmName = function () {\n            return \"http://www.w3.org/2001/04/xmlenc#sha256\";\n        };\n    }\n}\nexports.Sha256 = Sha256;\nclass Sha512 {\n    constructor() {\n        this.getHash = function (xml) {\n            const shasum = crypto.createHash(\"sha512\");\n            shasum.update(xml, \"utf8\");\n            const res = shasum.digest(\"base64\");\n            return res;\n        };\n        this.getAlgorithmName = function () {\n            return \"http://www.w3.org/2001/04/xmlenc#sha512\";\n        };\n    }\n}\nexports.Sha512 = Sha512;\n//# sourceMappingURL=hash-algorithms.js.map","\"use strict\";\n/* eslint-disable no-unused-vars */\n// Type definitions for @node-saml/xml-crypto\n// Project: https://github.com/node-saml/xml-crypto#readme\n// Original definitions by: Eric Heikes <https://github.com/eheikes>\n//                          Max Chehab <https://github.com/maxchehab>\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.createOptionalCallbackFunction = void 0;\n/**\n * ### Sign\n * #### Properties\n * - {@link SignedXml#privateKey} [required]\n * - {@link SignedXml#publicCert} [optional]\n * - {@link SignedXml#signatureAlgorithm} [optional]\n * - {@link SignedXml#canonicalizationAlgorithm} [optional]\n * #### Api\n *  - {@link SignedXml#addReference}\n *  - {@link SignedXml#computeSignature}\n *  - {@link SignedXml#getSignedXml}\n *  - {@link SignedXml#getSignatureXml}\n *  - {@link SignedXml#getOriginalXmlWithIds}\n *\n * ### Verify\n * #### Properties\n * -  {@link SignedXml#publicCert} [optional]\n * #### Api\n *  - {@link SignedXml#loadSignature}\n *  - {@link SignedXml#checkSignature}\n */\nfunction isErrorFirstCallback(possibleCallback) {\n    return typeof possibleCallback === \"function\";\n}\n/**\n * This function will add a callback version of a sync function.\n *\n * This follows the factory pattern.\n * Just call this function, passing the function that you'd like to add a callback version of.\n */\nfunction createOptionalCallbackFunction(syncVersion) {\n    return ((...args) => {\n        const possibleCallback = args[args.length - 1];\n        if (isErrorFirstCallback(possibleCallback)) {\n            try {\n                const result = syncVersion(...args.slice(0, -1));\n                possibleCallback(null, result);\n            }\n            catch (err) {\n                possibleCallback(err instanceof Error ? err : new Error(\"Unknown error\"));\n            }\n        }\n        else {\n            return syncVersion(...args);\n        }\n    });\n}\nexports.createOptionalCallbackFunction = createOptionalCallbackFunction;\n//# sourceMappingURL=types.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.HmacSha1 = exports.RsaSha512 = exports.RsaSha256 = exports.RsaSha1 = void 0;\nconst crypto = require(\"crypto\");\nconst types_1 = require(\"./types\");\nclass RsaSha1 {\n    constructor() {\n        this.getSignature = (0, types_1.createOptionalCallbackFunction)((signedInfo, privateKey) => {\n            const signer = crypto.createSign(\"RSA-SHA1\");\n            signer.update(signedInfo);\n            const res = signer.sign(privateKey, \"base64\");\n            return res;\n        });\n        this.verifySignature = (0, types_1.createOptionalCallbackFunction)((material, key, signatureValue) => {\n            const verifier = crypto.createVerify(\"RSA-SHA1\");\n            verifier.update(material);\n            const res = verifier.verify(key, signatureValue, \"base64\");\n            return res;\n        });\n        this.getAlgorithmName = () => {\n            return \"http://www.w3.org/2000/09/xmldsig#rsa-sha1\";\n        };\n    }\n}\nexports.RsaSha1 = RsaSha1;\nclass RsaSha256 {\n    constructor() {\n        this.getSignature = (0, types_1.createOptionalCallbackFunction)((signedInfo, privateKey) => {\n            const signer = crypto.createSign(\"RSA-SHA256\");\n            signer.update(signedInfo);\n            const res = signer.sign(privateKey, \"base64\");\n            return res;\n        });\n        this.verifySignature = (0, types_1.createOptionalCallbackFunction)((material, key, signatureValue) => {\n            const verifier = crypto.createVerify(\"RSA-SHA256\");\n            verifier.update(material);\n            const res = verifier.verify(key, signatureValue, \"base64\");\n            return res;\n        });\n        this.getAlgorithmName = () => {\n            return \"http://www.w3.org/2001/04/xmldsig-more#rsa-sha256\";\n        };\n    }\n}\nexports.RsaSha256 = RsaSha256;\nclass RsaSha512 {\n    constructor() {\n        this.getSignature = (0, types_1.createOptionalCallbackFunction)((signedInfo, privateKey) => {\n            const signer = crypto.createSign(\"RSA-SHA512\");\n            signer.update(signedInfo);\n            const res = signer.sign(privateKey, \"base64\");\n            return res;\n        });\n        this.verifySignature = (0, types_1.createOptionalCallbackFunction)((material, key, signatureValue) => {\n            const verifier = crypto.createVerify(\"RSA-SHA512\");\n            verifier.update(material);\n            const res = verifier.verify(key, signatureValue, \"base64\");\n            return res;\n        });\n        this.getAlgorithmName = () => {\n            return \"http://www.w3.org/2001/04/xmldsig-more#rsa-sha512\";\n        };\n    }\n}\nexports.RsaSha512 = RsaSha512;\nclass HmacSha1 {\n    constructor() {\n        this.getSignature = (0, types_1.createOptionalCallbackFunction)((signedInfo, privateKey) => {\n            const signer = crypto.createHmac(\"SHA1\", privateKey);\n            signer.update(signedInfo);\n            const res = signer.digest(\"base64\");\n            return res;\n        });\n        this.verifySignature = (0, types_1.createOptionalCallbackFunction)((material, key, signatureValue) => {\n            const verifier = crypto.createHmac(\"SHA1\", key);\n            verifier.update(material);\n            const res = verifier.digest(\"base64\");\n            return res === signatureValue;\n        });\n        this.getAlgorithmName = () => {\n            return \"http://www.w3.org/2000/09/xmldsig#hmac-sha1\";\n        };\n    }\n}\nexports.HmacSha1 = HmacSha1;\n//# sourceMappingURL=signature-algorithms.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.SignedXml = void 0;\nconst xpath = require(\"xpath\");\nconst xmldom = require(\"@xmldom/xmldom\");\nconst utils = require(\"./utils\");\nconst c14n = require(\"./c14n-canonicalization\");\nconst execC14n = require(\"./exclusive-canonicalization\");\nconst envelopedSignatures = require(\"./enveloped-signature\");\nconst hashAlgorithms = require(\"./hash-algorithms\");\nconst signatureAlgorithms = require(\"./signature-algorithms\");\nconst isDomNode = require(\"@xmldom/is-dom-node\");\nclass SignedXml {\n    /**\n     * The SignedXml constructor provides an abstraction for sign and verify xml documents. The object is constructed using\n     * @param options {@link SignedXmlOptions}\n     */\n    constructor(options = {}) {\n        /**\n         * One of the supported signature algorithms.\n         * @see {@link SignatureAlgorithmType}\n         */\n        this.signatureAlgorithm = undefined;\n        /**\n         * Rules used to convert an XML document into its canonical form.\n         */\n        this.canonicalizationAlgorithm = undefined;\n        /**\n         * It specifies a list of namespace prefixes that should be considered \"inclusive\" during the canonicalization process.\n         */\n        this.inclusiveNamespacesPrefixList = [];\n        this.namespaceResolver = {\n            lookupNamespaceURI: function ( /* prefix */) {\n                throw new Error(\"Not implemented\");\n            },\n        };\n        this.implicitTransforms = [];\n        this.keyInfoAttributes = {};\n        this.getKeyInfoContent = SignedXml.getKeyInfoContent;\n        this.getCertFromKeyInfo = SignedXml.getCertFromKeyInfo;\n        // Internal state\n        this.id = 0;\n        this.signedXml = \"\";\n        this.signatureXml = \"\";\n        this.signatureNode = null;\n        this.signatureValue = \"\";\n        this.originalXmlWithIds = \"\";\n        this.keyInfo = null;\n        /**\n         * Contains the references that were signed.\n         * @see {@link Reference}\n         */\n        this.references = [];\n        /**\n         *  To add a new transformation algorithm create a new class that implements the {@link TransformationAlgorithm} interface, and register it here. More info: {@link https://github.com/node-saml/xml-crypto#customizing-algorithms|Customizing Algorithms}\n         */\n        this.CanonicalizationAlgorithms = {\n            \"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\": c14n.C14nCanonicalization,\n            \"http://www.w3.org/TR/2001/REC-xml-c14n-20010315#WithComments\": c14n.C14nCanonicalizationWithComments,\n            \"http://www.w3.org/2001/10/xml-exc-c14n#\": execC14n.ExclusiveCanonicalization,\n            \"http://www.w3.org/2001/10/xml-exc-c14n#WithComments\": execC14n.ExclusiveCanonicalizationWithComments,\n            \"http://www.w3.org/2000/09/xmldsig#enveloped-signature\": envelopedSignatures.EnvelopedSignature,\n        };\n        /**\n         * To add a new hash algorithm create a new class that implements the {@link HashAlgorithm} interface, and register it here. More info: {@link https://github.com/node-saml/xml-crypto#customizing-algorithms|Customizing Algorithms}\n         */\n        this.HashAlgorithms = {\n            \"http://www.w3.org/2000/09/xmldsig#sha1\": hashAlgorithms.Sha1,\n            \"http://www.w3.org/2001/04/xmlenc#sha256\": hashAlgorithms.Sha256,\n            \"http://www.w3.org/2001/04/xmlenc#sha512\": hashAlgorithms.Sha512,\n        };\n        /**\n         * To add a new signature algorithm create a new class that implements the {@link SignatureAlgorithm} interface, and register it here. More info: {@link https://github.com/node-saml/xml-crypto#customizing-algorithms|Customizing Algorithms}\n         */\n        this.SignatureAlgorithms = {\n            \"http://www.w3.org/2000/09/xmldsig#rsa-sha1\": signatureAlgorithms.RsaSha1,\n            \"http://www.w3.org/2001/04/xmldsig-more#rsa-sha256\": signatureAlgorithms.RsaSha256,\n            \"http://www.w3.org/2001/04/xmldsig-more#rsa-sha512\": signatureAlgorithms.RsaSha512,\n            // Disabled by default due to key confusion concerns.\n            // 'http://www.w3.org/2000/09/xmldsig#hmac-sha1': SignatureAlgorithms.HmacSha1\n        };\n        const { idMode, idAttribute, privateKey, publicCert, signatureAlgorithm, canonicalizationAlgorithm, inclusiveNamespacesPrefixList, implicitTransforms, keyInfoAttributes, getKeyInfoContent, getCertFromKeyInfo, } = options;\n        // Options\n        this.idMode = idMode;\n        this.idAttributes = [\"Id\", \"ID\", \"id\"];\n        if (idAttribute) {\n            this.idAttributes.unshift(idAttribute);\n        }\n        this.privateKey = privateKey;\n        this.publicCert = publicCert;\n        this.signatureAlgorithm = signatureAlgorithm ?? this.signatureAlgorithm;\n        this.canonicalizationAlgorithm = canonicalizationAlgorithm;\n        if (typeof inclusiveNamespacesPrefixList === \"string\") {\n            this.inclusiveNamespacesPrefixList = inclusiveNamespacesPrefixList.split(\" \");\n        }\n        else if (utils.isArrayHasLength(inclusiveNamespacesPrefixList)) {\n            this.inclusiveNamespacesPrefixList = inclusiveNamespacesPrefixList;\n        }\n        this.implicitTransforms = implicitTransforms ?? this.implicitTransforms;\n        this.keyInfoAttributes = keyInfoAttributes ?? this.keyInfoAttributes;\n        this.getKeyInfoContent = getKeyInfoContent ?? this.getKeyInfoContent;\n        this.getCertFromKeyInfo = getCertFromKeyInfo ?? SignedXml.noop;\n        this.CanonicalizationAlgorithms;\n        this.HashAlgorithms;\n        this.SignatureAlgorithms;\n    }\n    /**\n     * Due to key-confusion issues, it's risky to have both hmac\n     * and digital signature algorithms enabled at the same time.\n     * This enables HMAC and disables other signing algorithms.\n     */\n    enableHMAC() {\n        this.SignatureAlgorithms = {\n            \"http://www.w3.org/2000/09/xmldsig#hmac-sha1\": signatureAlgorithms.HmacSha1,\n        };\n        this.getKeyInfoContent = SignedXml.noop;\n    }\n    /**\n     * Builds the contents of a KeyInfo element as an XML string.\n     *\n     * For example, if the value of the prefix argument is 'foo', then\n     * the resultant XML string will be \"<foo:X509Data></foo:X509Data>\"\n     *\n     * @return an XML string representation of the contents of a KeyInfo element, or `null` if no `KeyInfo` element should be included\n     */\n    static getKeyInfoContent({ publicCert, prefix }) {\n        if (publicCert == null) {\n            return null;\n        }\n        prefix = prefix ? `${prefix}:` : \"\";\n        let x509Certs = \"\";\n        if (Buffer.isBuffer(publicCert)) {\n            publicCert = publicCert.toString(\"latin1\");\n        }\n        let publicCertMatches = [];\n        if (typeof publicCert === \"string\") {\n            publicCertMatches = publicCert.match(utils.EXTRACT_X509_CERTS) || [];\n        }\n        if (publicCertMatches.length > 0) {\n            x509Certs = publicCertMatches\n                .map((c) => `<${prefix}X509Certificate>${utils\n                .pemToDer(c)\n                .toString(\"base64\")}</${prefix}X509Certificate>`)\n                .join(\"\");\n        }\n        return `<${prefix}X509Data>${x509Certs}</${prefix}X509Data>`;\n    }\n    /**\n     * Returns the value of the signing certificate based on the contents of the\n     * specified KeyInfo.\n     *\n     * @param keyInfo KeyInfo element (@see https://www.w3.org/TR/2008/REC-xmldsig-core-20080610/#sec-X509Data)\n     * @return the signing certificate as a string in PEM format\n     */\n    static getCertFromKeyInfo(keyInfo) {\n        if (keyInfo != null) {\n            const cert = xpath.select1(\".//*[local-name(.)='X509Certificate']\", keyInfo);\n            if (isDomNode.isNodeLike(cert)) {\n                return utils.derToPem(cert.textContent ?? \"\", \"CERTIFICATE\");\n            }\n        }\n        return null;\n    }\n    checkSignature(xml, callback) {\n        if (callback != null && typeof callback !== \"function\") {\n            throw new Error(\"Last parameter must be a callback function\");\n        }\n        this.signedXml = xml;\n        const doc = new xmldom.DOMParser().parseFromString(xml);\n        // Reset the references as only references from our re-parsed signedInfo node can be trusted\n        this.references = [];\n        const unverifiedSignedInfoCanon = this.getCanonSignedInfoXml(doc);\n        if (!unverifiedSignedInfoCanon) {\n            if (callback) {\n                callback(new Error(\"Canonical signed info cannot be empty\"), false);\n                return;\n            }\n            throw new Error(\"Canonical signed info cannot be empty\");\n        }\n        // unsigned, verify later to keep with consistent callback behavior\n        const parsedUnverifiedSignedInfo = new xmldom.DOMParser().parseFromString(unverifiedSignedInfoCanon, \"text/xml\");\n        const unverifiedSignedInfoDoc = parsedUnverifiedSignedInfo.documentElement;\n        if (!unverifiedSignedInfoDoc) {\n            if (callback) {\n                callback(new Error(\"Could not parse unverifiedSignedInfoCanon into a document\"), false);\n                return;\n            }\n            throw new Error(\"Could not parse unverifiedSignedInfoCanon into a document\");\n        }\n        const references = utils.findChildren(unverifiedSignedInfoDoc, \"Reference\");\n        if (!utils.isArrayHasLength(references)) {\n            if (callback) {\n                callback(new Error(\"could not find any Reference elements\"), false);\n                return;\n            }\n            throw new Error(\"could not find any Reference elements\");\n        }\n        // TODO: In a future release we'd like to load the Signature and its References at the same time,\n        // however, in the `.loadSignature()` method we don't have the entire document,\n        // which we need to to keep the inclusive namespaces\n        for (const reference of references) {\n            this.loadReference(reference);\n        }\n        if (!this.getReferences().every((ref) => this.validateReference(ref, doc))) {\n            if (callback) {\n                callback(new Error(\"Could not validate all references\"), false);\n                return;\n            }\n            return false;\n        }\n        // Stage B: Take the signature algorithm and key and verify the SignatureValue against the canonicalized SignedInfo\n        const signer = this.findSignatureAlgorithm(this.signatureAlgorithm);\n        const key = this.getCertFromKeyInfo(this.keyInfo) || this.publicCert || this.privateKey;\n        if (key == null) {\n            throw new Error(\"KeyInfo or publicCert or privateKey is required to validate signature\");\n        }\n        if (callback) {\n            signer.verifySignature(unverifiedSignedInfoCanon, key, this.signatureValue, callback);\n        }\n        else {\n            const verified = signer.verifySignature(unverifiedSignedInfoCanon, key, this.signatureValue);\n            if (verified === false) {\n                throw new Error(`invalid signature: the signature value ${this.signatureValue} is incorrect`);\n            }\n            return true;\n        }\n    }\n    getCanonSignedInfoXml(doc) {\n        if (this.signatureNode == null) {\n            throw new Error(\"No signature found.\");\n        }\n        if (typeof this.canonicalizationAlgorithm !== \"string\") {\n            throw new Error(\"Missing canonicalizationAlgorithm when trying to get signed info for XML\");\n        }\n        const signedInfo = utils.findChildren(this.signatureNode, \"SignedInfo\");\n        if (signedInfo.length === 0) {\n            throw new Error(\"could not find SignedInfo element in the message\");\n        }\n        if (signedInfo.length > 1) {\n            throw new Error(\"could not get canonicalized signed info for a signature that contains multiple SignedInfo nodes\");\n        }\n        if (this.canonicalizationAlgorithm === \"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" ||\n            this.canonicalizationAlgorithm ===\n                \"http://www.w3.org/TR/2001/REC-xml-c14n-20010315#WithComments\") {\n            if (!doc || typeof doc !== \"object\") {\n                throw new Error(\"When canonicalization method is non-exclusive, whole xml dom must be provided as an argument\");\n            }\n        }\n        /**\n         * Search for ancestor namespaces before canonicalization.\n         */\n        const ancestorNamespaces = utils.findAncestorNs(doc, \"//*[local-name()='SignedInfo']\");\n        const c14nOptions = {\n            ancestorNamespaces: ancestorNamespaces,\n        };\n        return this.getCanonXml([this.canonicalizationAlgorithm], signedInfo[0], c14nOptions);\n    }\n    getCanonReferenceXml(doc, ref, node) {\n        /**\n         * Search for ancestor namespaces before canonicalization.\n         */\n        if (Array.isArray(ref.transforms)) {\n            ref.ancestorNamespaces = utils.findAncestorNs(doc, ref.xpath, this.namespaceResolver);\n        }\n        const c14nOptions = {\n            inclusiveNamespacesPrefixList: ref.inclusiveNamespacesPrefixList,\n            ancestorNamespaces: ref.ancestorNamespaces,\n        };\n        return this.getCanonXml(ref.transforms, node, c14nOptions);\n    }\n    calculateSignatureValue(doc, callback) {\n        const signedInfoCanon = this.getCanonSignedInfoXml(doc);\n        const signer = this.findSignatureAlgorithm(this.signatureAlgorithm);\n        if (this.privateKey == null) {\n            throw new Error(\"Private key is required to compute signature\");\n        }\n        if (typeof callback === \"function\") {\n            signer.getSignature(signedInfoCanon, this.privateKey, callback);\n        }\n        else {\n            this.signatureValue = signer.getSignature(signedInfoCanon, this.privateKey);\n        }\n    }\n    findSignatureAlgorithm(name) {\n        if (name == null) {\n            throw new Error(\"signatureAlgorithm is required\");\n        }\n        const algo = this.SignatureAlgorithms[name];\n        if (algo) {\n            return new algo();\n        }\n        else {\n            throw new Error(`signature algorithm '${name}' is not supported`);\n        }\n    }\n    findCanonicalizationAlgorithm(name) {\n        if (name != null) {\n            const algo = this.CanonicalizationAlgorithms[name];\n            if (algo) {\n                return new algo();\n            }\n        }\n        throw new Error(`canonicalization algorithm '${name}' is not supported`);\n    }\n    findHashAlgorithm(name) {\n        const algo = this.HashAlgorithms[name];\n        if (algo) {\n            return new algo();\n        }\n        else {\n            throw new Error(`hash algorithm '${name}' is not supported`);\n        }\n    }\n    validateElementAgainstReferences(elemOrXpath, doc) {\n        let elem;\n        if (typeof elemOrXpath === \"string\") {\n            const firstElem = xpath.select1(elemOrXpath, doc);\n            isDomNode.assertIsElementNode(firstElem);\n            elem = firstElem;\n        }\n        else {\n            elem = elemOrXpath;\n        }\n        for (const ref of this.getReferences()) {\n            const uri = ref.uri?.[0] === \"#\" ? ref.uri.substring(1) : ref.uri;\n            for (const attr of this.idAttributes) {\n                const elemId = elem.getAttribute(attr);\n                if (uri === elemId) {\n                    ref.xpath = `//*[@*[local-name(.)='${attr}']='${uri}']`;\n                    break; // found the correct element, no need to check further\n                }\n            }\n            const canonXml = this.getCanonReferenceXml(doc, ref, elem);\n            const hash = this.findHashAlgorithm(ref.digestAlgorithm);\n            const digest = hash.getHash(canonXml);\n            if (utils.validateDigestValue(digest, ref.digestValue)) {\n                return ref;\n            }\n        }\n        throw new Error(\"No references passed validation\");\n    }\n    validateReference(ref, doc) {\n        const uri = ref.uri?.[0] === \"#\" ? ref.uri.substring(1) : ref.uri;\n        let elem = null;\n        if (uri === \"\") {\n            elem = xpath.select1(\"//*\", doc);\n        }\n        else if (uri?.indexOf(\"'\") !== -1) {\n            // xpath injection\n            throw new Error(\"Cannot validate a uri with quotes inside it\");\n        }\n        else {\n            let num_elements_for_id = 0;\n            for (const attr of this.idAttributes) {\n                const tmp_elemXpath = `//*[@*[local-name(.)='${attr}']='${uri}']`;\n                const tmp_elem = xpath.select(tmp_elemXpath, doc);\n                if (utils.isArrayHasLength(tmp_elem)) {\n                    num_elements_for_id += tmp_elem.length;\n                    if (num_elements_for_id > 1) {\n                        throw new Error(\"Cannot validate a document which contains multiple elements with the \" +\n                            \"same value for the ID / Id / Id attributes, in order to prevent \" +\n                            \"signature wrapping attack.\");\n                    }\n                    elem = tmp_elem[0];\n                    ref.xpath = tmp_elemXpath;\n                }\n            }\n        }\n        ref.getValidatedNode = (xpathSelector) => {\n            xpathSelector = xpathSelector || ref.xpath;\n            if (typeof xpathSelector !== \"string\" || ref.validationError != null) {\n                return null;\n            }\n            const selectedValue = xpath.select1(xpathSelector, doc);\n            return isDomNode.isNodeLike(selectedValue) ? selectedValue : null;\n        };\n        if (!isDomNode.isNodeLike(elem)) {\n            const validationError = new Error(`invalid signature: the signature references an element with uri ${ref.uri} but could not find such element in the xml`);\n            ref.validationError = validationError;\n            return false;\n        }\n        const canonXml = this.getCanonReferenceXml(doc, ref, elem);\n        const hash = this.findHashAlgorithm(ref.digestAlgorithm);\n        const digest = hash.getHash(canonXml);\n        if (!utils.validateDigestValue(digest, ref.digestValue)) {\n            const validationError = new Error(`invalid signature: for uri ${ref.uri} calculated digest is ${digest} but the xml to validate supplies digest ${ref.digestValue}`);\n            ref.validationError = validationError;\n            return false;\n        }\n        return true;\n    }\n    findSignatures(doc) {\n        const nodes = xpath.select(\"//*[local-name(.)='Signature' and namespace-uri(.)='http://www.w3.org/2000/09/xmldsig#']\", doc);\n        return isDomNode.isArrayOfNodes(nodes) ? nodes : [];\n    }\n    /**\n     * Loads the signature information from the provided XML node or string.\n     *\n     * @param signatureNode The XML node or string representing the signature.\n     */\n    loadSignature(signatureNode) {\n        if (typeof signatureNode === \"string\") {\n            this.signatureNode = signatureNode = new xmldom.DOMParser().parseFromString(signatureNode);\n        }\n        else {\n            this.signatureNode = signatureNode;\n        }\n        this.signatureXml = signatureNode.toString();\n        const node = xpath.select1(\".//*[local-name(.)='CanonicalizationMethod']/@Algorithm\", signatureNode);\n        if (!isDomNode.isNodeLike(node)) {\n            throw new Error(\"could not find CanonicalizationMethod/@Algorithm element\");\n        }\n        if (isDomNode.isAttributeNode(node)) {\n            this.canonicalizationAlgorithm = node.value;\n        }\n        const signatureAlgorithm = xpath.select1(\".//*[local-name(.)='SignatureMethod']/@Algorithm\", signatureNode);\n        if (isDomNode.isAttributeNode(signatureAlgorithm)) {\n            this.signatureAlgorithm = signatureAlgorithm.value;\n        }\n        const signedInfoNodes = utils.findChildren(this.signatureNode, \"SignedInfo\");\n        if (!utils.isArrayHasLength(signedInfoNodes)) {\n            throw new Error(\"no signed info node found\");\n        }\n        if (signedInfoNodes.length > 1) {\n            throw new Error(\"could not load signature that contains multiple SignedInfo nodes\");\n        }\n        // Try to operate on the c14n version of `signedInfo`. This forces the initial `getReferences()`\n        // API call to always return references that are loaded under the canonical `SignedInfo`\n        // in the case that the client access the `.references` **before** signature verification.\n        // Ensure canonicalization algorithm is exclusive, otherwise we'd need the entire document\n        let canonicalizationAlgorithmForSignedInfo = this.canonicalizationAlgorithm;\n        if (!canonicalizationAlgorithmForSignedInfo ||\n            canonicalizationAlgorithmForSignedInfo ===\n                \"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\" ||\n            canonicalizationAlgorithmForSignedInfo ===\n                \"http://www.w3.org/TR/2001/REC-xml-c14n-20010315#WithComments\") {\n            canonicalizationAlgorithmForSignedInfo = \"http://www.w3.org/2001/10/xml-exc-c14n#\";\n        }\n        const temporaryCanonSignedInfo = this.getCanonXml([canonicalizationAlgorithmForSignedInfo], signedInfoNodes[0]);\n        const temporaryCanonSignedInfoXml = new xmldom.DOMParser().parseFromString(temporaryCanonSignedInfo, \"text/xml\");\n        const signedInfoDoc = temporaryCanonSignedInfoXml.documentElement;\n        this.references = [];\n        const references = utils.findChildren(signedInfoDoc, \"Reference\");\n        if (!utils.isArrayHasLength(references)) {\n            throw new Error(\"could not find any Reference elements\");\n        }\n        for (const reference of references) {\n            this.loadReference(reference);\n        }\n        const signatureValue = xpath.select1(\".//*[local-name(.)='SignatureValue']/text()\", signatureNode);\n        if (isDomNode.isTextNode(signatureValue)) {\n            this.signatureValue = signatureValue.data.replace(/\\r?\\n/g, \"\");\n        }\n        const keyInfo = xpath.select1(\".//*[local-name(.)='KeyInfo']\", signatureNode);\n        if (isDomNode.isNodeLike(keyInfo)) {\n            this.keyInfo = keyInfo;\n        }\n    }\n    /**\n     * Load the reference xml node to a model\n     *\n     */\n    loadReference(refNode) {\n        let nodes = utils.findChildren(refNode, \"DigestMethod\");\n        if (nodes.length === 0) {\n            throw new Error(`could not find DigestMethod in reference ${refNode.toString()}`);\n        }\n        const digestAlgoNode = nodes[0];\n        const attr = utils.findAttr(digestAlgoNode, \"Algorithm\");\n        if (!attr) {\n            throw new Error(`could not find Algorithm attribute in node ${digestAlgoNode.toString()}`);\n        }\n        const digestAlgo = attr.value;\n        nodes = utils.findChildren(refNode, \"DigestValue\");\n        if (nodes.length === 0) {\n            throw new Error(`could not find DigestValue node in reference ${refNode.toString()}`);\n        }\n        if (nodes.length > 1) {\n            throw new Error(`could not load reference for a node that contains multiple DigestValue nodes: ${refNode.toString()}`);\n        }\n        const digestValue = nodes[0].textContent;\n        if (!digestValue) {\n            throw new Error(`could not find the value of DigestValue in ${refNode.toString()}`);\n        }\n        const transforms = [];\n        let inclusiveNamespacesPrefixList = [];\n        nodes = utils.findChildren(refNode, \"Transforms\");\n        if (nodes.length !== 0) {\n            const transformsNode = nodes[0];\n            const transformsAll = utils.findChildren(transformsNode, \"Transform\");\n            for (const transform of transformsAll) {\n                const transformAttr = utils.findAttr(transform, \"Algorithm\");\n                if (transformAttr) {\n                    transforms.push(transformAttr.value);\n                }\n            }\n            // This is a little strange, we are looking for children of the last child of `transformsNode`\n            const inclusiveNamespaces = utils.findChildren(transformsAll[transformsAll.length - 1], \"InclusiveNamespaces\");\n            if (utils.isArrayHasLength(inclusiveNamespaces)) {\n                // Should really only be one prefix list, but maybe there's some circumstances where more than one to let's handle it\n                inclusiveNamespacesPrefixList = inclusiveNamespaces\n                    .flatMap((namespace) => (namespace.getAttribute(\"PrefixList\") ?? \"\").split(\" \"))\n                    .filter((value) => value.length > 0);\n            }\n        }\n        if (utils.isArrayHasLength(this.implicitTransforms)) {\n            this.implicitTransforms.forEach(function (t) {\n                transforms.push(t);\n            });\n        }\n        /**\n         * DigestMethods take an octet stream rather than a node set. If the output of the last transform is a node set, we\n         * need to canonicalize the node set to an octet stream using non-exclusive canonicalization. If there are no\n         * transforms, we need to canonicalize because URI dereferencing for a same-document reference will return a node-set.\n         * @see:\n         * https://www.w3.org/TR/xmldsig-core1/#sec-DigestMethod\n         * https://www.w3.org/TR/xmldsig-core1/#sec-ReferenceProcessingModel\n         * https://www.w3.org/TR/xmldsig-core1/#sec-Same-Document\n         */\n        if (transforms.length === 0 ||\n            transforms[transforms.length - 1] === \"http://www.w3.org/2000/09/xmldsig#enveloped-signature\") {\n            transforms.push(\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\");\n        }\n        const refUri = isDomNode.isElementNode(refNode)\n            ? refNode.getAttribute(\"URI\") || undefined\n            : undefined;\n        this.addReference({\n            transforms,\n            digestAlgorithm: digestAlgo,\n            uri: refUri,\n            digestValue,\n            inclusiveNamespacesPrefixList,\n            isEmptyUri: false,\n        });\n    }\n    /**\n     * Adds a reference to the signature.\n     *\n     * @param xpath The XPath expression to select the XML nodes to be referenced.\n     * @param transforms An array of transform algorithms to be applied to the selected nodes.\n     * @param digestAlgorithm The digest algorithm to use for computing the digest value.\n     * @param uri The URI identifier for the reference. If empty, an empty URI will be used.\n     * @param digestValue The expected digest value for the reference.\n     * @param inclusiveNamespacesPrefixList The prefix list for inclusive namespace canonicalization.\n     * @param isEmptyUri Indicates whether the URI is empty. Defaults to `false`.\n     */\n    addReference({ xpath, transforms, digestAlgorithm, uri = \"\", digestValue, inclusiveNamespacesPrefixList = [], isEmptyUri = false, }) {\n        if (digestAlgorithm == null) {\n            throw new Error(\"digestAlgorithm is required\");\n        }\n        if (!utils.isArrayHasLength(transforms)) {\n            throw new Error(\"transforms must contain at least one transform algorithm\");\n        }\n        this.references.push({\n            xpath,\n            transforms,\n            digestAlgorithm,\n            uri,\n            digestValue,\n            inclusiveNamespacesPrefixList,\n            isEmptyUri,\n            getValidatedNode: () => {\n                throw new Error(\"Reference has not been validated yet; Did you call `sig.checkSignature()`?\");\n            },\n        });\n    }\n    getReferences() {\n        return this.references;\n    }\n    computeSignature(xml, options, callbackParam) {\n        let callback;\n        if (typeof options === \"function\" && callbackParam == null) {\n            callback = options;\n            options = {};\n        }\n        else {\n            callback = callbackParam;\n            options = (options ?? {});\n        }\n        const doc = new xmldom.DOMParser().parseFromString(xml);\n        let xmlNsAttr = \"xmlns\";\n        const signatureAttrs = [];\n        let currentPrefix;\n        const validActions = [\"append\", \"prepend\", \"before\", \"after\"];\n        const prefix = options.prefix;\n        const attrs = options.attrs || {};\n        const location = options.location || {};\n        const existingPrefixes = options.existingPrefixes || {};\n        this.namespaceResolver = {\n            lookupNamespaceURI: function (prefix) {\n                return prefix ? existingPrefixes[prefix] : null;\n            },\n        };\n        // defaults to the root node\n        location.reference = location.reference || \"/*\";\n        // defaults to append action\n        location.action = location.action || \"append\";\n        if (validActions.indexOf(location.action) === -1) {\n            const err = new Error(`location.action option has an invalid action: ${location.action}, must be any of the following values: ${validActions.join(\", \")}`);\n            if (!callback) {\n                throw err;\n            }\n            else {\n                callback(err);\n                return;\n            }\n        }\n        // automatic insertion of `:`\n        if (prefix) {\n            xmlNsAttr += `:${prefix}`;\n            currentPrefix = `${prefix}:`;\n        }\n        else {\n            currentPrefix = \"\";\n        }\n        Object.keys(attrs).forEach(function (name) {\n            if (name !== \"xmlns\" && name !== xmlNsAttr) {\n                signatureAttrs.push(`${name}=\"${attrs[name]}\"`);\n            }\n        });\n        // add the xml namespace attribute\n        signatureAttrs.push(`${xmlNsAttr}=\"http://www.w3.org/2000/09/xmldsig#\"`);\n        let signatureXml = `<${currentPrefix}Signature ${signatureAttrs.join(\" \")}>`;\n        signatureXml += this.createSignedInfo(doc, prefix);\n        signatureXml += this.getKeyInfo(prefix);\n        signatureXml += `</${currentPrefix}Signature>`;\n        this.originalXmlWithIds = doc.toString();\n        let existingPrefixesString = \"\";\n        Object.keys(existingPrefixes).forEach(function (key) {\n            existingPrefixesString += `xmlns:${key}=\"${existingPrefixes[key]}\" `;\n        });\n        // A trick to remove the namespaces that already exist in the xml\n        // This only works if the prefix and namespace match with those in the xml\n        const dummySignatureWrapper = `<Dummy ${existingPrefixesString}>${signatureXml}</Dummy>`;\n        const nodeXml = new xmldom.DOMParser().parseFromString(dummySignatureWrapper);\n        // Because we are using a dummy wrapper hack described above, we know there will be a `firstChild`\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        const signatureDoc = nodeXml.documentElement.firstChild;\n        const referenceNode = xpath.select1(location.reference, doc);\n        if (!isDomNode.isNodeLike(referenceNode)) {\n            const err2 = new Error(`the following xpath cannot be used because it was not found: ${location.reference}`);\n            if (!callback) {\n                throw err2;\n            }\n            else {\n                callback(err2);\n                return;\n            }\n        }\n        if (location.action === \"append\") {\n            referenceNode.appendChild(signatureDoc);\n        }\n        else if (location.action === \"prepend\") {\n            referenceNode.insertBefore(signatureDoc, referenceNode.firstChild);\n        }\n        else if (location.action === \"before\") {\n            if (referenceNode.parentNode == null) {\n                throw new Error(\"`location.reference` refers to the root node (by default), so we can't insert `before`\");\n            }\n            referenceNode.parentNode.insertBefore(signatureDoc, referenceNode);\n        }\n        else if (location.action === \"after\") {\n            if (referenceNode.parentNode == null) {\n                throw new Error(\"`location.reference` refers to the root node (by default), so we can't insert `after`\");\n            }\n            referenceNode.parentNode.insertBefore(signatureDoc, referenceNode.nextSibling);\n        }\n        this.signatureNode = signatureDoc;\n        const signedInfoNodes = utils.findChildren(this.signatureNode, \"SignedInfo\");\n        if (signedInfoNodes.length === 0) {\n            const err3 = new Error(\"could not find SignedInfo element in the message\");\n            if (!callback) {\n                throw err3;\n            }\n            else {\n                callback(err3);\n                return;\n            }\n        }\n        const signedInfoNode = signedInfoNodes[0];\n        if (typeof callback === \"function\") {\n            // Asynchronous flow\n            this.calculateSignatureValue(doc, (err, signature) => {\n                if (err) {\n                    callback(err);\n                }\n                else {\n                    this.signatureValue = signature || \"\";\n                    signatureDoc.insertBefore(this.createSignature(prefix), signedInfoNode.nextSibling);\n                    this.signatureXml = signatureDoc.toString();\n                    this.signedXml = doc.toString();\n                    callback(null, this);\n                }\n            });\n        }\n        else {\n            // Synchronous flow\n            this.calculateSignatureValue(doc);\n            signatureDoc.insertBefore(this.createSignature(prefix), signedInfoNode.nextSibling);\n            this.signatureXml = signatureDoc.toString();\n            this.signedXml = doc.toString();\n        }\n    }\n    getKeyInfo(prefix) {\n        const currentPrefix = prefix ? `${prefix}:` : \"\";\n        let keyInfoAttrs = \"\";\n        if (this.keyInfoAttributes) {\n            Object.keys(this.keyInfoAttributes).forEach((name) => {\n                keyInfoAttrs += ` ${name}=\"${this.keyInfoAttributes[name]}\"`;\n            });\n        }\n        const keyInfoContent = this.getKeyInfoContent({ publicCert: this.publicCert, prefix });\n        if (keyInfoAttrs || keyInfoContent) {\n            return `<${currentPrefix}KeyInfo${keyInfoAttrs}>${keyInfoContent}</${currentPrefix}KeyInfo>`;\n        }\n        return \"\";\n    }\n    /**\n     * Generate the Reference nodes (as part of the signature process)\n     *\n     */\n    createReferences(doc, prefix) {\n        let res = \"\";\n        prefix = prefix || \"\";\n        prefix = prefix ? `${prefix}:` : prefix;\n        for (const ref of this.getReferences()) {\n            const nodes = xpath.selectWithResolver(ref.xpath ?? \"\", doc, this.namespaceResolver);\n            if (!utils.isArrayHasLength(nodes)) {\n                throw new Error(`the following xpath cannot be signed because it was not found: ${ref.xpath}`);\n            }\n            for (const node of nodes) {\n                if (ref.isEmptyUri) {\n                    res += `<${prefix}Reference URI=\"\">`;\n                }\n                else {\n                    const id = this.ensureHasId(node);\n                    ref.uri = id;\n                    res += `<${prefix}Reference URI=\"#${id}\">`;\n                }\n                res += `<${prefix}Transforms>`;\n                for (const trans of ref.transforms || []) {\n                    const transform = this.findCanonicalizationAlgorithm(trans);\n                    res += `<${prefix}Transform Algorithm=\"${transform.getAlgorithmName()}\"`;\n                    if (utils.isArrayHasLength(ref.inclusiveNamespacesPrefixList)) {\n                        res += \">\";\n                        res += `<InclusiveNamespaces PrefixList=\"${ref.inclusiveNamespacesPrefixList.join(\" \")}\" xmlns=\"${transform.getAlgorithmName()}\"/>`;\n                        res += `</${prefix}Transform>`;\n                    }\n                    else {\n                        res += \" />\";\n                    }\n                }\n                const canonXml = this.getCanonReferenceXml(doc, ref, node);\n                const digestAlgorithm = this.findHashAlgorithm(ref.digestAlgorithm);\n                res +=\n                    `</${prefix}Transforms>` +\n                        `<${prefix}DigestMethod Algorithm=\"${digestAlgorithm.getAlgorithmName()}\" />` +\n                        `<${prefix}DigestValue>${digestAlgorithm.getHash(canonXml)}</${prefix}DigestValue>` +\n                        `</${prefix}Reference>`;\n            }\n        }\n        return res;\n    }\n    getCanonXml(transforms, node, options = {}) {\n        options.defaultNsForPrefix = options.defaultNsForPrefix ?? SignedXml.defaultNsForPrefix;\n        options.signatureNode = this.signatureNode;\n        const canonXml = node.cloneNode(true); // Deep clone\n        let transformedXml = canonXml;\n        transforms.forEach((transformName) => {\n            if (isDomNode.isNodeLike(transformedXml)) {\n                // If, after processing, `transformedNode` is a string, we can't do anymore transforms on it\n                const transform = this.findCanonicalizationAlgorithm(transformName);\n                transformedXml = transform.process(transformedXml, options);\n            }\n            //TODO: currently transform.process may return either Node or String value (enveloped transformation returns Node, exclusive-canonicalization returns String).\n            //This either needs to be more explicit in the API, or all should return the same.\n            //exclusive-canonicalization returns String since it builds the Xml by hand. If it had used xmldom it would incorrectly minimize empty tags\n            //to <x/> instead of <x></x> and also incorrectly handle some delicate line break issues.\n            //enveloped transformation returns Node since if it would return String consider this case:\n            //<x xmlns:p='ns'><p:y/></x>\n            //if only y is the node to sign then a string would be <p:y/> without the definition of the p namespace. probably xmldom toString() should have added it.\n        });\n        return transformedXml.toString();\n    }\n    /**\n     * Ensure an element has Id attribute. If not create it with unique value.\n     * Work with both normal and wssecurity Id flavour\n     */\n    ensureHasId(node) {\n        let attr;\n        if (this.idMode === \"wssecurity\") {\n            attr = utils.findAttr(node, \"Id\", \"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd\");\n        }\n        else {\n            this.idAttributes.some((idAttribute) => {\n                attr = utils.findAttr(node, idAttribute);\n                return !!attr; // This will break the loop as soon as a truthy attr is found.\n            });\n        }\n        if (attr) {\n            return attr.value;\n        }\n        //add the attribute\n        const id = `_${this.id++}`;\n        if (this.idMode === \"wssecurity\") {\n            node.setAttributeNS(\"http://www.w3.org/2000/xmlns/\", \"xmlns:wsu\", \"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd\");\n            node.setAttributeNS(\"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd\", \"wsu:Id\", id);\n        }\n        else {\n            node.setAttribute(\"Id\", id);\n        }\n        return id;\n    }\n    /**\n     * Create the SignedInfo element\n     *\n     */\n    createSignedInfo(doc, prefix) {\n        if (typeof this.canonicalizationAlgorithm !== \"string\") {\n            throw new Error(\"Missing canonicalizationAlgorithm when trying to create signed info for XML\");\n        }\n        const transform = this.findCanonicalizationAlgorithm(this.canonicalizationAlgorithm);\n        const algo = this.findSignatureAlgorithm(this.signatureAlgorithm);\n        let currentPrefix;\n        currentPrefix = prefix || \"\";\n        currentPrefix = currentPrefix ? `${currentPrefix}:` : currentPrefix;\n        let res = `<${currentPrefix}SignedInfo>`;\n        res += `<${currentPrefix}CanonicalizationMethod Algorithm=\"${transform.getAlgorithmName()}\"`;\n        if (utils.isArrayHasLength(this.inclusiveNamespacesPrefixList)) {\n            res += \">\";\n            res += `<InclusiveNamespaces PrefixList=\"${this.inclusiveNamespacesPrefixList.join(\" \")}\" xmlns=\"${transform.getAlgorithmName()}\"/>`;\n            res += `</${currentPrefix}CanonicalizationMethod>`;\n        }\n        else {\n            res += \" />\";\n        }\n        res += `<${currentPrefix}SignatureMethod Algorithm=\"${algo.getAlgorithmName()}\" />`;\n        res += this.createReferences(doc, prefix);\n        res += `</${currentPrefix}SignedInfo>`;\n        return res;\n    }\n    /**\n     * Create the Signature element\n     *\n     */\n    createSignature(prefix) {\n        let xmlNsAttr = \"xmlns\";\n        if (prefix) {\n            xmlNsAttr += `:${prefix}`;\n            prefix += \":\";\n        }\n        else {\n            prefix = \"\";\n        }\n        const signatureValueXml = `<${prefix}SignatureValue>${this.signatureValue}</${prefix}SignatureValue>`;\n        //the canonicalization requires to get a valid xml node.\n        //we need to wrap the info in a dummy signature since it contains the default namespace.\n        const dummySignatureWrapper = `<${prefix}Signature ${xmlNsAttr}=\"http://www.w3.org/2000/09/xmldsig#\">${signatureValueXml}</${prefix}Signature>`;\n        const doc = new xmldom.DOMParser().parseFromString(dummySignatureWrapper);\n        // Because we are using a dummy wrapper hack described above, we know there will be a `firstChild`\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        return doc.documentElement.firstChild;\n    }\n    /**\n     * Returns just the signature part, must be called only after {@link computeSignature}\n     *\n     * @returns The signature XML.\n     */\n    getSignatureXml() {\n        return this.signatureXml;\n    }\n    /**\n     * Returns the original xml with Id attributes added on relevant elements (required for validation), must be called only after {@link computeSignature}\n     *\n     * @returns The original XML with IDs.\n     */\n    getOriginalXmlWithIds() {\n        return this.originalXmlWithIds;\n    }\n    /**\n     * Returns the original xml document with the signature in it, must be called only after {@link computeSignature}\n     *\n     * @returns The signed XML.\n     */\n    getSignedXml() {\n        return this.signedXml;\n    }\n}\nexports.SignedXml = SignedXml;\nSignedXml.defaultNsForPrefix = {\n    ds: \"http://www.w3.org/2000/09/xmldsig#\",\n};\nSignedXml.noop = () => null;\n//# sourceMappingURL=signed-xml.js.map","var dom = require('./dom')\nexports.DOMImplementation = dom.DOMImplementation\nexports.XMLSerializer = dom.XMLSerializer\nexports.DOMParser = require('./dom-parser').DOMParser\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.C14nCanonicalizationWithComments = exports.C14nCanonicalization = void 0;\nconst utils = require(\"./utils\");\nconst isDomNode = require(\"@xmldom/is-dom-node\");\nclass C14nCanonicalization {\n    constructor() {\n        this.includeComments = false;\n        this.includeComments = false;\n    }\n    attrCompare(a, b) {\n        if (!a.namespaceURI && b.namespaceURI) {\n            return -1;\n        }\n        if (!b.namespaceURI && a.namespaceURI) {\n            return 1;\n        }\n        const left = a.namespaceURI + a.localName;\n        const right = b.namespaceURI + b.localName;\n        if (left === right) {\n            return 0;\n        }\n        else if (left < right) {\n            return -1;\n        }\n        else {\n            return 1;\n        }\n    }\n    nsCompare(a, b) {\n        const attr1 = a.prefix;\n        const attr2 = b.prefix;\n        if (attr1 === attr2) {\n            return 0;\n        }\n        return attr1.localeCompare(attr2);\n    }\n    renderAttrs(node) {\n        let i;\n        let attr;\n        const attrListToRender = [];\n        if (isDomNode.isCommentNode(node)) {\n            return this.renderComment(node);\n        }\n        if (node.attributes) {\n            for (i = 0; i < node.attributes.length; ++i) {\n                attr = node.attributes[i];\n                //ignore namespace definition attributes\n                if (attr.name.indexOf(\"xmlns\") === 0) {\n                    continue;\n                }\n                attrListToRender.push(attr);\n            }\n        }\n        attrListToRender.sort(this.attrCompare);\n        const res = attrListToRender.map((attr) => {\n            return ` ${attr.name}=\"${utils.encodeSpecialCharactersInAttribute(attr.value)}\"`;\n        });\n        return res.join(\"\");\n    }\n    /**\n     * Create the string of all namespace declarations that should appear on this element\n     *\n     * @param node The node we now render\n     * @param prefixesInScope The prefixes defined on this node parents which are a part of the output set\n     * @param defaultNs The current default namespace\n     * @param defaultNsForPrefix\n     * @param ancestorNamespaces Import ancestor namespaces if it is specified\n     * @api private\n     */\n    renderNs(node, prefixesInScope, defaultNs, defaultNsForPrefix, ancestorNamespaces) {\n        let i;\n        let attr;\n        const res = [];\n        let newDefaultNs = defaultNs;\n        const nsListToRender = [];\n        const currNs = node.namespaceURI || \"\";\n        //handle the namespace of the node itself\n        if (node.prefix) {\n            if (prefixesInScope.indexOf(node.prefix) === -1) {\n                nsListToRender.push({\n                    prefix: node.prefix,\n                    namespaceURI: node.namespaceURI || defaultNsForPrefix[node.prefix],\n                });\n                prefixesInScope.push(node.prefix);\n            }\n        }\n        else if (defaultNs !== currNs) {\n            //new default ns\n            newDefaultNs = node.namespaceURI || \"\";\n            res.push(' xmlns=\"', newDefaultNs, '\"');\n        }\n        //handle the attributes namespace\n        if (node.attributes) {\n            for (i = 0; i < node.attributes.length; ++i) {\n                attr = node.attributes[i];\n                //handle all prefixed attributes that are included in the prefix list and where\n                //the prefix is not defined already. New prefixes can only be defined by `xmlns:`.\n                if (attr.prefix === \"xmlns\" && prefixesInScope.indexOf(attr.localName) === -1) {\n                    nsListToRender.push({ prefix: attr.localName, namespaceURI: attr.value });\n                    prefixesInScope.push(attr.localName);\n                }\n                //handle all prefixed attributes that are not xmlns definitions and where\n                //the prefix is not defined already\n                if (attr.prefix &&\n                    prefixesInScope.indexOf(attr.prefix) === -1 &&\n                    attr.prefix !== \"xmlns\" &&\n                    attr.prefix !== \"xml\") {\n                    nsListToRender.push({ prefix: attr.prefix, namespaceURI: attr.namespaceURI });\n                    prefixesInScope.push(attr.prefix);\n                }\n            }\n        }\n        if (utils.isArrayHasLength(ancestorNamespaces)) {\n            // Remove namespaces which are already present in nsListToRender\n            for (const ancestorNamespace of ancestorNamespaces) {\n                let alreadyListed = false;\n                for (const nsToRender of nsListToRender) {\n                    if (nsToRender.prefix === ancestorNamespace.prefix &&\n                        nsToRender.namespaceURI === ancestorNamespace.namespaceURI) {\n                        alreadyListed = true;\n                    }\n                }\n                if (!alreadyListed) {\n                    nsListToRender.push(ancestorNamespace);\n                }\n            }\n        }\n        nsListToRender.sort(this.nsCompare);\n        //render namespaces\n        res.push(...nsListToRender.map((attr) => {\n            if (attr.prefix) {\n                return ` xmlns:${attr.prefix}=\"${attr.namespaceURI}\"`;\n            }\n            return ` xmlns=\"${attr.namespaceURI}\"`;\n        }));\n        return { rendered: res.join(\"\"), newDefaultNs };\n    }\n    /**\n     * @param node Node\n     */\n    processInner(node, prefixesInScope, defaultNs, defaultNsForPrefix, ancestorNamespaces) {\n        if (isDomNode.isCommentNode(node)) {\n            return this.renderComment(node);\n        }\n        if (node.data) {\n            return utils.encodeSpecialCharactersInText(node.data);\n        }\n        if (isDomNode.isElementNode(node)) {\n            let i;\n            let pfxCopy;\n            const ns = this.renderNs(node, prefixesInScope, defaultNs, defaultNsForPrefix, ancestorNamespaces);\n            const res = [\"<\", node.tagName, ns.rendered, this.renderAttrs(node), \">\"];\n            for (i = 0; i < node.childNodes.length; ++i) {\n                pfxCopy = prefixesInScope.slice(0);\n                res.push(this.processInner(node.childNodes[i], pfxCopy, ns.newDefaultNs, defaultNsForPrefix, []));\n            }\n            res.push(\"</\", node.tagName, \">\");\n            return res.join(\"\");\n        }\n        throw new Error(`Unable to canonicalize node type: ${node.nodeType}`);\n    }\n    // Thanks to deoxxa/xml-c14n for comment renderer\n    renderComment(node) {\n        if (!this.includeComments) {\n            return \"\";\n        }\n        const isOutsideDocument = node.ownerDocument === node.parentNode;\n        let isBeforeDocument = false;\n        let isAfterDocument = false;\n        if (isOutsideDocument) {\n            let nextNode = node;\n            let previousNode = node;\n            while (nextNode !== null) {\n                if (nextNode === node.ownerDocument.documentElement) {\n                    isBeforeDocument = true;\n                    break;\n                }\n                nextNode = nextNode.nextSibling;\n            }\n            while (previousNode !== null) {\n                if (previousNode === node.ownerDocument.documentElement) {\n                    isAfterDocument = true;\n                    break;\n                }\n                previousNode = previousNode.previousSibling;\n            }\n        }\n        const afterDocument = isAfterDocument ? \"\\n\" : \"\";\n        const beforeDocument = isBeforeDocument ? \"\\n\" : \"\";\n        const encodedText = utils.encodeSpecialCharactersInText(node.data);\n        return `${afterDocument}<!--${encodedText}-->${beforeDocument}`;\n    }\n    /**\n     * Perform canonicalization of the given node\n     *\n     * @param node\n     * @api public\n     */\n    process(node, options) {\n        options = options || {};\n        const defaultNs = options.defaultNs || \"\";\n        const defaultNsForPrefix = options.defaultNsForPrefix || {};\n        const ancestorNamespaces = options.ancestorNamespaces || [];\n        const prefixesInScope = [];\n        for (let i = 0; i < ancestorNamespaces.length; i++) {\n            prefixesInScope.push(ancestorNamespaces[i].prefix);\n        }\n        const res = this.processInner(node, prefixesInScope, defaultNs, defaultNsForPrefix, ancestorNamespaces);\n        return res;\n    }\n    getAlgorithmName() {\n        return \"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\";\n    }\n}\nexports.C14nCanonicalization = C14nCanonicalization;\n/**\n * Add c14n#WithComments here (very simple subclass)\n */\nclass C14nCanonicalizationWithComments extends C14nCanonicalization {\n    constructor() {\n        super();\n        this.includeComments = true;\n    }\n    getAlgorithmName() {\n        return \"http://www.w3.org/TR/2001/REC-xml-c14n-20010315#WithComments\";\n    }\n}\nexports.C14nCanonicalizationWithComments = C14nCanonicalizationWithComments;\n//# sourceMappingURL=c14n-canonicalization.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.ExclusiveCanonicalizationWithComments = exports.ExclusiveCanonicalization = void 0;\nconst utils = require(\"./utils\");\nconst isDomNode = require(\"@xmldom/is-dom-node\");\nfunction isPrefixInScope(prefixesInScope, prefix, namespaceURI) {\n    let ret = false;\n    prefixesInScope.forEach(function (pf) {\n        if (pf.prefix === prefix && pf.namespaceURI === namespaceURI) {\n            ret = true;\n        }\n    });\n    return ret;\n}\nclass ExclusiveCanonicalization {\n    constructor() {\n        this.includeComments = false;\n        this.includeComments = false;\n    }\n    attrCompare(a, b) {\n        if (!a.namespaceURI && b.namespaceURI) {\n            return -1;\n        }\n        if (!b.namespaceURI && a.namespaceURI) {\n            return 1;\n        }\n        const left = a.namespaceURI + a.localName;\n        const right = b.namespaceURI + b.localName;\n        if (left === right) {\n            return 0;\n        }\n        else if (left < right) {\n            return -1;\n        }\n        else {\n            return 1;\n        }\n    }\n    nsCompare(a, b) {\n        const attr1 = a.prefix;\n        const attr2 = b.prefix;\n        if (attr1 === attr2) {\n            return 0;\n        }\n        return attr1.localeCompare(attr2);\n    }\n    renderAttrs(node) {\n        let i;\n        let attr;\n        const res = [];\n        const attrListToRender = [];\n        if (isDomNode.isCommentNode(node)) {\n            return this.renderComment(node);\n        }\n        if (node.attributes) {\n            for (i = 0; i < node.attributes.length; ++i) {\n                attr = node.attributes[i];\n                //ignore namespace definition attributes\n                if (attr.name.indexOf(\"xmlns\") === 0) {\n                    continue;\n                }\n                attrListToRender.push(attr);\n            }\n        }\n        attrListToRender.sort(this.attrCompare);\n        for (attr of attrListToRender) {\n            res.push(\" \", attr.name, '=\"', utils.encodeSpecialCharactersInAttribute(attr.value), '\"');\n        }\n        return res.join(\"\");\n    }\n    /**\n     * Create the string of all namespace declarations that should appear on this element\n     *\n     * @param {Node} node. The node we now render\n     * @param {Array} prefixesInScope. The prefixes defined on this node\n     *                parents which are a part of the output set\n     * @param {String} defaultNs. The current default namespace\n     * @return {String}\n     * @api private\n     */\n    renderNs(node, prefixesInScope, defaultNs, defaultNsForPrefix, inclusiveNamespacesPrefixList) {\n        let i;\n        let attr;\n        const res = [];\n        let newDefaultNs = defaultNs;\n        const nsListToRender = [];\n        const currNs = node.namespaceURI || \"\";\n        //handle the namespaceof the node itself\n        if (node.prefix) {\n            if (!isPrefixInScope(prefixesInScope, node.prefix, node.namespaceURI || defaultNsForPrefix[node.prefix])) {\n                nsListToRender.push({\n                    prefix: node.prefix,\n                    namespaceURI: node.namespaceURI || defaultNsForPrefix[node.prefix],\n                });\n                prefixesInScope.push({\n                    prefix: node.prefix,\n                    namespaceURI: node.namespaceURI || defaultNsForPrefix[node.prefix],\n                });\n            }\n        }\n        else if (defaultNs !== currNs) {\n            //new default ns\n            newDefaultNs = node.namespaceURI;\n            res.push(' xmlns=\"', newDefaultNs, '\"');\n        }\n        //handle the attributes namespace\n        if (node.attributes) {\n            for (i = 0; i < node.attributes.length; ++i) {\n                attr = node.attributes[i];\n                //handle all prefixed attributes that are included in the prefix list and where\n                //the prefix is not defined already\n                if (attr.prefix &&\n                    !isPrefixInScope(prefixesInScope, attr.localName, attr.value) &&\n                    inclusiveNamespacesPrefixList.indexOf(attr.localName) >= 0) {\n                    nsListToRender.push({ prefix: attr.localName, namespaceURI: attr.value });\n                    prefixesInScope.push({ prefix: attr.localName, namespaceURI: attr.value });\n                }\n                //handle all prefixed attributes that are not xmlns definitions and where\n                //the prefix is not defined already\n                if (attr.prefix &&\n                    !isPrefixInScope(prefixesInScope, attr.prefix, attr.namespaceURI) &&\n                    attr.prefix !== \"xmlns\" &&\n                    attr.prefix !== \"xml\") {\n                    nsListToRender.push({ prefix: attr.prefix, namespaceURI: attr.namespaceURI });\n                    prefixesInScope.push({ prefix: attr.prefix, namespaceURI: attr.namespaceURI });\n                }\n            }\n        }\n        nsListToRender.sort(this.nsCompare);\n        //render namespaces\n        for (const p of nsListToRender) {\n            res.push(\" xmlns:\", p.prefix, '=\"', p.namespaceURI, '\"');\n        }\n        return { rendered: res.join(\"\"), newDefaultNs: newDefaultNs };\n    }\n    /**\n     * @param node Node\n     */\n    processInner(node, prefixesInScope, defaultNs, defaultNsForPrefix, inclusiveNamespacesPrefixList) {\n        if (isDomNode.isCommentNode(node)) {\n            return this.renderComment(node);\n        }\n        if (node.data) {\n            return utils.encodeSpecialCharactersInText(node.data);\n        }\n        if (isDomNode.isElementNode(node)) {\n            let i;\n            let pfxCopy;\n            const ns = this.renderNs(node, prefixesInScope, defaultNs, defaultNsForPrefix, inclusiveNamespacesPrefixList);\n            const res = [\"<\", node.tagName, ns.rendered, this.renderAttrs(node), \">\"];\n            for (i = 0; i < node.childNodes.length; ++i) {\n                pfxCopy = prefixesInScope.slice(0);\n                res.push(this.processInner(node.childNodes[i], pfxCopy, ns.newDefaultNs, defaultNsForPrefix, inclusiveNamespacesPrefixList));\n            }\n            res.push(\"</\", node.tagName, \">\");\n            return res.join(\"\");\n        }\n        throw new Error(`Unable to exclusive canonicalize node type: ${node.nodeType}`);\n    }\n    // Thanks to deoxxa/xml-c14n for comment renderer\n    renderComment(node) {\n        if (!this.includeComments) {\n            return \"\";\n        }\n        const isOutsideDocument = node.ownerDocument === node.parentNode;\n        let isBeforeDocument = false;\n        let isAfterDocument = false;\n        if (isOutsideDocument) {\n            let nextNode = node;\n            let previousNode = node;\n            while (nextNode != null) {\n                if (nextNode === node.ownerDocument.documentElement) {\n                    isBeforeDocument = true;\n                    break;\n                }\n                nextNode = nextNode.nextSibling;\n            }\n            while (previousNode != null) {\n                if (previousNode === node.ownerDocument.documentElement) {\n                    isAfterDocument = true;\n                    break;\n                }\n                previousNode = previousNode.previousSibling;\n            }\n        }\n        const afterDocument = isAfterDocument ? \"\\n\" : \"\";\n        const beforeDocument = isBeforeDocument ? \"\\n\" : \"\";\n        const encodedText = utils.encodeSpecialCharactersInText(node.data);\n        return `${afterDocument}<!--${encodedText}-->${beforeDocument}`;\n    }\n    /**\n     * Perform canonicalization of the given element node\n     *\n     * @api public\n     */\n    process(elem, options) {\n        options = options || {};\n        let inclusiveNamespacesPrefixList = options.inclusiveNamespacesPrefixList || [];\n        const defaultNs = options.defaultNs || \"\";\n        const defaultNsForPrefix = options.defaultNsForPrefix || {};\n        const ancestorNamespaces = options.ancestorNamespaces || [];\n        /**\n         * If the inclusiveNamespacesPrefixList has not been explicitly provided then look it up in CanonicalizationMethod/InclusiveNamespaces\n         */\n        if (!utils.isArrayHasLength(inclusiveNamespacesPrefixList)) {\n            const CanonicalizationMethod = utils.findChildren(elem, \"CanonicalizationMethod\");\n            if (CanonicalizationMethod.length !== 0) {\n                const inclusiveNamespaces = utils.findChildren(CanonicalizationMethod[0], \"InclusiveNamespaces\");\n                if (inclusiveNamespaces.length !== 0) {\n                    inclusiveNamespacesPrefixList = (inclusiveNamespaces[0].getAttribute(\"PrefixList\") || \"\").split(\" \");\n                }\n            }\n        }\n        /**\n         * If you have a PrefixList then use it and the ancestors to add the necessary namespaces\n         */\n        if (utils.isArrayHasLength(inclusiveNamespacesPrefixList)) {\n            inclusiveNamespacesPrefixList.forEach(function (prefix) {\n                if (ancestorNamespaces) {\n                    ancestorNamespaces.forEach(function (ancestorNamespace) {\n                        if (prefix === ancestorNamespace.prefix) {\n                            elem.setAttributeNS(\"http://www.w3.org/2000/xmlns/\", `xmlns:${prefix}`, ancestorNamespace.namespaceURI);\n                        }\n                    });\n                }\n            });\n        }\n        const res = this.processInner(elem, [], defaultNs, defaultNsForPrefix, inclusiveNamespacesPrefixList);\n        return res;\n    }\n    getAlgorithmName() {\n        return \"http://www.w3.org/2001/10/xml-exc-c14n#\";\n    }\n}\nexports.ExclusiveCanonicalization = ExclusiveCanonicalization;\nclass ExclusiveCanonicalizationWithComments extends ExclusiveCanonicalization {\n    constructor() {\n        super();\n        this.includeComments = true;\n    }\n    getAlgorithmName() {\n        return \"http://www.w3.org/2001/10/xml-exc-c14n#WithComments\";\n    }\n}\nexports.ExclusiveCanonicalizationWithComments = ExclusiveCanonicalizationWithComments;\n//# sourceMappingURL=exclusive-canonicalization.js.map","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.EnvelopedSignature = void 0;\nconst xpath = require(\"xpath\");\nconst isDomNode = require(\"@xmldom/is-dom-node\");\nclass EnvelopedSignature {\n    constructor() {\n        this.includeComments = false;\n        this.includeComments = false;\n    }\n    process(node, options) {\n        if (null == options.signatureNode) {\n            const signature = xpath.select1(\"./*[local-name(.)='Signature' and namespace-uri(.)='http://www.w3.org/2000/09/xmldsig#']\", node);\n            if (isDomNode.isNodeLike(signature) && signature.parentNode) {\n                signature.parentNode.removeChild(signature);\n            }\n            return node;\n        }\n        const signatureNode = options.signatureNode;\n        const expectedSignatureValue = xpath.select1(\".//*[local-name(.)='SignatureValue']/text()\", signatureNode);\n        if (isDomNode.isTextNode(expectedSignatureValue)) {\n            const expectedSignatureValueData = expectedSignatureValue.data;\n            const signatures = xpath.select(\".//*[local-name(.)='Signature' and namespace-uri(.)='http://www.w3.org/2000/09/xmldsig#']\", node);\n            for (const nodeSignature of Array.isArray(signatures) ? signatures : []) {\n                const signatureValue = xpath.select1(\".//*[local-name(.)='SignatureValue']/text()\", nodeSignature);\n                if (isDomNode.isTextNode(signatureValue)) {\n                    const signatureValueData = signatureValue.data;\n                    if (expectedSignatureValueData === signatureValueData) {\n                        if (nodeSignature.parentNode) {\n                            nodeSignature.parentNode.removeChild(nodeSignature);\n                        }\n                    }\n                }\n            }\n        }\n        return node;\n    }\n    getAlgorithmName() {\n        return \"http://www.w3.org/2000/09/xmldsig#enveloped-signature\";\n    }\n}\nexports.EnvelopedSignature = EnvelopedSignature;\n//# sourceMappingURL=enveloped-signature.js.map","\"use strict\";\nvar __createBinding = (this && this.__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}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n    for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.SignedXml = void 0;\nvar signed_xml_1 = require(\"./signed-xml\");\nObject.defineProperty(exports, \"SignedXml\", { enumerable: true, get: function () { return signed_xml_1.SignedXml; } });\n__exportStar(require(\"./utils\"), exports);\n__exportStar(require(\"./types\"), exports);\n//# sourceMappingURL=index.js.map","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport xml2js from 'xml2js';\nimport { SignedXml } from 'xml-crypto';\nimport Environment from '@Modules/environment/Environment.js';\n\nexport interface NamespacesProps {\n    [key: string]: string;\n}\nexport interface BodyContentProps {\n    [key: string]: any;\n}\nexport interface SoapEnvelopeObjProps {\n    [key: string]: any;\n}\n\nclass XmlBuilder {\n    environment: Environment;\n    constructor(environment: Environment) {\n        this.environment = environment;\n    }\n\n    /**\n     * Método para assinar o XML\n     */\n    assinarXML(xml: string, tagAssinar: string) {\n        const transforms = [\n            'http://www.w3.org/2000/09/xmldsig#enveloped-signature',\n            'http://www.w3.org/TR/2001/REC-xml-c14n-20010315'\n        ];\n\n        const signedXmlObj = new SignedXml({\n            publicCert: this.environment.getCert(),\n            privateKey: this.environment.getCertKey(),\n            canonicalizationAlgorithm: \"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\",\n            implicitTransforms: ['http://www.w3.org/TR/2001/REC-xml-c14n-20010315']\n        });\n\n        signedXmlObj.addReference({ xpath: `//*[local-name(.)='${tagAssinar}']`, digestAlgorithm: 'http://www.w3.org/2000/09/xmldsig#sha1', transforms });\n        signedXmlObj.signatureAlgorithm = 'http://www.w3.org/2000/09/xmldsig#rsa-sha1';\n        // Assinar o XML\n        signedXmlObj.computeSignature(xml);\n\n        // Obter o XML assinado\n        return signedXmlObj.getSignedXml();\n    }\n\n    /**\n     * Método que converte Objeto em XML\n     */\n    serializeXml<T>(obj: T, rootTag: string) {\n        let builder = new xml2js.Builder({\n            rootName: rootTag,\n            headless: true,\n            renderOpts: {\n                pretty: false\n            },\n            // cdata: true\n        });\n        return builder.buildObject(obj);\n    }\n\n    /**\n     * Método genérico para geração do XML\n     */\n    gerarXml<T>(xmlObject: T, rootTag: string) {\n        return this.serializeXml(xmlObject, rootTag);\n    }\n\n    /**\n     *  Método utilizado para cirar um envelop SOAP - Formato de mensagem para serviço SOAP (como o da SEFAZ)\n     */\n    buildSoapEnvelope(xml: string, soapMethod: string, soapVersion: string = \"soap12\", rootTagObj: any = null) {\n        const soapNamespaces: NamespacesProps = {\n            'soap12': 'http://www.w3.org/2003/05/soap-envelope', // SOAP 1.2\n            'soap': 'http://schemas.xmlsoap.org/soap/envelope/' // SOAP 1.1\n        };\n        const soapNamespace = soapNamespaces[soapVersion] || soapNamespaces['soap12'];\n\n        // Estrutura básica do envelope SOAP\n        let soapEnvelopeObj: SoapEnvelopeObjProps = {\n            '$': {\n                [`xmlns:${soapVersion}`]: soapNamespace,\n                'xmlns:xsi': 'http://www.w3.org/2001/XMLSchema-instance',\n                'xmlns:xsd': 'http://www.w3.org/2001/XMLSchema'\n            },\n            [`${soapVersion}:Body`]: {}\n        };\n\n        // Condicionando a inclusão de 'rootTagObj'\n        if (rootTagObj && rootTagObj.tag) {\n            let bodyContent: BodyContentProps = {\n                'nfeDadosMsg': {\n                    '$': {\n                        'xmlns': soapMethod\n                    },\n                    _: '[XML]'\n                }\n            };\n\n            if (rootTagObj.namespace) {\n                bodyContent['$'] = { 'xmlns': rootTagObj.namespace };\n            }\n\n            soapEnvelopeObj[`${soapVersion}:Body`][rootTagObj.tag] = bodyContent;\n        } else {\n            soapEnvelopeObj[`${soapVersion}:Body`] = {\n                'nfeDadosMsg': {\n                    '$': {\n                        'xmlns': soapMethod\n                    },\n                    _: '[XML]'\n                }\n            };\n        }\n\n        // Serializar o objeto do envelope SOAP para XML\n        let soapEnvXml = this.serializeXml(soapEnvelopeObj, `${soapVersion}:Envelope`);\n        return soapEnvXml.replace('[XML]', xml);\n    }\n\n}\n\nexport default XmlBuilder;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport path from 'path';\nimport { fileURLToPath } from 'url';\n\n\nconst baseDir = path.dirname(fileURLToPath(import.meta.url))\nconst dir = process.env.NODE_ENV === 'production' ? '../resources/schemas' : '../resources/schemas/';\n\n/**\n * Efetua a leitura do Schema\n */\n\ninterface SchemaProps {\n  [key: string]: string;\n}\n\nexport const getSchema = (metodo: string) => {\n  const pathSchemas = path.resolve(baseDir, dir);\n\n  const schema: SchemaProps = {\n    NFEStatusServico: `${pathSchemas}/consStatServ_v4.00.xsd`,\n    NFEConsultaProtocolo: `${pathSchemas}/consSitNFe_v4.00.xsd`,\n    RecepcaoEvento: `${pathSchemas}/envEvento_v1.00.xsd`,\n    NFeDistribuicaoDFe: `${pathSchemas}/distDFeInt_v1.01.xsd`,\n    NFEAutorizacao: `${pathSchemas}/enviNFe_v4.00.xsd`,\n    NFEInutilizacao: `${pathSchemas}/inutNFe_v4.00.xsd`,\n    NFERetAutorizacao: `${pathSchemas}/consReciNFe_v4.00.xsd`,\n  }\n\n  try {\n    return {\n      basePath: pathSchemas,\n      schemaPath: schema[metodo]\n    }\n  } catch (error: any) {\n    throw new Error(error.message);\n  }\n}","module.exports = {\r\n\r\n  isArray: function(value) {\r\n    if (Array.isArray) {\r\n      return Array.isArray(value);\r\n    }\r\n    // fallback for older browsers like  IE 8\r\n    return Object.prototype.toString.call( value ) === '[object Array]';\r\n  }\r\n\r\n};\r\n","var isArray = require('./array-helper').isArray;\r\n\r\nmodule.exports = {\r\n\r\n  copyOptions: function (options) {\r\n    var key, copy = {};\r\n    for (key in options) {\r\n      if (options.hasOwnProperty(key)) {\r\n        copy[key] = options[key];\r\n      }\r\n    }\r\n    return copy;\r\n  },\r\n\r\n  ensureFlagExists: function (item, options) {\r\n    if (!(item in options) || typeof options[item] !== 'boolean') {\r\n      options[item] = false;\r\n    }\r\n  },\r\n\r\n  ensureSpacesExists: function (options) {\r\n    if (!('spaces' in options) || (typeof options.spaces !== 'number' && typeof options.spaces !== 'string')) {\r\n      options.spaces = 0;\r\n    }\r\n  },\r\n\r\n  ensureAlwaysArrayExists: function (options) {\r\n    if (!('alwaysArray' in options) || (typeof options.alwaysArray !== 'boolean' && !isArray(options.alwaysArray))) {\r\n      options.alwaysArray = false;\r\n    }\r\n  },\r\n\r\n  ensureKeyExists: function (key, options) {\r\n    if (!(key + 'Key' in options) || typeof options[key + 'Key'] !== 'string') {\r\n      options[key + 'Key'] = options.compact ? '_' + key : key;\r\n    }\r\n  },\r\n\r\n  checkFnExists: function (key, options) {\r\n    return key + 'Fn' in options;\r\n  }\r\n\r\n};\r\n","var sax = require('sax');\r\nvar expat /*= require('node-expat');*/ = { on: function () { }, parse: function () { } };\r\nvar helper = require('./options-helper');\r\nvar isArray = require('./array-helper').isArray;\r\n\r\nvar options;\r\nvar pureJsParser = true;\r\nvar currentElement;\r\n\r\nfunction validateOptions(userOptions) {\r\n  options = helper.copyOptions(userOptions);\r\n  helper.ensureFlagExists('ignoreDeclaration', options);\r\n  helper.ensureFlagExists('ignoreInstruction', options);\r\n  helper.ensureFlagExists('ignoreAttributes', options);\r\n  helper.ensureFlagExists('ignoreText', options);\r\n  helper.ensureFlagExists('ignoreComment', options);\r\n  helper.ensureFlagExists('ignoreCdata', options);\r\n  helper.ensureFlagExists('ignoreDoctype', options);\r\n  helper.ensureFlagExists('compact', options);\r\n  helper.ensureFlagExists('alwaysChildren', options);\r\n  helper.ensureFlagExists('addParent', options);\r\n  helper.ensureFlagExists('trim', options);\r\n  helper.ensureFlagExists('nativeType', options);\r\n  helper.ensureFlagExists('nativeTypeAttributes', options);\r\n  helper.ensureFlagExists('sanitize', options);\r\n  helper.ensureFlagExists('instructionHasAttributes', options);\r\n  helper.ensureFlagExists('captureSpacesBetweenElements', options);\r\n  helper.ensureAlwaysArrayExists(options);\r\n  helper.ensureKeyExists('declaration', options);\r\n  helper.ensureKeyExists('instruction', options);\r\n  helper.ensureKeyExists('attributes', options);\r\n  helper.ensureKeyExists('text', options);\r\n  helper.ensureKeyExists('comment', options);\r\n  helper.ensureKeyExists('cdata', options);\r\n  helper.ensureKeyExists('doctype', options);\r\n  helper.ensureKeyExists('type', options);\r\n  helper.ensureKeyExists('name', options);\r\n  helper.ensureKeyExists('elements', options);\r\n  helper.ensureKeyExists('parent', options);\r\n  helper.checkFnExists('doctype', options);\r\n  helper.checkFnExists('instruction', options);\r\n  helper.checkFnExists('cdata', options);\r\n  helper.checkFnExists('comment', options);\r\n  helper.checkFnExists('text', options);\r\n  helper.checkFnExists('instructionName', options);\r\n  helper.checkFnExists('elementName', options);\r\n  helper.checkFnExists('attributeName', options);\r\n  helper.checkFnExists('attributeValue', options);\r\n  helper.checkFnExists('attributes', options);\r\n  return options;\r\n}\r\n\r\nfunction nativeType(value) {\r\n  var nValue = Number(value);\r\n  if (!isNaN(nValue)) {\r\n    return nValue;\r\n  }\r\n  var bValue = value.toLowerCase();\r\n  if (bValue === 'true') {\r\n    return true;\r\n  } else if (bValue === 'false') {\r\n    return false;\r\n  }\r\n  return value;\r\n}\r\n\r\nfunction addField(type, value) {\r\n  var key;\r\n  if (options.compact) {\r\n    if (\r\n      !currentElement[options[type + 'Key']] &&\r\n      (isArray(options.alwaysArray) ? options.alwaysArray.indexOf(options[type + 'Key']) !== -1 : options.alwaysArray)\r\n    ) {\r\n      currentElement[options[type + 'Key']] = [];\r\n    }\r\n    if (currentElement[options[type + 'Key']] && !isArray(currentElement[options[type + 'Key']])) {\r\n      currentElement[options[type + 'Key']] = [currentElement[options[type + 'Key']]];\r\n    }\r\n    if (type + 'Fn' in options && typeof value === 'string') {\r\n      value = options[type + 'Fn'](value, currentElement);\r\n    }\r\n    if (type === 'instruction' && ('instructionFn' in options || 'instructionNameFn' in options)) {\r\n      for (key in value) {\r\n        if (value.hasOwnProperty(key)) {\r\n          if ('instructionFn' in options) {\r\n            value[key] = options.instructionFn(value[key], key, currentElement);\r\n          } else {\r\n            var temp = value[key];\r\n            delete value[key];\r\n            value[options.instructionNameFn(key, temp, currentElement)] = temp;\r\n          }\r\n        }\r\n      }\r\n    }\r\n    if (isArray(currentElement[options[type + 'Key']])) {\r\n      currentElement[options[type + 'Key']].push(value);\r\n    } else {\r\n      currentElement[options[type + 'Key']] = value;\r\n    }\r\n  } else {\r\n    if (!currentElement[options.elementsKey]) {\r\n      currentElement[options.elementsKey] = [];\r\n    }\r\n    var element = {};\r\n    element[options.typeKey] = type;\r\n    if (type === 'instruction') {\r\n      for (key in value) {\r\n        if (value.hasOwnProperty(key)) {\r\n          break;\r\n        }\r\n      }\r\n      element[options.nameKey] = 'instructionNameFn' in options ? options.instructionNameFn(key, value, currentElement) : key;\r\n      if (options.instructionHasAttributes) {\r\n        element[options.attributesKey] = value[key][options.attributesKey];\r\n        if ('instructionFn' in options) {\r\n          element[options.attributesKey] = options.instructionFn(element[options.attributesKey], key, currentElement);\r\n        }\r\n      } else {\r\n        if ('instructionFn' in options) {\r\n          value[key] = options.instructionFn(value[key], key, currentElement);\r\n        }\r\n        element[options.instructionKey] = value[key];\r\n      }\r\n    } else {\r\n      if (type + 'Fn' in options) {\r\n        value = options[type + 'Fn'](value, currentElement);\r\n      }\r\n      element[options[type + 'Key']] = value;\r\n    }\r\n    if (options.addParent) {\r\n      element[options.parentKey] = currentElement;\r\n    }\r\n    currentElement[options.elementsKey].push(element);\r\n  }\r\n}\r\n\r\nfunction manipulateAttributes(attributes) {\r\n  if ('attributesFn' in options && attributes) {\r\n    attributes = options.attributesFn(attributes, currentElement);\r\n  }\r\n  if ((options.trim || 'attributeValueFn' in options || 'attributeNameFn' in options || options.nativeTypeAttributes) && attributes) {\r\n    var key;\r\n    for (key in attributes) {\r\n      if (attributes.hasOwnProperty(key)) {\r\n        if (options.trim) attributes[key] = attributes[key].trim();\r\n        if (options.nativeTypeAttributes) {\r\n          attributes[key] = nativeType(attributes[key]);\r\n        }\r\n        if ('attributeValueFn' in options) attributes[key] = options.attributeValueFn(attributes[key], key, currentElement);\r\n        if ('attributeNameFn' in options) {\r\n          var temp = attributes[key];\r\n          delete attributes[key];\r\n          attributes[options.attributeNameFn(key, attributes[key], currentElement)] = temp;\r\n        }\r\n      }\r\n    }\r\n  }\r\n  return attributes;\r\n}\r\n\r\nfunction onInstruction(instruction) {\r\n  var attributes = {};\r\n  if (instruction.body && (instruction.name.toLowerCase() === 'xml' || options.instructionHasAttributes)) {\r\n    var attrsRegExp = /([\\w:-]+)\\s*=\\s*(?:\"([^\"]*)\"|'([^']*)'|(\\w+))\\s*/g;\r\n    var match;\r\n    while ((match = attrsRegExp.exec(instruction.body)) !== null) {\r\n      attributes[match[1]] = match[2] || match[3] || match[4];\r\n    }\r\n    attributes = manipulateAttributes(attributes);\r\n  }\r\n  if (instruction.name.toLowerCase() === 'xml') {\r\n    if (options.ignoreDeclaration) {\r\n      return;\r\n    }\r\n    currentElement[options.declarationKey] = {};\r\n    if (Object.keys(attributes).length) {\r\n      currentElement[options.declarationKey][options.attributesKey] = attributes;\r\n    }\r\n    if (options.addParent) {\r\n      currentElement[options.declarationKey][options.parentKey] = currentElement;\r\n    }\r\n  } else {\r\n    if (options.ignoreInstruction) {\r\n      return;\r\n    }\r\n    if (options.trim) {\r\n      instruction.body = instruction.body.trim();\r\n    }\r\n    var value = {};\r\n    if (options.instructionHasAttributes && Object.keys(attributes).length) {\r\n      value[instruction.name] = {};\r\n      value[instruction.name][options.attributesKey] = attributes;\r\n    } else {\r\n      value[instruction.name] = instruction.body;\r\n    }\r\n    addField('instruction', value);\r\n  }\r\n}\r\n\r\nfunction onStartElement(name, attributes) {\r\n  var element;\r\n  if (typeof name === 'object') {\r\n    attributes = name.attributes;\r\n    name = name.name;\r\n  }\r\n  attributes = manipulateAttributes(attributes);\r\n  if ('elementNameFn' in options) {\r\n    name = options.elementNameFn(name, currentElement);\r\n  }\r\n  if (options.compact) {\r\n    element = {};\r\n    if (!options.ignoreAttributes && attributes && Object.keys(attributes).length) {\r\n      element[options.attributesKey] = {};\r\n      var key;\r\n      for (key in attributes) {\r\n        if (attributes.hasOwnProperty(key)) {\r\n          element[options.attributesKey][key] = attributes[key];\r\n        }\r\n      }\r\n    }\r\n    if (\r\n      !(name in currentElement) &&\r\n      (isArray(options.alwaysArray) ? options.alwaysArray.indexOf(name) !== -1 : options.alwaysArray)\r\n    ) {\r\n      currentElement[name] = [];\r\n    }\r\n    if (currentElement[name] && !isArray(currentElement[name])) {\r\n      currentElement[name] = [currentElement[name]];\r\n    }\r\n    if (isArray(currentElement[name])) {\r\n      currentElement[name].push(element);\r\n    } else {\r\n      currentElement[name] = element;\r\n    }\r\n  } else {\r\n    if (!currentElement[options.elementsKey]) {\r\n      currentElement[options.elementsKey] = [];\r\n    }\r\n    element = {};\r\n    element[options.typeKey] = 'element';\r\n    element[options.nameKey] = name;\r\n    if (!options.ignoreAttributes && attributes && Object.keys(attributes).length) {\r\n      element[options.attributesKey] = attributes;\r\n    }\r\n    if (options.alwaysChildren) {\r\n      element[options.elementsKey] = [];\r\n    }\r\n    currentElement[options.elementsKey].push(element);\r\n  }\r\n  element[options.parentKey] = currentElement; // will be deleted in onEndElement() if !options.addParent\r\n  currentElement = element;\r\n}\r\n\r\nfunction onText(text) {\r\n  if (options.ignoreText) {\r\n    return;\r\n  }\r\n  if (!text.trim() && !options.captureSpacesBetweenElements) {\r\n    return;\r\n  }\r\n  if (options.trim) {\r\n    text = text.trim();\r\n  }\r\n  if (options.nativeType) {\r\n    text = nativeType(text);\r\n  }\r\n  if (options.sanitize) {\r\n    text = text.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');\r\n  }\r\n  addField('text', text);\r\n}\r\n\r\nfunction onComment(comment) {\r\n  if (options.ignoreComment) {\r\n    return;\r\n  }\r\n  if (options.trim) {\r\n    comment = comment.trim();\r\n  }\r\n  addField('comment', comment);\r\n}\r\n\r\nfunction onEndElement(name) {\r\n  var parentElement = currentElement[options.parentKey];\r\n  if (!options.addParent) {\r\n    delete currentElement[options.parentKey];\r\n  }\r\n  currentElement = parentElement;\r\n}\r\n\r\nfunction onCdata(cdata) {\r\n  if (options.ignoreCdata) {\r\n    return;\r\n  }\r\n  if (options.trim) {\r\n    cdata = cdata.trim();\r\n  }\r\n  addField('cdata', cdata);\r\n}\r\n\r\nfunction onDoctype(doctype) {\r\n  if (options.ignoreDoctype) {\r\n    return;\r\n  }\r\n  doctype = doctype.replace(/^ /, '');\r\n  if (options.trim) {\r\n    doctype = doctype.trim();\r\n  }\r\n  addField('doctype', doctype);\r\n}\r\n\r\nfunction onError(error) {\r\n  error.note = error; //console.error(error);\r\n}\r\n\r\nmodule.exports = function (xml, userOptions) {\r\n\r\n  var parser = pureJsParser ? sax.parser(true, {}) : parser = new expat.Parser('UTF-8');\r\n  var result = {};\r\n  currentElement = result;\r\n\r\n  options = validateOptions(userOptions);\r\n\r\n  if (pureJsParser) {\r\n    parser.opt = {strictEntities: true};\r\n    parser.onopentag = onStartElement;\r\n    parser.ontext = onText;\r\n    parser.oncomment = onComment;\r\n    parser.onclosetag = onEndElement;\r\n    parser.onerror = onError;\r\n    parser.oncdata = onCdata;\r\n    parser.ondoctype = onDoctype;\r\n    parser.onprocessinginstruction = onInstruction;\r\n  } else {\r\n    parser.on('startElement', onStartElement);\r\n    parser.on('text', onText);\r\n    parser.on('comment', onComment);\r\n    parser.on('endElement', onEndElement);\r\n    parser.on('error', onError);\r\n    //parser.on('startCdata', onStartCdata);\r\n    //parser.on('endCdata', onEndCdata);\r\n    //parser.on('entityDecl', onEntityDecl);\r\n  }\r\n\r\n  if (pureJsParser) {\r\n    parser.write(xml).close();\r\n  } else {\r\n    if (!parser.parse(xml)) {\r\n      throw new Error('XML parsing error: ' + parser.getError());\r\n    }\r\n  }\r\n\r\n  if (result[options.elementsKey]) {\r\n    var temp = result[options.elementsKey];\r\n    delete result[options.elementsKey];\r\n    result[options.elementsKey] = temp;\r\n    delete result.text;\r\n  }\r\n\r\n  return result;\r\n\r\n};\r\n","var helper = require('./options-helper');\r\nvar xml2js = require('./xml2js');\r\n\r\nfunction validateOptions (userOptions) {\r\n  var options = helper.copyOptions(userOptions);\r\n  helper.ensureSpacesExists(options);\r\n  return options;\r\n}\r\n\r\nmodule.exports = function(xml, userOptions) {\r\n  var options, js, json, parentKey;\r\n  options = validateOptions(userOptions);\r\n  js = xml2js(xml, options);\r\n  parentKey = 'compact' in options && options.compact ? '_parent' : 'parent';\r\n  // parentKey = ptions.compact ? '_parent' : 'parent'; // consider this\r\n  if ('addParent' in options && options.addParent) {\r\n    json = JSON.stringify(js, function (k, v) { return k === parentKey? '_' : v; }, options.spaces);\r\n  } else {\r\n    json = JSON.stringify(js, null, options.spaces);\r\n  }\r\n  return json.replace(/\\u2028/g, '\\\\u2028').replace(/\\u2029/g, '\\\\u2029');\r\n};\r\n","var helper = require('./options-helper');\nvar isArray = require('./array-helper').isArray;\n\nvar currentElement, currentElementName;\n\nfunction validateOptions(userOptions) {\n  var options = helper.copyOptions(userOptions);\n  helper.ensureFlagExists('ignoreDeclaration', options);\n  helper.ensureFlagExists('ignoreInstruction', options);\n  helper.ensureFlagExists('ignoreAttributes', options);\n  helper.ensureFlagExists('ignoreText', options);\n  helper.ensureFlagExists('ignoreComment', options);\n  helper.ensureFlagExists('ignoreCdata', options);\n  helper.ensureFlagExists('ignoreDoctype', options);\n  helper.ensureFlagExists('compact', options);\n  helper.ensureFlagExists('indentText', options);\n  helper.ensureFlagExists('indentCdata', options);\n  helper.ensureFlagExists('indentAttributes', options);\n  helper.ensureFlagExists('indentInstruction', options);\n  helper.ensureFlagExists('fullTagEmptyElement', options);\n  helper.ensureFlagExists('noQuotesForNativeAttributes', options);\n  helper.ensureSpacesExists(options);\n  if (typeof options.spaces === 'number') {\n    options.spaces = Array(options.spaces + 1).join(' ');\n  }\n  helper.ensureKeyExists('declaration', options);\n  helper.ensureKeyExists('instruction', options);\n  helper.ensureKeyExists('attributes', options);\n  helper.ensureKeyExists('text', options);\n  helper.ensureKeyExists('comment', options);\n  helper.ensureKeyExists('cdata', options);\n  helper.ensureKeyExists('doctype', options);\n  helper.ensureKeyExists('type', options);\n  helper.ensureKeyExists('name', options);\n  helper.ensureKeyExists('elements', options);\n  helper.checkFnExists('doctype', options);\n  helper.checkFnExists('instruction', options);\n  helper.checkFnExists('cdata', options);\n  helper.checkFnExists('comment', options);\n  helper.checkFnExists('text', options);\n  helper.checkFnExists('instructionName', options);\n  helper.checkFnExists('elementName', options);\n  helper.checkFnExists('attributeName', options);\n  helper.checkFnExists('attributeValue', options);\n  helper.checkFnExists('attributes', options);\n  helper.checkFnExists('fullTagEmptyElement', options);\n  return options;\n}\n\nfunction writeIndentation(options, depth, firstLine) {\n  return (!firstLine && options.spaces ? '\\n' : '') + Array(depth + 1).join(options.spaces);\n}\n\nfunction writeAttributes(attributes, options, depth) {\n  if (options.ignoreAttributes) {\n    return '';\n  }\n  if ('attributesFn' in options) {\n    attributes = options.attributesFn(attributes, currentElementName, currentElement);\n  }\n  var key, attr, attrName, quote, result = [];\n  for (key in attributes) {\n    if (attributes.hasOwnProperty(key) && attributes[key] !== null && attributes[key] !== undefined) {\n      quote = options.noQuotesForNativeAttributes && typeof attributes[key] !== 'string' ? '' : '\"';\n      attr = '' + attributes[key]; // ensure number and boolean are converted to String\n      attr = attr.replace(/\"/g, '&quot;');\n      attrName = 'attributeNameFn' in options ? options.attributeNameFn(key, attr, currentElementName, currentElement) : key;\n      result.push((options.spaces && options.indentAttributes? writeIndentation(options, depth+1, false) : ' '));\n      result.push(attrName + '=' + quote + ('attributeValueFn' in options ? options.attributeValueFn(attr, key, currentElementName, currentElement) : attr) + quote);\n    }\n  }\n  if (attributes && Object.keys(attributes).length && options.spaces && options.indentAttributes) {\n    result.push(writeIndentation(options, depth, false));\n  }\n  return result.join('');\n}\n\nfunction writeDeclaration(declaration, options, depth) {\n  currentElement = declaration;\n  currentElementName = 'xml';\n  return options.ignoreDeclaration ? '' :  '<?' + 'xml' + writeAttributes(declaration[options.attributesKey], options, depth) + '?>';\n}\n\nfunction writeInstruction(instruction, options, depth) {\n  if (options.ignoreInstruction) {\n    return '';\n  }\n  var key;\n  for (key in instruction) {\n    if (instruction.hasOwnProperty(key)) {\n      break;\n    }\n  }\n  var instructionName = 'instructionNameFn' in options ? options.instructionNameFn(key, instruction[key], currentElementName, currentElement) : key;\n  if (typeof instruction[key] === 'object') {\n    currentElement = instruction;\n    currentElementName = instructionName;\n    return '<?' + instructionName + writeAttributes(instruction[key][options.attributesKey], options, depth) + '?>';\n  } else {\n    var instructionValue = instruction[key] ? instruction[key] : '';\n    if ('instructionFn' in options) instructionValue = options.instructionFn(instructionValue, key, currentElementName, currentElement);\n    return '<?' + instructionName + (instructionValue ? ' ' + instructionValue : '') + '?>';\n  }\n}\n\nfunction writeComment(comment, options) {\n  return options.ignoreComment ? '' : '<!--' + ('commentFn' in options ? options.commentFn(comment, currentElementName, currentElement) : comment) + '-->';\n}\n\nfunction writeCdata(cdata, options) {\n  return options.ignoreCdata ? '' : '<![CDATA[' + ('cdataFn' in options ? options.cdataFn(cdata, currentElementName, currentElement) : cdata.replace(']]>', ']]]]><![CDATA[>')) + ']]>';\n}\n\nfunction writeDoctype(doctype, options) {\n  return options.ignoreDoctype ? '' : '<!DOCTYPE ' + ('doctypeFn' in options ? options.doctypeFn(doctype, currentElementName, currentElement) : doctype) + '>';\n}\n\nfunction writeText(text, options) {\n  if (options.ignoreText) return '';\n  text = '' + text; // ensure Number and Boolean are converted to String\n  text = text.replace(/&amp;/g, '&'); // desanitize to avoid double sanitization\n  text = text.replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');\n  return 'textFn' in options ? options.textFn(text, currentElementName, currentElement) : text;\n}\n\nfunction hasContent(element, options) {\n  var i;\n  if (element.elements && element.elements.length) {\n    for (i = 0; i < element.elements.length; ++i) {\n      switch (element.elements[i][options.typeKey]) {\n      case 'text':\n        if (options.indentText) {\n          return true;\n        }\n        break; // skip to next key\n      case 'cdata':\n        if (options.indentCdata) {\n          return true;\n        }\n        break; // skip to next key\n      case 'instruction':\n        if (options.indentInstruction) {\n          return true;\n        }\n        break; // skip to next key\n      case 'doctype':\n      case 'comment':\n      case 'element':\n        return true;\n      default:\n        return true;\n      }\n    }\n  }\n  return false;\n}\n\nfunction writeElement(element, options, depth) {\n  currentElement = element;\n  currentElementName = element.name;\n  var xml = [], elementName = 'elementNameFn' in options ? options.elementNameFn(element.name, element) : element.name;\n  xml.push('<' + elementName);\n  if (element[options.attributesKey]) {\n    xml.push(writeAttributes(element[options.attributesKey], options, depth));\n  }\n  var withClosingTag = element[options.elementsKey] && element[options.elementsKey].length || element[options.attributesKey] && element[options.attributesKey]['xml:space'] === 'preserve';\n  if (!withClosingTag) {\n    if ('fullTagEmptyElementFn' in options) {\n      withClosingTag = options.fullTagEmptyElementFn(element.name, element);\n    } else {\n      withClosingTag = options.fullTagEmptyElement;\n    }\n  }\n  if (withClosingTag) {\n    xml.push('>');\n    if (element[options.elementsKey] && element[options.elementsKey].length) {\n      xml.push(writeElements(element[options.elementsKey], options, depth + 1));\n      currentElement = element;\n      currentElementName = element.name;\n    }\n    xml.push(options.spaces && hasContent(element, options) ? '\\n' + Array(depth + 1).join(options.spaces) : '');\n    xml.push('</' + elementName + '>');\n  } else {\n    xml.push('/>');\n  }\n  return xml.join('');\n}\n\nfunction writeElements(elements, options, depth, firstLine) {\n  return elements.reduce(function (xml, element) {\n    var indent = writeIndentation(options, depth, firstLine && !xml);\n    switch (element.type) {\n    case 'element': return xml + indent + writeElement(element, options, depth);\n    case 'comment': return xml + indent + writeComment(element[options.commentKey], options);\n    case 'doctype': return xml + indent + writeDoctype(element[options.doctypeKey], options);\n    case 'cdata': return xml + (options.indentCdata ? indent : '') + writeCdata(element[options.cdataKey], options);\n    case 'text': return xml + (options.indentText ? indent : '') + writeText(element[options.textKey], options);\n    case 'instruction':\n      var instruction = {};\n      instruction[element[options.nameKey]] = element[options.attributesKey] ? element : element[options.instructionKey];\n      return xml + (options.indentInstruction ? indent : '') + writeInstruction(instruction, options, depth);\n    }\n  }, '');\n}\n\nfunction hasContentCompact(element, options, anyContent) {\n  var key;\n  for (key in element) {\n    if (element.hasOwnProperty(key)) {\n      switch (key) {\n      case options.parentKey:\n      case options.attributesKey:\n        break; // skip to next key\n      case options.textKey:\n        if (options.indentText || anyContent) {\n          return true;\n        }\n        break; // skip to next key\n      case options.cdataKey:\n        if (options.indentCdata || anyContent) {\n          return true;\n        }\n        break; // skip to next key\n      case options.instructionKey:\n        if (options.indentInstruction || anyContent) {\n          return true;\n        }\n        break; // skip to next key\n      case options.doctypeKey:\n      case options.commentKey:\n        return true;\n      default:\n        return true;\n      }\n    }\n  }\n  return false;\n}\n\nfunction writeElementCompact(element, name, options, depth, indent) {\n  currentElement = element;\n  currentElementName = name;\n  var elementName = 'elementNameFn' in options ? options.elementNameFn(name, element) : name;\n  if (typeof element === 'undefined' || element === null || element === '') {\n    return 'fullTagEmptyElementFn' in options && options.fullTagEmptyElementFn(name, element) || options.fullTagEmptyElement ? '<' + elementName + '></' + elementName + '>' : '<' + elementName + '/>';\n  }\n  var xml = [];\n  if (name) {\n    xml.push('<' + elementName);\n    if (typeof element !== 'object') {\n      xml.push('>' + writeText(element,options) + '</' + elementName + '>');\n      return xml.join('');\n    }\n    if (element[options.attributesKey]) {\n      xml.push(writeAttributes(element[options.attributesKey], options, depth));\n    }\n    var withClosingTag = hasContentCompact(element, options, true) || element[options.attributesKey] && element[options.attributesKey]['xml:space'] === 'preserve';\n    if (!withClosingTag) {\n      if ('fullTagEmptyElementFn' in options) {\n        withClosingTag = options.fullTagEmptyElementFn(name, element);\n      } else {\n        withClosingTag = options.fullTagEmptyElement;\n      }\n    }\n    if (withClosingTag) {\n      xml.push('>');\n    } else {\n      xml.push('/>');\n      return xml.join('');\n    }\n  }\n  xml.push(writeElementsCompact(element, options, depth + 1, false));\n  currentElement = element;\n  currentElementName = name;\n  if (name) {\n    xml.push((indent ? writeIndentation(options, depth, false) : '') + '</' + elementName + '>');\n  }\n  return xml.join('');\n}\n\nfunction writeElementsCompact(element, options, depth, firstLine) {\n  var i, key, nodes, xml = [];\n  for (key in element) {\n    if (element.hasOwnProperty(key)) {\n      nodes = isArray(element[key]) ? element[key] : [element[key]];\n      for (i = 0; i < nodes.length; ++i) {\n        switch (key) {\n        case options.declarationKey: xml.push(writeDeclaration(nodes[i], options, depth)); break;\n        case options.instructionKey: xml.push((options.indentInstruction ? writeIndentation(options, depth, firstLine) : '') + writeInstruction(nodes[i], options, depth)); break;\n        case options.attributesKey: case options.parentKey: break; // skip\n        case options.textKey: xml.push((options.indentText ? writeIndentation(options, depth, firstLine) : '') + writeText(nodes[i], options)); break;\n        case options.cdataKey: xml.push((options.indentCdata ? writeIndentation(options, depth, firstLine) : '') + writeCdata(nodes[i], options)); break;\n        case options.doctypeKey: xml.push(writeIndentation(options, depth, firstLine) + writeDoctype(nodes[i], options)); break;\n        case options.commentKey: xml.push(writeIndentation(options, depth, firstLine) + writeComment(nodes[i], options)); break;\n        default: xml.push(writeIndentation(options, depth, firstLine) + writeElementCompact(nodes[i], key, options, depth, hasContentCompact(nodes[i], options)));\n        }\n        firstLine = firstLine && !xml.length;\n      }\n    }\n  }\n  return xml.join('');\n}\n\nmodule.exports = function (js, options) {\n  options = validateOptions(options);\n  var xml = [];\n  currentElement = js;\n  currentElementName = '_root_';\n  if (options.compact) {\n    xml.push(writeElementsCompact(js, options, 0, true));\n  } else {\n    if (js[options.declarationKey]) {\n      xml.push(writeDeclaration(js[options.declarationKey], options, 0));\n    }\n    if (js[options.elementsKey] && js[options.elementsKey].length) {\n      xml.push(writeElements(js[options.elementsKey], options, 0, !xml.length));\n    }\n  }\n  return xml.join('');\n};\n","var js2xml = require('./js2xml.js');\r\n\r\nmodule.exports = function (json, options) {\r\n  if (json instanceof Buffer) {\r\n    json = json.toString();\r\n  }\r\n  var js = null;\r\n  if (typeof (json) === 'string') {\r\n    try {\r\n      js = JSON.parse(json);\r\n    } catch (e) {\r\n      throw new Error('The JSON structure is invalid');\r\n    }\r\n  } else {\r\n    js = json;\r\n  }\r\n  return js2xml(js, options);\r\n};\r\n","/*jslint node:true */\r\n\r\nvar xml2js = require('./xml2js');\r\nvar xml2json = require('./xml2json');\r\nvar js2xml = require('./js2xml');\r\nvar json2xml = require('./json2xml');\r\n\r\nmodule.exports = {\r\n  xml2js: xml2js,\r\n  xml2json: xml2json,\r\n  js2xml: js2xml,\r\n  json2xml: json2xml\r\n};\r\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\n\nimport { GenericObject } from 'src/core/types';\nimport * as convert from \"xml-js\";\n\nexport default class XmlParser {\n    constructor() { }\n\n    findInObj = (obj: GenericObject, chave: string): any => {\n        if (obj.hasOwnProperty(chave)) {\n            return obj[chave];\n        }\n        for (let prop in obj) {\n            if (typeof obj[prop] === 'object') {\n                const result = this.findInObj(obj[prop], chave); // Passar a chave aqui\n                if (result) {\n                    return result;\n                }\n            }\n        }\n        return '';\n    };\n\n    removeJsonTextAttribute(value: string, parentElement: any) {\n        const pOpKeys = Object.keys(parentElement._parent);\n        const keyNo = pOpKeys.length;\n        const keyName = pOpKeys[keyNo - 1];\n        const arrOfKey = parentElement._parent[keyName];\n        const arrOfKeyLen = arrOfKey.length;\n        if (arrOfKeyLen > 0) {\n            const arr = arrOfKey;\n            const arrIndex = arrOfKey.length - 1;\n            arr[arrIndex] = value;\n        } else {\n            parentElement._parent[keyName] = value;\n        }\n    }\n\n    getStatusServicoBody(jsonData: any): any {\n        ;\n        return this.findInObj(jsonData, 'retConsStatServ');\n    }\n    getConsultaProtocoloBody(jsonData: any): any {\n        return this.findInObj(jsonData, 'retConsSitNFe');\n    }\n    getRecepcaoEventoBody(jsonData: any): any {\n        return this.findInObj(jsonData, 'retEnvEvento');\n    }\n    getDistribuicaoDFe(jsonData: any): any {\n        return this.findInObj(jsonData, 'nfeDistDFeInteresseResult');\n    }\n    getDistribuicaoDFeProcBody(jsonData: any): any {\n        return this.findInObj(jsonData, 'NFe');\n    }\n    getDistribuicaoDFeResBody(jsonData: any): any {\n        return this.findInObj(jsonData, 'resNFe');\n    }\n    getDistribuicaoDFeEventBody(jsonData: any): any {\n        return this.findInObj(jsonData, 'evento');\n    }\n    getAutorizacaoEventBody(jsonData: any): any {\n        return this.findInObj(jsonData, 'retEnviNFe');\n    }\n    getAutorizacaoFinalEventBody(jsonData: any): any {\n        return this.findInObj(jsonData, 'nfeProc');\n    }\n    getAutorizacaoRetornoEventBody(jsonData: any): any {\n        return this.findInObj(jsonData, 'protNFe');\n    }\n    getInutilizacaoRetornoEventBody(jsonData: any): any {\n        return this.findInObj(jsonData, 'infInut');\n    }\n\n    convertXmlToJson(xml: string, metodo: string, nsu?: string): GenericObject {\n        try {\n            const jsonAsString = convert.xml2json(xml, {\n                compact: true,\n                spaces: 2,\n                ignoreAttributes: true,\n                ignoreDeclaration: true,\n                trim: true,\n                ignoreInstruction: true,\n                ignoreComment: true,\n                ignoreCdata: true,\n                ignoreDoctype: true,\n                textFn: this.removeJsonTextAttribute,\n            });\n\n            const jsonData = JSON.parse(jsonAsString);\n            let jsonBody: any;\n\n            switch (metodo) {\n                case 'NFEStatusServico':\n                    jsonBody = this.getStatusServicoBody(jsonData)\n                    break;\n                case 'NFEConsultaProtocolo':\n                    jsonBody = this.getConsultaProtocoloBody(jsonData)\n                    break;\n                case 'RecepcaoEvento':\n                    jsonBody = this.getRecepcaoEventoBody(jsonData)\n                    break;\n                case 'NFeDistribuicaoDFe':\n                    jsonBody = this.getDistribuicaoDFe(jsonData)\n                    break;\n                case 'NFeDistribuicaoDFe_proc':\n                    jsonBody = jsonData\n                    break;\n                case 'NFeDistribuicaoDFe_res':\n                    jsonBody = this.getDistribuicaoDFeResBody(jsonData)\n                    break;\n                case 'NFeDistribuicaoDFe_event':\n                    jsonBody = this.getDistribuicaoDFeEventBody(jsonData)\n                    break;\n                case 'NFEAutorizacao':\n                    jsonBody = this.getAutorizacaoEventBody(jsonData)\n                    break;\n                case 'NFEAutorizacaoFinal':\n                    jsonBody = this.getAutorizacaoFinalEventBody(jsonData)\n                    break;\n                case 'NFCEAutorizacaoFinal':\n                    jsonBody = this.getAutorizacaoFinalEventBody(jsonData)\n                    break;\n                case 'NFERetAutorizacao':\n                    jsonBody = this.getAutorizacaoRetornoEventBody(jsonData)\n                    break;\n                case 'NFEInutilizacao':\n                    jsonBody = this.getInutilizacaoRetornoEventBody(jsonData)\n                    break;\n                default:\n                    throw new Error('Formato de XML desconhecido');\n            }\n\n            if (jsonBody) {\n                if (nsu) {\n                    jsonBody.nsu = nsu;\n                }\n                jsonBody.xml = xml;\n            }\n\n            return jsonBody;\n        } catch (error) {\n            throw new Error(`Erro ao converter XML para Json: ${error}`);\n        }\n    }\n}\n","\"use strict\";var e=require(\"path\"),t=require(\"fs\");class s{constructor(e,t,s){this.loader=e,this.resolver=t,this.merger=s}async assemble(t){const s=await this.resolver.resolveIncludes(t,!0,e.dirname(t)),r=this.normalizeRegexPatterns(s);return this.merger.mergeProperties(r)}normalizeRegexPatterns(e){return e.replace(/\\\\\\\\/g,\"\\\\\")}}class r{constructor(){this.schemaAttributes={}}extractSchemaAttributes(e){const t=e.match(/<xs:schema([^>]*)>/i);if(t){const e=t[1].trim().split(/\\s+/);for(const t of e){const[e,s]=t.split(\"=\");e&&s&&!this.schemaAttributes[e]&&(this.schemaAttributes[e]=s)}}}mergeSchemaAttributes(e){const t=e.match(/<xs:schema([^>]*)>/i);if(t){const e=t[1].trim().split(/\\s+/);for(const t of e){const[e,s]=t.split(\"=\");e&&s&&!this.schemaAttributes[e]&&(this.schemaAttributes[e]=s)}}}getSchemaAttributes(){return this.schemaAttributes}async load(e,s){return new Promise(((r,i)=>{t.readFile(e,\"utf8\",((e,t)=>{if(e)return i(e);s?this.extractSchemaAttributes(t):this.mergeSchemaAttributes(t),s||(t=t.replace(/<\\?xml.*?\\?>\\s*/i,\"\")),s||(t=t.replace(/<xs:schema[^>]*>/i,\"\").replace(/<\\/xs:schema>/i,\"\")),r(t)}))}))}}class i{constructor(e){this.loader=e}applySchemaAttributes(e){const t=this.loader.getSchemaAttributes(),s=e.match(/<xs:schema[^>]*>/i);if(s){const r=`<xs:schema ${Object.entries(t).map((([e,t])=>`${e}=${t}`)).join(\" \")}>`;return e.replace(s[0],r)}return e}reorderSchemaDirectives(e){const t=/<xs:import[^>]*\\/>/g,s=/<xs:include[^>]*\\/>/g,r=[...e.match(t)||[]],i=[...e.match(s)||[]];let c=e.replace(t,\"\").replace(s,\"\");const a=c.match(/<xs:schema[^>]*>/i);if(!a)throw new Error(\"A tag <xs:schema> não foi encontrada no conteúdo do schema.\");const n=a[0],o=c.indexOf(n)+n.length,h=c.slice(0,o),l=c.slice(o);return`${h}\\n${r.join(\"\\n\")}\\n${i.join(\"\\n\")}\\n${l}`}async resolveIncludes(t,s=!0,r=\".\"){let i=await this.loader.load(t,s);const c=/<xs:include\\s+schemaLocation=\"([^\"]+)\"\\s*\\/?>/g;let a;for(;null!==(a=c.exec(i));){const t=e.resolve(r,a[1]),s=await this.resolveIncludes(t,!1,r);i=i.replace(a[0],s)}return s&&(i=this.applySchemaAttributes(i),i=this.reorderSchemaDirectives(i)),i}}class c{constructor(e){this.strategy=e}mergeProperties(e){return e}}class a{merge(e,t){return`${t}`}}const n=new class{constructor(){this.loader=new r,this.resolver=new i(this.loader),this.setMergeStrategy(new a)}setMergeStrategy(e){return this.merger=new c(e),this}assemble(e){if(!this.merger)throw new Error(\"Merge strategy must be set before building XSDAssembler.\");return new s(this.loader,this.resolver,this.merger).assemble(e)}};module.exports=n;//# sourceMappingURL=index.js.map\n","/**\n    * @description      : \n    * @author           : \n    * @group            : \n    * @created          : 21/03/2025 - 21:50:20\n    * \n    * MODIFICATION LOG\n    * - Version         : 1.0.0\n    * - Date            : 21/03/2025\n    * - Author          : \n    * - Modification    : \n**/\n/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\n\nimport fs from 'fs';\nimport xsdValidator from 'xsd-schema-validator';\nimport NFeServicosUrl from '../config/NFeServicosUrl.json';\nimport soapMethod from '../config/soapMethod.json';\nimport cStatError from '../config/cStatError.json';\nimport { getSchema } from '../../adapters/SchemaLoader';\nimport Environment from '@Modules/environment/Environment.js';\nimport { NFeWizardProps, GenericObject, SoapMethod, NFeServicosUrlType, SaveXMLProps, SaveJSONProps, ProtNFe, ServicesUrl } from 'src/core/types';\nimport XmlParser from './XmlParser';\nimport xml2js from 'xml2js';\nimport libxmljs from 'libxmljs';\nimport xsdAssembler from 'xsd-assembler';\n\nclass Utility {\n    environment;\n    xmlParser: XmlParser;\n\n    constructor(environment: Environment) {\n        this.environment = environment;\n        this.xmlParser = new XmlParser();\n    }\n\n    /**\n     * Método utilitário para criar diretórios\n     */\n    createDir(path: string) {\n        if (!fs.existsSync(path)) {\n            fs.mkdirSync(path, { recursive: true });\n        }\n    }\n\n    /**\n     * Método utilitário para escrever arquivo\n     */\n    createFile(path: string, fileName: string, file: any, extension: string) {\n        if (extension.toLowerCase() === 'json') {\n            fs.writeFileSync(`${path}/${fileName}.${extension}`, JSON.stringify(file));\n        } else {\n            fs.writeFileSync(`${path}/${fileName}.${extension}`, file);\n        }\n    }\n\n    /**\n     * Função recursiva para encontrar a chave em qualquer nivel do objeto\n     */\n    findInObj = (obj: GenericObject, chave: string): any => {\n        if (obj.hasOwnProperty(chave)) {\n            return obj[chave];\n        }\n        for (let prop in obj) {\n            if (typeof obj[prop] === 'object') {\n                const result = this.findInObj(obj[prop], chave); // Passar a chave aqui\n                if (result) {\n                    return result;\n                }\n            }\n        }\n        return '';\n    };\n\n    /**\n     * Método responsável por gravar o XML como json\n     */\n    salvaJSON(props: SaveJSONProps) {\n        const { fileName, metodo, path, data } = props;\n        try {\n            let pathJson = path;\n\n            if (!pathJson || pathJson.trim() === '') {\n                pathJson = `../tmp/${metodo}/`\n            }\n\n            // Utiliza a função recursiva para encontrar a chave chNFe\n            // const chNFe = this.findInObj(json, 'chNFe');\n\n            this.createDir(pathJson);\n\n            this.createFile(pathJson, fileName, data, 'json');\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    /**\n     * Método responsável por gravar os XML recebidos em disco\n     */\n    salvaXMLFromJson(config: NFeWizardProps, xmlInJson: any, fileName = \"\", metodo = \"\") {\n        try {\n            let pathXml = config.dfe.pathXMLRetorno;\n\n            if (!pathXml || pathXml.trim() === '') {\n                pathXml = `../tmp/${metodo}/`\n            }\n\n            const { xml } = xmlInJson;\n\n            // Utiliza a função recursiva para encontrar a chave chNFe\n            const chNFe = this.findInObj(xmlInJson, 'chNFe');\n\n            this.createDir(pathXml);\n\n            this.createFile(pathXml, fileName || chNFe, xml, 'xml');\n\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    salvaXML(props: SaveXMLProps) {\n        const { fileName, metodo, path, data } = props;\n        try {\n            let pathXml = path;\n\n            if (!pathXml || pathXml.trim() === '') {\n                pathXml = `../tmp/${metodo}/`\n            }\n\n            // busca a chave chNFe\n            // xml2js.parseString(xml, (err, result) => {\n            //     if (err) {\n            //         console.error('Erro ao parsear o XML para captura do chNFe:', err);\n            //     } else {\n            //         console.log(result);\n            //     }\n            // });\n\n            this.createDir(pathXml);\n\n            this.createFile(pathXml, fileName, data, 'xml');\n\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    /**\n     * Recupera url para action e metoodo do SOAP\n     */\n    getSoapInfo1(uf: string, metodo: string) {\n        const methodConfig = soapMethod as SoapMethod;\n        const methodInfo = methodConfig[metodo];\n        if (!methodInfo) {\n            throw new Error(\"Método não encontrado no arquivo de configuração SOAP.\");\n        }\n\n        return {\n            method: methodInfo.method,\n            action: methodInfo.action,\n        };\n    }\n\n    getSoapInfo(uf: string, method: string) {\n        const servicos = NFeServicosUrl as ServicesUrl;\n        let chaveMethod = '';\n        let chaveSoap = '';\n\n        switch (uf) {\n            case 'SP':\n                chaveSoap = 'SOAP_V4_SP';\n                break;\n            case 'BA':\n                chaveSoap = 'SOAP_V4_BA';\n                break;\n            default:\n                chaveSoap = 'SOAP_V4';\n                break;\n        }\n\n        switch (uf) {\n            case 'SP':\n                chaveMethod = 'WSDL_V4_SP';\n                break;\n            default:\n                chaveMethod = 'WSDL_V4';\n                break;\n        }\n\n        const methodServices = servicos[chaveMethod];\n        const methodUrl = this.getLatestURLConsulta(methodServices, method);\n\n        const soapServices = servicos[chaveSoap];\n        const soapUrl = this.getLatestURLConsulta(soapServices, method);\n\n        if (!methodUrl || !soapUrl) {\n            throw new Error(\"Método não encontrado no arquivo de configuração SOAP.\");\n        }\n\n        return {\n            method: methodUrl,\n            action: soapUrl,\n        };\n    }\n\n    /**\n     * Marco, adicionei este metodo para concatenar todas url incluido as na Usar, mas no fim nao precisei usar por enquanto\n     * @param chave \n     * @returns \n     */\n    getLatestURLConsultaFix(chave: string): Record<string, string> {\n        const urls = NFeServicosUrl as NFeServicosUrlType;\n        const temp_urls: Record<string, string> = { ...urls[chave] };\n        if ('Usar' in temp_urls) {\n            const referencedChave = temp_urls['Usar'];\n            const referencedUrls = urls[referencedChave] || {};\n            Object.keys(referencedUrls).forEach((key) => {\n                if (!(key in temp_urls)) {\n                    temp_urls[key] = referencedUrls[key];\n                }\n            });\n            delete temp_urls['Usar'];\n        }\n        return temp_urls;\n    }\n\n    getLatestURLConsulta(data: Record<string, string>, metodo: string): string | null {\n        // Obtem todas as chaves do objeto\n        const keys = Object.keys(data);\n\n        // Monta o prefixo dinâmico com base no método fornecido\n        const prefix = `${metodo}_`;\n\n        // Filtra as chaves que começam com o prefixo dinâmico e extrai as versões\n        const versions = keys\n            .map(key => {\n                const match = key.match(new RegExp(`^${prefix}(\\\\d+\\\\.\\\\d+)$`));\n                return match ? parseFloat(match[1]) : null; // Extrai a versão como número\n            })\n            .filter(version => version !== null) // Remove versões que não existem\n            .sort((a, b) => b - a); // Ordena em ordem decrescente\n\n        // Busca a primeira URL que corresponder à versão mais alta\n        for (let version of versions) {\n            const key = `${prefix}${version.toFixed(2)}`; // Formata a chave\n            if (data[key]) {\n                return data[key]; // Retorna a URL encontrada\n            }\n        }\n\n        // Caso não encontre nenhuma versão numerada, retorna a URL sem versão\n        return data[metodo] || null;\n    };\n\n    /**\n     * Define o ambiente (UF e Produção ou Homologação) para geração das chaves de recuperação da URL do webservice\n     */\n    setAmbiente(metodo: string, ambienteNacional = false, versao: string, mod: string) {\n        const config = this.environment.getConfig();\n        const ambiente = config.nfe.ambiente === 2 ? 'H' : 'P';\n\n        const versaoDF = versao !== \"\" ? versao : config.nfe.versaoDF;\n\n        if (ambienteNacional) {\n            const chaveMae = `${mod}_AN_${ambiente}`;\n            const chaveFilha = `${metodo}_${versaoDF}`;\n\n            return { chaveMae, chaveFilha };\n        }\n\n        const chaveMae = `${mod}_${config.dfe.UF}_${ambiente}`;\n        const chaveFilha = `${metodo}_${versaoDF}`;\n\n        return { chaveMae, chaveFilha };\n    }\n\n    /**\n     * Retorna a url correta do webservice\n     */\n    getWebServiceUrl(metodo: string, ambienteNacional = false, versao = \"\", mod = \"NFe\"): string {\n        let { chaveMae, chaveFilha } = this.setAmbiente(metodo, ambienteNacional, versao, mod);\n        const urls = NFeServicosUrl as NFeServicosUrlType;\n\n        if ('Usar' in urls[chaveMae])\n            chaveMae = urls[chaveMae].Usar\n\n        const url = urls[chaveMae] && urls[chaveMae][chaveFilha];\n        if (!url) {\n            throw new Error(`Não foi possível recuperar a url para o webservice: ${chaveFilha}`);\n        }\n        return url;\n    }\n\n    getUrlNFCe(metodo: string, ambienteNacional = false, versao = \"\"): string {\n        let { chaveMae } = this.setAmbiente(metodo, ambienteNacional, versao, 'NFCe');\n        const urls = NFeServicosUrl as NFeServicosUrlType;\n        // removendo este codigo funciona\n        // if ('Usar' in urls[chaveMae]){\n        //     chaveMae = urls[chaveMae].Usar\n        // }\n        // const tempUrls = this.getLatestURLConsultaFix(chaveMae);\n        // const urlnew =tempUrls[metodo];\n        // const chaveFilha = this.getLatestURLConsulta(urls[chaveMae], metodo);\n        const url = urls[chaveMae] && this.getLatestURLConsulta(urls[chaveMae], metodo)\n        if (!url) {\n            throw new Error(`Não foi possível recuperar a url para consulta de NFCe: ${chaveMae}`);\n        }\n        return url;\n    }\n    /**\n     * Função para validar XML com Schema\n     */\n\n    formatErrorMessage(message: string) {\n        // Esta função extrai e formata a mensagem de erro\n        const regex = /\\[error\\]\\s(.+?)\\:\\s(.+?)\\s\\((\\d+):(\\d+)\\)/;\n        const match = message.match(regex);\n        if (match) {\n            const [_, errorCode, errorDescription, line, column] = match;\n            return `Erro na Validação do XML: ${errorCode} na linha ${line}, coluna ${column}. Descrição: ${errorDescription}`;\n        } else {\n            return `Erro Não Identificado na Validação do XML: ${message}`; // Retorna a mensagem original se ela não corresponder ao formato esperado\n        }\n    }\n\n    validateSchemaJsBased(xml: any, metodo: string) {\n        return new Promise(async (resolve, reject) => {\n            try {\n                const { basePath, schemaPath } = getSchema(metodo);\n                const completeXSD = await xsdAssembler.assemble(schemaPath);\n\n                const xmlDoc = libxmljs.parseXml(xml);\n                const xsdDoc = libxmljs.parseXml(completeXSD, { baseUrl: `${basePath}/` });\n\n                const isValid = xmlDoc.validate(xsdDoc);\n\n                if (isValid) {\n                    resolve({\n                        success: true,\n                        message: 'XML válido.',\n                    });\n                } else {\n                    reject({\n                        success: false,\n                        message: this.formatErrorMessage(xmlDoc.validationErrors[0].message),\n                    });\n                }\n            } catch (error: any) {\n                reject({\n                    success: false,\n                    message: this.formatErrorMessage(error.message),\n                });\n            }\n        });\n    }\n\n    validateSchemaJavaBased(xml: any, metodo: string) {\n        return new Promise(async (resolve, reject) => {\n            try {\n                const { schemaPath } = getSchema(metodo);\n\n                xsdValidator.validateXML(xml, schemaPath, (err, validationResult) => {\n                    if (err) {\n                        reject({\n                            success: false,\n                            message: this.formatErrorMessage(err.message),\n                        });\n                    } else if (!validationResult.valid) {\n                        reject({\n                            success: false,\n                            message: this.formatErrorMessage(validationResult.messages[0]),\n                        });\n                    } else {\n                        resolve({\n                            success: true,\n                            message: 'XML válido.',\n                        });\n                    }\n                });\n            } catch (error: any) {\n                reject({\n                    success: false,\n                    message: this.formatErrorMessage(error.message),\n                });\n            }\n        });\n    }\n\n    verificaRejeicao(data: string, metodo: string, name?: string) {\n        const responseInJson = this.xmlParser.convertXmlToJson(data, metodo);\n\n        // Gera erro em caso de Rejeição\n        const xMotivo = this.findInObj(responseInJson, 'xMotivo');\n        const infProt = this.findInObj(responseInJson, 'infProt');\n\n        // Salva XML de retorno\n        this.salvaRetorno(data, responseInJson, metodo, name);\n\n        // Gera erro em caso de Rejeição\n        if (xMotivo && (xMotivo.includes('Rejeição') || xMotivo.includes('Rejeicao'))) {\n            throw new Error(xMotivo);\n        }\n        if (infProt && (infProt?.xMotivo.includes('Rejeição') || infProt?.xMotivo.includes('Rejeicao'))) {\n            throw new Error(infProt?.xMotivo);\n        }\n        // if (infEvento && (infEvento?.xMotivo.includes('Rejeição') || infEvento?.xMotivo.includes('Rejeicao'))) {\n        //     throw new Error(xMotivo);\n        // }\n\n        return responseInJson;\n    }\n\n    getProtNFe(xmlRetorno: string): {\n        protNFe: ProtNFe[] | undefined;\n        nRec: string;\n    } {\n        let nRec = '';\n        let protNFe: ProtNFe[] | undefined;\n        xml2js.parseString(xmlRetorno, (err, result) => {\n            if (err) {\n                console.error('Erro ao parsear o XML para captura do nRec e protNFe:', err);\n            } else {\n                const nRecTag = this.findInObj(result, 'nRec')\n                nRec = nRecTag[0]\n\n                const protNFeTag = this.findInObj(result, 'protNFe')\n                protNFe = protNFeTag\n            }\n        });\n        return {\n            protNFe,\n            nRec\n        };\n    }\n\n    private getRequestLogFileName(metodo: string, tipo: string) {\n        switch (metodo) {\n            case 'NFEStatusServico':\n                return `NFeStatusServico-${tipo}`\n            case 'NFEConsultaProtocolo':\n                return `NFeConsultaProtocolo-${tipo}`\n            case 'NFeDistribuicaoDFe':\n                return `NFeDistribuicaoDFe-${tipo}`\n            case 'RecepcaoEvento':\n                return `RecepcaoEvento-${tipo}`\n            case 'NFECancelamento':\n                return `NFECancelamento-${tipo}`\n            case 'NFEInutilizacao':\n                return `NFEInutilizacao-${tipo}`\n            case 'NFEAutorizacao':\n                return `NFEAutorizacao-${tipo}`\n            case 'NFCEAutorizacao':\n                return `NFCEAutorizacao-${tipo}`\n            case 'NFERetAutorizacao':\n                return `NFERetAutorizacao-${tipo}`\n\n            default:\n                throw new Error('Erro: Requisição de nome para método não implementado.')\n        }\n    }\n\n    salvaConsulta(xmlConsulta: string, xmlFormated: string, metodo: string, name?: string) {\n        try {\n            const fileName = name || this.getRequestLogFileName(metodo, 'consulta');\n            const { armazenarXMLConsulta, pathXMLConsulta, armazenarXMLConsultaComTagSoap } = this.environment.config.dfe\n            const xmlConsultaASalvar = armazenarXMLConsultaComTagSoap ? xmlFormated : xmlConsulta;\n\n            if (armazenarXMLConsulta) {\n                this.salvaXML({\n                    data: xmlConsultaASalvar,\n                    fileName,\n                    metodo,\n                    path: pathXMLConsulta,\n                });\n            }\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    salvaRetorno(xmlRetorno: string, responseInJson: GenericObject | undefined, metodo: string, name?: string) {\n        try {\n            const fileName = name || this.getRequestLogFileName(metodo, 'retorno');\n            const { armazenarXMLRetorno, pathXMLRetorno, armazenarRetornoEmJSON } = this.environment.config.dfe\n\n            if (armazenarXMLRetorno && xmlRetorno) {\n                this.salvaXML({\n                    data: xmlRetorno,\n                    fileName,\n                    metodo,\n                    path: pathXMLRetorno,\n                });\n\n                if (armazenarRetornoEmJSON && responseInJson) {\n                    this.salvaJSON({\n                        data: responseInJson,\n                        fileName,\n                        metodo,\n                        path: pathXMLRetorno,\n                    });\n                }\n            }\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n}\n\nexport default Utility;","import XmlBuilder from '@Adapters/XmlBuilder';\nimport Utility from '@Core/utils/Utility';\nimport { GerarConsultaImpl } from '@Interfaces';\nimport Environment from '@Modules/environment/Environment.js';\n\nclass GerarConsulta implements GerarConsultaImpl {\n    utility: Utility;\n    environment: Environment;\n    xmlBuilder: XmlBuilder;\n\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder) {\n        this.environment = environment;\n        this.utility = utility;\n        this.xmlBuilder = xmlBuilder;\n    }\n\n    async gerarConsulta(xmlConsulta: string, metodo: string, ambienteNacional = false, versao = \"\", mod = \"NFe\", rootTag: boolean = false, tag = \"\") {\n        try {\n            const config = this.environment.getConfig();\n            // Valida Schema\n            if (config.lib?.useForSchemaValidation !== 'validateSchemaJsBased') {\n                await this.utility.validateSchemaJavaBased(xmlConsulta, metodo);\n            } else {\n                await this.utility.validateSchemaJsBased(xmlConsulta, metodo);\n            }\n\n            // Capturando a url do método para o namespace xmlns\n            const { method, action } = this.utility.getSoapInfo(config.dfe.UF, metodo);\n\n            // Criando envelop SOAP (estrutura para e envio do XML)\n            let rootTagObj = null;\n            if (rootTag) {\n                rootTagObj = {\n                    tag,\n                    namespace: method,\n                };\n            }\n            const xmlFormated = this.xmlBuilder.buildSoapEnvelope(xmlConsulta, method, 'soap12', rootTagObj);\n\n            // Retorna o Http.Agent contendo os certificados das Autoridades Certificadoras\n            const agent = this.environment.getHttpAgent();\n\n            // Retorna a url do webservice NFEStatusServico\n            const webServiceUrl = this.utility.getWebServiceUrl(metodo, ambienteNacional, versao, mod);\n\n            return {\n                xmlFormated,\n                agent,\n                webServiceUrl,\n                action\n            }\n\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n}\n\nexport default GerarConsulta;","function _typeof(o) {\n  \"@babel/helpers - typeof\";\n\n  return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n    return typeof o;\n  } : function (o) {\n    return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n  }, _typeof(o);\n}\nexport { _typeof as default };","export default function toInteger(dirtyNumber) {\n  if (dirtyNumber === null || dirtyNumber === true || dirtyNumber === false) {\n    return NaN;\n  }\n  var number = Number(dirtyNumber);\n  if (isNaN(number)) {\n    return number;\n  }\n  return number < 0 ? Math.ceil(number) : Math.floor(number);\n}","export default function requiredArgs(required, args) {\n  if (args.length < required) {\n    throw new TypeError(required + ' argument' + (required > 1 ? 's' : '') + ' required, but only ' + args.length + ' present');\n  }\n}","import _typeof from \"@babel/runtime/helpers/esm/typeof\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name toDate\n * @category Common Helpers\n * @summary Convert the given argument to an instance of Date.\n *\n * @description\n * Convert the given argument to an instance of Date.\n *\n * If the argument is an instance of Date, the function returns its clone.\n *\n * If the argument is a number, it is treated as a timestamp.\n *\n * If the argument is none of the above, the function returns Invalid Date.\n *\n * **Note**: *all* Date arguments passed to any *date-fns* function is processed by `toDate`.\n *\n * @param {Date|Number} argument - the value to convert\n * @returns {Date} the parsed date in the local time zone\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // Clone the date:\n * const result = toDate(new Date(2014, 1, 11, 11, 30, 30))\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert the timestamp to date:\n * const result = toDate(1392098430000)\n * //=> Tue Feb 11 2014 11:30:30\n */\nexport default function toDate(argument) {\n  requiredArgs(1, arguments);\n  var argStr = Object.prototype.toString.call(argument);\n\n  // Clone the date\n  if (argument instanceof Date || _typeof(argument) === 'object' && argStr === '[object Date]') {\n    // Prevent the date to lose the milliseconds when passed to new Date() in IE10\n    return new Date(argument.getTime());\n  } else if (typeof argument === 'number' || argStr === '[object Number]') {\n    return new Date(argument);\n  } else {\n    if ((typeof argument === 'string' || argStr === '[object String]') && typeof console !== 'undefined') {\n      // eslint-disable-next-line no-console\n      console.warn(\"Starting with v2.0.0-beta.1 date-fns doesn't accept strings as date arguments. Please use `parseISO` to parse strings. See: https://github.com/date-fns/date-fns/blob/master/docs/upgradeGuide.md#string-arguments\");\n      // eslint-disable-next-line no-console\n      console.warn(new Error().stack);\n    }\n    return new Date(NaN);\n  }\n}","var defaultOptions = {};\nexport function getDefaultOptions() {\n  return defaultOptions;\n}\nexport function setDefaultOptions(newOptions) {\n  defaultOptions = newOptions;\n}","import isDate from \"../isDate/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name isValid\n * @category Common Helpers\n * @summary Is the given date valid?\n *\n * @description\n * Returns false if argument is Invalid Date and true otherwise.\n * Argument is converted to Date using `toDate`. See [toDate]{@link https://date-fns.org/docs/toDate}\n * Invalid Date is a Date, whose time value is NaN.\n *\n * Time value of Date: http://es5.github.io/#x15.9.1.1\n *\n * @param {*} date - the date to check\n * @returns {Boolean} the date is valid\n * @throws {TypeError} 1 argument required\n *\n * @example\n * // For the valid date:\n * const result = isValid(new Date(2014, 1, 31))\n * //=> true\n *\n * @example\n * // For the value, convertable into a date:\n * const result = isValid(1393804800000)\n * //=> true\n *\n * @example\n * // For the invalid date:\n * const result = isValid(new Date(''))\n * //=> false\n */\nexport default function isValid(dirtyDate) {\n  requiredArgs(1, arguments);\n  if (!isDate(dirtyDate) && typeof dirtyDate !== 'number') {\n    return false;\n  }\n  var date = toDate(dirtyDate);\n  return !isNaN(Number(date));\n}","import _typeof from \"@babel/runtime/helpers/esm/typeof\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name isDate\n * @category Common Helpers\n * @summary Is the given value a date?\n *\n * @description\n * Returns true if the given value is an instance of Date. The function works for dates transferred across iframes.\n *\n * @param {*} value - the value to check\n * @returns {boolean} true if the given value is a date\n * @throws {TypeError} 1 arguments required\n *\n * @example\n * // For a valid date:\n * const result = isDate(new Date())\n * //=> true\n *\n * @example\n * // For an invalid date:\n * const result = isDate(new Date(NaN))\n * //=> true\n *\n * @example\n * // For some value:\n * const result = isDate('2014-02-31')\n * //=> false\n *\n * @example\n * // For an object:\n * const result = isDate({})\n * //=> false\n */\nexport default function isDate(value) {\n  requiredArgs(1, arguments);\n  return value instanceof Date || _typeof(value) === 'object' && Object.prototype.toString.call(value) === '[object Date]';\n}","import addMilliseconds from \"../addMilliseconds/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\n/**\n * @name subMilliseconds\n * @category Millisecond Helpers\n * @summary Subtract the specified number of milliseconds from the given date.\n *\n * @description\n * Subtract the specified number of milliseconds from the given date.\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of milliseconds to be subtracted. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the milliseconds subtracted\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Subtract 750 milliseconds from 10 July 2014 12:45:30.000:\n * const result = subMilliseconds(new Date(2014, 6, 10, 12, 45, 30, 0), 750)\n * //=> Thu Jul 10 2014 12:45:29.250\n */\nexport default function subMilliseconds(dirtyDate, dirtyAmount) {\n  requiredArgs(2, arguments);\n  var amount = toInteger(dirtyAmount);\n  return addMilliseconds(dirtyDate, -amount);\n}","import toInteger from \"../_lib/toInteger/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\n/**\n * @name addMilliseconds\n * @category Millisecond Helpers\n * @summary Add the specified number of milliseconds to the given date.\n *\n * @description\n * Add the specified number of milliseconds to the given date.\n *\n * @param {Date|Number} date - the date to be changed\n * @param {Number} amount - the amount of milliseconds to be added. Positive decimals will be rounded using `Math.floor`, decimals less than zero will be rounded using `Math.ceil`.\n * @returns {Date} the new date with the milliseconds added\n * @throws {TypeError} 2 arguments required\n *\n * @example\n * // Add 750 milliseconds to 10 July 2014 12:45:30.000:\n * const result = addMilliseconds(new Date(2014, 6, 10, 12, 45, 30, 0), 750)\n * //=> Thu Jul 10 2014 12:45:30.750\n */\nexport default function addMilliseconds(dirtyDate, dirtyAmount) {\n  requiredArgs(2, arguments);\n  var timestamp = toDate(dirtyDate).getTime();\n  var amount = toInteger(dirtyAmount);\n  return new Date(timestamp + amount);\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nexport default function startOfUTCISOWeek(dirtyDate) {\n  requiredArgs(1, arguments);\n  var weekStartsOn = 1;\n  var date = toDate(dirtyDate);\n  var day = date.getUTCDay();\n  var diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n  date.setUTCDate(date.getUTCDate() - diff);\n  date.setUTCHours(0, 0, 0, 0);\n  return date;\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport startOfUTCISOWeek from \"../startOfUTCISOWeek/index.js\";\nexport default function getUTCISOWeekYear(dirtyDate) {\n  requiredArgs(1, arguments);\n  var date = toDate(dirtyDate);\n  var year = date.getUTCFullYear();\n  var fourthOfJanuaryOfNextYear = new Date(0);\n  fourthOfJanuaryOfNextYear.setUTCFullYear(year + 1, 0, 4);\n  fourthOfJanuaryOfNextYear.setUTCHours(0, 0, 0, 0);\n  var startOfNextYear = startOfUTCISOWeek(fourthOfJanuaryOfNextYear);\n  var fourthOfJanuaryOfThisYear = new Date(0);\n  fourthOfJanuaryOfThisYear.setUTCFullYear(year, 0, 4);\n  fourthOfJanuaryOfThisYear.setUTCHours(0, 0, 0, 0);\n  var startOfThisYear = startOfUTCISOWeek(fourthOfJanuaryOfThisYear);\n  if (date.getTime() >= startOfNextYear.getTime()) {\n    return year + 1;\n  } else if (date.getTime() >= startOfThisYear.getTime()) {\n    return year;\n  } else {\n    return year - 1;\n  }\n}","import toDate from \"../../toDate/index.js\";\nimport startOfUTCISOWeek from \"../startOfUTCISOWeek/index.js\";\nimport startOfUTCISOWeekYear from \"../startOfUTCISOWeekYear/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nvar MILLISECONDS_IN_WEEK = 604800000;\nexport default function getUTCISOWeek(dirtyDate) {\n  requiredArgs(1, arguments);\n  var date = toDate(dirtyDate);\n  var diff = startOfUTCISOWeek(date).getTime() - startOfUTCISOWeekYear(date).getTime();\n\n  // Round the number of days to the nearest integer\n  // because the number of milliseconds in a week is not constant\n  // (e.g. it's different in the week of the daylight saving time clock shift)\n  return Math.round(diff / MILLISECONDS_IN_WEEK) + 1;\n}","import getUTCISOWeekYear from \"../getUTCISOWeekYear/index.js\";\nimport startOfUTCISOWeek from \"../startOfUTCISOWeek/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nexport default function startOfUTCISOWeekYear(dirtyDate) {\n  requiredArgs(1, arguments);\n  var year = getUTCISOWeekYear(dirtyDate);\n  var fourthOfJanuary = new Date(0);\n  fourthOfJanuary.setUTCFullYear(year, 0, 4);\n  fourthOfJanuary.setUTCHours(0, 0, 0, 0);\n  var date = startOfUTCISOWeek(fourthOfJanuary);\n  return date;\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport toInteger from \"../toInteger/index.js\";\nimport { getDefaultOptions } from \"../defaultOptions/index.js\";\nexport default function startOfUTCWeek(dirtyDate, options) {\n  var _ref, _ref2, _ref3, _options$weekStartsOn, _options$locale, _options$locale$optio, _defaultOptions$local, _defaultOptions$local2;\n  requiredArgs(1, arguments);\n  var defaultOptions = getDefaultOptions();\n  var weekStartsOn = toInteger((_ref = (_ref2 = (_ref3 = (_options$weekStartsOn = options === null || options === void 0 ? void 0 : options.weekStartsOn) !== null && _options$weekStartsOn !== void 0 ? _options$weekStartsOn : options === null || options === void 0 ? void 0 : (_options$locale = options.locale) === null || _options$locale === void 0 ? void 0 : (_options$locale$optio = _options$locale.options) === null || _options$locale$optio === void 0 ? void 0 : _options$locale$optio.weekStartsOn) !== null && _ref3 !== void 0 ? _ref3 : defaultOptions.weekStartsOn) !== null && _ref2 !== void 0 ? _ref2 : (_defaultOptions$local = defaultOptions.locale) === null || _defaultOptions$local === void 0 ? void 0 : (_defaultOptions$local2 = _defaultOptions$local.options) === null || _defaultOptions$local2 === void 0 ? void 0 : _defaultOptions$local2.weekStartsOn) !== null && _ref !== void 0 ? _ref : 0);\n\n  // Test if weekStartsOn is between 0 and 6 _and_ is not NaN\n  if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {\n    throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');\n  }\n  var date = toDate(dirtyDate);\n  var day = date.getUTCDay();\n  var diff = (day < weekStartsOn ? 7 : 0) + day - weekStartsOn;\n  date.setUTCDate(date.getUTCDate() - diff);\n  date.setUTCHours(0, 0, 0, 0);\n  return date;\n}","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport startOfUTCWeek from \"../startOfUTCWeek/index.js\";\nimport toInteger from \"../toInteger/index.js\";\nimport { getDefaultOptions } from \"../defaultOptions/index.js\";\nexport default function getUTCWeekYear(dirtyDate, options) {\n  var _ref, _ref2, _ref3, _options$firstWeekCon, _options$locale, _options$locale$optio, _defaultOptions$local, _defaultOptions$local2;\n  requiredArgs(1, arguments);\n  var date = toDate(dirtyDate);\n  var year = date.getUTCFullYear();\n  var defaultOptions = getDefaultOptions();\n  var firstWeekContainsDate = toInteger((_ref = (_ref2 = (_ref3 = (_options$firstWeekCon = options === null || options === void 0 ? void 0 : options.firstWeekContainsDate) !== null && _options$firstWeekCon !== void 0 ? _options$firstWeekCon : options === null || options === void 0 ? void 0 : (_options$locale = options.locale) === null || _options$locale === void 0 ? void 0 : (_options$locale$optio = _options$locale.options) === null || _options$locale$optio === void 0 ? void 0 : _options$locale$optio.firstWeekContainsDate) !== null && _ref3 !== void 0 ? _ref3 : defaultOptions.firstWeekContainsDate) !== null && _ref2 !== void 0 ? _ref2 : (_defaultOptions$local = defaultOptions.locale) === null || _defaultOptions$local === void 0 ? void 0 : (_defaultOptions$local2 = _defaultOptions$local.options) === null || _defaultOptions$local2 === void 0 ? void 0 : _defaultOptions$local2.firstWeekContainsDate) !== null && _ref !== void 0 ? _ref : 1);\n\n  // Test if weekStartsOn is between 1 and 7 _and_ is not NaN\n  if (!(firstWeekContainsDate >= 1 && firstWeekContainsDate <= 7)) {\n    throw new RangeError('firstWeekContainsDate must be between 1 and 7 inclusively');\n  }\n  var firstWeekOfNextYear = new Date(0);\n  firstWeekOfNextYear.setUTCFullYear(year + 1, 0, firstWeekContainsDate);\n  firstWeekOfNextYear.setUTCHours(0, 0, 0, 0);\n  var startOfNextYear = startOfUTCWeek(firstWeekOfNextYear, options);\n  var firstWeekOfThisYear = new Date(0);\n  firstWeekOfThisYear.setUTCFullYear(year, 0, firstWeekContainsDate);\n  firstWeekOfThisYear.setUTCHours(0, 0, 0, 0);\n  var startOfThisYear = startOfUTCWeek(firstWeekOfThisYear, options);\n  if (date.getTime() >= startOfNextYear.getTime()) {\n    return year + 1;\n  } else if (date.getTime() >= startOfThisYear.getTime()) {\n    return year;\n  } else {\n    return year - 1;\n  }\n}","import toDate from \"../../toDate/index.js\";\nimport startOfUTCWeek from \"../startOfUTCWeek/index.js\";\nimport startOfUTCWeekYear from \"../startOfUTCWeekYear/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nvar MILLISECONDS_IN_WEEK = 604800000;\nexport default function getUTCWeek(dirtyDate, options) {\n  requiredArgs(1, arguments);\n  var date = toDate(dirtyDate);\n  var diff = startOfUTCWeek(date, options).getTime() - startOfUTCWeekYear(date, options).getTime();\n\n  // Round the number of days to the nearest integer\n  // because the number of milliseconds in a week is not constant\n  // (e.g. it's different in the week of the daylight saving time clock shift)\n  return Math.round(diff / MILLISECONDS_IN_WEEK) + 1;\n}","import getUTCWeekYear from \"../getUTCWeekYear/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nimport startOfUTCWeek from \"../startOfUTCWeek/index.js\";\nimport toInteger from \"../toInteger/index.js\";\nimport { getDefaultOptions } from \"../defaultOptions/index.js\";\nexport default function startOfUTCWeekYear(dirtyDate, options) {\n  var _ref, _ref2, _ref3, _options$firstWeekCon, _options$locale, _options$locale$optio, _defaultOptions$local, _defaultOptions$local2;\n  requiredArgs(1, arguments);\n  var defaultOptions = getDefaultOptions();\n  var firstWeekContainsDate = toInteger((_ref = (_ref2 = (_ref3 = (_options$firstWeekCon = options === null || options === void 0 ? void 0 : options.firstWeekContainsDate) !== null && _options$firstWeekCon !== void 0 ? _options$firstWeekCon : options === null || options === void 0 ? void 0 : (_options$locale = options.locale) === null || _options$locale === void 0 ? void 0 : (_options$locale$optio = _options$locale.options) === null || _options$locale$optio === void 0 ? void 0 : _options$locale$optio.firstWeekContainsDate) !== null && _ref3 !== void 0 ? _ref3 : defaultOptions.firstWeekContainsDate) !== null && _ref2 !== void 0 ? _ref2 : (_defaultOptions$local = defaultOptions.locale) === null || _defaultOptions$local === void 0 ? void 0 : (_defaultOptions$local2 = _defaultOptions$local.options) === null || _defaultOptions$local2 === void 0 ? void 0 : _defaultOptions$local2.firstWeekContainsDate) !== null && _ref !== void 0 ? _ref : 1);\n  var year = getUTCWeekYear(dirtyDate, options);\n  var firstWeek = new Date(0);\n  firstWeek.setUTCFullYear(year, 0, firstWeekContainsDate);\n  firstWeek.setUTCHours(0, 0, 0, 0);\n  var date = startOfUTCWeek(firstWeek, options);\n  return date;\n}","export default function addLeadingZeros(number, targetLength) {\n  var sign = number < 0 ? '-' : '';\n  var output = Math.abs(number).toString();\n  while (output.length < targetLength) {\n    output = '0' + output;\n  }\n  return sign + output;\n}","import addLeadingZeros from \"../../addLeadingZeros/index.js\";\n/*\n * |     | Unit                           |     | Unit                           |\n * |-----|--------------------------------|-----|--------------------------------|\n * |  a  | AM, PM                         |  A* |                                |\n * |  d  | Day of month                   |  D  |                                |\n * |  h  | Hour [1-12]                    |  H  | Hour [0-23]                    |\n * |  m  | Minute                         |  M  | Month                          |\n * |  s  | Second                         |  S  | Fraction of second             |\n * |  y  | Year (abs)                     |  Y  |                                |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n */\nvar formatters = {\n  // Year\n  y: function y(date, token) {\n    // From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_tokens\n    // | Year     |     y | yy |   yyy |  yyyy | yyyyy |\n    // |----------|-------|----|-------|-------|-------|\n    // | AD 1     |     1 | 01 |   001 |  0001 | 00001 |\n    // | AD 12    |    12 | 12 |   012 |  0012 | 00012 |\n    // | AD 123   |   123 | 23 |   123 |  0123 | 00123 |\n    // | AD 1234  |  1234 | 34 |  1234 |  1234 | 01234 |\n    // | AD 12345 | 12345 | 45 | 12345 | 12345 | 12345 |\n\n    var signedYear = date.getUTCFullYear();\n    // Returns 1 for 1 BC (which is year 0 in JavaScript)\n    var year = signedYear > 0 ? signedYear : 1 - signedYear;\n    return addLeadingZeros(token === 'yy' ? year % 100 : year, token.length);\n  },\n  // Month\n  M: function M(date, token) {\n    var month = date.getUTCMonth();\n    return token === 'M' ? String(month + 1) : addLeadingZeros(month + 1, 2);\n  },\n  // Day of the month\n  d: function d(date, token) {\n    return addLeadingZeros(date.getUTCDate(), token.length);\n  },\n  // AM or PM\n  a: function a(date, token) {\n    var dayPeriodEnumValue = date.getUTCHours() / 12 >= 1 ? 'pm' : 'am';\n    switch (token) {\n      case 'a':\n      case 'aa':\n        return dayPeriodEnumValue.toUpperCase();\n      case 'aaa':\n        return dayPeriodEnumValue;\n      case 'aaaaa':\n        return dayPeriodEnumValue[0];\n      case 'aaaa':\n      default:\n        return dayPeriodEnumValue === 'am' ? 'a.m.' : 'p.m.';\n    }\n  },\n  // Hour [1-12]\n  h: function h(date, token) {\n    return addLeadingZeros(date.getUTCHours() % 12 || 12, token.length);\n  },\n  // Hour [0-23]\n  H: function H(date, token) {\n    return addLeadingZeros(date.getUTCHours(), token.length);\n  },\n  // Minute\n  m: function m(date, token) {\n    return addLeadingZeros(date.getUTCMinutes(), token.length);\n  },\n  // Second\n  s: function s(date, token) {\n    return addLeadingZeros(date.getUTCSeconds(), token.length);\n  },\n  // Fraction of second\n  S: function S(date, token) {\n    var numberOfDigits = token.length;\n    var milliseconds = date.getUTCMilliseconds();\n    var fractionalSeconds = Math.floor(milliseconds * Math.pow(10, numberOfDigits - 3));\n    return addLeadingZeros(fractionalSeconds, token.length);\n  }\n};\nexport default formatters;","import getUTCDayOfYear from \"../../../_lib/getUTCDayOfYear/index.js\";\nimport getUTCISOWeek from \"../../../_lib/getUTCISOWeek/index.js\";\nimport getUTCISOWeekYear from \"../../../_lib/getUTCISOWeekYear/index.js\";\nimport getUTCWeek from \"../../../_lib/getUTCWeek/index.js\";\nimport getUTCWeekYear from \"../../../_lib/getUTCWeekYear/index.js\";\nimport addLeadingZeros from \"../../addLeadingZeros/index.js\";\nimport lightFormatters from \"../lightFormatters/index.js\";\nvar dayPeriodEnum = {\n  am: 'am',\n  pm: 'pm',\n  midnight: 'midnight',\n  noon: 'noon',\n  morning: 'morning',\n  afternoon: 'afternoon',\n  evening: 'evening',\n  night: 'night'\n};\n/*\n * |     | Unit                           |     | Unit                           |\n * |-----|--------------------------------|-----|--------------------------------|\n * |  a  | AM, PM                         |  A* | Milliseconds in day            |\n * |  b  | AM, PM, noon, midnight         |  B  | Flexible day period            |\n * |  c  | Stand-alone local day of week  |  C* | Localized hour w/ day period   |\n * |  d  | Day of month                   |  D  | Day of year                    |\n * |  e  | Local day of week              |  E  | Day of week                    |\n * |  f  |                                |  F* | Day of week in month           |\n * |  g* | Modified Julian day            |  G  | Era                            |\n * |  h  | Hour [1-12]                    |  H  | Hour [0-23]                    |\n * |  i! | ISO day of week                |  I! | ISO week of year               |\n * |  j* | Localized hour w/ day period   |  J* | Localized hour w/o day period  |\n * |  k  | Hour [1-24]                    |  K  | Hour [0-11]                    |\n * |  l* | (deprecated)                   |  L  | Stand-alone month              |\n * |  m  | Minute                         |  M  | Month                          |\n * |  n  |                                |  N  |                                |\n * |  o! | Ordinal number modifier        |  O  | Timezone (GMT)                 |\n * |  p! | Long localized time            |  P! | Long localized date            |\n * |  q  | Stand-alone quarter            |  Q  | Quarter                        |\n * |  r* | Related Gregorian year         |  R! | ISO week-numbering year        |\n * |  s  | Second                         |  S  | Fraction of second             |\n * |  t! | Seconds timestamp              |  T! | Milliseconds timestamp         |\n * |  u  | Extended year                  |  U* | Cyclic year                    |\n * |  v* | Timezone (generic non-locat.)  |  V* | Timezone (location)            |\n * |  w  | Local week of year             |  W* | Week of month                  |\n * |  x  | Timezone (ISO-8601 w/o Z)      |  X  | Timezone (ISO-8601)            |\n * |  y  | Year (abs)                     |  Y  | Local week-numbering year      |\n * |  z  | Timezone (specific non-locat.) |  Z* | Timezone (aliases)             |\n *\n * Letters marked by * are not implemented but reserved by Unicode standard.\n *\n * Letters marked by ! are non-standard, but implemented by date-fns:\n * - `o` modifies the previous token to turn it into an ordinal (see `format` docs)\n * - `i` is ISO day of week. For `i` and `ii` is returns numeric ISO week days,\n *   i.e. 7 for Sunday, 1 for Monday, etc.\n * - `I` is ISO week of year, as opposed to `w` which is local week of year.\n * - `R` is ISO week-numbering year, as opposed to `Y` which is local week-numbering year.\n *   `R` is supposed to be used in conjunction with `I` and `i`\n *   for universal ISO week-numbering date, whereas\n *   `Y` is supposed to be used in conjunction with `w` and `e`\n *   for week-numbering date specific to the locale.\n * - `P` is long localized date format\n * - `p` is long localized time format\n */\n\nvar formatters = {\n  // Era\n  G: function G(date, token, localize) {\n    var era = date.getUTCFullYear() > 0 ? 1 : 0;\n    switch (token) {\n      // AD, BC\n      case 'G':\n      case 'GG':\n      case 'GGG':\n        return localize.era(era, {\n          width: 'abbreviated'\n        });\n      // A, B\n      case 'GGGGG':\n        return localize.era(era, {\n          width: 'narrow'\n        });\n      // Anno Domini, Before Christ\n      case 'GGGG':\n      default:\n        return localize.era(era, {\n          width: 'wide'\n        });\n    }\n  },\n  // Year\n  y: function y(date, token, localize) {\n    // Ordinal number\n    if (token === 'yo') {\n      var signedYear = date.getUTCFullYear();\n      // Returns 1 for 1 BC (which is year 0 in JavaScript)\n      var year = signedYear > 0 ? signedYear : 1 - signedYear;\n      return localize.ordinalNumber(year, {\n        unit: 'year'\n      });\n    }\n    return lightFormatters.y(date, token);\n  },\n  // Local week-numbering year\n  Y: function Y(date, token, localize, options) {\n    var signedWeekYear = getUTCWeekYear(date, options);\n    // Returns 1 for 1 BC (which is year 0 in JavaScript)\n    var weekYear = signedWeekYear > 0 ? signedWeekYear : 1 - signedWeekYear;\n\n    // Two digit year\n    if (token === 'YY') {\n      var twoDigitYear = weekYear % 100;\n      return addLeadingZeros(twoDigitYear, 2);\n    }\n\n    // Ordinal number\n    if (token === 'Yo') {\n      return localize.ordinalNumber(weekYear, {\n        unit: 'year'\n      });\n    }\n\n    // Padding\n    return addLeadingZeros(weekYear, token.length);\n  },\n  // ISO week-numbering year\n  R: function R(date, token) {\n    var isoWeekYear = getUTCISOWeekYear(date);\n\n    // Padding\n    return addLeadingZeros(isoWeekYear, token.length);\n  },\n  // Extended year. This is a single number designating the year of this calendar system.\n  // The main difference between `y` and `u` localizers are B.C. years:\n  // | Year | `y` | `u` |\n  // |------|-----|-----|\n  // | AC 1 |   1 |   1 |\n  // | BC 1 |   1 |   0 |\n  // | BC 2 |   2 |  -1 |\n  // Also `yy` always returns the last two digits of a year,\n  // while `uu` pads single digit years to 2 characters and returns other years unchanged.\n  u: function u(date, token) {\n    var year = date.getUTCFullYear();\n    return addLeadingZeros(year, token.length);\n  },\n  // Quarter\n  Q: function Q(date, token, localize) {\n    var quarter = Math.ceil((date.getUTCMonth() + 1) / 3);\n    switch (token) {\n      // 1, 2, 3, 4\n      case 'Q':\n        return String(quarter);\n      // 01, 02, 03, 04\n      case 'QQ':\n        return addLeadingZeros(quarter, 2);\n      // 1st, 2nd, 3rd, 4th\n      case 'Qo':\n        return localize.ordinalNumber(quarter, {\n          unit: 'quarter'\n        });\n      // Q1, Q2, Q3, Q4\n      case 'QQQ':\n        return localize.quarter(quarter, {\n          width: 'abbreviated',\n          context: 'formatting'\n        });\n      // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n      case 'QQQQQ':\n        return localize.quarter(quarter, {\n          width: 'narrow',\n          context: 'formatting'\n        });\n      // 1st quarter, 2nd quarter, ...\n      case 'QQQQ':\n      default:\n        return localize.quarter(quarter, {\n          width: 'wide',\n          context: 'formatting'\n        });\n    }\n  },\n  // Stand-alone quarter\n  q: function q(date, token, localize) {\n    var quarter = Math.ceil((date.getUTCMonth() + 1) / 3);\n    switch (token) {\n      // 1, 2, 3, 4\n      case 'q':\n        return String(quarter);\n      // 01, 02, 03, 04\n      case 'qq':\n        return addLeadingZeros(quarter, 2);\n      // 1st, 2nd, 3rd, 4th\n      case 'qo':\n        return localize.ordinalNumber(quarter, {\n          unit: 'quarter'\n        });\n      // Q1, Q2, Q3, Q4\n      case 'qqq':\n        return localize.quarter(quarter, {\n          width: 'abbreviated',\n          context: 'standalone'\n        });\n      // 1, 2, 3, 4 (narrow quarter; could be not numerical)\n      case 'qqqqq':\n        return localize.quarter(quarter, {\n          width: 'narrow',\n          context: 'standalone'\n        });\n      // 1st quarter, 2nd quarter, ...\n      case 'qqqq':\n      default:\n        return localize.quarter(quarter, {\n          width: 'wide',\n          context: 'standalone'\n        });\n    }\n  },\n  // Month\n  M: function M(date, token, localize) {\n    var month = date.getUTCMonth();\n    switch (token) {\n      case 'M':\n      case 'MM':\n        return lightFormatters.M(date, token);\n      // 1st, 2nd, ..., 12th\n      case 'Mo':\n        return localize.ordinalNumber(month + 1, {\n          unit: 'month'\n        });\n      // Jan, Feb, ..., Dec\n      case 'MMM':\n        return localize.month(month, {\n          width: 'abbreviated',\n          context: 'formatting'\n        });\n      // J, F, ..., D\n      case 'MMMMM':\n        return localize.month(month, {\n          width: 'narrow',\n          context: 'formatting'\n        });\n      // January, February, ..., December\n      case 'MMMM':\n      default:\n        return localize.month(month, {\n          width: 'wide',\n          context: 'formatting'\n        });\n    }\n  },\n  // Stand-alone month\n  L: function L(date, token, localize) {\n    var month = date.getUTCMonth();\n    switch (token) {\n      // 1, 2, ..., 12\n      case 'L':\n        return String(month + 1);\n      // 01, 02, ..., 12\n      case 'LL':\n        return addLeadingZeros(month + 1, 2);\n      // 1st, 2nd, ..., 12th\n      case 'Lo':\n        return localize.ordinalNumber(month + 1, {\n          unit: 'month'\n        });\n      // Jan, Feb, ..., Dec\n      case 'LLL':\n        return localize.month(month, {\n          width: 'abbreviated',\n          context: 'standalone'\n        });\n      // J, F, ..., D\n      case 'LLLLL':\n        return localize.month(month, {\n          width: 'narrow',\n          context: 'standalone'\n        });\n      // January, February, ..., December\n      case 'LLLL':\n      default:\n        return localize.month(month, {\n          width: 'wide',\n          context: 'standalone'\n        });\n    }\n  },\n  // Local week of year\n  w: function w(date, token, localize, options) {\n    var week = getUTCWeek(date, options);\n    if (token === 'wo') {\n      return localize.ordinalNumber(week, {\n        unit: 'week'\n      });\n    }\n    return addLeadingZeros(week, token.length);\n  },\n  // ISO week of year\n  I: function I(date, token, localize) {\n    var isoWeek = getUTCISOWeek(date);\n    if (token === 'Io') {\n      return localize.ordinalNumber(isoWeek, {\n        unit: 'week'\n      });\n    }\n    return addLeadingZeros(isoWeek, token.length);\n  },\n  // Day of the month\n  d: function d(date, token, localize) {\n    if (token === 'do') {\n      return localize.ordinalNumber(date.getUTCDate(), {\n        unit: 'date'\n      });\n    }\n    return lightFormatters.d(date, token);\n  },\n  // Day of year\n  D: function D(date, token, localize) {\n    var dayOfYear = getUTCDayOfYear(date);\n    if (token === 'Do') {\n      return localize.ordinalNumber(dayOfYear, {\n        unit: 'dayOfYear'\n      });\n    }\n    return addLeadingZeros(dayOfYear, token.length);\n  },\n  // Day of week\n  E: function E(date, token, localize) {\n    var dayOfWeek = date.getUTCDay();\n    switch (token) {\n      // Tue\n      case 'E':\n      case 'EE':\n      case 'EEE':\n        return localize.day(dayOfWeek, {\n          width: 'abbreviated',\n          context: 'formatting'\n        });\n      // T\n      case 'EEEEE':\n        return localize.day(dayOfWeek, {\n          width: 'narrow',\n          context: 'formatting'\n        });\n      // Tu\n      case 'EEEEEE':\n        return localize.day(dayOfWeek, {\n          width: 'short',\n          context: 'formatting'\n        });\n      // Tuesday\n      case 'EEEE':\n      default:\n        return localize.day(dayOfWeek, {\n          width: 'wide',\n          context: 'formatting'\n        });\n    }\n  },\n  // Local day of week\n  e: function e(date, token, localize, options) {\n    var dayOfWeek = date.getUTCDay();\n    var localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n    switch (token) {\n      // Numerical value (Nth day of week with current locale or weekStartsOn)\n      case 'e':\n        return String(localDayOfWeek);\n      // Padded numerical value\n      case 'ee':\n        return addLeadingZeros(localDayOfWeek, 2);\n      // 1st, 2nd, ..., 7th\n      case 'eo':\n        return localize.ordinalNumber(localDayOfWeek, {\n          unit: 'day'\n        });\n      case 'eee':\n        return localize.day(dayOfWeek, {\n          width: 'abbreviated',\n          context: 'formatting'\n        });\n      // T\n      case 'eeeee':\n        return localize.day(dayOfWeek, {\n          width: 'narrow',\n          context: 'formatting'\n        });\n      // Tu\n      case 'eeeeee':\n        return localize.day(dayOfWeek, {\n          width: 'short',\n          context: 'formatting'\n        });\n      // Tuesday\n      case 'eeee':\n      default:\n        return localize.day(dayOfWeek, {\n          width: 'wide',\n          context: 'formatting'\n        });\n    }\n  },\n  // Stand-alone local day of week\n  c: function c(date, token, localize, options) {\n    var dayOfWeek = date.getUTCDay();\n    var localDayOfWeek = (dayOfWeek - options.weekStartsOn + 8) % 7 || 7;\n    switch (token) {\n      // Numerical value (same as in `e`)\n      case 'c':\n        return String(localDayOfWeek);\n      // Padded numerical value\n      case 'cc':\n        return addLeadingZeros(localDayOfWeek, token.length);\n      // 1st, 2nd, ..., 7th\n      case 'co':\n        return localize.ordinalNumber(localDayOfWeek, {\n          unit: 'day'\n        });\n      case 'ccc':\n        return localize.day(dayOfWeek, {\n          width: 'abbreviated',\n          context: 'standalone'\n        });\n      // T\n      case 'ccccc':\n        return localize.day(dayOfWeek, {\n          width: 'narrow',\n          context: 'standalone'\n        });\n      // Tu\n      case 'cccccc':\n        return localize.day(dayOfWeek, {\n          width: 'short',\n          context: 'standalone'\n        });\n      // Tuesday\n      case 'cccc':\n      default:\n        return localize.day(dayOfWeek, {\n          width: 'wide',\n          context: 'standalone'\n        });\n    }\n  },\n  // ISO day of week\n  i: function i(date, token, localize) {\n    var dayOfWeek = date.getUTCDay();\n    var isoDayOfWeek = dayOfWeek === 0 ? 7 : dayOfWeek;\n    switch (token) {\n      // 2\n      case 'i':\n        return String(isoDayOfWeek);\n      // 02\n      case 'ii':\n        return addLeadingZeros(isoDayOfWeek, token.length);\n      // 2nd\n      case 'io':\n        return localize.ordinalNumber(isoDayOfWeek, {\n          unit: 'day'\n        });\n      // Tue\n      case 'iii':\n        return localize.day(dayOfWeek, {\n          width: 'abbreviated',\n          context: 'formatting'\n        });\n      // T\n      case 'iiiii':\n        return localize.day(dayOfWeek, {\n          width: 'narrow',\n          context: 'formatting'\n        });\n      // Tu\n      case 'iiiiii':\n        return localize.day(dayOfWeek, {\n          width: 'short',\n          context: 'formatting'\n        });\n      // Tuesday\n      case 'iiii':\n      default:\n        return localize.day(dayOfWeek, {\n          width: 'wide',\n          context: 'formatting'\n        });\n    }\n  },\n  // AM or PM\n  a: function a(date, token, localize) {\n    var hours = date.getUTCHours();\n    var dayPeriodEnumValue = hours / 12 >= 1 ? 'pm' : 'am';\n    switch (token) {\n      case 'a':\n      case 'aa':\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'abbreviated',\n          context: 'formatting'\n        });\n      case 'aaa':\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'abbreviated',\n          context: 'formatting'\n        }).toLowerCase();\n      case 'aaaaa':\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'narrow',\n          context: 'formatting'\n        });\n      case 'aaaa':\n      default:\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'wide',\n          context: 'formatting'\n        });\n    }\n  },\n  // AM, PM, midnight, noon\n  b: function b(date, token, localize) {\n    var hours = date.getUTCHours();\n    var dayPeriodEnumValue;\n    if (hours === 12) {\n      dayPeriodEnumValue = dayPeriodEnum.noon;\n    } else if (hours === 0) {\n      dayPeriodEnumValue = dayPeriodEnum.midnight;\n    } else {\n      dayPeriodEnumValue = hours / 12 >= 1 ? 'pm' : 'am';\n    }\n    switch (token) {\n      case 'b':\n      case 'bb':\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'abbreviated',\n          context: 'formatting'\n        });\n      case 'bbb':\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'abbreviated',\n          context: 'formatting'\n        }).toLowerCase();\n      case 'bbbbb':\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'narrow',\n          context: 'formatting'\n        });\n      case 'bbbb':\n      default:\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'wide',\n          context: 'formatting'\n        });\n    }\n  },\n  // in the morning, in the afternoon, in the evening, at night\n  B: function B(date, token, localize) {\n    var hours = date.getUTCHours();\n    var dayPeriodEnumValue;\n    if (hours >= 17) {\n      dayPeriodEnumValue = dayPeriodEnum.evening;\n    } else if (hours >= 12) {\n      dayPeriodEnumValue = dayPeriodEnum.afternoon;\n    } else if (hours >= 4) {\n      dayPeriodEnumValue = dayPeriodEnum.morning;\n    } else {\n      dayPeriodEnumValue = dayPeriodEnum.night;\n    }\n    switch (token) {\n      case 'B':\n      case 'BB':\n      case 'BBB':\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'abbreviated',\n          context: 'formatting'\n        });\n      case 'BBBBB':\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'narrow',\n          context: 'formatting'\n        });\n      case 'BBBB':\n      default:\n        return localize.dayPeriod(dayPeriodEnumValue, {\n          width: 'wide',\n          context: 'formatting'\n        });\n    }\n  },\n  // Hour [1-12]\n  h: function h(date, token, localize) {\n    if (token === 'ho') {\n      var hours = date.getUTCHours() % 12;\n      if (hours === 0) hours = 12;\n      return localize.ordinalNumber(hours, {\n        unit: 'hour'\n      });\n    }\n    return lightFormatters.h(date, token);\n  },\n  // Hour [0-23]\n  H: function H(date, token, localize) {\n    if (token === 'Ho') {\n      return localize.ordinalNumber(date.getUTCHours(), {\n        unit: 'hour'\n      });\n    }\n    return lightFormatters.H(date, token);\n  },\n  // Hour [0-11]\n  K: function K(date, token, localize) {\n    var hours = date.getUTCHours() % 12;\n    if (token === 'Ko') {\n      return localize.ordinalNumber(hours, {\n        unit: 'hour'\n      });\n    }\n    return addLeadingZeros(hours, token.length);\n  },\n  // Hour [1-24]\n  k: function k(date, token, localize) {\n    var hours = date.getUTCHours();\n    if (hours === 0) hours = 24;\n    if (token === 'ko') {\n      return localize.ordinalNumber(hours, {\n        unit: 'hour'\n      });\n    }\n    return addLeadingZeros(hours, token.length);\n  },\n  // Minute\n  m: function m(date, token, localize) {\n    if (token === 'mo') {\n      return localize.ordinalNumber(date.getUTCMinutes(), {\n        unit: 'minute'\n      });\n    }\n    return lightFormatters.m(date, token);\n  },\n  // Second\n  s: function s(date, token, localize) {\n    if (token === 'so') {\n      return localize.ordinalNumber(date.getUTCSeconds(), {\n        unit: 'second'\n      });\n    }\n    return lightFormatters.s(date, token);\n  },\n  // Fraction of second\n  S: function S(date, token) {\n    return lightFormatters.S(date, token);\n  },\n  // Timezone (ISO-8601. If offset is 0, output is always `'Z'`)\n  X: function X(date, token, _localize, options) {\n    var originalDate = options._originalDate || date;\n    var timezoneOffset = originalDate.getTimezoneOffset();\n    if (timezoneOffset === 0) {\n      return 'Z';\n    }\n    switch (token) {\n      // Hours and optional minutes\n      case 'X':\n        return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n      // Hours, minutes and optional seconds without `:` delimiter\n      // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n      // so this token always has the same output as `XX`\n      case 'XXXX':\n      case 'XX':\n        // Hours and minutes without `:` delimiter\n        return formatTimezone(timezoneOffset);\n\n      // Hours, minutes and optional seconds with `:` delimiter\n      // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n      // so this token always has the same output as `XXX`\n      case 'XXXXX':\n      case 'XXX': // Hours and minutes with `:` delimiter\n      default:\n        return formatTimezone(timezoneOffset, ':');\n    }\n  },\n  // Timezone (ISO-8601. If offset is 0, output is `'+00:00'` or equivalent)\n  x: function x(date, token, _localize, options) {\n    var originalDate = options._originalDate || date;\n    var timezoneOffset = originalDate.getTimezoneOffset();\n    switch (token) {\n      // Hours and optional minutes\n      case 'x':\n        return formatTimezoneWithOptionalMinutes(timezoneOffset);\n\n      // Hours, minutes and optional seconds without `:` delimiter\n      // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n      // so this token always has the same output as `xx`\n      case 'xxxx':\n      case 'xx':\n        // Hours and minutes without `:` delimiter\n        return formatTimezone(timezoneOffset);\n\n      // Hours, minutes and optional seconds with `:` delimiter\n      // Note: neither ISO-8601 nor JavaScript supports seconds in timezone offsets\n      // so this token always has the same output as `xxx`\n      case 'xxxxx':\n      case 'xxx': // Hours and minutes with `:` delimiter\n      default:\n        return formatTimezone(timezoneOffset, ':');\n    }\n  },\n  // Timezone (GMT)\n  O: function O(date, token, _localize, options) {\n    var originalDate = options._originalDate || date;\n    var timezoneOffset = originalDate.getTimezoneOffset();\n    switch (token) {\n      // Short\n      case 'O':\n      case 'OO':\n      case 'OOO':\n        return 'GMT' + formatTimezoneShort(timezoneOffset, ':');\n      // Long\n      case 'OOOO':\n      default:\n        return 'GMT' + formatTimezone(timezoneOffset, ':');\n    }\n  },\n  // Timezone (specific non-location)\n  z: function z(date, token, _localize, options) {\n    var originalDate = options._originalDate || date;\n    var timezoneOffset = originalDate.getTimezoneOffset();\n    switch (token) {\n      // Short\n      case 'z':\n      case 'zz':\n      case 'zzz':\n        return 'GMT' + formatTimezoneShort(timezoneOffset, ':');\n      // Long\n      case 'zzzz':\n      default:\n        return 'GMT' + formatTimezone(timezoneOffset, ':');\n    }\n  },\n  // Seconds timestamp\n  t: function t(date, token, _localize, options) {\n    var originalDate = options._originalDate || date;\n    var timestamp = Math.floor(originalDate.getTime() / 1000);\n    return addLeadingZeros(timestamp, token.length);\n  },\n  // Milliseconds timestamp\n  T: function T(date, token, _localize, options) {\n    var originalDate = options._originalDate || date;\n    var timestamp = originalDate.getTime();\n    return addLeadingZeros(timestamp, token.length);\n  }\n};\nfunction formatTimezoneShort(offset, dirtyDelimiter) {\n  var sign = offset > 0 ? '-' : '+';\n  var absOffset = Math.abs(offset);\n  var hours = Math.floor(absOffset / 60);\n  var minutes = absOffset % 60;\n  if (minutes === 0) {\n    return sign + String(hours);\n  }\n  var delimiter = dirtyDelimiter || '';\n  return sign + String(hours) + delimiter + addLeadingZeros(minutes, 2);\n}\nfunction formatTimezoneWithOptionalMinutes(offset, dirtyDelimiter) {\n  if (offset % 60 === 0) {\n    var sign = offset > 0 ? '-' : '+';\n    return sign + addLeadingZeros(Math.abs(offset) / 60, 2);\n  }\n  return formatTimezone(offset, dirtyDelimiter);\n}\nfunction formatTimezone(offset, dirtyDelimiter) {\n  var delimiter = dirtyDelimiter || '';\n  var sign = offset > 0 ? '-' : '+';\n  var absOffset = Math.abs(offset);\n  var hours = addLeadingZeros(Math.floor(absOffset / 60), 2);\n  var minutes = addLeadingZeros(absOffset % 60, 2);\n  return sign + hours + delimiter + minutes;\n}\nexport default formatters;","import toDate from \"../../toDate/index.js\";\nimport requiredArgs from \"../requiredArgs/index.js\";\nvar MILLISECONDS_IN_DAY = 86400000;\nexport default function getUTCDayOfYear(dirtyDate) {\n  requiredArgs(1, arguments);\n  var date = toDate(dirtyDate);\n  var timestamp = date.getTime();\n  date.setUTCMonth(0, 1);\n  date.setUTCHours(0, 0, 0, 0);\n  var startOfYearTimestamp = date.getTime();\n  var difference = timestamp - startOfYearTimestamp;\n  return Math.floor(difference / MILLISECONDS_IN_DAY) + 1;\n}","var dateLongFormatter = function dateLongFormatter(pattern, formatLong) {\n  switch (pattern) {\n    case 'P':\n      return formatLong.date({\n        width: 'short'\n      });\n    case 'PP':\n      return formatLong.date({\n        width: 'medium'\n      });\n    case 'PPP':\n      return formatLong.date({\n        width: 'long'\n      });\n    case 'PPPP':\n    default:\n      return formatLong.date({\n        width: 'full'\n      });\n  }\n};\nvar timeLongFormatter = function timeLongFormatter(pattern, formatLong) {\n  switch (pattern) {\n    case 'p':\n      return formatLong.time({\n        width: 'short'\n      });\n    case 'pp':\n      return formatLong.time({\n        width: 'medium'\n      });\n    case 'ppp':\n      return formatLong.time({\n        width: 'long'\n      });\n    case 'pppp':\n    default:\n      return formatLong.time({\n        width: 'full'\n      });\n  }\n};\nvar dateTimeLongFormatter = function dateTimeLongFormatter(pattern, formatLong) {\n  var matchResult = pattern.match(/(P+)(p+)?/) || [];\n  var datePattern = matchResult[1];\n  var timePattern = matchResult[2];\n  if (!timePattern) {\n    return dateLongFormatter(pattern, formatLong);\n  }\n  var dateTimeFormat;\n  switch (datePattern) {\n    case 'P':\n      dateTimeFormat = formatLong.dateTime({\n        width: 'short'\n      });\n      break;\n    case 'PP':\n      dateTimeFormat = formatLong.dateTime({\n        width: 'medium'\n      });\n      break;\n    case 'PPP':\n      dateTimeFormat = formatLong.dateTime({\n        width: 'long'\n      });\n      break;\n    case 'PPPP':\n    default:\n      dateTimeFormat = formatLong.dateTime({\n        width: 'full'\n      });\n      break;\n  }\n  return dateTimeFormat.replace('{{date}}', dateLongFormatter(datePattern, formatLong)).replace('{{time}}', timeLongFormatter(timePattern, formatLong));\n};\nvar longFormatters = {\n  p: timeLongFormatter,\n  P: dateTimeLongFormatter\n};\nexport default longFormatters;","var protectedDayOfYearTokens = ['D', 'DD'];\nvar protectedWeekYearTokens = ['YY', 'YYYY'];\nexport function isProtectedDayOfYearToken(token) {\n  return protectedDayOfYearTokens.indexOf(token) !== -1;\n}\nexport function isProtectedWeekYearToken(token) {\n  return protectedWeekYearTokens.indexOf(token) !== -1;\n}\nexport function throwProtectedError(token, format, input) {\n  if (token === 'YYYY') {\n    throw new RangeError(\"Use `yyyy` instead of `YYYY` (in `\".concat(format, \"`) for formatting years to the input `\").concat(input, \"`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\"));\n  } else if (token === 'YY') {\n    throw new RangeError(\"Use `yy` instead of `YY` (in `\".concat(format, \"`) for formatting years to the input `\").concat(input, \"`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\"));\n  } else if (token === 'D') {\n    throw new RangeError(\"Use `d` instead of `D` (in `\".concat(format, \"`) for formatting days of the month to the input `\").concat(input, \"`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\"));\n  } else if (token === 'DD') {\n    throw new RangeError(\"Use `dd` instead of `DD` (in `\".concat(format, \"`) for formatting days of the month to the input `\").concat(input, \"`; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\"));\n  }\n}","var formatDistanceLocale = {\n  lessThanXSeconds: {\n    one: 'less than a second',\n    other: 'less than {{count}} seconds'\n  },\n  xSeconds: {\n    one: '1 second',\n    other: '{{count}} seconds'\n  },\n  halfAMinute: 'half a minute',\n  lessThanXMinutes: {\n    one: 'less than a minute',\n    other: 'less than {{count}} minutes'\n  },\n  xMinutes: {\n    one: '1 minute',\n    other: '{{count}} minutes'\n  },\n  aboutXHours: {\n    one: 'about 1 hour',\n    other: 'about {{count}} hours'\n  },\n  xHours: {\n    one: '1 hour',\n    other: '{{count}} hours'\n  },\n  xDays: {\n    one: '1 day',\n    other: '{{count}} days'\n  },\n  aboutXWeeks: {\n    one: 'about 1 week',\n    other: 'about {{count}} weeks'\n  },\n  xWeeks: {\n    one: '1 week',\n    other: '{{count}} weeks'\n  },\n  aboutXMonths: {\n    one: 'about 1 month',\n    other: 'about {{count}} months'\n  },\n  xMonths: {\n    one: '1 month',\n    other: '{{count}} months'\n  },\n  aboutXYears: {\n    one: 'about 1 year',\n    other: 'about {{count}} years'\n  },\n  xYears: {\n    one: '1 year',\n    other: '{{count}} years'\n  },\n  overXYears: {\n    one: 'over 1 year',\n    other: 'over {{count}} years'\n  },\n  almostXYears: {\n    one: 'almost 1 year',\n    other: 'almost {{count}} years'\n  }\n};\nvar formatDistance = function formatDistance(token, count, options) {\n  var result;\n  var tokenValue = formatDistanceLocale[token];\n  if (typeof tokenValue === 'string') {\n    result = tokenValue;\n  } else if (count === 1) {\n    result = tokenValue.one;\n  } else {\n    result = tokenValue.other.replace('{{count}}', count.toString());\n  }\n  if (options !== null && options !== void 0 && options.addSuffix) {\n    if (options.comparison && options.comparison > 0) {\n      return 'in ' + result;\n    } else {\n      return result + ' ago';\n    }\n  }\n  return result;\n};\nexport default formatDistance;","export default function buildFormatLongFn(args) {\n  return function () {\n    var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n    // TODO: Remove String()\n    var width = options.width ? String(options.width) : args.defaultWidth;\n    var format = args.formats[width] || args.formats[args.defaultWidth];\n    return format;\n  };\n}","import buildFormatLongFn from \"../../../_lib/buildFormatLongFn/index.js\";\nvar dateFormats = {\n  full: 'EEEE, MMMM do, y',\n  long: 'MMMM do, y',\n  medium: 'MMM d, y',\n  short: 'MM/dd/yyyy'\n};\nvar timeFormats = {\n  full: 'h:mm:ss a zzzz',\n  long: 'h:mm:ss a z',\n  medium: 'h:mm:ss a',\n  short: 'h:mm a'\n};\nvar dateTimeFormats = {\n  full: \"{{date}} 'at' {{time}}\",\n  long: \"{{date}} 'at' {{time}}\",\n  medium: '{{date}}, {{time}}',\n  short: '{{date}}, {{time}}'\n};\nvar formatLong = {\n  date: buildFormatLongFn({\n    formats: dateFormats,\n    defaultWidth: 'full'\n  }),\n  time: buildFormatLongFn({\n    formats: timeFormats,\n    defaultWidth: 'full'\n  }),\n  dateTime: buildFormatLongFn({\n    formats: dateTimeFormats,\n    defaultWidth: 'full'\n  })\n};\nexport default formatLong;","var formatRelativeLocale = {\n  lastWeek: \"'last' eeee 'at' p\",\n  yesterday: \"'yesterday at' p\",\n  today: \"'today at' p\",\n  tomorrow: \"'tomorrow at' p\",\n  nextWeek: \"eeee 'at' p\",\n  other: 'P'\n};\nvar formatRelative = function formatRelative(token, _date, _baseDate, _options) {\n  return formatRelativeLocale[token];\n};\nexport default formatRelative;","export default function buildLocalizeFn(args) {\n  return function (dirtyIndex, options) {\n    var context = options !== null && options !== void 0 && options.context ? String(options.context) : 'standalone';\n    var valuesArray;\n    if (context === 'formatting' && args.formattingValues) {\n      var defaultWidth = args.defaultFormattingWidth || args.defaultWidth;\n      var width = options !== null && options !== void 0 && options.width ? String(options.width) : defaultWidth;\n      valuesArray = args.formattingValues[width] || args.formattingValues[defaultWidth];\n    } else {\n      var _defaultWidth = args.defaultWidth;\n      var _width = options !== null && options !== void 0 && options.width ? String(options.width) : args.defaultWidth;\n      valuesArray = args.values[_width] || args.values[_defaultWidth];\n    }\n    var index = args.argumentCallback ? args.argumentCallback(dirtyIndex) : dirtyIndex;\n    // @ts-ignore: For some reason TypeScript just don't want to match it, no matter how hard we try. I challenge you to try to remove it!\n    return valuesArray[index];\n  };\n}","export default function buildMatchFn(args) {\n  return function (string) {\n    var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n    var width = options.width;\n    var matchPattern = width && args.matchPatterns[width] || args.matchPatterns[args.defaultMatchWidth];\n    var matchResult = string.match(matchPattern);\n    if (!matchResult) {\n      return null;\n    }\n    var matchedString = matchResult[0];\n    var parsePatterns = width && args.parsePatterns[width] || args.parsePatterns[args.defaultParseWidth];\n    var key = Array.isArray(parsePatterns) ? findIndex(parsePatterns, function (pattern) {\n      return pattern.test(matchedString);\n    }) : findKey(parsePatterns, function (pattern) {\n      return pattern.test(matchedString);\n    });\n    var value;\n    value = args.valueCallback ? args.valueCallback(key) : key;\n    value = options.valueCallback ? options.valueCallback(value) : value;\n    var rest = string.slice(matchedString.length);\n    return {\n      value: value,\n      rest: rest\n    };\n  };\n}\nfunction findKey(object, predicate) {\n  for (var key in object) {\n    if (object.hasOwnProperty(key) && predicate(object[key])) {\n      return key;\n    }\n  }\n  return undefined;\n}\nfunction findIndex(array, predicate) {\n  for (var key = 0; key < array.length; key++) {\n    if (predicate(array[key])) {\n      return key;\n    }\n  }\n  return undefined;\n}","import buildMatchFn from \"../../../_lib/buildMatchFn/index.js\";\nimport buildMatchPatternFn from \"../../../_lib/buildMatchPatternFn/index.js\";\nvar matchOrdinalNumberPattern = /^(\\d+)(th|st|nd|rd)?/i;\nvar parseOrdinalNumberPattern = /\\d+/i;\nvar matchEraPatterns = {\n  narrow: /^(b|a)/i,\n  abbreviated: /^(b\\.?\\s?c\\.?|b\\.?\\s?c\\.?\\s?e\\.?|a\\.?\\s?d\\.?|c\\.?\\s?e\\.?)/i,\n  wide: /^(before christ|before common era|anno domini|common era)/i\n};\nvar parseEraPatterns = {\n  any: [/^b/i, /^(a|c)/i]\n};\nvar matchQuarterPatterns = {\n  narrow: /^[1234]/i,\n  abbreviated: /^q[1234]/i,\n  wide: /^[1234](th|st|nd|rd)? quarter/i\n};\nvar parseQuarterPatterns = {\n  any: [/1/i, /2/i, /3/i, /4/i]\n};\nvar matchMonthPatterns = {\n  narrow: /^[jfmasond]/i,\n  abbreviated: /^(jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec)/i,\n  wide: /^(january|february|march|april|may|june|july|august|september|october|november|december)/i\n};\nvar parseMonthPatterns = {\n  narrow: [/^j/i, /^f/i, /^m/i, /^a/i, /^m/i, /^j/i, /^j/i, /^a/i, /^s/i, /^o/i, /^n/i, /^d/i],\n  any: [/^ja/i, /^f/i, /^mar/i, /^ap/i, /^may/i, /^jun/i, /^jul/i, /^au/i, /^s/i, /^o/i, /^n/i, /^d/i]\n};\nvar matchDayPatterns = {\n  narrow: /^[smtwf]/i,\n  short: /^(su|mo|tu|we|th|fr|sa)/i,\n  abbreviated: /^(sun|mon|tue|wed|thu|fri|sat)/i,\n  wide: /^(sunday|monday|tuesday|wednesday|thursday|friday|saturday)/i\n};\nvar parseDayPatterns = {\n  narrow: [/^s/i, /^m/i, /^t/i, /^w/i, /^t/i, /^f/i, /^s/i],\n  any: [/^su/i, /^m/i, /^tu/i, /^w/i, /^th/i, /^f/i, /^sa/i]\n};\nvar matchDayPeriodPatterns = {\n  narrow: /^(a|p|mi|n|(in the|at) (morning|afternoon|evening|night))/i,\n  any: /^([ap]\\.?\\s?m\\.?|midnight|noon|(in the|at) (morning|afternoon|evening|night))/i\n};\nvar parseDayPeriodPatterns = {\n  any: {\n    am: /^a/i,\n    pm: /^p/i,\n    midnight: /^mi/i,\n    noon: /^no/i,\n    morning: /morning/i,\n    afternoon: /afternoon/i,\n    evening: /evening/i,\n    night: /night/i\n  }\n};\nvar match = {\n  ordinalNumber: buildMatchPatternFn({\n    matchPattern: matchOrdinalNumberPattern,\n    parsePattern: parseOrdinalNumberPattern,\n    valueCallback: function valueCallback(value) {\n      return parseInt(value, 10);\n    }\n  }),\n  era: buildMatchFn({\n    matchPatterns: matchEraPatterns,\n    defaultMatchWidth: 'wide',\n    parsePatterns: parseEraPatterns,\n    defaultParseWidth: 'any'\n  }),\n  quarter: buildMatchFn({\n    matchPatterns: matchQuarterPatterns,\n    defaultMatchWidth: 'wide',\n    parsePatterns: parseQuarterPatterns,\n    defaultParseWidth: 'any',\n    valueCallback: function valueCallback(index) {\n      return index + 1;\n    }\n  }),\n  month: buildMatchFn({\n    matchPatterns: matchMonthPatterns,\n    defaultMatchWidth: 'wide',\n    parsePatterns: parseMonthPatterns,\n    defaultParseWidth: 'any'\n  }),\n  day: buildMatchFn({\n    matchPatterns: matchDayPatterns,\n    defaultMatchWidth: 'wide',\n    parsePatterns: parseDayPatterns,\n    defaultParseWidth: 'any'\n  }),\n  dayPeriod: buildMatchFn({\n    matchPatterns: matchDayPeriodPatterns,\n    defaultMatchWidth: 'any',\n    parsePatterns: parseDayPeriodPatterns,\n    defaultParseWidth: 'any'\n  })\n};\nexport default match;","import formatDistance from \"./_lib/formatDistance/index.js\";\nimport formatLong from \"./_lib/formatLong/index.js\";\nimport formatRelative from \"./_lib/formatRelative/index.js\";\nimport localize from \"./_lib/localize/index.js\";\nimport match from \"./_lib/match/index.js\";\n/**\n * @type {Locale}\n * @category Locales\n * @summary English locale (United States).\n * @language English\n * @iso-639-2 eng\n * @author Sasha Koss [@kossnocorp]{@link https://github.com/kossnocorp}\n * @author Lesha Koss [@leshakoss]{@link https://github.com/leshakoss}\n */\nvar locale = {\n  code: 'en-US',\n  formatDistance: formatDistance,\n  formatLong: formatLong,\n  formatRelative: formatRelative,\n  localize: localize,\n  match: match,\n  options: {\n    weekStartsOn: 0 /* Sunday */,\n    firstWeekContainsDate: 1\n  }\n};\nexport default locale;","import buildLocalizeFn from \"../../../_lib/buildLocalizeFn/index.js\";\nvar eraValues = {\n  narrow: ['B', 'A'],\n  abbreviated: ['BC', 'AD'],\n  wide: ['Before Christ', 'Anno Domini']\n};\nvar quarterValues = {\n  narrow: ['1', '2', '3', '4'],\n  abbreviated: ['Q1', 'Q2', 'Q3', 'Q4'],\n  wide: ['1st quarter', '2nd quarter', '3rd quarter', '4th quarter']\n};\n\n// Note: in English, the names of days of the week and months are capitalized.\n// If you are making a new locale based on this one, check if the same is true for the language you're working on.\n// Generally, formatted dates should look like they are in the middle of a sentence,\n// e.g. in Spanish language the weekdays and months should be in the lowercase.\nvar monthValues = {\n  narrow: ['J', 'F', 'M', 'A', 'M', 'J', 'J', 'A', 'S', 'O', 'N', 'D'],\n  abbreviated: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'],\n  wide: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']\n};\nvar dayValues = {\n  narrow: ['S', 'M', 'T', 'W', 'T', 'F', 'S'],\n  short: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n  abbreviated: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n  wide: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday']\n};\nvar dayPeriodValues = {\n  narrow: {\n    am: 'a',\n    pm: 'p',\n    midnight: 'mi',\n    noon: 'n',\n    morning: 'morning',\n    afternoon: 'afternoon',\n    evening: 'evening',\n    night: 'night'\n  },\n  abbreviated: {\n    am: 'AM',\n    pm: 'PM',\n    midnight: 'midnight',\n    noon: 'noon',\n    morning: 'morning',\n    afternoon: 'afternoon',\n    evening: 'evening',\n    night: 'night'\n  },\n  wide: {\n    am: 'a.m.',\n    pm: 'p.m.',\n    midnight: 'midnight',\n    noon: 'noon',\n    morning: 'morning',\n    afternoon: 'afternoon',\n    evening: 'evening',\n    night: 'night'\n  }\n};\nvar formattingDayPeriodValues = {\n  narrow: {\n    am: 'a',\n    pm: 'p',\n    midnight: 'mi',\n    noon: 'n',\n    morning: 'in the morning',\n    afternoon: 'in the afternoon',\n    evening: 'in the evening',\n    night: 'at night'\n  },\n  abbreviated: {\n    am: 'AM',\n    pm: 'PM',\n    midnight: 'midnight',\n    noon: 'noon',\n    morning: 'in the morning',\n    afternoon: 'in the afternoon',\n    evening: 'in the evening',\n    night: 'at night'\n  },\n  wide: {\n    am: 'a.m.',\n    pm: 'p.m.',\n    midnight: 'midnight',\n    noon: 'noon',\n    morning: 'in the morning',\n    afternoon: 'in the afternoon',\n    evening: 'in the evening',\n    night: 'at night'\n  }\n};\nvar ordinalNumber = function ordinalNumber(dirtyNumber, _options) {\n  var number = Number(dirtyNumber);\n\n  // If ordinal numbers depend on context, for example,\n  // if they are different for different grammatical genders,\n  // use `options.unit`.\n  //\n  // `unit` can be 'year', 'quarter', 'month', 'week', 'date', 'dayOfYear',\n  // 'day', 'hour', 'minute', 'second'.\n\n  var rem100 = number % 100;\n  if (rem100 > 20 || rem100 < 10) {\n    switch (rem100 % 10) {\n      case 1:\n        return number + 'st';\n      case 2:\n        return number + 'nd';\n      case 3:\n        return number + 'rd';\n    }\n  }\n  return number + 'th';\n};\nvar localize = {\n  ordinalNumber: ordinalNumber,\n  era: buildLocalizeFn({\n    values: eraValues,\n    defaultWidth: 'wide'\n  }),\n  quarter: buildLocalizeFn({\n    values: quarterValues,\n    defaultWidth: 'wide',\n    argumentCallback: function argumentCallback(quarter) {\n      return quarter - 1;\n    }\n  }),\n  month: buildLocalizeFn({\n    values: monthValues,\n    defaultWidth: 'wide'\n  }),\n  day: buildLocalizeFn({\n    values: dayValues,\n    defaultWidth: 'wide'\n  }),\n  dayPeriod: buildLocalizeFn({\n    values: dayPeriodValues,\n    defaultWidth: 'wide',\n    formattingValues: formattingDayPeriodValues,\n    defaultFormattingWidth: 'wide'\n  })\n};\nexport default localize;","export default function buildMatchPatternFn(args) {\n  return function (string) {\n    var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n    var matchResult = string.match(args.matchPattern);\n    if (!matchResult) return null;\n    var matchedString = matchResult[0];\n    var parseResult = string.match(args.parsePattern);\n    if (!parseResult) return null;\n    var value = args.valueCallback ? args.valueCallback(parseResult[0]) : parseResult[0];\n    value = options.valueCallback ? options.valueCallback(value) : value;\n    var rest = string.slice(matchedString.length);\n    return {\n      value: value,\n      rest: rest\n    };\n  };\n}","import isValid from \"../isValid/index.js\";\nimport subMilliseconds from \"../subMilliseconds/index.js\";\nimport toDate from \"../toDate/index.js\";\nimport formatters from \"../_lib/format/formatters/index.js\";\nimport longFormatters from \"../_lib/format/longFormatters/index.js\";\nimport getTimezoneOffsetInMilliseconds from \"../_lib/getTimezoneOffsetInMilliseconds/index.js\";\nimport { isProtectedDayOfYearToken, isProtectedWeekYearToken, throwProtectedError } from \"../_lib/protectedTokens/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\nimport { getDefaultOptions } from \"../_lib/defaultOptions/index.js\";\nimport defaultLocale from \"../_lib/defaultLocale/index.js\"; // This RegExp consists of three parts separated by `|`:\n// - [yYQqMLwIdDecihHKkms]o matches any available ordinal number token\n//   (one of the certain letters followed by `o`)\n// - (\\w)\\1* matches any sequences of the same letter\n// - '' matches two quote characters in a row\n// - '(''|[^'])+('|$) matches anything surrounded by two quote characters ('),\n//   except a single quote symbol, which ends the sequence.\n//   Two quote characters do not end the sequence.\n//   If there is no matching single quote\n//   then the sequence will continue until the end of the string.\n// - . matches any single character unmatched by previous parts of the RegExps\nvar formattingTokensRegExp = /[yYQqMLwIdDecihHKkms]o|(\\w)\\1*|''|'(''|[^'])+('|$)|./g;\n\n// This RegExp catches symbols escaped by quotes, and also\n// sequences of symbols P, p, and the combinations like `PPPPPPPppppp`\nvar longFormattingTokensRegExp = /P+p+|P+|p+|''|'(''|[^'])+('|$)|./g;\nvar escapedStringRegExp = /^'([^]*?)'?$/;\nvar doubleQuoteRegExp = /''/g;\nvar unescapedLatinCharacterRegExp = /[a-zA-Z]/;\n\n/**\n * @name format\n * @category Common Helpers\n * @summary Format the date.\n *\n * @description\n * Return the formatted date string in the given format. The result may vary by locale.\n *\n * > ⚠️ Please note that the `format` tokens differ from Moment.js and other libraries.\n * > See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * The characters wrapped between two single quotes characters (') are escaped.\n * Two single quotes in a row, whether inside or outside a quoted sequence, represent a 'real' single quote.\n * (see the last example)\n *\n * Format of the string is based on Unicode Technical Standard #35:\n * https://www.unicode.org/reports/tr35/tr35-dates.html#Date_Field_Symbol_Table\n * with a few additions (see note 7 below the table).\n *\n * Accepted patterns:\n * | Unit                            | Pattern | Result examples                   | Notes |\n * |---------------------------------|---------|-----------------------------------|-------|\n * | Era                             | G..GGG  | AD, BC                            |       |\n * |                                 | GGGG    | Anno Domini, Before Christ        | 2     |\n * |                                 | GGGGG   | A, B                              |       |\n * | Calendar year                   | y       | 44, 1, 1900, 2017                 | 5     |\n * |                                 | yo      | 44th, 1st, 0th, 17th              | 5,7   |\n * |                                 | yy      | 44, 01, 00, 17                    | 5     |\n * |                                 | yyy     | 044, 001, 1900, 2017              | 5     |\n * |                                 | yyyy    | 0044, 0001, 1900, 2017            | 5     |\n * |                                 | yyyyy   | ...                               | 3,5   |\n * | Local week-numbering year       | Y       | 44, 1, 1900, 2017                 | 5     |\n * |                                 | Yo      | 44th, 1st, 1900th, 2017th         | 5,7   |\n * |                                 | YY      | 44, 01, 00, 17                    | 5,8   |\n * |                                 | YYY     | 044, 001, 1900, 2017              | 5     |\n * |                                 | YYYY    | 0044, 0001, 1900, 2017            | 5,8   |\n * |                                 | YYYYY   | ...                               | 3,5   |\n * | ISO week-numbering year         | R       | -43, 0, 1, 1900, 2017             | 5,7   |\n * |                                 | RR      | -43, 00, 01, 1900, 2017           | 5,7   |\n * |                                 | RRR     | -043, 000, 001, 1900, 2017        | 5,7   |\n * |                                 | RRRR    | -0043, 0000, 0001, 1900, 2017     | 5,7   |\n * |                                 | RRRRR   | ...                               | 3,5,7 |\n * | Extended year                   | u       | -43, 0, 1, 1900, 2017             | 5     |\n * |                                 | uu      | -43, 01, 1900, 2017               | 5     |\n * |                                 | uuu     | -043, 001, 1900, 2017             | 5     |\n * |                                 | uuuu    | -0043, 0001, 1900, 2017           | 5     |\n * |                                 | uuuuu   | ...                               | 3,5   |\n * | Quarter (formatting)            | Q       | 1, 2, 3, 4                        |       |\n * |                                 | Qo      | 1st, 2nd, 3rd, 4th                | 7     |\n * |                                 | QQ      | 01, 02, 03, 04                    |       |\n * |                                 | QQQ     | Q1, Q2, Q3, Q4                    |       |\n * |                                 | QQQQ    | 1st quarter, 2nd quarter, ...     | 2     |\n * |                                 | QQQQQ   | 1, 2, 3, 4                        | 4     |\n * | Quarter (stand-alone)           | q       | 1, 2, 3, 4                        |       |\n * |                                 | qo      | 1st, 2nd, 3rd, 4th                | 7     |\n * |                                 | qq      | 01, 02, 03, 04                    |       |\n * |                                 | qqq     | Q1, Q2, Q3, Q4                    |       |\n * |                                 | qqqq    | 1st quarter, 2nd quarter, ...     | 2     |\n * |                                 | qqqqq   | 1, 2, 3, 4                        | 4     |\n * | Month (formatting)              | M       | 1, 2, ..., 12                     |       |\n * |                                 | Mo      | 1st, 2nd, ..., 12th               | 7     |\n * |                                 | MM      | 01, 02, ..., 12                   |       |\n * |                                 | MMM     | Jan, Feb, ..., Dec                |       |\n * |                                 | MMMM    | January, February, ..., December  | 2     |\n * |                                 | MMMMM   | J, F, ..., D                      |       |\n * | Month (stand-alone)             | L       | 1, 2, ..., 12                     |       |\n * |                                 | Lo      | 1st, 2nd, ..., 12th               | 7     |\n * |                                 | LL      | 01, 02, ..., 12                   |       |\n * |                                 | LLL     | Jan, Feb, ..., Dec                |       |\n * |                                 | LLLL    | January, February, ..., December  | 2     |\n * |                                 | LLLLL   | J, F, ..., D                      |       |\n * | Local week of year              | w       | 1, 2, ..., 53                     |       |\n * |                                 | wo      | 1st, 2nd, ..., 53th               | 7     |\n * |                                 | ww      | 01, 02, ..., 53                   |       |\n * | ISO week of year                | I       | 1, 2, ..., 53                     | 7     |\n * |                                 | Io      | 1st, 2nd, ..., 53th               | 7     |\n * |                                 | II      | 01, 02, ..., 53                   | 7     |\n * | Day of month                    | d       | 1, 2, ..., 31                     |       |\n * |                                 | do      | 1st, 2nd, ..., 31st               | 7     |\n * |                                 | dd      | 01, 02, ..., 31                   |       |\n * | Day of year                     | D       | 1, 2, ..., 365, 366               | 9     |\n * |                                 | Do      | 1st, 2nd, ..., 365th, 366th       | 7     |\n * |                                 | DD      | 01, 02, ..., 365, 366             | 9     |\n * |                                 | DDD     | 001, 002, ..., 365, 366           |       |\n * |                                 | DDDD    | ...                               | 3     |\n * | Day of week (formatting)        | E..EEE  | Mon, Tue, Wed, ..., Sun           |       |\n * |                                 | EEEE    | Monday, Tuesday, ..., Sunday      | 2     |\n * |                                 | EEEEE   | M, T, W, T, F, S, S               |       |\n * |                                 | EEEEEE  | Mo, Tu, We, Th, Fr, Sa, Su        |       |\n * | ISO day of week (formatting)    | i       | 1, 2, 3, ..., 7                   | 7     |\n * |                                 | io      | 1st, 2nd, ..., 7th                | 7     |\n * |                                 | ii      | 01, 02, ..., 07                   | 7     |\n * |                                 | iii     | Mon, Tue, Wed, ..., Sun           | 7     |\n * |                                 | iiii    | Monday, Tuesday, ..., Sunday      | 2,7   |\n * |                                 | iiiii   | M, T, W, T, F, S, S               | 7     |\n * |                                 | iiiiii  | Mo, Tu, We, Th, Fr, Sa, Su        | 7     |\n * | Local day of week (formatting)  | e       | 2, 3, 4, ..., 1                   |       |\n * |                                 | eo      | 2nd, 3rd, ..., 1st                | 7     |\n * |                                 | ee      | 02, 03, ..., 01                   |       |\n * |                                 | eee     | Mon, Tue, Wed, ..., Sun           |       |\n * |                                 | eeee    | Monday, Tuesday, ..., Sunday      | 2     |\n * |                                 | eeeee   | M, T, W, T, F, S, S               |       |\n * |                                 | eeeeee  | Mo, Tu, We, Th, Fr, Sa, Su        |       |\n * | Local day of week (stand-alone) | c       | 2, 3, 4, ..., 1                   |       |\n * |                                 | co      | 2nd, 3rd, ..., 1st                | 7     |\n * |                                 | cc      | 02, 03, ..., 01                   |       |\n * |                                 | ccc     | Mon, Tue, Wed, ..., Sun           |       |\n * |                                 | cccc    | Monday, Tuesday, ..., Sunday      | 2     |\n * |                                 | ccccc   | M, T, W, T, F, S, S               |       |\n * |                                 | cccccc  | Mo, Tu, We, Th, Fr, Sa, Su        |       |\n * | AM, PM                          | a..aa   | AM, PM                            |       |\n * |                                 | aaa     | am, pm                            |       |\n * |                                 | aaaa    | a.m., p.m.                        | 2     |\n * |                                 | aaaaa   | a, p                              |       |\n * | AM, PM, noon, midnight          | b..bb   | AM, PM, noon, midnight            |       |\n * |                                 | bbb     | am, pm, noon, midnight            |       |\n * |                                 | bbbb    | a.m., p.m., noon, midnight        | 2     |\n * |                                 | bbbbb   | a, p, n, mi                       |       |\n * | Flexible day period             | B..BBB  | at night, in the morning, ...     |       |\n * |                                 | BBBB    | at night, in the morning, ...     | 2     |\n * |                                 | BBBBB   | at night, in the morning, ...     |       |\n * | Hour [1-12]                     | h       | 1, 2, ..., 11, 12                 |       |\n * |                                 | ho      | 1st, 2nd, ..., 11th, 12th         | 7     |\n * |                                 | hh      | 01, 02, ..., 11, 12               |       |\n * | Hour [0-23]                     | H       | 0, 1, 2, ..., 23                  |       |\n * |                                 | Ho      | 0th, 1st, 2nd, ..., 23rd          | 7     |\n * |                                 | HH      | 00, 01, 02, ..., 23               |       |\n * | Hour [0-11]                     | K       | 1, 2, ..., 11, 0                  |       |\n * |                                 | Ko      | 1st, 2nd, ..., 11th, 0th          | 7     |\n * |                                 | KK      | 01, 02, ..., 11, 00               |       |\n * | Hour [1-24]                     | k       | 24, 1, 2, ..., 23                 |       |\n * |                                 | ko      | 24th, 1st, 2nd, ..., 23rd         | 7     |\n * |                                 | kk      | 24, 01, 02, ..., 23               |       |\n * | Minute                          | m       | 0, 1, ..., 59                     |       |\n * |                                 | mo      | 0th, 1st, ..., 59th               | 7     |\n * |                                 | mm      | 00, 01, ..., 59                   |       |\n * | Second                          | s       | 0, 1, ..., 59                     |       |\n * |                                 | so      | 0th, 1st, ..., 59th               | 7     |\n * |                                 | ss      | 00, 01, ..., 59                   |       |\n * | Fraction of second              | S       | 0, 1, ..., 9                      |       |\n * |                                 | SS      | 00, 01, ..., 99                   |       |\n * |                                 | SSS     | 000, 001, ..., 999                |       |\n * |                                 | SSSS    | ...                               | 3     |\n * | Timezone (ISO-8601 w/ Z)        | X       | -08, +0530, Z                     |       |\n * |                                 | XX      | -0800, +0530, Z                   |       |\n * |                                 | XXX     | -08:00, +05:30, Z                 |       |\n * |                                 | XXXX    | -0800, +0530, Z, +123456          | 2     |\n * |                                 | XXXXX   | -08:00, +05:30, Z, +12:34:56      |       |\n * | Timezone (ISO-8601 w/o Z)       | x       | -08, +0530, +00                   |       |\n * |                                 | xx      | -0800, +0530, +0000               |       |\n * |                                 | xxx     | -08:00, +05:30, +00:00            | 2     |\n * |                                 | xxxx    | -0800, +0530, +0000, +123456      |       |\n * |                                 | xxxxx   | -08:00, +05:30, +00:00, +12:34:56 |       |\n * | Timezone (GMT)                  | O...OOO | GMT-8, GMT+5:30, GMT+0            |       |\n * |                                 | OOOO    | GMT-08:00, GMT+05:30, GMT+00:00   | 2     |\n * | Timezone (specific non-locat.)  | z...zzz | GMT-8, GMT+5:30, GMT+0            | 6     |\n * |                                 | zzzz    | GMT-08:00, GMT+05:30, GMT+00:00   | 2,6   |\n * | Seconds timestamp               | t       | 512969520                         | 7     |\n * |                                 | tt      | ...                               | 3,7   |\n * | Milliseconds timestamp          | T       | 512969520900                      | 7     |\n * |                                 | TT      | ...                               | 3,7   |\n * | Long localized date             | P       | 04/29/1453                        | 7     |\n * |                                 | PP      | Apr 29, 1453                      | 7     |\n * |                                 | PPP     | April 29th, 1453                  | 7     |\n * |                                 | PPPP    | Friday, April 29th, 1453          | 2,7   |\n * | Long localized time             | p       | 12:00 AM                          | 7     |\n * |                                 | pp      | 12:00:00 AM                       | 7     |\n * |                                 | ppp     | 12:00:00 AM GMT+2                 | 7     |\n * |                                 | pppp    | 12:00:00 AM GMT+02:00             | 2,7   |\n * | Combination of date and time    | Pp      | 04/29/1453, 12:00 AM              | 7     |\n * |                                 | PPpp    | Apr 29, 1453, 12:00:00 AM         | 7     |\n * |                                 | PPPppp  | April 29th, 1453 at ...           | 7     |\n * |                                 | PPPPpppp| Friday, April 29th, 1453 at ...   | 2,7   |\n * Notes:\n * 1. \"Formatting\" units (e.g. formatting quarter) in the default en-US locale\n *    are the same as \"stand-alone\" units, but are different in some languages.\n *    \"Formatting\" units are declined according to the rules of the language\n *    in the context of a date. \"Stand-alone\" units are always nominative singular:\n *\n *    `format(new Date(2017, 10, 6), 'do LLLL', {locale: cs}) //=> '6. listopad'`\n *\n *    `format(new Date(2017, 10, 6), 'do MMMM', {locale: cs}) //=> '6. listopadu'`\n *\n * 2. Any sequence of the identical letters is a pattern, unless it is escaped by\n *    the single quote characters (see below).\n *    If the sequence is longer than listed in table (e.g. `EEEEEEEEEEE`)\n *    the output will be the same as default pattern for this unit, usually\n *    the longest one (in case of ISO weekdays, `EEEE`). Default patterns for units\n *    are marked with \"2\" in the last column of the table.\n *\n *    `format(new Date(2017, 10, 6), 'MMM') //=> 'Nov'`\n *\n *    `format(new Date(2017, 10, 6), 'MMMM') //=> 'November'`\n *\n *    `format(new Date(2017, 10, 6), 'MMMMM') //=> 'N'`\n *\n *    `format(new Date(2017, 10, 6), 'MMMMMM') //=> 'November'`\n *\n *    `format(new Date(2017, 10, 6), 'MMMMMMM') //=> 'November'`\n *\n * 3. Some patterns could be unlimited length (such as `yyyyyyyy`).\n *    The output will be padded with zeros to match the length of the pattern.\n *\n *    `format(new Date(2017, 10, 6), 'yyyyyyyy') //=> '00002017'`\n *\n * 4. `QQQQQ` and `qqqqq` could be not strictly numerical in some locales.\n *    These tokens represent the shortest form of the quarter.\n *\n * 5. The main difference between `y` and `u` patterns are B.C. years:\n *\n *    | Year | `y` | `u` |\n *    |------|-----|-----|\n *    | AC 1 |   1 |   1 |\n *    | BC 1 |   1 |   0 |\n *    | BC 2 |   2 |  -1 |\n *\n *    Also `yy` always returns the last two digits of a year,\n *    while `uu` pads single digit years to 2 characters and returns other years unchanged:\n *\n *    | Year | `yy` | `uu` |\n *    |------|------|------|\n *    | 1    |   01 |   01 |\n *    | 14   |   14 |   14 |\n *    | 376  |   76 |  376 |\n *    | 1453 |   53 | 1453 |\n *\n *    The same difference is true for local and ISO week-numbering years (`Y` and `R`),\n *    except local week-numbering years are dependent on `options.weekStartsOn`\n *    and `options.firstWeekContainsDate` (compare [getISOWeekYear]{@link https://date-fns.org/docs/getISOWeekYear}\n *    and [getWeekYear]{@link https://date-fns.org/docs/getWeekYear}).\n *\n * 6. Specific non-location timezones are currently unavailable in `date-fns`,\n *    so right now these tokens fall back to GMT timezones.\n *\n * 7. These patterns are not in the Unicode Technical Standard #35:\n *    - `i`: ISO day of week\n *    - `I`: ISO week of year\n *    - `R`: ISO week-numbering year\n *    - `t`: seconds timestamp\n *    - `T`: milliseconds timestamp\n *    - `o`: ordinal number modifier\n *    - `P`: long localized date\n *    - `p`: long localized time\n *\n * 8. `YY` and `YYYY` tokens represent week-numbering years but they are often confused with years.\n *    You should enable `options.useAdditionalWeekYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * 9. `D` and `DD` tokens represent days of the year but they are often confused with days of the month.\n *    You should enable `options.useAdditionalDayOfYearTokens` to use them. See: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n *\n * @param {Date|Number} date - the original date\n * @param {String} format - the string of tokens\n * @param {Object} [options] - an object with options.\n * @param {Locale} [options.locale=defaultLocale] - the locale object. See [Locale]{@link https://date-fns.org/docs/Locale}\n * @param {0|1|2|3|4|5|6} [options.weekStartsOn=0] - the index of the first day of the week (0 - Sunday)\n * @param {Number} [options.firstWeekContainsDate=1] - the day of January, which is\n * @param {Boolean} [options.useAdditionalWeekYearTokens=false] - if true, allows usage of the week-numbering year tokens `YY` and `YYYY`;\n *   see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @param {Boolean} [options.useAdditionalDayOfYearTokens=false] - if true, allows usage of the day of year tokens `D` and `DD`;\n *   see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @returns {String} the formatted date string\n * @throws {TypeError} 2 arguments required\n * @throws {RangeError} `date` must not be Invalid Date\n * @throws {RangeError} `options.locale` must contain `localize` property\n * @throws {RangeError} `options.locale` must contain `formatLong` property\n * @throws {RangeError} `options.weekStartsOn` must be between 0 and 6\n * @throws {RangeError} `options.firstWeekContainsDate` must be between 1 and 7\n * @throws {RangeError} use `yyyy` instead of `YYYY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws {RangeError} use `yy` instead of `YY` for formatting years using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws {RangeError} use `d` instead of `D` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws {RangeError} use `dd` instead of `DD` for formatting days of the month using [format provided] to the input [input provided]; see: https://github.com/date-fns/date-fns/blob/master/docs/unicodeTokens.md\n * @throws {RangeError} format string contains an unescaped latin alphabet character\n *\n * @example\n * // Represent 11 February 2014 in middle-endian format:\n * const result = format(new Date(2014, 1, 11), 'MM/dd/yyyy')\n * //=> '02/11/2014'\n *\n * @example\n * // Represent 2 July 2014 in Esperanto:\n * import { eoLocale } from 'date-fns/locale/eo'\n * const result = format(new Date(2014, 6, 2), \"do 'de' MMMM yyyy\", {\n *   locale: eoLocale\n * })\n * //=> '2-a de julio 2014'\n *\n * @example\n * // Escape string by single quote characters:\n * const result = format(new Date(2014, 6, 2, 15), \"h 'o''clock'\")\n * //=> \"3 o'clock\"\n */\n\nexport default function format(dirtyDate, dirtyFormatStr, options) {\n  var _ref, _options$locale, _ref2, _ref3, _ref4, _options$firstWeekCon, _options$locale2, _options$locale2$opti, _defaultOptions$local, _defaultOptions$local2, _ref5, _ref6, _ref7, _options$weekStartsOn, _options$locale3, _options$locale3$opti, _defaultOptions$local3, _defaultOptions$local4;\n  requiredArgs(2, arguments);\n  var formatStr = String(dirtyFormatStr);\n  var defaultOptions = getDefaultOptions();\n  var locale = (_ref = (_options$locale = options === null || options === void 0 ? void 0 : options.locale) !== null && _options$locale !== void 0 ? _options$locale : defaultOptions.locale) !== null && _ref !== void 0 ? _ref : defaultLocale;\n  var firstWeekContainsDate = toInteger((_ref2 = (_ref3 = (_ref4 = (_options$firstWeekCon = options === null || options === void 0 ? void 0 : options.firstWeekContainsDate) !== null && _options$firstWeekCon !== void 0 ? _options$firstWeekCon : options === null || options === void 0 ? void 0 : (_options$locale2 = options.locale) === null || _options$locale2 === void 0 ? void 0 : (_options$locale2$opti = _options$locale2.options) === null || _options$locale2$opti === void 0 ? void 0 : _options$locale2$opti.firstWeekContainsDate) !== null && _ref4 !== void 0 ? _ref4 : defaultOptions.firstWeekContainsDate) !== null && _ref3 !== void 0 ? _ref3 : (_defaultOptions$local = defaultOptions.locale) === null || _defaultOptions$local === void 0 ? void 0 : (_defaultOptions$local2 = _defaultOptions$local.options) === null || _defaultOptions$local2 === void 0 ? void 0 : _defaultOptions$local2.firstWeekContainsDate) !== null && _ref2 !== void 0 ? _ref2 : 1);\n\n  // Test if weekStartsOn is between 1 and 7 _and_ is not NaN\n  if (!(firstWeekContainsDate >= 1 && firstWeekContainsDate <= 7)) {\n    throw new RangeError('firstWeekContainsDate must be between 1 and 7 inclusively');\n  }\n  var weekStartsOn = toInteger((_ref5 = (_ref6 = (_ref7 = (_options$weekStartsOn = options === null || options === void 0 ? void 0 : options.weekStartsOn) !== null && _options$weekStartsOn !== void 0 ? _options$weekStartsOn : options === null || options === void 0 ? void 0 : (_options$locale3 = options.locale) === null || _options$locale3 === void 0 ? void 0 : (_options$locale3$opti = _options$locale3.options) === null || _options$locale3$opti === void 0 ? void 0 : _options$locale3$opti.weekStartsOn) !== null && _ref7 !== void 0 ? _ref7 : defaultOptions.weekStartsOn) !== null && _ref6 !== void 0 ? _ref6 : (_defaultOptions$local3 = defaultOptions.locale) === null || _defaultOptions$local3 === void 0 ? void 0 : (_defaultOptions$local4 = _defaultOptions$local3.options) === null || _defaultOptions$local4 === void 0 ? void 0 : _defaultOptions$local4.weekStartsOn) !== null && _ref5 !== void 0 ? _ref5 : 0);\n\n  // Test if weekStartsOn is between 0 and 6 _and_ is not NaN\n  if (!(weekStartsOn >= 0 && weekStartsOn <= 6)) {\n    throw new RangeError('weekStartsOn must be between 0 and 6 inclusively');\n  }\n  if (!locale.localize) {\n    throw new RangeError('locale must contain localize property');\n  }\n  if (!locale.formatLong) {\n    throw new RangeError('locale must contain formatLong property');\n  }\n  var originalDate = toDate(dirtyDate);\n  if (!isValid(originalDate)) {\n    throw new RangeError('Invalid time value');\n  }\n\n  // Convert the date in system timezone to the same date in UTC+00:00 timezone.\n  // This ensures that when UTC functions will be implemented, locales will be compatible with them.\n  // See an issue about UTC functions: https://github.com/date-fns/date-fns/issues/376\n  var timezoneOffset = getTimezoneOffsetInMilliseconds(originalDate);\n  var utcDate = subMilliseconds(originalDate, timezoneOffset);\n  var formatterOptions = {\n    firstWeekContainsDate: firstWeekContainsDate,\n    weekStartsOn: weekStartsOn,\n    locale: locale,\n    _originalDate: originalDate\n  };\n  var result = formatStr.match(longFormattingTokensRegExp).map(function (substring) {\n    var firstCharacter = substring[0];\n    if (firstCharacter === 'p' || firstCharacter === 'P') {\n      var longFormatter = longFormatters[firstCharacter];\n      return longFormatter(substring, locale.formatLong);\n    }\n    return substring;\n  }).join('').match(formattingTokensRegExp).map(function (substring) {\n    // Replace two single quote characters with one single quote character\n    if (substring === \"''\") {\n      return \"'\";\n    }\n    var firstCharacter = substring[0];\n    if (firstCharacter === \"'\") {\n      return cleanEscapedString(substring);\n    }\n    var formatter = formatters[firstCharacter];\n    if (formatter) {\n      if (!(options !== null && options !== void 0 && options.useAdditionalWeekYearTokens) && isProtectedWeekYearToken(substring)) {\n        throwProtectedError(substring, dirtyFormatStr, String(dirtyDate));\n      }\n      if (!(options !== null && options !== void 0 && options.useAdditionalDayOfYearTokens) && isProtectedDayOfYearToken(substring)) {\n        throwProtectedError(substring, dirtyFormatStr, String(dirtyDate));\n      }\n      return formatter(utcDate, substring, locale.localize, formatterOptions);\n    }\n    if (firstCharacter.match(unescapedLatinCharacterRegExp)) {\n      throw new RangeError('Format string contains an unescaped latin alphabet character `' + firstCharacter + '`');\n    }\n    return substring;\n  }).join('');\n  return result;\n}\nfunction cleanEscapedString(input) {\n  var matched = input.match(escapedStringRegExp);\n  if (!matched) {\n    return input;\n  }\n  return matched[1].replace(doubleQuoteRegExp, \"'\");\n}","/**\n * Google Chrome as of 67.0.3396.87 introduced timezones with offset that includes seconds.\n * They usually appear for dates that denote time before the timezones were introduced\n * (e.g. for 'Europe/Prague' timezone the offset is GMT+00:57:44 before 1 October 1891\n * and GMT+01:00:00 after that date)\n *\n * Date#getTimezoneOffset returns the offset in minutes and would return 57 for the example above,\n * which would lead to incorrect calculations.\n *\n * This function returns the timezone offset in milliseconds that takes seconds in account.\n */\nexport default function getTimezoneOffsetInMilliseconds(date) {\n  var utcDate = new Date(Date.UTC(date.getFullYear(), date.getMonth(), date.getDate(), date.getHours(), date.getMinutes(), date.getSeconds(), date.getMilliseconds()));\n  utcDate.setUTCFullYear(date.getFullYear());\n  return date.getTime() - utcDate.getTime();\n}","import { millisecondsInHour, millisecondsInMinute } from \"../constants/index.js\";\nimport requiredArgs from \"../_lib/requiredArgs/index.js\";\nimport toInteger from \"../_lib/toInteger/index.js\";\n/**\n * @name parseISO\n * @category Common Helpers\n * @summary Parse ISO string\n *\n * @description\n * Parse the given string in ISO 8601 format and return an instance of Date.\n *\n * Function accepts complete ISO 8601 formats as well as partial implementations.\n * ISO 8601: http://en.wikipedia.org/wiki/ISO_8601\n *\n * If the argument isn't a string, the function cannot parse the string or\n * the values are invalid, it returns Invalid Date.\n *\n * @param {String} argument - the value to convert\n * @param {Object} [options] - an object with options.\n * @param {0|1|2} [options.additionalDigits=2] - the additional number of digits in the extended year format\n * @returns {Date} the parsed date in the local time zone\n * @throws {TypeError} 1 argument required\n * @throws {RangeError} `options.additionalDigits` must be 0, 1 or 2\n *\n * @example\n * // Convert string '2014-02-11T11:30:30' to date:\n * const result = parseISO('2014-02-11T11:30:30')\n * //=> Tue Feb 11 2014 11:30:30\n *\n * @example\n * // Convert string '+02014101' to date,\n * // if the additional number of digits in the extended year format is 1:\n * const result = parseISO('+02014101', { additionalDigits: 1 })\n * //=> Fri Apr 11 2014 00:00:00\n */\nexport default function parseISO(argument, options) {\n  var _options$additionalDi;\n  requiredArgs(1, arguments);\n  var additionalDigits = toInteger((_options$additionalDi = options === null || options === void 0 ? void 0 : options.additionalDigits) !== null && _options$additionalDi !== void 0 ? _options$additionalDi : 2);\n  if (additionalDigits !== 2 && additionalDigits !== 1 && additionalDigits !== 0) {\n    throw new RangeError('additionalDigits must be 0, 1 or 2');\n  }\n  if (!(typeof argument === 'string' || Object.prototype.toString.call(argument) === '[object String]')) {\n    return new Date(NaN);\n  }\n  var dateStrings = splitDateString(argument);\n  var date;\n  if (dateStrings.date) {\n    var parseYearResult = parseYear(dateStrings.date, additionalDigits);\n    date = parseDate(parseYearResult.restDateString, parseYearResult.year);\n  }\n  if (!date || isNaN(date.getTime())) {\n    return new Date(NaN);\n  }\n  var timestamp = date.getTime();\n  var time = 0;\n  var offset;\n  if (dateStrings.time) {\n    time = parseTime(dateStrings.time);\n    if (isNaN(time)) {\n      return new Date(NaN);\n    }\n  }\n  if (dateStrings.timezone) {\n    offset = parseTimezone(dateStrings.timezone);\n    if (isNaN(offset)) {\n      return new Date(NaN);\n    }\n  } else {\n    var dirtyDate = new Date(timestamp + time);\n    // js parsed string assuming it's in UTC timezone\n    // but we need it to be parsed in our timezone\n    // so we use utc values to build date in our timezone.\n    // Year values from 0 to 99 map to the years 1900 to 1999\n    // so set year explicitly with setFullYear.\n    var result = new Date(0);\n    result.setFullYear(dirtyDate.getUTCFullYear(), dirtyDate.getUTCMonth(), dirtyDate.getUTCDate());\n    result.setHours(dirtyDate.getUTCHours(), dirtyDate.getUTCMinutes(), dirtyDate.getUTCSeconds(), dirtyDate.getUTCMilliseconds());\n    return result;\n  }\n  return new Date(timestamp + time + offset);\n}\nvar patterns = {\n  dateTimeDelimiter: /[T ]/,\n  timeZoneDelimiter: /[Z ]/i,\n  timezone: /([Z+-].*)$/\n};\nvar dateRegex = /^-?(?:(\\d{3})|(\\d{2})(?:-?(\\d{2}))?|W(\\d{2})(?:-?(\\d{1}))?|)$/;\nvar timeRegex = /^(\\d{2}(?:[.,]\\d*)?)(?::?(\\d{2}(?:[.,]\\d*)?))?(?::?(\\d{2}(?:[.,]\\d*)?))?$/;\nvar timezoneRegex = /^([+-])(\\d{2})(?::?(\\d{2}))?$/;\nfunction splitDateString(dateString) {\n  var dateStrings = {};\n  var array = dateString.split(patterns.dateTimeDelimiter);\n  var timeString;\n\n  // The regex match should only return at maximum two array elements.\n  // [date], [time], or [date, time].\n  if (array.length > 2) {\n    return dateStrings;\n  }\n  if (/:/.test(array[0])) {\n    timeString = array[0];\n  } else {\n    dateStrings.date = array[0];\n    timeString = array[1];\n    if (patterns.timeZoneDelimiter.test(dateStrings.date)) {\n      dateStrings.date = dateString.split(patterns.timeZoneDelimiter)[0];\n      timeString = dateString.substr(dateStrings.date.length, dateString.length);\n    }\n  }\n  if (timeString) {\n    var token = patterns.timezone.exec(timeString);\n    if (token) {\n      dateStrings.time = timeString.replace(token[1], '');\n      dateStrings.timezone = token[1];\n    } else {\n      dateStrings.time = timeString;\n    }\n  }\n  return dateStrings;\n}\nfunction parseYear(dateString, additionalDigits) {\n  var regex = new RegExp('^(?:(\\\\d{4}|[+-]\\\\d{' + (4 + additionalDigits) + '})|(\\\\d{2}|[+-]\\\\d{' + (2 + additionalDigits) + '})$)');\n  var captures = dateString.match(regex);\n  // Invalid ISO-formatted year\n  if (!captures) return {\n    year: NaN,\n    restDateString: ''\n  };\n  var year = captures[1] ? parseInt(captures[1]) : null;\n  var century = captures[2] ? parseInt(captures[2]) : null;\n\n  // either year or century is null, not both\n  return {\n    year: century === null ? year : century * 100,\n    restDateString: dateString.slice((captures[1] || captures[2]).length)\n  };\n}\nfunction parseDate(dateString, year) {\n  // Invalid ISO-formatted year\n  if (year === null) return new Date(NaN);\n  var captures = dateString.match(dateRegex);\n  // Invalid ISO-formatted string\n  if (!captures) return new Date(NaN);\n  var isWeekDate = !!captures[4];\n  var dayOfYear = parseDateUnit(captures[1]);\n  var month = parseDateUnit(captures[2]) - 1;\n  var day = parseDateUnit(captures[3]);\n  var week = parseDateUnit(captures[4]);\n  var dayOfWeek = parseDateUnit(captures[5]) - 1;\n  if (isWeekDate) {\n    if (!validateWeekDate(year, week, dayOfWeek)) {\n      return new Date(NaN);\n    }\n    return dayOfISOWeekYear(year, week, dayOfWeek);\n  } else {\n    var date = new Date(0);\n    if (!validateDate(year, month, day) || !validateDayOfYearDate(year, dayOfYear)) {\n      return new Date(NaN);\n    }\n    date.setUTCFullYear(year, month, Math.max(dayOfYear, day));\n    return date;\n  }\n}\nfunction parseDateUnit(value) {\n  return value ? parseInt(value) : 1;\n}\nfunction parseTime(timeString) {\n  var captures = timeString.match(timeRegex);\n  if (!captures) return NaN; // Invalid ISO-formatted time\n\n  var hours = parseTimeUnit(captures[1]);\n  var minutes = parseTimeUnit(captures[2]);\n  var seconds = parseTimeUnit(captures[3]);\n  if (!validateTime(hours, minutes, seconds)) {\n    return NaN;\n  }\n  return hours * millisecondsInHour + minutes * millisecondsInMinute + seconds * 1000;\n}\nfunction parseTimeUnit(value) {\n  return value && parseFloat(value.replace(',', '.')) || 0;\n}\nfunction parseTimezone(timezoneString) {\n  if (timezoneString === 'Z') return 0;\n  var captures = timezoneString.match(timezoneRegex);\n  if (!captures) return 0;\n  var sign = captures[1] === '+' ? -1 : 1;\n  var hours = parseInt(captures[2]);\n  var minutes = captures[3] && parseInt(captures[3]) || 0;\n  if (!validateTimezone(hours, minutes)) {\n    return NaN;\n  }\n  return sign * (hours * millisecondsInHour + minutes * millisecondsInMinute);\n}\nfunction dayOfISOWeekYear(isoWeekYear, week, day) {\n  var date = new Date(0);\n  date.setUTCFullYear(isoWeekYear, 0, 4);\n  var fourthOfJanuaryDay = date.getUTCDay() || 7;\n  var diff = (week - 1) * 7 + day + 1 - fourthOfJanuaryDay;\n  date.setUTCDate(date.getUTCDate() + diff);\n  return date;\n}\n\n// Validation functions\n\n// February is null to handle the leap year (using ||)\nvar daysInMonths = [31, null, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\nfunction isLeapYearIndex(year) {\n  return year % 400 === 0 || year % 4 === 0 && year % 100 !== 0;\n}\nfunction validateDate(year, month, date) {\n  return month >= 0 && month <= 11 && date >= 1 && date <= (daysInMonths[month] || (isLeapYearIndex(year) ? 29 : 28));\n}\nfunction validateDayOfYearDate(year, dayOfYear) {\n  return dayOfYear >= 1 && dayOfYear <= (isLeapYearIndex(year) ? 366 : 365);\n}\nfunction validateWeekDate(_year, week, day) {\n  return week >= 1 && week <= 53 && day >= 0 && day <= 6;\n}\nfunction validateTime(hours, minutes, seconds) {\n  if (hours === 24) {\n    return minutes === 0 && seconds === 0;\n  }\n  return seconds >= 0 && seconds < 60 && minutes >= 0 && minutes < 60 && hours >= 0 && hours < 25;\n}\nfunction validateTimezone(_hours, minutes) {\n  return minutes >= 0 && minutes <= 59;\n}","/**\n * Days in 1 week.\n *\n * @name daysInWeek\n * @constant\n * @type {number}\n * @default\n */\nexport var daysInWeek = 7;\n\n/**\n * Days in 1 year\n * One years equals 365.2425 days according to the formula:\n *\n * > Leap year occures every 4 years, except for years that are divisable by 100 and not divisable by 400.\n * > 1 mean year = (365+1/4-1/100+1/400) days = 365.2425 days\n *\n * @name daysInYear\n * @constant\n * @type {number}\n * @default\n */\nexport var daysInYear = 365.2425;\n\n/**\n * Maximum allowed time.\n *\n * @name maxTime\n * @constant\n * @type {number}\n * @default\n */\nexport var maxTime = Math.pow(10, 8) * 24 * 60 * 60 * 1000;\n\n/**\n * Milliseconds in 1 minute\n *\n * @name millisecondsInMinute\n * @constant\n * @type {number}\n * @default\n */\nexport var millisecondsInMinute = 60000;\n\n/**\n * Milliseconds in 1 hour\n *\n * @name millisecondsInHour\n * @constant\n * @type {number}\n * @default\n */\nexport var millisecondsInHour = 3600000;\n\n/**\n * Milliseconds in 1 second\n *\n * @name millisecondsInSecond\n * @constant\n * @type {number}\n * @default\n */\nexport var millisecondsInSecond = 1000;\n\n/**\n * Minimum allowed time.\n *\n * @name minTime\n * @constant\n * @type {number}\n * @default\n */\nexport var minTime = -maxTime;\n\n/**\n * Minutes in 1 hour\n *\n * @name minutesInHour\n * @constant\n * @type {number}\n * @default\n */\nexport var minutesInHour = 60;\n\n/**\n * Months in 1 quarter\n *\n * @name monthsInQuarter\n * @constant\n * @type {number}\n * @default\n */\nexport var monthsInQuarter = 3;\n\n/**\n * Months in 1 year\n *\n * @name monthsInYear\n * @constant\n * @type {number}\n * @default\n */\nexport var monthsInYear = 12;\n\n/**\n * Quarters in 1 year\n *\n * @name quartersInYear\n * @constant\n * @type {number}\n * @default\n */\nexport var quartersInYear = 4;\n\n/**\n * Seconds in 1 hour\n *\n * @name secondsInHour\n * @constant\n * @type {number}\n * @default\n */\nexport var secondsInHour = 3600;\n\n/**\n * Seconds in 1 minute\n *\n * @name secondsInMinute\n * @constant\n * @type {number}\n * @default\n */\nexport var secondsInMinute = 60;\n\n/**\n * Seconds in 1 day\n *\n * @name secondsInDay\n * @constant\n * @type {number}\n * @default\n */\nexport var secondsInDay = secondsInHour * 24;\n\n/**\n * Seconds in 1 week\n *\n * @name secondsInWeek\n * @constant\n * @type {number}\n * @default\n */\nexport var secondsInWeek = secondsInDay * 7;\n\n/**\n * Seconds in 1 year\n *\n * @name secondsInYear\n * @constant\n * @type {number}\n * @default\n */\nexport var secondsInYear = secondsInDay * daysInYear;\n\n/**\n * Seconds in 1 month\n *\n * @name secondsInMonth\n * @constant\n * @type {number}\n * @default\n */\nexport var secondsInMonth = secondsInYear / 12;\n\n/**\n * Seconds in 1 quarter\n *\n * @name secondsInQuarter\n * @constant\n * @type {number}\n * @default\n */\nexport var secondsInQuarter = secondsInMonth * 3;","import Utility from '@Core/utils/Utility';\nimport { SaveFilesImpl } from '@Interfaces';\nimport Environment from '@Modules/environment/Environment.js';\nimport { GenericObject } from '@Types';\nimport { AxiosResponse } from 'axios';\nimport { format } from 'date-fns';\n\n/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nclass SaveFiles implements SaveFilesImpl{\n    utility: Utility;\n    environment: Environment;\n    constructor(environment: Environment, utility: Utility) {\n        this.environment = environment;\n        this.utility = utility;\n    }\n\n    public salvaArquivos(xmlConsulta: string, responseInJson: GenericObject | undefined, xmlRetorno: AxiosResponse<any, any>, metodo: string, xmlFormated?: string, options?: Record<string, any>): void {\n        // Recupera configuração do ambiente para verificar se os arquivos gerados serão gravados em disco\n        const config = this.environment.getConfig();\n        let dateAndTimeInFileName = config.dfe.incluirTimestampNoNomeDosArquivos;\n        const { armazenarXMLConsultaComTagSoap } = this.environment.config.dfe\n        const xmlConsultaASalvar = armazenarXMLConsultaComTagSoap ? xmlFormated : xmlConsulta;\n\n        const createFileName = (prefix: string | undefined) => {\n            const dtaTime = dateAndTimeInFileName ? `-${format(new Date(), 'dd-MM-yyyy-HHmm')}` : '';\n\n            const baseFileName = `${metodo}`;\n            const prefixPart = prefix ? `-${prefix}` : '';\n            const nfePart = responseInJson && responseInJson.chNFe ? `-${responseInJson.chNFe}` : '';\n            const dateTimePart = dtaTime;\n\n            return `${baseFileName}${prefixPart}${nfePart}${dateTimePart}`;\n        }\n\n        const salvarArquivo = (data: any, prefix: string | undefined, path: string | undefined, fileType: 'xml' | 'json') => {\n            const fileName = createFileName(prefix);\n            const method = fileType === 'xml' ? 'salvaXML' : 'salvaJSON';\n\n            this.utility[method]({\n                data: data || '',\n                fileName,\n                metodo: metodo,\n                path,\n            });\n        };\n\n        if (config.dfe.armazenarXMLConsulta) {\n            salvarArquivo(xmlConsultaASalvar, 'consulta', config.dfe.pathXMLConsulta, 'xml');\n        }\n        if (config.dfe.armazenarXMLRetorno) {\n            salvarArquivo(xmlRetorno.data, 'retorno', config.dfe.pathXMLRetorno, 'xml');\n        }\n        if (config.dfe.armazenarRetornoEmJSON) {\n            salvarArquivo(responseInJson, undefined, config.dfe.pathRetornoEmJSON, 'json');\n        }\n    }\n}\n\nexport default SaveFiles;","'use strict';\n\nexport default function bind(fn, thisArg) {\n  return function wrap() {\n    return fn.apply(thisArg, arguments);\n  };\n}\n","'use strict';\n\nimport bind from './helpers/bind.js';\n\n// utils is a library of generic helper functions non-specific to axios\n\nconst {toString} = Object.prototype;\nconst {getPrototypeOf} = Object;\n\nconst kindOf = (cache => thing => {\n    const str = toString.call(thing);\n    return cache[str] || (cache[str] = str.slice(8, -1).toLowerCase());\n})(Object.create(null));\n\nconst kindOfTest = (type) => {\n  type = type.toLowerCase();\n  return (thing) => kindOf(thing) === type\n}\n\nconst typeOfTest = type => thing => typeof thing === type;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n *\n * @returns {boolean} True if value is an Array, otherwise false\n */\nconst {isArray} = Array;\n\n/**\n * Determine if a value is undefined\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nconst isUndefined = typeOfTest('undefined');\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n  return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)\n    && isFunction(val.constructor.isBuffer) && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nconst isArrayBuffer = kindOfTest('ArrayBuffer');\n\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n  let result;\n  if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {\n    result = ArrayBuffer.isView(val);\n  } else {\n    result = (val) && (val.buffer) && (isArrayBuffer(val.buffer));\n  }\n  return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a String, otherwise false\n */\nconst isString = typeOfTest('string');\n\n/**\n * Determine if a value is a Function\n *\n * @param {*} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nconst isFunction = typeOfTest('function');\n\n/**\n * Determine if a value is a Number\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Number, otherwise false\n */\nconst isNumber = typeOfTest('number');\n\n/**\n * Determine if a value is an Object\n *\n * @param {*} thing The value to test\n *\n * @returns {boolean} True if value is an Object, otherwise false\n */\nconst isObject = (thing) => thing !== null && typeof thing === 'object';\n\n/**\n * Determine if a value is a Boolean\n *\n * @param {*} thing The value to test\n * @returns {boolean} True if value is a Boolean, otherwise false\n */\nconst isBoolean = thing => thing === true || thing === false;\n\n/**\n * Determine if a value is a plain Object\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a plain Object, otherwise false\n */\nconst isPlainObject = (val) => {\n  if (kindOf(val) !== 'object') {\n    return false;\n  }\n\n  const prototype = getPrototypeOf(val);\n  return (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in val) && !(Symbol.iterator in val);\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Date, otherwise false\n */\nconst isDate = kindOfTest('Date');\n\n/**\n * Determine if a value is a File\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a File, otherwise false\n */\nconst isFile = kindOfTest('File');\n\n/**\n * Determine if a value is a Blob\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nconst isBlob = kindOfTest('Blob');\n\n/**\n * Determine if a value is a FileList\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a File, otherwise false\n */\nconst isFileList = kindOfTest('FileList');\n\n/**\n * Determine if a value is a Stream\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nconst isStream = (val) => isObject(val) && isFunction(val.pipe);\n\n/**\n * Determine if a value is a FormData\n *\n * @param {*} thing The value to test\n *\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nconst isFormData = (thing) => {\n  let kind;\n  return thing && (\n    (typeof FormData === 'function' && thing instanceof FormData) || (\n      isFunction(thing.append) && (\n        (kind = kindOf(thing)) === 'formdata' ||\n        // detect form-data instance\n        (kind === 'object' && isFunction(thing.toString) && thing.toString() === '[object FormData]')\n      )\n    )\n  )\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nconst isURLSearchParams = kindOfTest('URLSearchParams');\n\nconst [isReadableStream, isRequest, isResponse, isHeaders] = ['ReadableStream', 'Request', 'Response', 'Headers'].map(kindOfTest);\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n *\n * @returns {String} The String freed of excess whitespace\n */\nconst trim = (str) => str.trim ?\n  str.trim() : str.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '');\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n *\n * @param {Boolean} [allOwnKeys = false]\n * @returns {any}\n */\nfunction forEach(obj, fn, {allOwnKeys = false} = {}) {\n  // Don't bother if no value provided\n  if (obj === null || typeof obj === 'undefined') {\n    return;\n  }\n\n  let i;\n  let l;\n\n  // Force an array if not already something iterable\n  if (typeof obj !== 'object') {\n    /*eslint no-param-reassign:0*/\n    obj = [obj];\n  }\n\n  if (isArray(obj)) {\n    // Iterate over array values\n    for (i = 0, l = obj.length; i < l; i++) {\n      fn.call(null, obj[i], i, obj);\n    }\n  } else {\n    // Iterate over object keys\n    const keys = allOwnKeys ? Object.getOwnPropertyNames(obj) : Object.keys(obj);\n    const len = keys.length;\n    let key;\n\n    for (i = 0; i < len; i++) {\n      key = keys[i];\n      fn.call(null, obj[key], key, obj);\n    }\n  }\n}\n\nfunction findKey(obj, key) {\n  key = key.toLowerCase();\n  const keys = Object.keys(obj);\n  let i = keys.length;\n  let _key;\n  while (i-- > 0) {\n    _key = keys[i];\n    if (key === _key.toLowerCase()) {\n      return _key;\n    }\n  }\n  return null;\n}\n\nconst _global = (() => {\n  /*eslint no-undef:0*/\n  if (typeof globalThis !== \"undefined\") return globalThis;\n  return typeof self !== \"undefined\" ? self : (typeof window !== 'undefined' ? window : global)\n})();\n\nconst isContextDefined = (context) => !isUndefined(context) && context !== _global;\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n *\n * @returns {Object} Result of all merge properties\n */\nfunction merge(/* obj1, obj2, obj3, ... */) {\n  const {caseless} = isContextDefined(this) && this || {};\n  const result = {};\n  const assignValue = (val, key) => {\n    const targetKey = caseless && findKey(result, key) || key;\n    if (isPlainObject(result[targetKey]) && isPlainObject(val)) {\n      result[targetKey] = merge(result[targetKey], val);\n    } else if (isPlainObject(val)) {\n      result[targetKey] = merge({}, val);\n    } else if (isArray(val)) {\n      result[targetKey] = val.slice();\n    } else {\n      result[targetKey] = val;\n    }\n  }\n\n  for (let i = 0, l = arguments.length; i < l; i++) {\n    arguments[i] && forEach(arguments[i], assignValue);\n  }\n  return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n *\n * @param {Boolean} [allOwnKeys]\n * @returns {Object} The resulting value of object a\n */\nconst extend = (a, b, thisArg, {allOwnKeys}= {}) => {\n  forEach(b, (val, key) => {\n    if (thisArg && isFunction(val)) {\n      a[key] = bind(val, thisArg);\n    } else {\n      a[key] = val;\n    }\n  }, {allOwnKeys});\n  return a;\n}\n\n/**\n * Remove byte order marker. This catches EF BB BF (the UTF-8 BOM)\n *\n * @param {string} content with BOM\n *\n * @returns {string} content value without BOM\n */\nconst stripBOM = (content) => {\n  if (content.charCodeAt(0) === 0xFEFF) {\n    content = content.slice(1);\n  }\n  return content;\n}\n\n/**\n * Inherit the prototype methods from one constructor into another\n * @param {function} constructor\n * @param {function} superConstructor\n * @param {object} [props]\n * @param {object} [descriptors]\n *\n * @returns {void}\n */\nconst inherits = (constructor, superConstructor, props, descriptors) => {\n  constructor.prototype = Object.create(superConstructor.prototype, descriptors);\n  constructor.prototype.constructor = constructor;\n  Object.defineProperty(constructor, 'super', {\n    value: superConstructor.prototype\n  });\n  props && Object.assign(constructor.prototype, props);\n}\n\n/**\n * Resolve object with deep prototype chain to a flat object\n * @param {Object} sourceObj source object\n * @param {Object} [destObj]\n * @param {Function|Boolean} [filter]\n * @param {Function} [propFilter]\n *\n * @returns {Object}\n */\nconst toFlatObject = (sourceObj, destObj, filter, propFilter) => {\n  let props;\n  let i;\n  let prop;\n  const merged = {};\n\n  destObj = destObj || {};\n  // eslint-disable-next-line no-eq-null,eqeqeq\n  if (sourceObj == null) return destObj;\n\n  do {\n    props = Object.getOwnPropertyNames(sourceObj);\n    i = props.length;\n    while (i-- > 0) {\n      prop = props[i];\n      if ((!propFilter || propFilter(prop, sourceObj, destObj)) && !merged[prop]) {\n        destObj[prop] = sourceObj[prop];\n        merged[prop] = true;\n      }\n    }\n    sourceObj = filter !== false && getPrototypeOf(sourceObj);\n  } while (sourceObj && (!filter || filter(sourceObj, destObj)) && sourceObj !== Object.prototype);\n\n  return destObj;\n}\n\n/**\n * Determines whether a string ends with the characters of a specified string\n *\n * @param {String} str\n * @param {String} searchString\n * @param {Number} [position= 0]\n *\n * @returns {boolean}\n */\nconst endsWith = (str, searchString, position) => {\n  str = String(str);\n  if (position === undefined || position > str.length) {\n    position = str.length;\n  }\n  position -= searchString.length;\n  const lastIndex = str.indexOf(searchString, position);\n  return lastIndex !== -1 && lastIndex === position;\n}\n\n\n/**\n * Returns new array from array like object or null if failed\n *\n * @param {*} [thing]\n *\n * @returns {?Array}\n */\nconst toArray = (thing) => {\n  if (!thing) return null;\n  if (isArray(thing)) return thing;\n  let i = thing.length;\n  if (!isNumber(i)) return null;\n  const arr = new Array(i);\n  while (i-- > 0) {\n    arr[i] = thing[i];\n  }\n  return arr;\n}\n\n/**\n * Checking if the Uint8Array exists and if it does, it returns a function that checks if the\n * thing passed in is an instance of Uint8Array\n *\n * @param {TypedArray}\n *\n * @returns {Array}\n */\n// eslint-disable-next-line func-names\nconst isTypedArray = (TypedArray => {\n  // eslint-disable-next-line func-names\n  return thing => {\n    return TypedArray && thing instanceof TypedArray;\n  };\n})(typeof Uint8Array !== 'undefined' && getPrototypeOf(Uint8Array));\n\n/**\n * For each entry in the object, call the function with the key and value.\n *\n * @param {Object<any, any>} obj - The object to iterate over.\n * @param {Function} fn - The function to call for each entry.\n *\n * @returns {void}\n */\nconst forEachEntry = (obj, fn) => {\n  const generator = obj && obj[Symbol.iterator];\n\n  const iterator = generator.call(obj);\n\n  let result;\n\n  while ((result = iterator.next()) && !result.done) {\n    const pair = result.value;\n    fn.call(obj, pair[0], pair[1]);\n  }\n}\n\n/**\n * It takes a regular expression and a string, and returns an array of all the matches\n *\n * @param {string} regExp - The regular expression to match against.\n * @param {string} str - The string to search.\n *\n * @returns {Array<boolean>}\n */\nconst matchAll = (regExp, str) => {\n  let matches;\n  const arr = [];\n\n  while ((matches = regExp.exec(str)) !== null) {\n    arr.push(matches);\n  }\n\n  return arr;\n}\n\n/* Checking if the kindOfTest function returns true when passed an HTMLFormElement. */\nconst isHTMLForm = kindOfTest('HTMLFormElement');\n\nconst toCamelCase = str => {\n  return str.toLowerCase().replace(/[-_\\s]([a-z\\d])(\\w*)/g,\n    function replacer(m, p1, p2) {\n      return p1.toUpperCase() + p2;\n    }\n  );\n};\n\n/* Creating a function that will check if an object has a property. */\nconst hasOwnProperty = (({hasOwnProperty}) => (obj, prop) => hasOwnProperty.call(obj, prop))(Object.prototype);\n\n/**\n * Determine if a value is a RegExp object\n *\n * @param {*} val The value to test\n *\n * @returns {boolean} True if value is a RegExp object, otherwise false\n */\nconst isRegExp = kindOfTest('RegExp');\n\nconst reduceDescriptors = (obj, reducer) => {\n  const descriptors = Object.getOwnPropertyDescriptors(obj);\n  const reducedDescriptors = {};\n\n  forEach(descriptors, (descriptor, name) => {\n    let ret;\n    if ((ret = reducer(descriptor, name, obj)) !== false) {\n      reducedDescriptors[name] = ret || descriptor;\n    }\n  });\n\n  Object.defineProperties(obj, reducedDescriptors);\n}\n\n/**\n * Makes all methods read-only\n * @param {Object} obj\n */\n\nconst freezeMethods = (obj) => {\n  reduceDescriptors(obj, (descriptor, name) => {\n    // skip restricted props in strict mode\n    if (isFunction(obj) && ['arguments', 'caller', 'callee'].indexOf(name) !== -1) {\n      return false;\n    }\n\n    const value = obj[name];\n\n    if (!isFunction(value)) return;\n\n    descriptor.enumerable = false;\n\n    if ('writable' in descriptor) {\n      descriptor.writable = false;\n      return;\n    }\n\n    if (!descriptor.set) {\n      descriptor.set = () => {\n        throw Error('Can not rewrite read-only method \\'' + name + '\\'');\n      };\n    }\n  });\n}\n\nconst toObjectSet = (arrayOrString, delimiter) => {\n  const obj = {};\n\n  const define = (arr) => {\n    arr.forEach(value => {\n      obj[value] = true;\n    });\n  }\n\n  isArray(arrayOrString) ? define(arrayOrString) : define(String(arrayOrString).split(delimiter));\n\n  return obj;\n}\n\nconst noop = () => {}\n\nconst toFiniteNumber = (value, defaultValue) => {\n  return value != null && Number.isFinite(value = +value) ? value : defaultValue;\n}\n\n/**\n * If the thing is a FormData object, return true, otherwise return false.\n *\n * @param {unknown} thing - The thing to check.\n *\n * @returns {boolean}\n */\nfunction isSpecCompliantForm(thing) {\n  return !!(thing && isFunction(thing.append) && thing[Symbol.toStringTag] === 'FormData' && thing[Symbol.iterator]);\n}\n\nconst toJSONObject = (obj) => {\n  const stack = new Array(10);\n\n  const visit = (source, i) => {\n\n    if (isObject(source)) {\n      if (stack.indexOf(source) >= 0) {\n        return;\n      }\n\n      if(!('toJSON' in source)) {\n        stack[i] = source;\n        const target = isArray(source) ? [] : {};\n\n        forEach(source, (value, key) => {\n          const reducedValue = visit(value, i + 1);\n          !isUndefined(reducedValue) && (target[key] = reducedValue);\n        });\n\n        stack[i] = undefined;\n\n        return target;\n      }\n    }\n\n    return source;\n  }\n\n  return visit(obj, 0);\n}\n\nconst isAsyncFn = kindOfTest('AsyncFunction');\n\nconst isThenable = (thing) =>\n  thing && (isObject(thing) || isFunction(thing)) && isFunction(thing.then) && isFunction(thing.catch);\n\n// original code\n// https://github.com/DigitalBrainJS/AxiosPromise/blob/16deab13710ec09779922131f3fa5954320f83ab/lib/utils.js#L11-L34\n\nconst _setImmediate = ((setImmediateSupported, postMessageSupported) => {\n  if (setImmediateSupported) {\n    return setImmediate;\n  }\n\n  return postMessageSupported ? ((token, callbacks) => {\n    _global.addEventListener(\"message\", ({source, data}) => {\n      if (source === _global && data === token) {\n        callbacks.length && callbacks.shift()();\n      }\n    }, false);\n\n    return (cb) => {\n      callbacks.push(cb);\n      _global.postMessage(token, \"*\");\n    }\n  })(`axios@${Math.random()}`, []) : (cb) => setTimeout(cb);\n})(\n  typeof setImmediate === 'function',\n  isFunction(_global.postMessage)\n);\n\nconst asap = typeof queueMicrotask !== 'undefined' ?\n  queueMicrotask.bind(_global) : ( typeof process !== 'undefined' && process.nextTick || _setImmediate);\n\n// *********************\n\nexport default {\n  isArray,\n  isArrayBuffer,\n  isBuffer,\n  isFormData,\n  isArrayBufferView,\n  isString,\n  isNumber,\n  isBoolean,\n  isObject,\n  isPlainObject,\n  isReadableStream,\n  isRequest,\n  isResponse,\n  isHeaders,\n  isUndefined,\n  isDate,\n  isFile,\n  isBlob,\n  isRegExp,\n  isFunction,\n  isStream,\n  isURLSearchParams,\n  isTypedArray,\n  isFileList,\n  forEach,\n  merge,\n  extend,\n  trim,\n  stripBOM,\n  inherits,\n  toFlatObject,\n  kindOf,\n  kindOfTest,\n  endsWith,\n  toArray,\n  forEachEntry,\n  matchAll,\n  isHTMLForm,\n  hasOwnProperty,\n  hasOwnProp: hasOwnProperty, // an alias to avoid ESLint no-prototype-builtins detection\n  reduceDescriptors,\n  freezeMethods,\n  toObjectSet,\n  toCamelCase,\n  noop,\n  toFiniteNumber,\n  findKey,\n  global: _global,\n  isContextDefined,\n  isSpecCompliantForm,\n  toJSONObject,\n  isAsyncFn,\n  isThenable,\n  setImmediate: _setImmediate,\n  asap\n};\n","'use strict';\n\nimport utils from '../utils.js';\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [config] The config.\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n *\n * @returns {Error} The created error.\n */\nfunction AxiosError(message, code, config, request, response) {\n  Error.call(this);\n\n  if (Error.captureStackTrace) {\n    Error.captureStackTrace(this, this.constructor);\n  } else {\n    this.stack = (new Error()).stack;\n  }\n\n  this.message = message;\n  this.name = 'AxiosError';\n  code && (this.code = code);\n  config && (this.config = config);\n  request && (this.request = request);\n  if (response) {\n    this.response = response;\n    this.status = response.status ? response.status : null;\n  }\n}\n\nutils.inherits(AxiosError, Error, {\n  toJSON: function toJSON() {\n    return {\n      // Standard\n      message: this.message,\n      name: this.name,\n      // Microsoft\n      description: this.description,\n      number: this.number,\n      // Mozilla\n      fileName: this.fileName,\n      lineNumber: this.lineNumber,\n      columnNumber: this.columnNumber,\n      stack: this.stack,\n      // Axios\n      config: utils.toJSONObject(this.config),\n      code: this.code,\n      status: this.status\n    };\n  }\n});\n\nconst prototype = AxiosError.prototype;\nconst descriptors = {};\n\n[\n  'ERR_BAD_OPTION_VALUE',\n  'ERR_BAD_OPTION',\n  'ECONNABORTED',\n  'ETIMEDOUT',\n  'ERR_NETWORK',\n  'ERR_FR_TOO_MANY_REDIRECTS',\n  'ERR_DEPRECATED',\n  'ERR_BAD_RESPONSE',\n  'ERR_BAD_REQUEST',\n  'ERR_CANCELED',\n  'ERR_NOT_SUPPORT',\n  'ERR_INVALID_URL'\n// eslint-disable-next-line func-names\n].forEach(code => {\n  descriptors[code] = {value: code};\n});\n\nObject.defineProperties(AxiosError, descriptors);\nObject.defineProperty(prototype, 'isAxiosError', {value: true});\n\n// eslint-disable-next-line func-names\nAxiosError.from = (error, code, config, request, response, customProps) => {\n  const axiosError = Object.create(prototype);\n\n  utils.toFlatObject(error, axiosError, function filter(obj) {\n    return obj !== Error.prototype;\n  }, prop => {\n    return prop !== 'isAxiosError';\n  });\n\n  AxiosError.call(axiosError, error.message, code, config, request, response);\n\n  axiosError.cause = error;\n\n  axiosError.name = error.name;\n\n  customProps && Object.assign(axiosError, customProps);\n\n  return axiosError;\n};\n\nexport default AxiosError;\n","var util = require('util');\nvar Stream = require('stream').Stream;\nvar DelayedStream = require('delayed-stream');\n\nmodule.exports = CombinedStream;\nfunction CombinedStream() {\n  this.writable = false;\n  this.readable = true;\n  this.dataSize = 0;\n  this.maxDataSize = 2 * 1024 * 1024;\n  this.pauseStreams = true;\n\n  this._released = false;\n  this._streams = [];\n  this._currentStream = null;\n  this._insideLoop = false;\n  this._pendingNext = false;\n}\nutil.inherits(CombinedStream, Stream);\n\nCombinedStream.create = function(options) {\n  var combinedStream = new this();\n\n  options = options || {};\n  for (var option in options) {\n    combinedStream[option] = options[option];\n  }\n\n  return combinedStream;\n};\n\nCombinedStream.isStreamLike = function(stream) {\n  return (typeof stream !== 'function')\n    && (typeof stream !== 'string')\n    && (typeof stream !== 'boolean')\n    && (typeof stream !== 'number')\n    && (!Buffer.isBuffer(stream));\n};\n\nCombinedStream.prototype.append = function(stream) {\n  var isStreamLike = CombinedStream.isStreamLike(stream);\n\n  if (isStreamLike) {\n    if (!(stream instanceof DelayedStream)) {\n      var newStream = DelayedStream.create(stream, {\n        maxDataSize: Infinity,\n        pauseStream: this.pauseStreams,\n      });\n      stream.on('data', this._checkDataSize.bind(this));\n      stream = newStream;\n    }\n\n    this._handleErrors(stream);\n\n    if (this.pauseStreams) {\n      stream.pause();\n    }\n  }\n\n  this._streams.push(stream);\n  return this;\n};\n\nCombinedStream.prototype.pipe = function(dest, options) {\n  Stream.prototype.pipe.call(this, dest, options);\n  this.resume();\n  return dest;\n};\n\nCombinedStream.prototype._getNext = function() {\n  this._currentStream = null;\n\n  if (this._insideLoop) {\n    this._pendingNext = true;\n    return; // defer call\n  }\n\n  this._insideLoop = true;\n  try {\n    do {\n      this._pendingNext = false;\n      this._realGetNext();\n    } while (this._pendingNext);\n  } finally {\n    this._insideLoop = false;\n  }\n};\n\nCombinedStream.prototype._realGetNext = function() {\n  var stream = this._streams.shift();\n\n\n  if (typeof stream == 'undefined') {\n    this.end();\n    return;\n  }\n\n  if (typeof stream !== 'function') {\n    this._pipeNext(stream);\n    return;\n  }\n\n  var getStream = stream;\n  getStream(function(stream) {\n    var isStreamLike = CombinedStream.isStreamLike(stream);\n    if (isStreamLike) {\n      stream.on('data', this._checkDataSize.bind(this));\n      this._handleErrors(stream);\n    }\n\n    this._pipeNext(stream);\n  }.bind(this));\n};\n\nCombinedStream.prototype._pipeNext = function(stream) {\n  this._currentStream = stream;\n\n  var isStreamLike = CombinedStream.isStreamLike(stream);\n  if (isStreamLike) {\n    stream.on('end', this._getNext.bind(this));\n    stream.pipe(this, {end: false});\n    return;\n  }\n\n  var value = stream;\n  this.write(value);\n  this._getNext();\n};\n\nCombinedStream.prototype._handleErrors = function(stream) {\n  var self = this;\n  stream.on('error', function(err) {\n    self._emitError(err);\n  });\n};\n\nCombinedStream.prototype.write = function(data) {\n  this.emit('data', data);\n};\n\nCombinedStream.prototype.pause = function() {\n  if (!this.pauseStreams) {\n    return;\n  }\n\n  if(this.pauseStreams && this._currentStream && typeof(this._currentStream.pause) == 'function') this._currentStream.pause();\n  this.emit('pause');\n};\n\nCombinedStream.prototype.resume = function() {\n  if (!this._released) {\n    this._released = true;\n    this.writable = true;\n    this._getNext();\n  }\n\n  if(this.pauseStreams && this._currentStream && typeof(this._currentStream.resume) == 'function') this._currentStream.resume();\n  this.emit('resume');\n};\n\nCombinedStream.prototype.end = function() {\n  this._reset();\n  this.emit('end');\n};\n\nCombinedStream.prototype.destroy = function() {\n  this._reset();\n  this.emit('close');\n};\n\nCombinedStream.prototype._reset = function() {\n  this.writable = false;\n  this._streams = [];\n  this._currentStream = null;\n};\n\nCombinedStream.prototype._checkDataSize = function() {\n  this._updateDataSize();\n  if (this.dataSize <= this.maxDataSize) {\n    return;\n  }\n\n  var message =\n    'DelayedStream#maxDataSize of ' + this.maxDataSize + ' bytes exceeded.';\n  this._emitError(new Error(message));\n};\n\nCombinedStream.prototype._updateDataSize = function() {\n  this.dataSize = 0;\n\n  var self = this;\n  this._streams.forEach(function(stream) {\n    if (!stream.dataSize) {\n      return;\n    }\n\n    self.dataSize += stream.dataSize;\n  });\n\n  if (this._currentStream && this._currentStream.dataSize) {\n    this.dataSize += this._currentStream.dataSize;\n  }\n};\n\nCombinedStream.prototype._emitError = function(err) {\n  this._reset();\n  this.emit('error', err);\n};\n","var Stream = require('stream').Stream;\nvar util = require('util');\n\nmodule.exports = DelayedStream;\nfunction DelayedStream() {\n  this.source = null;\n  this.dataSize = 0;\n  this.maxDataSize = 1024 * 1024;\n  this.pauseStream = true;\n\n  this._maxDataSizeExceeded = false;\n  this._released = false;\n  this._bufferedEvents = [];\n}\nutil.inherits(DelayedStream, Stream);\n\nDelayedStream.create = function(source, options) {\n  var delayedStream = new this();\n\n  options = options || {};\n  for (var option in options) {\n    delayedStream[option] = options[option];\n  }\n\n  delayedStream.source = source;\n\n  var realEmit = source.emit;\n  source.emit = function() {\n    delayedStream._handleEmit(arguments);\n    return realEmit.apply(source, arguments);\n  };\n\n  source.on('error', function() {});\n  if (delayedStream.pauseStream) {\n    source.pause();\n  }\n\n  return delayedStream;\n};\n\nObject.defineProperty(DelayedStream.prototype, 'readable', {\n  configurable: true,\n  enumerable: true,\n  get: function() {\n    return this.source.readable;\n  }\n});\n\nDelayedStream.prototype.setEncoding = function() {\n  return this.source.setEncoding.apply(this.source, arguments);\n};\n\nDelayedStream.prototype.resume = function() {\n  if (!this._released) {\n    this.release();\n  }\n\n  this.source.resume();\n};\n\nDelayedStream.prototype.pause = function() {\n  this.source.pause();\n};\n\nDelayedStream.prototype.release = function() {\n  this._released = true;\n\n  this._bufferedEvents.forEach(function(args) {\n    this.emit.apply(this, args);\n  }.bind(this));\n  this._bufferedEvents = [];\n};\n\nDelayedStream.prototype.pipe = function() {\n  var r = Stream.prototype.pipe.apply(this, arguments);\n  this.resume();\n  return r;\n};\n\nDelayedStream.prototype._handleEmit = function(args) {\n  if (this._released) {\n    this.emit.apply(this, args);\n    return;\n  }\n\n  if (args[0] === 'data') {\n    this.dataSize += args[1].length;\n    this._checkIfMaxDataSizeExceeded();\n  }\n\n  this._bufferedEvents.push(args);\n};\n\nDelayedStream.prototype._checkIfMaxDataSizeExceeded = function() {\n  if (this._maxDataSizeExceeded) {\n    return;\n  }\n\n  if (this.dataSize <= this.maxDataSize) {\n    return;\n  }\n\n  this._maxDataSizeExceeded = true;\n  var message =\n    'DelayedStream#maxDataSize of ' + this.maxDataSize + ' bytes exceeded.'\n  this.emit('error', new Error(message));\n};\n","/*!\n * mime-types\n * Copyright(c) 2014 Jonathan Ong\n * Copyright(c) 2015 Douglas Christopher Wilson\n * MIT Licensed\n */\n\n'use strict'\n\n/**\n * Module dependencies.\n * @private\n */\n\nvar db = require('mime-db')\nvar extname = require('path').extname\n\n/**\n * Module variables.\n * @private\n */\n\nvar EXTRACT_TYPE_REGEXP = /^\\s*([^;\\s]*)(?:;|\\s|$)/\nvar TEXT_TYPE_REGEXP = /^text\\//i\n\n/**\n * Module exports.\n * @public\n */\n\nexports.charset = charset\nexports.charsets = { lookup: charset }\nexports.contentType = contentType\nexports.extension = extension\nexports.extensions = Object.create(null)\nexports.lookup = lookup\nexports.types = Object.create(null)\n\n// Populate the extensions/types maps\npopulateMaps(exports.extensions, exports.types)\n\n/**\n * Get the default charset for a MIME type.\n *\n * @param {string} type\n * @return {boolean|string}\n */\n\nfunction charset (type) {\n  if (!type || typeof type !== 'string') {\n    return false\n  }\n\n  // TODO: use media-typer\n  var match = EXTRACT_TYPE_REGEXP.exec(type)\n  var mime = match && db[match[1].toLowerCase()]\n\n  if (mime && mime.charset) {\n    return mime.charset\n  }\n\n  // default text/* to utf-8\n  if (match && TEXT_TYPE_REGEXP.test(match[1])) {\n    return 'UTF-8'\n  }\n\n  return false\n}\n\n/**\n * Create a full Content-Type header given a MIME type or extension.\n *\n * @param {string} str\n * @return {boolean|string}\n */\n\nfunction contentType (str) {\n  // TODO: should this even be in this module?\n  if (!str || typeof str !== 'string') {\n    return false\n  }\n\n  var mime = str.indexOf('/') === -1\n    ? exports.lookup(str)\n    : str\n\n  if (!mime) {\n    return false\n  }\n\n  // TODO: use content-type or other module\n  if (mime.indexOf('charset') === -1) {\n    var charset = exports.charset(mime)\n    if (charset) mime += '; charset=' + charset.toLowerCase()\n  }\n\n  return mime\n}\n\n/**\n * Get the default extension for a MIME type.\n *\n * @param {string} type\n * @return {boolean|string}\n */\n\nfunction extension (type) {\n  if (!type || typeof type !== 'string') {\n    return false\n  }\n\n  // TODO: use media-typer\n  var match = EXTRACT_TYPE_REGEXP.exec(type)\n\n  // get extensions\n  var exts = match && exports.extensions[match[1].toLowerCase()]\n\n  if (!exts || !exts.length) {\n    return false\n  }\n\n  return exts[0]\n}\n\n/**\n * Lookup the MIME type for a file path/extension.\n *\n * @param {string} path\n * @return {boolean|string}\n */\n\nfunction lookup (path) {\n  if (!path || typeof path !== 'string') {\n    return false\n  }\n\n  // get the extension (\"ext\" or \".ext\" or full path)\n  var extension = extname('x.' + path)\n    .toLowerCase()\n    .substr(1)\n\n  if (!extension) {\n    return false\n  }\n\n  return exports.types[extension] || false\n}\n\n/**\n * Populate the extensions and types maps.\n * @private\n */\n\nfunction populateMaps (extensions, types) {\n  // source preference (least -> most)\n  var preference = ['nginx', 'apache', undefined, 'iana']\n\n  Object.keys(db).forEach(function forEachMimeType (type) {\n    var mime = db[type]\n    var exts = mime.extensions\n\n    if (!exts || !exts.length) {\n      return\n    }\n\n    // mime -> extensions\n    extensions[type] = exts\n\n    // extension -> mime\n    for (var i = 0; i < exts.length; i++) {\n      var extension = exts[i]\n\n      if (types[extension]) {\n        var from = preference.indexOf(db[types[extension]].source)\n        var to = preference.indexOf(mime.source)\n\n        if (types[extension] !== 'application/octet-stream' &&\n          (from > to || (from === to && types[extension].substr(0, 12) === 'application/'))) {\n          // skip the remapping\n          continue\n        }\n      }\n\n      // set the extension -> mime\n      types[extension] = type\n    }\n  })\n}\n","/*!\n * mime-db\n * Copyright(c) 2014 Jonathan Ong\n * Copyright(c) 2015-2022 Douglas Christopher Wilson\n * MIT Licensed\n */\n\n/**\n * Module exports.\n */\n\nmodule.exports = require('./db.json')\n","var defer = require('./defer.js');\n\n// API\nmodule.exports = async;\n\n/**\n * Runs provided callback asynchronously\n * even if callback itself is not\n *\n * @param   {function} callback - callback to invoke\n * @returns {function} - augmented callback\n */\nfunction async(callback)\n{\n  var isAsync = false;\n\n  // check if async happened\n  defer(function() { isAsync = true; });\n\n  return function async_callback(err, result)\n  {\n    if (isAsync)\n    {\n      callback(err, result);\n    }\n    else\n    {\n      defer(function nextTick_callback()\n      {\n        callback(err, result);\n      });\n    }\n  };\n}\n","module.exports = defer;\n\n/**\n * Runs provided function on next iteration of the event loop\n *\n * @param {function} fn - function to run\n */\nfunction defer(fn)\n{\n  var nextTick = typeof setImmediate == 'function'\n    ? setImmediate\n    : (\n      typeof process == 'object' && typeof process.nextTick == 'function'\n      ? process.nextTick\n      : null\n    );\n\n  if (nextTick)\n  {\n    nextTick(fn);\n  }\n  else\n  {\n    setTimeout(fn, 0);\n  }\n}\n","// API\nmodule.exports = abort;\n\n/**\n * Aborts leftover active jobs\n *\n * @param {object} state - current state object\n */\nfunction abort(state)\n{\n  Object.keys(state.jobs).forEach(clean.bind(state));\n\n  // reset leftover jobs\n  state.jobs = {};\n}\n\n/**\n * Cleans up leftover job by invoking abort function for the provided job id\n *\n * @this  state\n * @param {string|number} key - job id to abort\n */\nfunction clean(key)\n{\n  if (typeof this.jobs[key] == 'function')\n  {\n    this.jobs[key]();\n  }\n}\n","var async = require('./async.js')\n  , abort = require('./abort.js')\n  ;\n\n// API\nmodule.exports = iterate;\n\n/**\n * Iterates over each job object\n *\n * @param {array|object} list - array or object (named list) to iterate over\n * @param {function} iterator - iterator to run\n * @param {object} state - current job status\n * @param {function} callback - invoked when all elements processed\n */\nfunction iterate(list, iterator, state, callback)\n{\n  // store current index\n  var key = state['keyedList'] ? state['keyedList'][state.index] : state.index;\n\n  state.jobs[key] = runJob(iterator, key, list[key], function(error, output)\n  {\n    // don't repeat yourself\n    // skip secondary callbacks\n    if (!(key in state.jobs))\n    {\n      return;\n    }\n\n    // clean up jobs\n    delete state.jobs[key];\n\n    if (error)\n    {\n      // don't process rest of the results\n      // stop still active jobs\n      // and reset the list\n      abort(state);\n    }\n    else\n    {\n      state.results[key] = output;\n    }\n\n    // return salvaged results\n    callback(error, state.results);\n  });\n}\n\n/**\n * Runs iterator over provided job element\n *\n * @param   {function} iterator - iterator to invoke\n * @param   {string|number} key - key/index of the element in the list of jobs\n * @param   {mixed} item - job description\n * @param   {function} callback - invoked after iterator is done with the job\n * @returns {function|mixed} - job abort function or something else\n */\nfunction runJob(iterator, key, item, callback)\n{\n  var aborter;\n\n  // allow shortcut if iterator expects only two arguments\n  if (iterator.length == 2)\n  {\n    aborter = iterator(item, async(callback));\n  }\n  // otherwise go with full three arguments\n  else\n  {\n    aborter = iterator(item, key, async(callback));\n  }\n\n  return aborter;\n}\n","// API\nmodule.exports = state;\n\n/**\n * Creates initial state object\n * for iteration over list\n *\n * @param   {array|object} list - list to iterate over\n * @param   {function|null} sortMethod - function to use for keys sort,\n *                                     or `null` to keep them as is\n * @returns {object} - initial state object\n */\nfunction state(list, sortMethod)\n{\n  var isNamedList = !Array.isArray(list)\n    , initState =\n    {\n      index    : 0,\n      keyedList: isNamedList || sortMethod ? Object.keys(list) : null,\n      jobs     : {},\n      results  : isNamedList ? {} : [],\n      size     : isNamedList ? Object.keys(list).length : list.length\n    }\n    ;\n\n  if (sortMethod)\n  {\n    // sort array keys based on it's values\n    // sort object's keys just on own merit\n    initState.keyedList.sort(isNamedList ? sortMethod : function(a, b)\n    {\n      return sortMethod(list[a], list[b]);\n    });\n  }\n\n  return initState;\n}\n","var abort = require('./abort.js')\n  , async = require('./async.js')\n  ;\n\n// API\nmodule.exports = terminator;\n\n/**\n * Terminates jobs in the attached state context\n *\n * @this  AsyncKitState#\n * @param {function} callback - final callback to invoke after termination\n */\nfunction terminator(callback)\n{\n  if (!Object.keys(this.jobs).length)\n  {\n    return;\n  }\n\n  // fast forward iteration index\n  this.index = this.size;\n\n  // abort jobs\n  abort(this);\n\n  // send back results we have so far\n  async(callback)(null, this.results);\n}\n","var iterate    = require('./lib/iterate.js')\n  , initState  = require('./lib/state.js')\n  , terminator = require('./lib/terminator.js')\n  ;\n\n// Public API\nmodule.exports = parallel;\n\n/**\n * Runs iterator over provided array elements in parallel\n *\n * @param   {array|object} list - array or object (named list) to iterate over\n * @param   {function} iterator - iterator to run\n * @param   {function} callback - invoked when all elements processed\n * @returns {function} - jobs terminator\n */\nfunction parallel(list, iterator, callback)\n{\n  var state = initState(list);\n\n  while (state.index < (state['keyedList'] || list).length)\n  {\n    iterate(list, iterator, state, function(error, result)\n    {\n      if (error)\n      {\n        callback(error, result);\n        return;\n      }\n\n      // looks like it's the last one\n      if (Object.keys(state.jobs).length === 0)\n      {\n        callback(null, state.results);\n        return;\n      }\n    });\n\n    state.index++;\n  }\n\n  return terminator.bind(state, callback);\n}\n","var iterate    = require('./lib/iterate.js')\n  , initState  = require('./lib/state.js')\n  , terminator = require('./lib/terminator.js')\n  ;\n\n// Public API\nmodule.exports = serialOrdered;\n// sorting helpers\nmodule.exports.ascending  = ascending;\nmodule.exports.descending = descending;\n\n/**\n * Runs iterator over provided sorted array elements in series\n *\n * @param   {array|object} list - array or object (named list) to iterate over\n * @param   {function} iterator - iterator to run\n * @param   {function} sortMethod - custom sort function\n * @param   {function} callback - invoked when all elements processed\n * @returns {function} - jobs terminator\n */\nfunction serialOrdered(list, iterator, sortMethod, callback)\n{\n  var state = initState(list, sortMethod);\n\n  iterate(list, iterator, state, function iteratorHandler(error, result)\n  {\n    if (error)\n    {\n      callback(error, result);\n      return;\n    }\n\n    state.index++;\n\n    // are we there yet?\n    if (state.index < (state['keyedList'] || list).length)\n    {\n      iterate(list, iterator, state, iteratorHandler);\n      return;\n    }\n\n    // done here\n    callback(null, state.results);\n  });\n\n  return terminator.bind(state, callback);\n}\n\n/*\n * -- Sort methods\n */\n\n/**\n * sort helper to sort array elements in ascending order\n *\n * @param   {mixed} a - an item to compare\n * @param   {mixed} b - an item to compare\n * @returns {number} - comparison result\n */\nfunction ascending(a, b)\n{\n  return a < b ? -1 : a > b ? 1 : 0;\n}\n\n/**\n * sort helper to sort array elements in descending order\n *\n * @param   {mixed} a - an item to compare\n * @param   {mixed} b - an item to compare\n * @returns {number} - comparison result\n */\nfunction descending(a, b)\n{\n  return -1 * ascending(a, b);\n}\n","var serialOrdered = require('./serialOrdered.js');\n\n// Public API\nmodule.exports = serial;\n\n/**\n * Runs iterator over provided array elements in series\n *\n * @param   {array|object} list - array or object (named list) to iterate over\n * @param   {function} iterator - iterator to run\n * @param   {function} callback - invoked when all elements processed\n * @returns {function} - jobs terminator\n */\nfunction serial(list, iterator, callback)\n{\n  return serialOrdered(list, iterator, null, callback);\n}\n","module.exports =\n{\n  parallel      : require('./parallel.js'),\n  serial        : require('./serial.js'),\n  serialOrdered : require('./serialOrdered.js')\n};\n","// populates missing values\nmodule.exports = function(dst, src) {\n\n  Object.keys(src).forEach(function(prop)\n  {\n    dst[prop] = dst[prop] || src[prop];\n  });\n\n  return dst;\n};\n","var CombinedStream = require('combined-stream');\nvar util = require('util');\nvar path = require('path');\nvar http = require('http');\nvar https = require('https');\nvar parseUrl = require('url').parse;\nvar fs = require('fs');\nvar Stream = require('stream').Stream;\nvar mime = require('mime-types');\nvar asynckit = require('asynckit');\nvar populate = require('./populate.js');\n\n// Public API\nmodule.exports = FormData;\n\n// make it a Stream\nutil.inherits(FormData, CombinedStream);\n\n/**\n * Create readable \"multipart/form-data\" streams.\n * Can be used to submit forms\n * and file uploads to other web applications.\n *\n * @constructor\n * @param {Object} options - Properties to be added/overriden for FormData and CombinedStream\n */\nfunction FormData(options) {\n  if (!(this instanceof FormData)) {\n    return new FormData(options);\n  }\n\n  this._overheadLength = 0;\n  this._valueLength = 0;\n  this._valuesToMeasure = [];\n\n  CombinedStream.call(this);\n\n  options = options || {};\n  for (var option in options) {\n    this[option] = options[option];\n  }\n}\n\nFormData.LINE_BREAK = '\\r\\n';\nFormData.DEFAULT_CONTENT_TYPE = 'application/octet-stream';\n\nFormData.prototype.append = function(field, value, options) {\n\n  options = options || {};\n\n  // allow filename as single option\n  if (typeof options == 'string') {\n    options = {filename: options};\n  }\n\n  var append = CombinedStream.prototype.append.bind(this);\n\n  // all that streamy business can't handle numbers\n  if (typeof value == 'number') {\n    value = '' + value;\n  }\n\n  // https://github.com/felixge/node-form-data/issues/38\n  if (util.isArray(value)) {\n    // Please convert your array into string\n    // the way web server expects it\n    this._error(new Error('Arrays are not supported.'));\n    return;\n  }\n\n  var header = this._multiPartHeader(field, value, options);\n  var footer = this._multiPartFooter();\n\n  append(header);\n  append(value);\n  append(footer);\n\n  // pass along options.knownLength\n  this._trackLength(header, value, options);\n};\n\nFormData.prototype._trackLength = function(header, value, options) {\n  var valueLength = 0;\n\n  // used w/ getLengthSync(), when length is known.\n  // e.g. for streaming directly from a remote server,\n  // w/ a known file a size, and not wanting to wait for\n  // incoming file to finish to get its size.\n  if (options.knownLength != null) {\n    valueLength += +options.knownLength;\n  } else if (Buffer.isBuffer(value)) {\n    valueLength = value.length;\n  } else if (typeof value === 'string') {\n    valueLength = Buffer.byteLength(value);\n  }\n\n  this._valueLength += valueLength;\n\n  // @check why add CRLF? does this account for custom/multiple CRLFs?\n  this._overheadLength +=\n    Buffer.byteLength(header) +\n    FormData.LINE_BREAK.length;\n\n  // empty or either doesn't have path or not an http response or not a stream\n  if (!value || ( !value.path && !(value.readable && value.hasOwnProperty('httpVersion')) && !(value instanceof Stream))) {\n    return;\n  }\n\n  // no need to bother with the length\n  if (!options.knownLength) {\n    this._valuesToMeasure.push(value);\n  }\n};\n\nFormData.prototype._lengthRetriever = function(value, callback) {\n\n  if (value.hasOwnProperty('fd')) {\n\n    // take read range into a account\n    // `end` = Infinity –> read file till the end\n    //\n    // TODO: Looks like there is bug in Node fs.createReadStream\n    // it doesn't respect `end` options without `start` options\n    // Fix it when node fixes it.\n    // https://github.com/joyent/node/issues/7819\n    if (value.end != undefined && value.end != Infinity && value.start != undefined) {\n\n      // when end specified\n      // no need to calculate range\n      // inclusive, starts with 0\n      callback(null, value.end + 1 - (value.start ? value.start : 0));\n\n    // not that fast snoopy\n    } else {\n      // still need to fetch file size from fs\n      fs.stat(value.path, function(err, stat) {\n\n        var fileSize;\n\n        if (err) {\n          callback(err);\n          return;\n        }\n\n        // update final size based on the range options\n        fileSize = stat.size - (value.start ? value.start : 0);\n        callback(null, fileSize);\n      });\n    }\n\n  // or http response\n  } else if (value.hasOwnProperty('httpVersion')) {\n    callback(null, +value.headers['content-length']);\n\n  // or request stream http://github.com/mikeal/request\n  } else if (value.hasOwnProperty('httpModule')) {\n    // wait till response come back\n    value.on('response', function(response) {\n      value.pause();\n      callback(null, +response.headers['content-length']);\n    });\n    value.resume();\n\n  // something else\n  } else {\n    callback('Unknown stream');\n  }\n};\n\nFormData.prototype._multiPartHeader = function(field, value, options) {\n  // custom header specified (as string)?\n  // it becomes responsible for boundary\n  // (e.g. to handle extra CRLFs on .NET servers)\n  if (typeof options.header == 'string') {\n    return options.header;\n  }\n\n  var contentDisposition = this._getContentDisposition(value, options);\n  var contentType = this._getContentType(value, options);\n\n  var contents = '';\n  var headers  = {\n    // add custom disposition as third element or keep it two elements if not\n    'Content-Disposition': ['form-data', 'name=\"' + field + '\"'].concat(contentDisposition || []),\n    // if no content type. allow it to be empty array\n    'Content-Type': [].concat(contentType || [])\n  };\n\n  // allow custom headers.\n  if (typeof options.header == 'object') {\n    populate(headers, options.header);\n  }\n\n  var header;\n  for (var prop in headers) {\n    if (!headers.hasOwnProperty(prop)) continue;\n    header = headers[prop];\n\n    // skip nullish headers.\n    if (header == null) {\n      continue;\n    }\n\n    // convert all headers to arrays.\n    if (!Array.isArray(header)) {\n      header = [header];\n    }\n\n    // add non-empty headers.\n    if (header.length) {\n      contents += prop + ': ' + header.join('; ') + FormData.LINE_BREAK;\n    }\n  }\n\n  return '--' + this.getBoundary() + FormData.LINE_BREAK + contents + FormData.LINE_BREAK;\n};\n\nFormData.prototype._getContentDisposition = function(value, options) {\n\n  var filename\n    , contentDisposition\n    ;\n\n  if (typeof options.filepath === 'string') {\n    // custom filepath for relative paths\n    filename = path.normalize(options.filepath).replace(/\\\\/g, '/');\n  } else if (options.filename || value.name || value.path) {\n    // custom filename take precedence\n    // formidable and the browser add a name property\n    // fs- and request- streams have path property\n    filename = path.basename(options.filename || value.name || value.path);\n  } else if (value.readable && value.hasOwnProperty('httpVersion')) {\n    // or try http response\n    filename = path.basename(value.client._httpMessage.path || '');\n  }\n\n  if (filename) {\n    contentDisposition = 'filename=\"' + filename + '\"';\n  }\n\n  return contentDisposition;\n};\n\nFormData.prototype._getContentType = function(value, options) {\n\n  // use custom content-type above all\n  var contentType = options.contentType;\n\n  // or try `name` from formidable, browser\n  if (!contentType && value.name) {\n    contentType = mime.lookup(value.name);\n  }\n\n  // or try `path` from fs-, request- streams\n  if (!contentType && value.path) {\n    contentType = mime.lookup(value.path);\n  }\n\n  // or if it's http-reponse\n  if (!contentType && value.readable && value.hasOwnProperty('httpVersion')) {\n    contentType = value.headers['content-type'];\n  }\n\n  // or guess it from the filepath or filename\n  if (!contentType && (options.filepath || options.filename)) {\n    contentType = mime.lookup(options.filepath || options.filename);\n  }\n\n  // fallback to the default content type if `value` is not simple value\n  if (!contentType && typeof value == 'object') {\n    contentType = FormData.DEFAULT_CONTENT_TYPE;\n  }\n\n  return contentType;\n};\n\nFormData.prototype._multiPartFooter = function() {\n  return function(next) {\n    var footer = FormData.LINE_BREAK;\n\n    var lastPart = (this._streams.length === 0);\n    if (lastPart) {\n      footer += this._lastBoundary();\n    }\n\n    next(footer);\n  }.bind(this);\n};\n\nFormData.prototype._lastBoundary = function() {\n  return '--' + this.getBoundary() + '--' + FormData.LINE_BREAK;\n};\n\nFormData.prototype.getHeaders = function(userHeaders) {\n  var header;\n  var formHeaders = {\n    'content-type': 'multipart/form-data; boundary=' + this.getBoundary()\n  };\n\n  for (header in userHeaders) {\n    if (userHeaders.hasOwnProperty(header)) {\n      formHeaders[header.toLowerCase()] = userHeaders[header];\n    }\n  }\n\n  return formHeaders;\n};\n\nFormData.prototype.setBoundary = function(boundary) {\n  this._boundary = boundary;\n};\n\nFormData.prototype.getBoundary = function() {\n  if (!this._boundary) {\n    this._generateBoundary();\n  }\n\n  return this._boundary;\n};\n\nFormData.prototype.getBuffer = function() {\n  var dataBuffer = new Buffer.alloc( 0 );\n  var boundary = this.getBoundary();\n\n  // Create the form content. Add Line breaks to the end of data.\n  for (var i = 0, len = this._streams.length; i < len; i++) {\n    if (typeof this._streams[i] !== 'function') {\n\n      // Add content to the buffer.\n      if(Buffer.isBuffer(this._streams[i])) {\n        dataBuffer = Buffer.concat( [dataBuffer, this._streams[i]]);\n      }else {\n        dataBuffer = Buffer.concat( [dataBuffer, Buffer.from(this._streams[i])]);\n      }\n\n      // Add break after content.\n      if (typeof this._streams[i] !== 'string' || this._streams[i].substring( 2, boundary.length + 2 ) !== boundary) {\n        dataBuffer = Buffer.concat( [dataBuffer, Buffer.from(FormData.LINE_BREAK)] );\n      }\n    }\n  }\n\n  // Add the footer and return the Buffer object.\n  return Buffer.concat( [dataBuffer, Buffer.from(this._lastBoundary())] );\n};\n\nFormData.prototype._generateBoundary = function() {\n  // This generates a 50 character boundary similar to those used by Firefox.\n  // They are optimized for boyer-moore parsing.\n  var boundary = '--------------------------';\n  for (var i = 0; i < 24; i++) {\n    boundary += Math.floor(Math.random() * 10).toString(16);\n  }\n\n  this._boundary = boundary;\n};\n\n// Note: getLengthSync DOESN'T calculate streams length\n// As workaround one can calculate file size manually\n// and add it as knownLength option\nFormData.prototype.getLengthSync = function() {\n  var knownLength = this._overheadLength + this._valueLength;\n\n  // Don't get confused, there are 3 \"internal\" streams for each keyval pair\n  // so it basically checks if there is any value added to the form\n  if (this._streams.length) {\n    knownLength += this._lastBoundary().length;\n  }\n\n  // https://github.com/form-data/form-data/issues/40\n  if (!this.hasKnownLength()) {\n    // Some async length retrievers are present\n    // therefore synchronous length calculation is false.\n    // Please use getLength(callback) to get proper length\n    this._error(new Error('Cannot calculate proper length in synchronous way.'));\n  }\n\n  return knownLength;\n};\n\n// Public API to check if length of added values is known\n// https://github.com/form-data/form-data/issues/196\n// https://github.com/form-data/form-data/issues/262\nFormData.prototype.hasKnownLength = function() {\n  var hasKnownLength = true;\n\n  if (this._valuesToMeasure.length) {\n    hasKnownLength = false;\n  }\n\n  return hasKnownLength;\n};\n\nFormData.prototype.getLength = function(cb) {\n  var knownLength = this._overheadLength + this._valueLength;\n\n  if (this._streams.length) {\n    knownLength += this._lastBoundary().length;\n  }\n\n  if (!this._valuesToMeasure.length) {\n    process.nextTick(cb.bind(this, null, knownLength));\n    return;\n  }\n\n  asynckit.parallel(this._valuesToMeasure, this._lengthRetriever, function(err, values) {\n    if (err) {\n      cb(err);\n      return;\n    }\n\n    values.forEach(function(length) {\n      knownLength += length;\n    });\n\n    cb(null, knownLength);\n  });\n};\n\nFormData.prototype.submit = function(params, cb) {\n  var request\n    , options\n    , defaults = {method: 'post'}\n    ;\n\n  // parse provided url if it's string\n  // or treat it as options object\n  if (typeof params == 'string') {\n\n    params = parseUrl(params);\n    options = populate({\n      port: params.port,\n      path: params.pathname,\n      host: params.hostname,\n      protocol: params.protocol\n    }, defaults);\n\n  // use custom params\n  } else {\n\n    options = populate(params, defaults);\n    // if no port provided use default one\n    if (!options.port) {\n      options.port = options.protocol == 'https:' ? 443 : 80;\n    }\n  }\n\n  // put that good code in getHeaders to some use\n  options.headers = this.getHeaders(params.headers);\n\n  // https if specified, fallback to http in any other case\n  if (options.protocol == 'https:') {\n    request = https.request(options);\n  } else {\n    request = http.request(options);\n  }\n\n  // get content length and fire away\n  this.getLength(function(err, length) {\n    if (err && err !== 'Unknown stream') {\n      this._error(err);\n      return;\n    }\n\n    // add content length\n    if (length) {\n      request.setHeader('Content-Length', length);\n    }\n\n    this.pipe(request);\n    if (cb) {\n      var onResponse;\n\n      var callback = function (error, responce) {\n        request.removeListener('error', callback);\n        request.removeListener('response', onResponse);\n\n        return cb.call(this, error, responce);\n      };\n\n      onResponse = callback.bind(this, null);\n\n      request.on('error', callback);\n      request.on('response', onResponse);\n    }\n  }.bind(this));\n\n  return request;\n};\n\nFormData.prototype._error = function(err) {\n  if (!this.error) {\n    this.error = err;\n    this.pause();\n    this.emit('error', err);\n  }\n};\n\nFormData.prototype.toString = function () {\n  return '[object FormData]';\n};\n","'use strict';\n\nimport utils from '../utils.js';\nimport AxiosError from '../core/AxiosError.js';\n// temporary hotfix to avoid circular references until AxiosURLSearchParams is refactored\nimport PlatformFormData from '../platform/node/classes/FormData.js';\n\n/**\n * Determines if the given thing is a array or js object.\n *\n * @param {string} thing - The object or array to be visited.\n *\n * @returns {boolean}\n */\nfunction isVisitable(thing) {\n  return utils.isPlainObject(thing) || utils.isArray(thing);\n}\n\n/**\n * It removes the brackets from the end of a string\n *\n * @param {string} key - The key of the parameter.\n *\n * @returns {string} the key without the brackets.\n */\nfunction removeBrackets(key) {\n  return utils.endsWith(key, '[]') ? key.slice(0, -2) : key;\n}\n\n/**\n * It takes a path, a key, and a boolean, and returns a string\n *\n * @param {string} path - The path to the current key.\n * @param {string} key - The key of the current object being iterated over.\n * @param {string} dots - If true, the key will be rendered with dots instead of brackets.\n *\n * @returns {string} The path to the current key.\n */\nfunction renderKey(path, key, dots) {\n  if (!path) return key;\n  return path.concat(key).map(function each(token, i) {\n    // eslint-disable-next-line no-param-reassign\n    token = removeBrackets(token);\n    return !dots && i ? '[' + token + ']' : token;\n  }).join(dots ? '.' : '');\n}\n\n/**\n * If the array is an array and none of its elements are visitable, then it's a flat array.\n *\n * @param {Array<any>} arr - The array to check\n *\n * @returns {boolean}\n */\nfunction isFlatArray(arr) {\n  return utils.isArray(arr) && !arr.some(isVisitable);\n}\n\nconst predicates = utils.toFlatObject(utils, {}, null, function filter(prop) {\n  return /^is[A-Z]/.test(prop);\n});\n\n/**\n * Convert a data object to FormData\n *\n * @param {Object} obj\n * @param {?Object} [formData]\n * @param {?Object} [options]\n * @param {Function} [options.visitor]\n * @param {Boolean} [options.metaTokens = true]\n * @param {Boolean} [options.dots = false]\n * @param {?Boolean} [options.indexes = false]\n *\n * @returns {Object}\n **/\n\n/**\n * It converts an object into a FormData object\n *\n * @param {Object<any, any>} obj - The object to convert to form data.\n * @param {string} formData - The FormData object to append to.\n * @param {Object<string, any>} options\n *\n * @returns\n */\nfunction toFormData(obj, formData, options) {\n  if (!utils.isObject(obj)) {\n    throw new TypeError('target must be an object');\n  }\n\n  // eslint-disable-next-line no-param-reassign\n  formData = formData || new (PlatformFormData || FormData)();\n\n  // eslint-disable-next-line no-param-reassign\n  options = utils.toFlatObject(options, {\n    metaTokens: true,\n    dots: false,\n    indexes: false\n  }, false, function defined(option, source) {\n    // eslint-disable-next-line no-eq-null,eqeqeq\n    return !utils.isUndefined(source[option]);\n  });\n\n  const metaTokens = options.metaTokens;\n  // eslint-disable-next-line no-use-before-define\n  const visitor = options.visitor || defaultVisitor;\n  const dots = options.dots;\n  const indexes = options.indexes;\n  const _Blob = options.Blob || typeof Blob !== 'undefined' && Blob;\n  const useBlob = _Blob && utils.isSpecCompliantForm(formData);\n\n  if (!utils.isFunction(visitor)) {\n    throw new TypeError('visitor must be a function');\n  }\n\n  function convertValue(value) {\n    if (value === null) return '';\n\n    if (utils.isDate(value)) {\n      return value.toISOString();\n    }\n\n    if (!useBlob && utils.isBlob(value)) {\n      throw new AxiosError('Blob is not supported. Use a Buffer instead.');\n    }\n\n    if (utils.isArrayBuffer(value) || utils.isTypedArray(value)) {\n      return useBlob && typeof Blob === 'function' ? new Blob([value]) : Buffer.from(value);\n    }\n\n    return value;\n  }\n\n  /**\n   * Default visitor.\n   *\n   * @param {*} value\n   * @param {String|Number} key\n   * @param {Array<String|Number>} path\n   * @this {FormData}\n   *\n   * @returns {boolean} return true to visit the each prop of the value recursively\n   */\n  function defaultVisitor(value, key, path) {\n    let arr = value;\n\n    if (value && !path && typeof value === 'object') {\n      if (utils.endsWith(key, '{}')) {\n        // eslint-disable-next-line no-param-reassign\n        key = metaTokens ? key : key.slice(0, -2);\n        // eslint-disable-next-line no-param-reassign\n        value = JSON.stringify(value);\n      } else if (\n        (utils.isArray(value) && isFlatArray(value)) ||\n        ((utils.isFileList(value) || utils.endsWith(key, '[]')) && (arr = utils.toArray(value))\n        )) {\n        // eslint-disable-next-line no-param-reassign\n        key = removeBrackets(key);\n\n        arr.forEach(function each(el, index) {\n          !(utils.isUndefined(el) || el === null) && formData.append(\n            // eslint-disable-next-line no-nested-ternary\n            indexes === true ? renderKey([key], index, dots) : (indexes === null ? key : key + '[]'),\n            convertValue(el)\n          );\n        });\n        return false;\n      }\n    }\n\n    if (isVisitable(value)) {\n      return true;\n    }\n\n    formData.append(renderKey(path, key, dots), convertValue(value));\n\n    return false;\n  }\n\n  const stack = [];\n\n  const exposedHelpers = Object.assign(predicates, {\n    defaultVisitor,\n    convertValue,\n    isVisitable\n  });\n\n  function build(value, path) {\n    if (utils.isUndefined(value)) return;\n\n    if (stack.indexOf(value) !== -1) {\n      throw Error('Circular reference detected in ' + path.join('.'));\n    }\n\n    stack.push(value);\n\n    utils.forEach(value, function each(el, key) {\n      const result = !(utils.isUndefined(el) || el === null) && visitor.call(\n        formData, el, utils.isString(key) ? key.trim() : key, path, exposedHelpers\n      );\n\n      if (result === true) {\n        build(el, path ? path.concat(key) : [key]);\n      }\n    });\n\n    stack.pop();\n  }\n\n  if (!utils.isObject(obj)) {\n    throw new TypeError('data must be an object');\n  }\n\n  build(obj);\n\n  return formData;\n}\n\nexport default toFormData;\n","'use strict';\n\nimport toFormData from './toFormData.js';\n\n/**\n * It encodes a string by replacing all characters that are not in the unreserved set with\n * their percent-encoded equivalents\n *\n * @param {string} str - The string to encode.\n *\n * @returns {string} The encoded string.\n */\nfunction encode(str) {\n  const charMap = {\n    '!': '%21',\n    \"'\": '%27',\n    '(': '%28',\n    ')': '%29',\n    '~': '%7E',\n    '%20': '+',\n    '%00': '\\x00'\n  };\n  return encodeURIComponent(str).replace(/[!'()~]|%20|%00/g, function replacer(match) {\n    return charMap[match];\n  });\n}\n\n/**\n * It takes a params object and converts it to a FormData object\n *\n * @param {Object<string, any>} params - The parameters to be converted to a FormData object.\n * @param {Object<string, any>} options - The options object passed to the Axios constructor.\n *\n * @returns {void}\n */\nfunction AxiosURLSearchParams(params, options) {\n  this._pairs = [];\n\n  params && toFormData(params, this, options);\n}\n\nconst prototype = AxiosURLSearchParams.prototype;\n\nprototype.append = function append(name, value) {\n  this._pairs.push([name, value]);\n};\n\nprototype.toString = function toString(encoder) {\n  const _encode = encoder ? function(value) {\n    return encoder.call(this, value, encode);\n  } : encode;\n\n  return this._pairs.map(function each(pair) {\n    return _encode(pair[0]) + '=' + _encode(pair[1]);\n  }, '').join('&');\n};\n\nexport default AxiosURLSearchParams;\n","'use strict';\n\nimport utils from '../utils.js';\nimport AxiosURLSearchParams from '../helpers/AxiosURLSearchParams.js';\n\n/**\n * It replaces all instances of the characters `:`, `$`, `,`, `+`, `[`, and `]` with their\n * URI encoded counterparts\n *\n * @param {string} val The value to be encoded.\n *\n * @returns {string} The encoded value.\n */\nfunction encode(val) {\n  return encodeURIComponent(val).\n    replace(/%3A/gi, ':').\n    replace(/%24/g, '$').\n    replace(/%2C/gi, ',').\n    replace(/%20/g, '+').\n    replace(/%5B/gi, '[').\n    replace(/%5D/gi, ']');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @param {?(object|Function)} options\n *\n * @returns {string} The formatted url\n */\nexport default function buildURL(url, params, options) {\n  /*eslint no-param-reassign:0*/\n  if (!params) {\n    return url;\n  }\n  \n  const _encode = options && options.encode || encode;\n\n  if (utils.isFunction(options)) {\n    options = {\n      serialize: options\n    };\n  } \n\n  const serializeFn = options && options.serialize;\n\n  let serializedParams;\n\n  if (serializeFn) {\n    serializedParams = serializeFn(params, options);\n  } else {\n    serializedParams = utils.isURLSearchParams(params) ?\n      params.toString() :\n      new AxiosURLSearchParams(params, options).toString(_encode);\n  }\n\n  if (serializedParams) {\n    const hashmarkIndex = url.indexOf(\"#\");\n\n    if (hashmarkIndex !== -1) {\n      url = url.slice(0, hashmarkIndex);\n    }\n    url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n  }\n\n  return url;\n}\n","'use strict';\n\nimport utils from './../utils.js';\n\nclass InterceptorManager {\n  constructor() {\n    this.handlers = [];\n  }\n\n  /**\n   * Add a new interceptor to the stack\n   *\n   * @param {Function} fulfilled The function to handle `then` for a `Promise`\n   * @param {Function} rejected The function to handle `reject` for a `Promise`\n   *\n   * @return {Number} An ID used to remove interceptor later\n   */\n  use(fulfilled, rejected, options) {\n    this.handlers.push({\n      fulfilled,\n      rejected,\n      synchronous: options ? options.synchronous : false,\n      runWhen: options ? options.runWhen : null\n    });\n    return this.handlers.length - 1;\n  }\n\n  /**\n   * Remove an interceptor from the stack\n   *\n   * @param {Number} id The ID that was returned by `use`\n   *\n   * @returns {Boolean} `true` if the interceptor was removed, `false` otherwise\n   */\n  eject(id) {\n    if (this.handlers[id]) {\n      this.handlers[id] = null;\n    }\n  }\n\n  /**\n   * Clear all interceptors from the stack\n   *\n   * @returns {void}\n   */\n  clear() {\n    if (this.handlers) {\n      this.handlers = [];\n    }\n  }\n\n  /**\n   * Iterate over all the registered interceptors\n   *\n   * This method is particularly useful for skipping over any\n   * interceptors that may have become `null` calling `eject`.\n   *\n   * @param {Function} fn The function to call for each interceptor\n   *\n   * @returns {void}\n   */\n  forEach(fn) {\n    utils.forEach(this.handlers, function forEachHandler(h) {\n      if (h !== null) {\n        fn(h);\n      }\n    });\n  }\n}\n\nexport default InterceptorManager;\n","'use strict';\n\nexport default {\n  silentJSONParsing: true,\n  forcedJSONParsing: true,\n  clarifyTimeoutError: false\n};\n","'use strict';\n\nimport url from 'url';\nexport default url.URLSearchParams;\n","import crypto from 'crypto';\nimport URLSearchParams from './classes/URLSearchParams.js'\nimport FormData from './classes/FormData.js'\n\nconst ALPHA = 'abcdefghijklmnopqrstuvwxyz'\n\nconst DIGIT = '0123456789';\n\nconst ALPHABET = {\n  DIGIT,\n  ALPHA,\n  ALPHA_DIGIT: ALPHA + ALPHA.toUpperCase() + DIGIT\n}\n\nconst generateString = (size = 16, alphabet = ALPHABET.ALPHA_DIGIT) => {\n  let str = '';\n  const {length} = alphabet;\n  const randomValues = new Uint32Array(size);\n  crypto.randomFillSync(randomValues);\n  for (let i = 0; i < size; i++) {\n    str += alphabet[randomValues[i] % length];\n  }\n\n  return str;\n}\n\n\nexport default {\n  isNode: true,\n  classes: {\n    URLSearchParams,\n    FormData,\n    Blob: typeof Blob !== 'undefined' && Blob || null\n  },\n  ALPHABET,\n  generateString,\n  protocols: [ 'http', 'https', 'file', 'data' ]\n};\n","const hasBrowserEnv = typeof window !== 'undefined' && typeof document !== 'undefined';\n\nconst _navigator = typeof navigator === 'object' && navigator || undefined;\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n *  typeof window -> undefined\n *  typeof document -> undefined\n *\n * react-native:\n *  navigator.product -> 'ReactNative'\n * nativescript\n *  navigator.product -> 'NativeScript' or 'NS'\n *\n * @returns {boolean}\n */\nconst hasStandardBrowserEnv = hasBrowserEnv &&\n  (!_navigator || ['ReactNative', 'NativeScript', 'NS'].indexOf(_navigator.product) < 0);\n\n/**\n * Determine if we're running in a standard browser webWorker environment\n *\n * Although the `isStandardBrowserEnv` method indicates that\n * `allows axios to run in a web worker`, the WebWorker will still be\n * filtered out due to its judgment standard\n * `typeof window !== 'undefined' && typeof document !== 'undefined'`.\n * This leads to a problem when axios post `FormData` in webWorker\n */\nconst hasStandardBrowserWebWorkerEnv = (() => {\n  return (\n    typeof WorkerGlobalScope !== 'undefined' &&\n    // eslint-disable-next-line no-undef\n    self instanceof WorkerGlobalScope &&\n    typeof self.importScripts === 'function'\n  );\n})();\n\nconst origin = hasBrowserEnv && window.location.href || 'http://localhost';\n\nexport {\n  hasBrowserEnv,\n  hasStandardBrowserWebWorkerEnv,\n  hasStandardBrowserEnv,\n  _navigator as navigator,\n  origin\n}\n","import platform from './node/index.js';\nimport * as utils from './common/utils.js';\n\nexport default {\n  ...utils,\n  ...platform\n}\n","'use strict';\n\nimport utils from '../utils.js';\n\n/**\n * It takes a string like `foo[x][y][z]` and returns an array like `['foo', 'x', 'y', 'z']\n *\n * @param {string} name - The name of the property to get.\n *\n * @returns An array of strings.\n */\nfunction parsePropPath(name) {\n  // foo[x][y][z]\n  // foo.x.y.z\n  // foo-x-y-z\n  // foo x y z\n  return utils.matchAll(/\\w+|\\[(\\w*)]/g, name).map(match => {\n    return match[0] === '[]' ? '' : match[1] || match[0];\n  });\n}\n\n/**\n * Convert an array to an object.\n *\n * @param {Array<any>} arr - The array to convert to an object.\n *\n * @returns An object with the same keys and values as the array.\n */\nfunction arrayToObject(arr) {\n  const obj = {};\n  const keys = Object.keys(arr);\n  let i;\n  const len = keys.length;\n  let key;\n  for (i = 0; i < len; i++) {\n    key = keys[i];\n    obj[key] = arr[key];\n  }\n  return obj;\n}\n\n/**\n * It takes a FormData object and returns a JavaScript object\n *\n * @param {string} formData The FormData object to convert to JSON.\n *\n * @returns {Object<string, any> | null} The converted object.\n */\nfunction formDataToJSON(formData) {\n  function buildPath(path, value, target, index) {\n    let name = path[index++];\n\n    if (name === '__proto__') return true;\n\n    const isNumericKey = Number.isFinite(+name);\n    const isLast = index >= path.length;\n    name = !name && utils.isArray(target) ? target.length : name;\n\n    if (isLast) {\n      if (utils.hasOwnProp(target, name)) {\n        target[name] = [target[name], value];\n      } else {\n        target[name] = value;\n      }\n\n      return !isNumericKey;\n    }\n\n    if (!target[name] || !utils.isObject(target[name])) {\n      target[name] = [];\n    }\n\n    const result = buildPath(path, value, target[name], index);\n\n    if (result && utils.isArray(target[name])) {\n      target[name] = arrayToObject(target[name]);\n    }\n\n    return !isNumericKey;\n  }\n\n  if (utils.isFormData(formData) && utils.isFunction(formData.entries)) {\n    const obj = {};\n\n    utils.forEachEntry(formData, (name, value) => {\n      buildPath(parsePropPath(name), value, obj, 0);\n    });\n\n    return obj;\n  }\n\n  return null;\n}\n\nexport default formDataToJSON;\n","'use strict';\n\nimport utils from '../utils.js';\nimport AxiosError from '../core/AxiosError.js';\nimport transitionalDefaults from './transitional.js';\nimport toFormData from '../helpers/toFormData.js';\nimport toURLEncodedForm from '../helpers/toURLEncodedForm.js';\nimport platform from '../platform/index.js';\nimport formDataToJSON from '../helpers/formDataToJSON.js';\n\n/**\n * It takes a string, tries to parse it, and if it fails, it returns the stringified version\n * of the input\n *\n * @param {any} rawValue - The value to be stringified.\n * @param {Function} parser - A function that parses a string into a JavaScript object.\n * @param {Function} encoder - A function that takes a value and returns a string.\n *\n * @returns {string} A stringified version of the rawValue.\n */\nfunction stringifySafely(rawValue, parser, encoder) {\n  if (utils.isString(rawValue)) {\n    try {\n      (parser || JSON.parse)(rawValue);\n      return utils.trim(rawValue);\n    } catch (e) {\n      if (e.name !== 'SyntaxError') {\n        throw e;\n      }\n    }\n  }\n\n  return (encoder || JSON.stringify)(rawValue);\n}\n\nconst defaults = {\n\n  transitional: transitionalDefaults,\n\n  adapter: ['xhr', 'http', 'fetch'],\n\n  transformRequest: [function transformRequest(data, headers) {\n    const contentType = headers.getContentType() || '';\n    const hasJSONContentType = contentType.indexOf('application/json') > -1;\n    const isObjectPayload = utils.isObject(data);\n\n    if (isObjectPayload && utils.isHTMLForm(data)) {\n      data = new FormData(data);\n    }\n\n    const isFormData = utils.isFormData(data);\n\n    if (isFormData) {\n      return hasJSONContentType ? JSON.stringify(formDataToJSON(data)) : data;\n    }\n\n    if (utils.isArrayBuffer(data) ||\n      utils.isBuffer(data) ||\n      utils.isStream(data) ||\n      utils.isFile(data) ||\n      utils.isBlob(data) ||\n      utils.isReadableStream(data)\n    ) {\n      return data;\n    }\n    if (utils.isArrayBufferView(data)) {\n      return data.buffer;\n    }\n    if (utils.isURLSearchParams(data)) {\n      headers.setContentType('application/x-www-form-urlencoded;charset=utf-8', false);\n      return data.toString();\n    }\n\n    let isFileList;\n\n    if (isObjectPayload) {\n      if (contentType.indexOf('application/x-www-form-urlencoded') > -1) {\n        return toURLEncodedForm(data, this.formSerializer).toString();\n      }\n\n      if ((isFileList = utils.isFileList(data)) || contentType.indexOf('multipart/form-data') > -1) {\n        const _FormData = this.env && this.env.FormData;\n\n        return toFormData(\n          isFileList ? {'files[]': data} : data,\n          _FormData && new _FormData(),\n          this.formSerializer\n        );\n      }\n    }\n\n    if (isObjectPayload || hasJSONContentType ) {\n      headers.setContentType('application/json', false);\n      return stringifySafely(data);\n    }\n\n    return data;\n  }],\n\n  transformResponse: [function transformResponse(data) {\n    const transitional = this.transitional || defaults.transitional;\n    const forcedJSONParsing = transitional && transitional.forcedJSONParsing;\n    const JSONRequested = this.responseType === 'json';\n\n    if (utils.isResponse(data) || utils.isReadableStream(data)) {\n      return data;\n    }\n\n    if (data && utils.isString(data) && ((forcedJSONParsing && !this.responseType) || JSONRequested)) {\n      const silentJSONParsing = transitional && transitional.silentJSONParsing;\n      const strictJSONParsing = !silentJSONParsing && JSONRequested;\n\n      try {\n        return JSON.parse(data);\n      } catch (e) {\n        if (strictJSONParsing) {\n          if (e.name === 'SyntaxError') {\n            throw AxiosError.from(e, AxiosError.ERR_BAD_RESPONSE, this, null, this.response);\n          }\n          throw e;\n        }\n      }\n    }\n\n    return data;\n  }],\n\n  /**\n   * A timeout in milliseconds to abort a request. If set to 0 (default) a\n   * timeout is not created.\n   */\n  timeout: 0,\n\n  xsrfCookieName: 'XSRF-TOKEN',\n  xsrfHeaderName: 'X-XSRF-TOKEN',\n\n  maxContentLength: -1,\n  maxBodyLength: -1,\n\n  env: {\n    FormData: platform.classes.FormData,\n    Blob: platform.classes.Blob\n  },\n\n  validateStatus: function validateStatus(status) {\n    return status >= 200 && status < 300;\n  },\n\n  headers: {\n    common: {\n      'Accept': 'application/json, text/plain, */*',\n      'Content-Type': undefined\n    }\n  }\n};\n\nutils.forEach(['delete', 'get', 'head', 'post', 'put', 'patch'], (method) => {\n  defaults.headers[method] = {};\n});\n\nexport default defaults;\n","'use strict';\n\nimport utils from '../utils.js';\nimport toFormData from './toFormData.js';\nimport platform from '../platform/index.js';\n\nexport default function toURLEncodedForm(data, options) {\n  return toFormData(data, new platform.classes.URLSearchParams(), Object.assign({\n    visitor: function(value, key, path, helpers) {\n      if (platform.isNode && utils.isBuffer(value)) {\n        this.append(key, value.toString('base64'));\n        return false;\n      }\n\n      return helpers.defaultVisitor.apply(this, arguments);\n    }\n  }, options));\n}\n","'use strict';\n\nimport utils from './../utils.js';\n\n// RawAxiosHeaders whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nconst ignoreDuplicateOf = utils.toObjectSet([\n  'age', 'authorization', 'content-length', 'content-type', 'etag',\n  'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',\n  'last-modified', 'location', 'max-forwards', 'proxy-authorization',\n  'referer', 'retry-after', 'user-agent'\n]);\n\n/**\n * Parse headers into an object\n *\n * ```\n * Date: Wed, 27 Aug 2014 08:58:49 GMT\n * Content-Type: application/json\n * Connection: keep-alive\n * Transfer-Encoding: chunked\n * ```\n *\n * @param {String} rawHeaders Headers needing to be parsed\n *\n * @returns {Object} Headers parsed into an object\n */\nexport default rawHeaders => {\n  const parsed = {};\n  let key;\n  let val;\n  let i;\n\n  rawHeaders && rawHeaders.split('\\n').forEach(function parser(line) {\n    i = line.indexOf(':');\n    key = line.substring(0, i).trim().toLowerCase();\n    val = line.substring(i + 1).trim();\n\n    if (!key || (parsed[key] && ignoreDuplicateOf[key])) {\n      return;\n    }\n\n    if (key === 'set-cookie') {\n      if (parsed[key]) {\n        parsed[key].push(val);\n      } else {\n        parsed[key] = [val];\n      }\n    } else {\n      parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n    }\n  });\n\n  return parsed;\n};\n","'use strict';\n\nimport utils from '../utils.js';\nimport parseHeaders from '../helpers/parseHeaders.js';\n\nconst $internals = Symbol('internals');\n\nfunction normalizeHeader(header) {\n  return header && String(header).trim().toLowerCase();\n}\n\nfunction normalizeValue(value) {\n  if (value === false || value == null) {\n    return value;\n  }\n\n  return utils.isArray(value) ? value.map(normalizeValue) : String(value);\n}\n\nfunction parseTokens(str) {\n  const tokens = Object.create(null);\n  const tokensRE = /([^\\s,;=]+)\\s*(?:=\\s*([^,;]+))?/g;\n  let match;\n\n  while ((match = tokensRE.exec(str))) {\n    tokens[match[1]] = match[2];\n  }\n\n  return tokens;\n}\n\nconst isValidHeaderName = (str) => /^[-_a-zA-Z0-9^`|~,!#$%&'*+.]+$/.test(str.trim());\n\nfunction matchHeaderValue(context, value, header, filter, isHeaderNameFilter) {\n  if (utils.isFunction(filter)) {\n    return filter.call(this, value, header);\n  }\n\n  if (isHeaderNameFilter) {\n    value = header;\n  }\n\n  if (!utils.isString(value)) return;\n\n  if (utils.isString(filter)) {\n    return value.indexOf(filter) !== -1;\n  }\n\n  if (utils.isRegExp(filter)) {\n    return filter.test(value);\n  }\n}\n\nfunction formatHeader(header) {\n  return header.trim()\n    .toLowerCase().replace(/([a-z\\d])(\\w*)/g, (w, char, str) => {\n      return char.toUpperCase() + str;\n    });\n}\n\nfunction buildAccessors(obj, header) {\n  const accessorName = utils.toCamelCase(' ' + header);\n\n  ['get', 'set', 'has'].forEach(methodName => {\n    Object.defineProperty(obj, methodName + accessorName, {\n      value: function(arg1, arg2, arg3) {\n        return this[methodName].call(this, header, arg1, arg2, arg3);\n      },\n      configurable: true\n    });\n  });\n}\n\nclass AxiosHeaders {\n  constructor(headers) {\n    headers && this.set(headers);\n  }\n\n  set(header, valueOrRewrite, rewrite) {\n    const self = this;\n\n    function setHeader(_value, _header, _rewrite) {\n      const lHeader = normalizeHeader(_header);\n\n      if (!lHeader) {\n        throw new Error('header name must be a non-empty string');\n      }\n\n      const key = utils.findKey(self, lHeader);\n\n      if(!key || self[key] === undefined || _rewrite === true || (_rewrite === undefined && self[key] !== false)) {\n        self[key || _header] = normalizeValue(_value);\n      }\n    }\n\n    const setHeaders = (headers, _rewrite) =>\n      utils.forEach(headers, (_value, _header) => setHeader(_value, _header, _rewrite));\n\n    if (utils.isPlainObject(header) || header instanceof this.constructor) {\n      setHeaders(header, valueOrRewrite)\n    } else if(utils.isString(header) && (header = header.trim()) && !isValidHeaderName(header)) {\n      setHeaders(parseHeaders(header), valueOrRewrite);\n    } else if (utils.isHeaders(header)) {\n      for (const [key, value] of header.entries()) {\n        setHeader(value, key, rewrite);\n      }\n    } else {\n      header != null && setHeader(valueOrRewrite, header, rewrite);\n    }\n\n    return this;\n  }\n\n  get(header, parser) {\n    header = normalizeHeader(header);\n\n    if (header) {\n      const key = utils.findKey(this, header);\n\n      if (key) {\n        const value = this[key];\n\n        if (!parser) {\n          return value;\n        }\n\n        if (parser === true) {\n          return parseTokens(value);\n        }\n\n        if (utils.isFunction(parser)) {\n          return parser.call(this, value, key);\n        }\n\n        if (utils.isRegExp(parser)) {\n          return parser.exec(value);\n        }\n\n        throw new TypeError('parser must be boolean|regexp|function');\n      }\n    }\n  }\n\n  has(header, matcher) {\n    header = normalizeHeader(header);\n\n    if (header) {\n      const key = utils.findKey(this, header);\n\n      return !!(key && this[key] !== undefined && (!matcher || matchHeaderValue(this, this[key], key, matcher)));\n    }\n\n    return false;\n  }\n\n  delete(header, matcher) {\n    const self = this;\n    let deleted = false;\n\n    function deleteHeader(_header) {\n      _header = normalizeHeader(_header);\n\n      if (_header) {\n        const key = utils.findKey(self, _header);\n\n        if (key && (!matcher || matchHeaderValue(self, self[key], key, matcher))) {\n          delete self[key];\n\n          deleted = true;\n        }\n      }\n    }\n\n    if (utils.isArray(header)) {\n      header.forEach(deleteHeader);\n    } else {\n      deleteHeader(header);\n    }\n\n    return deleted;\n  }\n\n  clear(matcher) {\n    const keys = Object.keys(this);\n    let i = keys.length;\n    let deleted = false;\n\n    while (i--) {\n      const key = keys[i];\n      if(!matcher || matchHeaderValue(this, this[key], key, matcher, true)) {\n        delete this[key];\n        deleted = true;\n      }\n    }\n\n    return deleted;\n  }\n\n  normalize(format) {\n    const self = this;\n    const headers = {};\n\n    utils.forEach(this, (value, header) => {\n      const key = utils.findKey(headers, header);\n\n      if (key) {\n        self[key] = normalizeValue(value);\n        delete self[header];\n        return;\n      }\n\n      const normalized = format ? formatHeader(header) : String(header).trim();\n\n      if (normalized !== header) {\n        delete self[header];\n      }\n\n      self[normalized] = normalizeValue(value);\n\n      headers[normalized] = true;\n    });\n\n    return this;\n  }\n\n  concat(...targets) {\n    return this.constructor.concat(this, ...targets);\n  }\n\n  toJSON(asStrings) {\n    const obj = Object.create(null);\n\n    utils.forEach(this, (value, header) => {\n      value != null && value !== false && (obj[header] = asStrings && utils.isArray(value) ? value.join(', ') : value);\n    });\n\n    return obj;\n  }\n\n  [Symbol.iterator]() {\n    return Object.entries(this.toJSON())[Symbol.iterator]();\n  }\n\n  toString() {\n    return Object.entries(this.toJSON()).map(([header, value]) => header + ': ' + value).join('\\n');\n  }\n\n  get [Symbol.toStringTag]() {\n    return 'AxiosHeaders';\n  }\n\n  static from(thing) {\n    return thing instanceof this ? thing : new this(thing);\n  }\n\n  static concat(first, ...targets) {\n    const computed = new this(first);\n\n    targets.forEach((target) => computed.set(target));\n\n    return computed;\n  }\n\n  static accessor(header) {\n    const internals = this[$internals] = (this[$internals] = {\n      accessors: {}\n    });\n\n    const accessors = internals.accessors;\n    const prototype = this.prototype;\n\n    function defineAccessor(_header) {\n      const lHeader = normalizeHeader(_header);\n\n      if (!accessors[lHeader]) {\n        buildAccessors(prototype, _header);\n        accessors[lHeader] = true;\n      }\n    }\n\n    utils.isArray(header) ? header.forEach(defineAccessor) : defineAccessor(header);\n\n    return this;\n  }\n}\n\nAxiosHeaders.accessor(['Content-Type', 'Content-Length', 'Accept', 'Accept-Encoding', 'User-Agent', 'Authorization']);\n\n// reserved names hotfix\nutils.reduceDescriptors(AxiosHeaders.prototype, ({value}, key) => {\n  let mapped = key[0].toUpperCase() + key.slice(1); // map `set` => `Set`\n  return {\n    get: () => value,\n    set(headerValue) {\n      this[mapped] = headerValue;\n    }\n  }\n});\n\nutils.freezeMethods(AxiosHeaders);\n\nexport default AxiosHeaders;\n","'use strict';\n\nimport utils from './../utils.js';\nimport defaults from '../defaults/index.js';\nimport AxiosHeaders from '../core/AxiosHeaders.js';\n\n/**\n * Transform the data for a request or a response\n *\n * @param {Array|Function} fns A single function or Array of functions\n * @param {?Object} response The response object\n *\n * @returns {*} The resulting transformed data\n */\nexport default function transformData(fns, response) {\n  const config = this || defaults;\n  const context = response || config;\n  const headers = AxiosHeaders.from(context.headers);\n  let data = context.data;\n\n  utils.forEach(fns, function transform(fn) {\n    data = fn.call(config, data, headers.normalize(), response ? response.status : undefined);\n  });\n\n  headers.normalize();\n\n  return data;\n}\n","'use strict';\n\nexport default function isCancel(value) {\n  return !!(value && value.__CANCEL__);\n}\n","'use strict';\n\nimport AxiosError from '../core/AxiosError.js';\nimport utils from '../utils.js';\n\n/**\n * A `CanceledError` is an object that is thrown when an operation is canceled.\n *\n * @param {string=} message The message.\n * @param {Object=} config The config.\n * @param {Object=} request The request.\n *\n * @returns {CanceledError} The created error.\n */\nfunction CanceledError(message, config, request) {\n  // eslint-disable-next-line no-eq-null,eqeqeq\n  AxiosError.call(this, message == null ? 'canceled' : message, AxiosError.ERR_CANCELED, config, request);\n  this.name = 'CanceledError';\n}\n\nutils.inherits(CanceledError, AxiosError, {\n  __CANCEL__: true\n});\n\nexport default CanceledError;\n","'use strict';\n\nimport AxiosError from './AxiosError.js';\n\n/**\n * Resolve or reject a Promise based on response status.\n *\n * @param {Function} resolve A function that resolves the promise.\n * @param {Function} reject A function that rejects the promise.\n * @param {object} response The response.\n *\n * @returns {object} The response.\n */\nexport default function settle(resolve, reject, response) {\n  const validateStatus = response.config.validateStatus;\n  if (!response.status || !validateStatus || validateStatus(response.status)) {\n    resolve(response);\n  } else {\n    reject(new AxiosError(\n      'Request failed with status code ' + response.status,\n      [AxiosError.ERR_BAD_REQUEST, AxiosError.ERR_BAD_RESPONSE][Math.floor(response.status / 100) - 4],\n      response.config,\n      response.request,\n      response\n    ));\n  }\n}\n","'use strict';\n\nimport isAbsoluteURL from '../helpers/isAbsoluteURL.js';\nimport combineURLs from '../helpers/combineURLs.js';\n\n/**\n * Creates a new URL by combining the baseURL with the requestedURL,\n * only when the requestedURL is not already an absolute URL.\n * If the requestURL is absolute, this function returns the requestedURL untouched.\n *\n * @param {string} baseURL The base URL\n * @param {string} requestedURL Absolute or relative URL to combine\n *\n * @returns {string} The combined full path\n */\nexport default function buildFullPath(baseURL, requestedURL, allowAbsoluteUrls) {\n  let isRelativeUrl = !isAbsoluteURL(requestedURL);\n  if (baseURL && (isRelativeUrl || allowAbsoluteUrls == false)) {\n    return combineURLs(baseURL, requestedURL);\n  }\n  return requestedURL;\n}\n","'use strict';\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n *\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nexport default function isAbsoluteURL(url) {\n  // A URL is considered absolute if it begins with \"<scheme>://\" or \"//\" (protocol-relative URL).\n  // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed\n  // by any combination of letters, digits, plus, period, or hyphen.\n  return /^([a-z][a-z\\d+\\-.]*:)?\\/\\//i.test(url);\n}\n","'use strict';\n\n/**\n * Creates a new URL by combining the specified URLs\n *\n * @param {string} baseURL The base URL\n * @param {string} relativeURL The relative URL\n *\n * @returns {string} The combined URL\n */\nexport default function combineURLs(baseURL, relativeURL) {\n  return relativeURL\n    ? baseURL.replace(/\\/?\\/$/, '') + '/' + relativeURL.replace(/^\\/+/, '')\n    : baseURL;\n}\n","'use strict';\n\nvar parseUrl = require('url').parse;\n\nvar DEFAULT_PORTS = {\n  ftp: 21,\n  gopher: 70,\n  http: 80,\n  https: 443,\n  ws: 80,\n  wss: 443,\n};\n\nvar stringEndsWith = String.prototype.endsWith || function(s) {\n  return s.length <= this.length &&\n    this.indexOf(s, this.length - s.length) !== -1;\n};\n\n/**\n * @param {string|object} url - The URL, or the result from url.parse.\n * @return {string} The URL of the proxy that should handle the request to the\n *  given URL. If no proxy is set, this will be an empty string.\n */\nfunction getProxyForUrl(url) {\n  var parsedUrl = typeof url === 'string' ? parseUrl(url) : url || {};\n  var proto = parsedUrl.protocol;\n  var hostname = parsedUrl.host;\n  var port = parsedUrl.port;\n  if (typeof hostname !== 'string' || !hostname || typeof proto !== 'string') {\n    return '';  // Don't proxy URLs without a valid scheme or host.\n  }\n\n  proto = proto.split(':', 1)[0];\n  // Stripping ports in this way instead of using parsedUrl.hostname to make\n  // sure that the brackets around IPv6 addresses are kept.\n  hostname = hostname.replace(/:\\d*$/, '');\n  port = parseInt(port) || DEFAULT_PORTS[proto] || 0;\n  if (!shouldProxy(hostname, port)) {\n    return '';  // Don't proxy URLs that match NO_PROXY.\n  }\n\n  var proxy =\n    getEnv('npm_config_' + proto + '_proxy') ||\n    getEnv(proto + '_proxy') ||\n    getEnv('npm_config_proxy') ||\n    getEnv('all_proxy');\n  if (proxy && proxy.indexOf('://') === -1) {\n    // Missing scheme in proxy, default to the requested URL's scheme.\n    proxy = proto + '://' + proxy;\n  }\n  return proxy;\n}\n\n/**\n * Determines whether a given URL should be proxied.\n *\n * @param {string} hostname - The host name of the URL.\n * @param {number} port - The effective port of the URL.\n * @returns {boolean} Whether the given URL should be proxied.\n * @private\n */\nfunction shouldProxy(hostname, port) {\n  var NO_PROXY =\n    (getEnv('npm_config_no_proxy') || getEnv('no_proxy')).toLowerCase();\n  if (!NO_PROXY) {\n    return true;  // Always proxy if NO_PROXY is not set.\n  }\n  if (NO_PROXY === '*') {\n    return false;  // Never proxy if wildcard is set.\n  }\n\n  return NO_PROXY.split(/[,\\s]/).every(function(proxy) {\n    if (!proxy) {\n      return true;  // Skip zero-length hosts.\n    }\n    var parsedProxy = proxy.match(/^(.+):(\\d+)$/);\n    var parsedProxyHostname = parsedProxy ? parsedProxy[1] : proxy;\n    var parsedProxyPort = parsedProxy ? parseInt(parsedProxy[2]) : 0;\n    if (parsedProxyPort && parsedProxyPort !== port) {\n      return true;  // Skip if ports don't match.\n    }\n\n    if (!/^[.*]/.test(parsedProxyHostname)) {\n      // No wildcards, so stop proxying if there is an exact match.\n      return hostname !== parsedProxyHostname;\n    }\n\n    if (parsedProxyHostname.charAt(0) === '*') {\n      // Remove leading wildcard.\n      parsedProxyHostname = parsedProxyHostname.slice(1);\n    }\n    // Stop proxying if the hostname ends with the no_proxy host.\n    return !stringEndsWith.call(hostname, parsedProxyHostname);\n  });\n}\n\n/**\n * Get the value for an environment variable.\n *\n * @param {string} key - The name of the environment variable.\n * @return {string} The value of the environment variable.\n * @private\n */\nfunction getEnv(key) {\n  return process.env[key.toLowerCase()] || process.env[key.toUpperCase()] || '';\n}\n\nexports.getProxyForUrl = getProxyForUrl;\n","/**\n * Helpers.\n */\n\nvar s = 1000;\nvar m = s * 60;\nvar h = m * 60;\nvar d = h * 24;\nvar w = d * 7;\nvar y = d * 365.25;\n\n/**\n * Parse or format the given `val`.\n *\n * Options:\n *\n *  - `long` verbose formatting [false]\n *\n * @param {String|Number} val\n * @param {Object} [options]\n * @throws {Error} throw an error if val is not a non-empty string or a number\n * @return {String|Number}\n * @api public\n */\n\nmodule.exports = function(val, options) {\n  options = options || {};\n  var type = typeof val;\n  if (type === 'string' && val.length > 0) {\n    return parse(val);\n  } else if (type === 'number' && isFinite(val)) {\n    return options.long ? fmtLong(val) : fmtShort(val);\n  }\n  throw new Error(\n    'val is not a non-empty string or a valid number. val=' +\n      JSON.stringify(val)\n  );\n};\n\n/**\n * Parse the given `str` and return milliseconds.\n *\n * @param {String} str\n * @return {Number}\n * @api private\n */\n\nfunction parse(str) {\n  str = String(str);\n  if (str.length > 100) {\n    return;\n  }\n  var match = /^(-?(?:\\d+)?\\.?\\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(\n    str\n  );\n  if (!match) {\n    return;\n  }\n  var n = parseFloat(match[1]);\n  var type = (match[2] || 'ms').toLowerCase();\n  switch (type) {\n    case 'years':\n    case 'year':\n    case 'yrs':\n    case 'yr':\n    case 'y':\n      return n * y;\n    case 'weeks':\n    case 'week':\n    case 'w':\n      return n * w;\n    case 'days':\n    case 'day':\n    case 'd':\n      return n * d;\n    case 'hours':\n    case 'hour':\n    case 'hrs':\n    case 'hr':\n    case 'h':\n      return n * h;\n    case 'minutes':\n    case 'minute':\n    case 'mins':\n    case 'min':\n    case 'm':\n      return n * m;\n    case 'seconds':\n    case 'second':\n    case 'secs':\n    case 'sec':\n    case 's':\n      return n * s;\n    case 'milliseconds':\n    case 'millisecond':\n    case 'msecs':\n    case 'msec':\n    case 'ms':\n      return n;\n    default:\n      return undefined;\n  }\n}\n\n/**\n * Short format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtShort(ms) {\n  var msAbs = Math.abs(ms);\n  if (msAbs >= d) {\n    return Math.round(ms / d) + 'd';\n  }\n  if (msAbs >= h) {\n    return Math.round(ms / h) + 'h';\n  }\n  if (msAbs >= m) {\n    return Math.round(ms / m) + 'm';\n  }\n  if (msAbs >= s) {\n    return Math.round(ms / s) + 's';\n  }\n  return ms + 'ms';\n}\n\n/**\n * Long format for `ms`.\n *\n * @param {Number} ms\n * @return {String}\n * @api private\n */\n\nfunction fmtLong(ms) {\n  var msAbs = Math.abs(ms);\n  if (msAbs >= d) {\n    return plural(ms, msAbs, d, 'day');\n  }\n  if (msAbs >= h) {\n    return plural(ms, msAbs, h, 'hour');\n  }\n  if (msAbs >= m) {\n    return plural(ms, msAbs, m, 'minute');\n  }\n  if (msAbs >= s) {\n    return plural(ms, msAbs, s, 'second');\n  }\n  return ms + ' ms';\n}\n\n/**\n * Pluralization helper.\n */\n\nfunction plural(ms, msAbs, n, name) {\n  var isPlural = msAbs >= n * 1.5;\n  return Math.round(ms / n) + ' ' + name + (isPlural ? 's' : '');\n}\n","\n/**\n * This is the common logic for both the Node.js and web browser\n * implementations of `debug()`.\n */\n\nfunction setup(env) {\n\tcreateDebug.debug = createDebug;\n\tcreateDebug.default = createDebug;\n\tcreateDebug.coerce = coerce;\n\tcreateDebug.disable = disable;\n\tcreateDebug.enable = enable;\n\tcreateDebug.enabled = enabled;\n\tcreateDebug.humanize = require('ms');\n\tcreateDebug.destroy = destroy;\n\n\tObject.keys(env).forEach(key => {\n\t\tcreateDebug[key] = env[key];\n\t});\n\n\t/**\n\t* The currently active debug mode names, and names to skip.\n\t*/\n\n\tcreateDebug.names = [];\n\tcreateDebug.skips = [];\n\n\t/**\n\t* Map of special \"%n\" handling functions, for the debug \"format\" argument.\n\t*\n\t* Valid key names are a single, lower or upper-case letter, i.e. \"n\" and \"N\".\n\t*/\n\tcreateDebug.formatters = {};\n\n\t/**\n\t* Selects a color for a debug namespace\n\t* @param {String} namespace The namespace string for the debug instance to be colored\n\t* @return {Number|String} An ANSI color code for the given namespace\n\t* @api private\n\t*/\n\tfunction selectColor(namespace) {\n\t\tlet hash = 0;\n\n\t\tfor (let i = 0; i < namespace.length; i++) {\n\t\t\thash = ((hash << 5) - hash) + namespace.charCodeAt(i);\n\t\t\thash |= 0; // Convert to 32bit integer\n\t\t}\n\n\t\treturn createDebug.colors[Math.abs(hash) % createDebug.colors.length];\n\t}\n\tcreateDebug.selectColor = selectColor;\n\n\t/**\n\t* Create a debugger with the given `namespace`.\n\t*\n\t* @param {String} namespace\n\t* @return {Function}\n\t* @api public\n\t*/\n\tfunction createDebug(namespace) {\n\t\tlet prevTime;\n\t\tlet enableOverride = null;\n\t\tlet namespacesCache;\n\t\tlet enabledCache;\n\n\t\tfunction debug(...args) {\n\t\t\t// Disabled?\n\t\t\tif (!debug.enabled) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst self = debug;\n\n\t\t\t// Set `diff` timestamp\n\t\t\tconst curr = Number(new Date());\n\t\t\tconst ms = curr - (prevTime || curr);\n\t\t\tself.diff = ms;\n\t\t\tself.prev = prevTime;\n\t\t\tself.curr = curr;\n\t\t\tprevTime = curr;\n\n\t\t\targs[0] = createDebug.coerce(args[0]);\n\n\t\t\tif (typeof args[0] !== 'string') {\n\t\t\t\t// Anything else let's inspect with %O\n\t\t\t\targs.unshift('%O');\n\t\t\t}\n\n\t\t\t// Apply any `formatters` transformations\n\t\t\tlet index = 0;\n\t\t\targs[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => {\n\t\t\t\t// If we encounter an escaped % then don't increase the array index\n\t\t\t\tif (match === '%%') {\n\t\t\t\t\treturn '%';\n\t\t\t\t}\n\t\t\t\tindex++;\n\t\t\t\tconst formatter = createDebug.formatters[format];\n\t\t\t\tif (typeof formatter === 'function') {\n\t\t\t\t\tconst val = args[index];\n\t\t\t\t\tmatch = formatter.call(self, val);\n\n\t\t\t\t\t// Now we need to remove `args[index]` since it's inlined in the `format`\n\t\t\t\t\targs.splice(index, 1);\n\t\t\t\t\tindex--;\n\t\t\t\t}\n\t\t\t\treturn match;\n\t\t\t});\n\n\t\t\t// Apply env-specific formatting (colors, etc.)\n\t\t\tcreateDebug.formatArgs.call(self, args);\n\n\t\t\tconst logFn = self.log || createDebug.log;\n\t\t\tlogFn.apply(self, args);\n\t\t}\n\n\t\tdebug.namespace = namespace;\n\t\tdebug.useColors = createDebug.useColors();\n\t\tdebug.color = createDebug.selectColor(namespace);\n\t\tdebug.extend = extend;\n\t\tdebug.destroy = createDebug.destroy; // XXX Temporary. Will be removed in the next major release.\n\n\t\tObject.defineProperty(debug, 'enabled', {\n\t\t\tenumerable: true,\n\t\t\tconfigurable: false,\n\t\t\tget: () => {\n\t\t\t\tif (enableOverride !== null) {\n\t\t\t\t\treturn enableOverride;\n\t\t\t\t}\n\t\t\t\tif (namespacesCache !== createDebug.namespaces) {\n\t\t\t\t\tnamespacesCache = createDebug.namespaces;\n\t\t\t\t\tenabledCache = createDebug.enabled(namespace);\n\t\t\t\t}\n\n\t\t\t\treturn enabledCache;\n\t\t\t},\n\t\t\tset: v => {\n\t\t\t\tenableOverride = v;\n\t\t\t}\n\t\t});\n\n\t\t// Env-specific initialization logic for debug instances\n\t\tif (typeof createDebug.init === 'function') {\n\t\t\tcreateDebug.init(debug);\n\t\t}\n\n\t\treturn debug;\n\t}\n\n\tfunction extend(namespace, delimiter) {\n\t\tconst newDebug = createDebug(this.namespace + (typeof delimiter === 'undefined' ? ':' : delimiter) + namespace);\n\t\tnewDebug.log = this.log;\n\t\treturn newDebug;\n\t}\n\n\t/**\n\t* Enables a debug mode by namespaces. This can include modes\n\t* separated by a colon and wildcards.\n\t*\n\t* @param {String} namespaces\n\t* @api public\n\t*/\n\tfunction enable(namespaces) {\n\t\tcreateDebug.save(namespaces);\n\t\tcreateDebug.namespaces = namespaces;\n\n\t\tcreateDebug.names = [];\n\t\tcreateDebug.skips = [];\n\n\t\tlet i;\n\t\tconst split = (typeof namespaces === 'string' ? namespaces : '').split(/[\\s,]+/);\n\t\tconst len = split.length;\n\n\t\tfor (i = 0; i < len; i++) {\n\t\t\tif (!split[i]) {\n\t\t\t\t// ignore empty strings\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tnamespaces = split[i].replace(/\\*/g, '.*?');\n\n\t\t\tif (namespaces[0] === '-') {\n\t\t\t\tcreateDebug.skips.push(new RegExp('^' + namespaces.slice(1) + '$'));\n\t\t\t} else {\n\t\t\t\tcreateDebug.names.push(new RegExp('^' + namespaces + '$'));\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t* Disable debug output.\n\t*\n\t* @return {String} namespaces\n\t* @api public\n\t*/\n\tfunction disable() {\n\t\tconst namespaces = [\n\t\t\t...createDebug.names.map(toNamespace),\n\t\t\t...createDebug.skips.map(toNamespace).map(namespace => '-' + namespace)\n\t\t].join(',');\n\t\tcreateDebug.enable('');\n\t\treturn namespaces;\n\t}\n\n\t/**\n\t* Returns true if the given mode name is enabled, false otherwise.\n\t*\n\t* @param {String} name\n\t* @return {Boolean}\n\t* @api public\n\t*/\n\tfunction enabled(name) {\n\t\tif (name[name.length - 1] === '*') {\n\t\t\treturn true;\n\t\t}\n\n\t\tlet i;\n\t\tlet len;\n\n\t\tfor (i = 0, len = createDebug.skips.length; i < len; i++) {\n\t\t\tif (createDebug.skips[i].test(name)) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t}\n\n\t\tfor (i = 0, len = createDebug.names.length; i < len; i++) {\n\t\t\tif (createDebug.names[i].test(name)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\t/**\n\t* Convert regexp to namespace\n\t*\n\t* @param {RegExp} regxep\n\t* @return {String} namespace\n\t* @api private\n\t*/\n\tfunction toNamespace(regexp) {\n\t\treturn regexp.toString()\n\t\t\t.substring(2, regexp.toString().length - 2)\n\t\t\t.replace(/\\.\\*\\?$/, '*');\n\t}\n\n\t/**\n\t* Coerce `val`.\n\t*\n\t* @param {Mixed} val\n\t* @return {Mixed}\n\t* @api private\n\t*/\n\tfunction coerce(val) {\n\t\tif (val instanceof Error) {\n\t\t\treturn val.stack || val.message;\n\t\t}\n\t\treturn val;\n\t}\n\n\t/**\n\t* XXX DO NOT USE. This is a temporary stub function.\n\t* XXX It WILL be removed in the next major release.\n\t*/\n\tfunction destroy() {\n\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t}\n\n\tcreateDebug.enable(createDebug.load());\n\n\treturn createDebug;\n}\n\nmodule.exports = setup;\n","'use strict';\n\nmodule.exports = (flag, argv = process.argv) => {\n\tconst prefix = flag.startsWith('-') ? '' : (flag.length === 1 ? '-' : '--');\n\tconst position = argv.indexOf(prefix + flag);\n\tconst terminatorPosition = argv.indexOf('--');\n\treturn position !== -1 && (terminatorPosition === -1 || position < terminatorPosition);\n};\n","/**\n * Module dependencies.\n */\n\nconst tty = require('tty');\nconst util = require('util');\n\n/**\n * This is the Node.js implementation of `debug()`.\n */\n\nexports.init = init;\nexports.log = log;\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.destroy = util.deprecate(\n\t() => {},\n\t'Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.'\n);\n\n/**\n * Colors.\n */\n\nexports.colors = [6, 2, 3, 4, 5, 1];\n\ntry {\n\t// Optional dependency (as in, doesn't need to be installed, NOT like optionalDependencies in package.json)\n\t// eslint-disable-next-line import/no-extraneous-dependencies\n\tconst supportsColor = require('supports-color');\n\n\tif (supportsColor && (supportsColor.stderr || supportsColor).level >= 2) {\n\t\texports.colors = [\n\t\t\t20,\n\t\t\t21,\n\t\t\t26,\n\t\t\t27,\n\t\t\t32,\n\t\t\t33,\n\t\t\t38,\n\t\t\t39,\n\t\t\t40,\n\t\t\t41,\n\t\t\t42,\n\t\t\t43,\n\t\t\t44,\n\t\t\t45,\n\t\t\t56,\n\t\t\t57,\n\t\t\t62,\n\t\t\t63,\n\t\t\t68,\n\t\t\t69,\n\t\t\t74,\n\t\t\t75,\n\t\t\t76,\n\t\t\t77,\n\t\t\t78,\n\t\t\t79,\n\t\t\t80,\n\t\t\t81,\n\t\t\t92,\n\t\t\t93,\n\t\t\t98,\n\t\t\t99,\n\t\t\t112,\n\t\t\t113,\n\t\t\t128,\n\t\t\t129,\n\t\t\t134,\n\t\t\t135,\n\t\t\t148,\n\t\t\t149,\n\t\t\t160,\n\t\t\t161,\n\t\t\t162,\n\t\t\t163,\n\t\t\t164,\n\t\t\t165,\n\t\t\t166,\n\t\t\t167,\n\t\t\t168,\n\t\t\t169,\n\t\t\t170,\n\t\t\t171,\n\t\t\t172,\n\t\t\t173,\n\t\t\t178,\n\t\t\t179,\n\t\t\t184,\n\t\t\t185,\n\t\t\t196,\n\t\t\t197,\n\t\t\t198,\n\t\t\t199,\n\t\t\t200,\n\t\t\t201,\n\t\t\t202,\n\t\t\t203,\n\t\t\t204,\n\t\t\t205,\n\t\t\t206,\n\t\t\t207,\n\t\t\t208,\n\t\t\t209,\n\t\t\t214,\n\t\t\t215,\n\t\t\t220,\n\t\t\t221\n\t\t];\n\t}\n} catch (error) {\n\t// Swallow - we only care if `supports-color` is available; it doesn't have to be.\n}\n\n/**\n * Build up the default `inspectOpts` object from the environment variables.\n *\n *   $ DEBUG_COLORS=no DEBUG_DEPTH=10 DEBUG_SHOW_HIDDEN=enabled node script.js\n */\n\nexports.inspectOpts = Object.keys(process.env).filter(key => {\n\treturn /^debug_/i.test(key);\n}).reduce((obj, key) => {\n\t// Camel-case\n\tconst prop = key\n\t\t.substring(6)\n\t\t.toLowerCase()\n\t\t.replace(/_([a-z])/g, (_, k) => {\n\t\t\treturn k.toUpperCase();\n\t\t});\n\n\t// Coerce string value into JS value\n\tlet val = process.env[key];\n\tif (/^(yes|on|true|enabled)$/i.test(val)) {\n\t\tval = true;\n\t} else if (/^(no|off|false|disabled)$/i.test(val)) {\n\t\tval = false;\n\t} else if (val === 'null') {\n\t\tval = null;\n\t} else {\n\t\tval = Number(val);\n\t}\n\n\tobj[prop] = val;\n\treturn obj;\n}, {});\n\n/**\n * Is stdout a TTY? Colored output is enabled when `true`.\n */\n\nfunction useColors() {\n\treturn 'colors' in exports.inspectOpts ?\n\t\tBoolean(exports.inspectOpts.colors) :\n\t\ttty.isatty(process.stderr.fd);\n}\n\n/**\n * Adds ANSI color escape codes if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\tconst {namespace: name, useColors} = this;\n\n\tif (useColors) {\n\t\tconst c = this.color;\n\t\tconst colorCode = '\\u001B[3' + (c < 8 ? c : '8;5;' + c);\n\t\tconst prefix = `  ${colorCode};1m${name} \\u001B[0m`;\n\n\t\targs[0] = prefix + args[0].split('\\n').join('\\n' + prefix);\n\t\targs.push(colorCode + 'm+' + module.exports.humanize(this.diff) + '\\u001B[0m');\n\t} else {\n\t\targs[0] = getDate() + name + ' ' + args[0];\n\t}\n}\n\nfunction getDate() {\n\tif (exports.inspectOpts.hideDate) {\n\t\treturn '';\n\t}\n\treturn new Date().toISOString() + ' ';\n}\n\n/**\n * Invokes `util.formatWithOptions()` with the specified arguments and writes to stderr.\n */\n\nfunction log(...args) {\n\treturn process.stderr.write(util.formatWithOptions(exports.inspectOpts, ...args) + '\\n');\n}\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\tif (namespaces) {\n\t\tprocess.env.DEBUG = namespaces;\n\t} else {\n\t\t// If you set a process.env field to null or undefined, it gets cast to the\n\t\t// string 'null' or 'undefined'. Just delete instead.\n\t\tdelete process.env.DEBUG;\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\n\nfunction load() {\n\treturn process.env.DEBUG;\n}\n\n/**\n * Init logic for `debug` instances.\n *\n * Create a new `inspectOpts` object in case `useColors` is set\n * differently for a particular `debug` instance.\n */\n\nfunction init(debug) {\n\tdebug.inspectOpts = {};\n\n\tconst keys = Object.keys(exports.inspectOpts);\n\tfor (let i = 0; i < keys.length; i++) {\n\t\tdebug.inspectOpts[keys[i]] = exports.inspectOpts[keys[i]];\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %o to `util.inspect()`, all on a single line.\n */\n\nformatters.o = function (v) {\n\tthis.inspectOpts.colors = this.useColors;\n\treturn util.inspect(v, this.inspectOpts)\n\t\t.split('\\n')\n\t\t.map(str => str.trim())\n\t\t.join(' ');\n};\n\n/**\n * Map %O to `util.inspect()`, allowing multiple lines if needed.\n */\n\nformatters.O = function (v) {\n\tthis.inspectOpts.colors = this.useColors;\n\treturn util.inspect(v, this.inspectOpts);\n};\n","'use strict';\nconst os = require('os');\nconst tty = require('tty');\nconst hasFlag = require('has-flag');\n\nconst {env} = process;\n\nlet forceColor;\nif (hasFlag('no-color') ||\n\thasFlag('no-colors') ||\n\thasFlag('color=false') ||\n\thasFlag('color=never')) {\n\tforceColor = 0;\n} else if (hasFlag('color') ||\n\thasFlag('colors') ||\n\thasFlag('color=true') ||\n\thasFlag('color=always')) {\n\tforceColor = 1;\n}\n\nif ('FORCE_COLOR' in env) {\n\tif (env.FORCE_COLOR === 'true') {\n\t\tforceColor = 1;\n\t} else if (env.FORCE_COLOR === 'false') {\n\t\tforceColor = 0;\n\t} else {\n\t\tforceColor = env.FORCE_COLOR.length === 0 ? 1 : Math.min(parseInt(env.FORCE_COLOR, 10), 3);\n\t}\n}\n\nfunction translateLevel(level) {\n\tif (level === 0) {\n\t\treturn false;\n\t}\n\n\treturn {\n\t\tlevel,\n\t\thasBasic: true,\n\t\thas256: level >= 2,\n\t\thas16m: level >= 3\n\t};\n}\n\nfunction supportsColor(haveStream, streamIsTTY) {\n\tif (forceColor === 0) {\n\t\treturn 0;\n\t}\n\n\tif (hasFlag('color=16m') ||\n\t\thasFlag('color=full') ||\n\t\thasFlag('color=truecolor')) {\n\t\treturn 3;\n\t}\n\n\tif (hasFlag('color=256')) {\n\t\treturn 2;\n\t}\n\n\tif (haveStream && !streamIsTTY && forceColor === undefined) {\n\t\treturn 0;\n\t}\n\n\tconst min = forceColor || 0;\n\n\tif (env.TERM === 'dumb') {\n\t\treturn min;\n\t}\n\n\tif (process.platform === 'win32') {\n\t\t// Windows 10 build 10586 is the first Windows release that supports 256 colors.\n\t\t// Windows 10 build 14931 is the first release that supports 16m/TrueColor.\n\t\tconst osRelease = os.release().split('.');\n\t\tif (\n\t\t\tNumber(osRelease[0]) >= 10 &&\n\t\t\tNumber(osRelease[2]) >= 10586\n\t\t) {\n\t\t\treturn Number(osRelease[2]) >= 14931 ? 3 : 2;\n\t\t}\n\n\t\treturn 1;\n\t}\n\n\tif ('CI' in env) {\n\t\tif (['TRAVIS', 'CIRCLECI', 'APPVEYOR', 'GITLAB_CI', 'GITHUB_ACTIONS', 'BUILDKITE'].some(sign => sign in env) || env.CI_NAME === 'codeship') {\n\t\t\treturn 1;\n\t\t}\n\n\t\treturn min;\n\t}\n\n\tif ('TEAMCITY_VERSION' in env) {\n\t\treturn /^(9\\.(0*[1-9]\\d*)\\.|\\d{2,}\\.)/.test(env.TEAMCITY_VERSION) ? 1 : 0;\n\t}\n\n\tif (env.COLORTERM === 'truecolor') {\n\t\treturn 3;\n\t}\n\n\tif ('TERM_PROGRAM' in env) {\n\t\tconst version = parseInt((env.TERM_PROGRAM_VERSION || '').split('.')[0], 10);\n\n\t\tswitch (env.TERM_PROGRAM) {\n\t\t\tcase 'iTerm.app':\n\t\t\t\treturn version >= 3 ? 3 : 2;\n\t\t\tcase 'Apple_Terminal':\n\t\t\t\treturn 2;\n\t\t\t// No default\n\t\t}\n\t}\n\n\tif (/-256(color)?$/i.test(env.TERM)) {\n\t\treturn 2;\n\t}\n\n\tif (/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(env.TERM)) {\n\t\treturn 1;\n\t}\n\n\tif ('COLORTERM' in env) {\n\t\treturn 1;\n\t}\n\n\treturn min;\n}\n\nfunction getSupportLevel(stream) {\n\tconst level = supportsColor(stream, stream && stream.isTTY);\n\treturn translateLevel(level);\n}\n\nmodule.exports = {\n\tsupportsColor: getSupportLevel,\n\tstdout: translateLevel(supportsColor(true, tty.isatty(1))),\n\tstderr: translateLevel(supportsColor(true, tty.isatty(2)))\n};\n","/**\n * Detect Electron renderer / nwjs process, which is node, but we should\n * treat as a browser.\n */\n\nif (typeof process === 'undefined' || process.type === 'renderer' || process.browser === true || process.__nwjs) {\n\tmodule.exports = require('./browser.js');\n} else {\n\tmodule.exports = require('./node.js');\n}\n","/* eslint-env browser */\n\n/**\n * This is the web browser implementation of `debug()`.\n */\n\nexports.formatArgs = formatArgs;\nexports.save = save;\nexports.load = load;\nexports.useColors = useColors;\nexports.storage = localstorage();\nexports.destroy = (() => {\n\tlet warned = false;\n\n\treturn () => {\n\t\tif (!warned) {\n\t\t\twarned = true;\n\t\t\tconsole.warn('Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.');\n\t\t}\n\t};\n})();\n\n/**\n * Colors.\n */\n\nexports.colors = [\n\t'#0000CC',\n\t'#0000FF',\n\t'#0033CC',\n\t'#0033FF',\n\t'#0066CC',\n\t'#0066FF',\n\t'#0099CC',\n\t'#0099FF',\n\t'#00CC00',\n\t'#00CC33',\n\t'#00CC66',\n\t'#00CC99',\n\t'#00CCCC',\n\t'#00CCFF',\n\t'#3300CC',\n\t'#3300FF',\n\t'#3333CC',\n\t'#3333FF',\n\t'#3366CC',\n\t'#3366FF',\n\t'#3399CC',\n\t'#3399FF',\n\t'#33CC00',\n\t'#33CC33',\n\t'#33CC66',\n\t'#33CC99',\n\t'#33CCCC',\n\t'#33CCFF',\n\t'#6600CC',\n\t'#6600FF',\n\t'#6633CC',\n\t'#6633FF',\n\t'#66CC00',\n\t'#66CC33',\n\t'#9900CC',\n\t'#9900FF',\n\t'#9933CC',\n\t'#9933FF',\n\t'#99CC00',\n\t'#99CC33',\n\t'#CC0000',\n\t'#CC0033',\n\t'#CC0066',\n\t'#CC0099',\n\t'#CC00CC',\n\t'#CC00FF',\n\t'#CC3300',\n\t'#CC3333',\n\t'#CC3366',\n\t'#CC3399',\n\t'#CC33CC',\n\t'#CC33FF',\n\t'#CC6600',\n\t'#CC6633',\n\t'#CC9900',\n\t'#CC9933',\n\t'#CCCC00',\n\t'#CCCC33',\n\t'#FF0000',\n\t'#FF0033',\n\t'#FF0066',\n\t'#FF0099',\n\t'#FF00CC',\n\t'#FF00FF',\n\t'#FF3300',\n\t'#FF3333',\n\t'#FF3366',\n\t'#FF3399',\n\t'#FF33CC',\n\t'#FF33FF',\n\t'#FF6600',\n\t'#FF6633',\n\t'#FF9900',\n\t'#FF9933',\n\t'#FFCC00',\n\t'#FFCC33'\n];\n\n/**\n * Currently only WebKit-based Web Inspectors, Firefox >= v31,\n * and the Firebug extension (any Firefox version) are known\n * to support \"%c\" CSS customizations.\n *\n * TODO: add a `localStorage` variable to explicitly enable/disable colors\n */\n\n// eslint-disable-next-line complexity\nfunction useColors() {\n\t// NB: In an Electron preload script, document will be defined but not fully\n\t// initialized. Since we know we're in Chrome, we'll just detect this case\n\t// explicitly\n\tif (typeof window !== 'undefined' && window.process && (window.process.type === 'renderer' || window.process.__nwjs)) {\n\t\treturn true;\n\t}\n\n\t// Internet Explorer and Edge do not support colors.\n\tif (typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\\/(\\d+)/)) {\n\t\treturn false;\n\t}\n\n\t// Is webkit? http://stackoverflow.com/a/16459606/376773\n\t// document is undefined in react-native: https://github.com/facebook/react-native/pull/1632\n\treturn (typeof document !== 'undefined' && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance) ||\n\t\t// Is firebug? http://stackoverflow.com/a/398120/376773\n\t\t(typeof window !== 'undefined' && window.console && (window.console.firebug || (window.console.exception && window.console.table))) ||\n\t\t// Is firefox >= v31?\n\t\t// https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\\/(\\d+)/) && parseInt(RegExp.$1, 10) >= 31) ||\n\t\t// Double check webkit in userAgent just in case we are in a worker\n\t\t(typeof navigator !== 'undefined' && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\\/(\\d+)/));\n}\n\n/**\n * Colorize log arguments if enabled.\n *\n * @api public\n */\n\nfunction formatArgs(args) {\n\targs[0] = (this.useColors ? '%c' : '') +\n\t\tthis.namespace +\n\t\t(this.useColors ? ' %c' : ' ') +\n\t\targs[0] +\n\t\t(this.useColors ? '%c ' : ' ') +\n\t\t'+' + module.exports.humanize(this.diff);\n\n\tif (!this.useColors) {\n\t\treturn;\n\t}\n\n\tconst c = 'color: ' + this.color;\n\targs.splice(1, 0, c, 'color: inherit');\n\n\t// The final \"%c\" is somewhat tricky, because there could be other\n\t// arguments passed either before or after the %c, so we need to\n\t// figure out the correct index to insert the CSS into\n\tlet index = 0;\n\tlet lastC = 0;\n\targs[0].replace(/%[a-zA-Z%]/g, match => {\n\t\tif (match === '%%') {\n\t\t\treturn;\n\t\t}\n\t\tindex++;\n\t\tif (match === '%c') {\n\t\t\t// We only are interested in the *last* %c\n\t\t\t// (the user may have provided their own)\n\t\t\tlastC = index;\n\t\t}\n\t});\n\n\targs.splice(lastC, 0, c);\n}\n\n/**\n * Invokes `console.debug()` when available.\n * No-op when `console.debug` is not a \"function\".\n * If `console.debug` is not available, falls back\n * to `console.log`.\n *\n * @api public\n */\nexports.log = console.debug || console.log || (() => {});\n\n/**\n * Save `namespaces`.\n *\n * @param {String} namespaces\n * @api private\n */\nfunction save(namespaces) {\n\ttry {\n\t\tif (namespaces) {\n\t\t\texports.storage.setItem('debug', namespaces);\n\t\t} else {\n\t\t\texports.storage.removeItem('debug');\n\t\t}\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\n/**\n * Load `namespaces`.\n *\n * @return {String} returns the previously persisted debug modes\n * @api private\n */\nfunction load() {\n\tlet r;\n\ttry {\n\t\tr = exports.storage.getItem('debug');\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n\n\t// If debug isn't set in LS, and we're in Electron, try to load $DEBUG\n\tif (!r && typeof process !== 'undefined' && 'env' in process) {\n\t\tr = process.env.DEBUG;\n\t}\n\n\treturn r;\n}\n\n/**\n * Localstorage attempts to return the localstorage.\n *\n * This is necessary because safari throws\n * when a user disables cookies/localstorage\n * and you attempt to access it.\n *\n * @return {LocalStorage}\n * @api private\n */\n\nfunction localstorage() {\n\ttry {\n\t\t// TVMLKit (Apple TV JS Runtime) does not have a window object, just localStorage in the global context\n\t\t// The Browser also has localStorage in the global context.\n\t\treturn localStorage;\n\t} catch (error) {\n\t\t// Swallow\n\t\t// XXX (@Qix-) should we be logging these?\n\t}\n}\n\nmodule.exports = require('./common')(exports);\n\nconst {formatters} = module.exports;\n\n/**\n * Map %j to `JSON.stringify()`, since no Web Inspectors do that by default.\n */\n\nformatters.j = function (v) {\n\ttry {\n\t\treturn JSON.stringify(v);\n\t} catch (error) {\n\t\treturn '[UnexpectedJSONParseError]: ' + error.message;\n\t}\n};\n","var url = require(\"url\");\nvar URL = url.URL;\nvar http = require(\"http\");\nvar https = require(\"https\");\nvar Writable = require(\"stream\").Writable;\nvar assert = require(\"assert\");\nvar debug = require(\"./debug\");\n\n// Whether to use the native URL object or the legacy url module\nvar useNativeURL = false;\ntry {\n  assert(new URL());\n}\ncatch (error) {\n  useNativeURL = error.code === \"ERR_INVALID_URL\";\n}\n\n// URL fields to preserve in copy operations\nvar preservedUrlFields = [\n  \"auth\",\n  \"host\",\n  \"hostname\",\n  \"href\",\n  \"path\",\n  \"pathname\",\n  \"port\",\n  \"protocol\",\n  \"query\",\n  \"search\",\n  \"hash\",\n];\n\n// Create handlers that pass events from native requests\nvar events = [\"abort\", \"aborted\", \"connect\", \"error\", \"socket\", \"timeout\"];\nvar eventHandlers = Object.create(null);\nevents.forEach(function (event) {\n  eventHandlers[event] = function (arg1, arg2, arg3) {\n    this._redirectable.emit(event, arg1, arg2, arg3);\n  };\n});\n\n// Error types with codes\nvar InvalidUrlError = createErrorType(\n  \"ERR_INVALID_URL\",\n  \"Invalid URL\",\n  TypeError\n);\nvar RedirectionError = createErrorType(\n  \"ERR_FR_REDIRECTION_FAILURE\",\n  \"Redirected request failed\"\n);\nvar TooManyRedirectsError = createErrorType(\n  \"ERR_FR_TOO_MANY_REDIRECTS\",\n  \"Maximum number of redirects exceeded\",\n  RedirectionError\n);\nvar MaxBodyLengthExceededError = createErrorType(\n  \"ERR_FR_MAX_BODY_LENGTH_EXCEEDED\",\n  \"Request body larger than maxBodyLength limit\"\n);\nvar WriteAfterEndError = createErrorType(\n  \"ERR_STREAM_WRITE_AFTER_END\",\n  \"write after end\"\n);\n\n// istanbul ignore next\nvar destroy = Writable.prototype.destroy || noop;\n\n// An HTTP(S) request that can be redirected\nfunction RedirectableRequest(options, responseCallback) {\n  // Initialize the request\n  Writable.call(this);\n  this._sanitizeOptions(options);\n  this._options = options;\n  this._ended = false;\n  this._ending = false;\n  this._redirectCount = 0;\n  this._redirects = [];\n  this._requestBodyLength = 0;\n  this._requestBodyBuffers = [];\n\n  // Attach a callback if passed\n  if (responseCallback) {\n    this.on(\"response\", responseCallback);\n  }\n\n  // React to responses of native requests\n  var self = this;\n  this._onNativeResponse = function (response) {\n    try {\n      self._processResponse(response);\n    }\n    catch (cause) {\n      self.emit(\"error\", cause instanceof RedirectionError ?\n        cause : new RedirectionError({ cause: cause }));\n    }\n  };\n\n  // Perform the first request\n  this._performRequest();\n}\nRedirectableRequest.prototype = Object.create(Writable.prototype);\n\nRedirectableRequest.prototype.abort = function () {\n  destroyRequest(this._currentRequest);\n  this._currentRequest.abort();\n  this.emit(\"abort\");\n};\n\nRedirectableRequest.prototype.destroy = function (error) {\n  destroyRequest(this._currentRequest, error);\n  destroy.call(this, error);\n  return this;\n};\n\n// Writes buffered data to the current native request\nRedirectableRequest.prototype.write = function (data, encoding, callback) {\n  // Writing is not allowed if end has been called\n  if (this._ending) {\n    throw new WriteAfterEndError();\n  }\n\n  // Validate input and shift parameters if necessary\n  if (!isString(data) && !isBuffer(data)) {\n    throw new TypeError(\"data should be a string, Buffer or Uint8Array\");\n  }\n  if (isFunction(encoding)) {\n    callback = encoding;\n    encoding = null;\n  }\n\n  // Ignore empty buffers, since writing them doesn't invoke the callback\n  // https://github.com/nodejs/node/issues/22066\n  if (data.length === 0) {\n    if (callback) {\n      callback();\n    }\n    return;\n  }\n  // Only write when we don't exceed the maximum body length\n  if (this._requestBodyLength + data.length <= this._options.maxBodyLength) {\n    this._requestBodyLength += data.length;\n    this._requestBodyBuffers.push({ data: data, encoding: encoding });\n    this._currentRequest.write(data, encoding, callback);\n  }\n  // Error when we exceed the maximum body length\n  else {\n    this.emit(\"error\", new MaxBodyLengthExceededError());\n    this.abort();\n  }\n};\n\n// Ends the current native request\nRedirectableRequest.prototype.end = function (data, encoding, callback) {\n  // Shift parameters if necessary\n  if (isFunction(data)) {\n    callback = data;\n    data = encoding = null;\n  }\n  else if (isFunction(encoding)) {\n    callback = encoding;\n    encoding = null;\n  }\n\n  // Write data if needed and end\n  if (!data) {\n    this._ended = this._ending = true;\n    this._currentRequest.end(null, null, callback);\n  }\n  else {\n    var self = this;\n    var currentRequest = this._currentRequest;\n    this.write(data, encoding, function () {\n      self._ended = true;\n      currentRequest.end(null, null, callback);\n    });\n    this._ending = true;\n  }\n};\n\n// Sets a header value on the current native request\nRedirectableRequest.prototype.setHeader = function (name, value) {\n  this._options.headers[name] = value;\n  this._currentRequest.setHeader(name, value);\n};\n\n// Clears a header value on the current native request\nRedirectableRequest.prototype.removeHeader = function (name) {\n  delete this._options.headers[name];\n  this._currentRequest.removeHeader(name);\n};\n\n// Global timeout for all underlying requests\nRedirectableRequest.prototype.setTimeout = function (msecs, callback) {\n  var self = this;\n\n  // Destroys the socket on timeout\n  function destroyOnTimeout(socket) {\n    socket.setTimeout(msecs);\n    socket.removeListener(\"timeout\", socket.destroy);\n    socket.addListener(\"timeout\", socket.destroy);\n  }\n\n  // Sets up a timer to trigger a timeout event\n  function startTimer(socket) {\n    if (self._timeout) {\n      clearTimeout(self._timeout);\n    }\n    self._timeout = setTimeout(function () {\n      self.emit(\"timeout\");\n      clearTimer();\n    }, msecs);\n    destroyOnTimeout(socket);\n  }\n\n  // Stops a timeout from triggering\n  function clearTimer() {\n    // Clear the timeout\n    if (self._timeout) {\n      clearTimeout(self._timeout);\n      self._timeout = null;\n    }\n\n    // Clean up all attached listeners\n    self.removeListener(\"abort\", clearTimer);\n    self.removeListener(\"error\", clearTimer);\n    self.removeListener(\"response\", clearTimer);\n    self.removeListener(\"close\", clearTimer);\n    if (callback) {\n      self.removeListener(\"timeout\", callback);\n    }\n    if (!self.socket) {\n      self._currentRequest.removeListener(\"socket\", startTimer);\n    }\n  }\n\n  // Attach callback if passed\n  if (callback) {\n    this.on(\"timeout\", callback);\n  }\n\n  // Start the timer if or when the socket is opened\n  if (this.socket) {\n    startTimer(this.socket);\n  }\n  else {\n    this._currentRequest.once(\"socket\", startTimer);\n  }\n\n  // Clean up on events\n  this.on(\"socket\", destroyOnTimeout);\n  this.on(\"abort\", clearTimer);\n  this.on(\"error\", clearTimer);\n  this.on(\"response\", clearTimer);\n  this.on(\"close\", clearTimer);\n\n  return this;\n};\n\n// Proxy all other public ClientRequest methods\n[\n  \"flushHeaders\", \"getHeader\",\n  \"setNoDelay\", \"setSocketKeepAlive\",\n].forEach(function (method) {\n  RedirectableRequest.prototype[method] = function (a, b) {\n    return this._currentRequest[method](a, b);\n  };\n});\n\n// Proxy all public ClientRequest properties\n[\"aborted\", \"connection\", \"socket\"].forEach(function (property) {\n  Object.defineProperty(RedirectableRequest.prototype, property, {\n    get: function () { return this._currentRequest[property]; },\n  });\n});\n\nRedirectableRequest.prototype._sanitizeOptions = function (options) {\n  // Ensure headers are always present\n  if (!options.headers) {\n    options.headers = {};\n  }\n\n  // Since http.request treats host as an alias of hostname,\n  // but the url module interprets host as hostname plus port,\n  // eliminate the host property to avoid confusion.\n  if (options.host) {\n    // Use hostname if set, because it has precedence\n    if (!options.hostname) {\n      options.hostname = options.host;\n    }\n    delete options.host;\n  }\n\n  // Complete the URL object when necessary\n  if (!options.pathname && options.path) {\n    var searchPos = options.path.indexOf(\"?\");\n    if (searchPos < 0) {\n      options.pathname = options.path;\n    }\n    else {\n      options.pathname = options.path.substring(0, searchPos);\n      options.search = options.path.substring(searchPos);\n    }\n  }\n};\n\n\n// Executes the next native request (initial or redirect)\nRedirectableRequest.prototype._performRequest = function () {\n  // Load the native protocol\n  var protocol = this._options.protocol;\n  var nativeProtocol = this._options.nativeProtocols[protocol];\n  if (!nativeProtocol) {\n    throw new TypeError(\"Unsupported protocol \" + protocol);\n  }\n\n  // If specified, use the agent corresponding to the protocol\n  // (HTTP and HTTPS use different types of agents)\n  if (this._options.agents) {\n    var scheme = protocol.slice(0, -1);\n    this._options.agent = this._options.agents[scheme];\n  }\n\n  // Create the native request and set up its event handlers\n  var request = this._currentRequest =\n        nativeProtocol.request(this._options, this._onNativeResponse);\n  request._redirectable = this;\n  for (var event of events) {\n    request.on(event, eventHandlers[event]);\n  }\n\n  // RFC7230§5.3.1: When making a request directly to an origin server, […]\n  // a client MUST send only the absolute path […] as the request-target.\n  this._currentUrl = /^\\//.test(this._options.path) ?\n    url.format(this._options) :\n    // When making a request to a proxy, […]\n    // a client MUST send the target URI in absolute-form […].\n    this._options.path;\n\n  // End a redirected request\n  // (The first request must be ended explicitly with RedirectableRequest#end)\n  if (this._isRedirect) {\n    // Write the request entity and end\n    var i = 0;\n    var self = this;\n    var buffers = this._requestBodyBuffers;\n    (function writeNext(error) {\n      // Only write if this request has not been redirected yet\n      /* istanbul ignore else */\n      if (request === self._currentRequest) {\n        // Report any write errors\n        /* istanbul ignore if */\n        if (error) {\n          self.emit(\"error\", error);\n        }\n        // Write the next buffer if there are still left\n        else if (i < buffers.length) {\n          var buffer = buffers[i++];\n          /* istanbul ignore else */\n          if (!request.finished) {\n            request.write(buffer.data, buffer.encoding, writeNext);\n          }\n        }\n        // End the request if `end` has been called on us\n        else if (self._ended) {\n          request.end();\n        }\n      }\n    }());\n  }\n};\n\n// Processes a response from the current native request\nRedirectableRequest.prototype._processResponse = function (response) {\n  // Store the redirected response\n  var statusCode = response.statusCode;\n  if (this._options.trackRedirects) {\n    this._redirects.push({\n      url: this._currentUrl,\n      headers: response.headers,\n      statusCode: statusCode,\n    });\n  }\n\n  // RFC7231§6.4: The 3xx (Redirection) class of status code indicates\n  // that further action needs to be taken by the user agent in order to\n  // fulfill the request. If a Location header field is provided,\n  // the user agent MAY automatically redirect its request to the URI\n  // referenced by the Location field value,\n  // even if the specific status code is not understood.\n\n  // If the response is not a redirect; return it as-is\n  var location = response.headers.location;\n  if (!location || this._options.followRedirects === false ||\n      statusCode < 300 || statusCode >= 400) {\n    response.responseUrl = this._currentUrl;\n    response.redirects = this._redirects;\n    this.emit(\"response\", response);\n\n    // Clean up\n    this._requestBodyBuffers = [];\n    return;\n  }\n\n  // The response is a redirect, so abort the current request\n  destroyRequest(this._currentRequest);\n  // Discard the remainder of the response to avoid waiting for data\n  response.destroy();\n\n  // RFC7231§6.4: A client SHOULD detect and intervene\n  // in cyclical redirections (i.e., \"infinite\" redirection loops).\n  if (++this._redirectCount > this._options.maxRedirects) {\n    throw new TooManyRedirectsError();\n  }\n\n  // Store the request headers if applicable\n  var requestHeaders;\n  var beforeRedirect = this._options.beforeRedirect;\n  if (beforeRedirect) {\n    requestHeaders = Object.assign({\n      // The Host header was set by nativeProtocol.request\n      Host: response.req.getHeader(\"host\"),\n    }, this._options.headers);\n  }\n\n  // RFC7231§6.4: Automatic redirection needs to done with\n  // care for methods not known to be safe, […]\n  // RFC7231§6.4.2–3: For historical reasons, a user agent MAY change\n  // the request method from POST to GET for the subsequent request.\n  var method = this._options.method;\n  if ((statusCode === 301 || statusCode === 302) && this._options.method === \"POST\" ||\n      // RFC7231§6.4.4: The 303 (See Other) status code indicates that\n      // the server is redirecting the user agent to a different resource […]\n      // A user agent can perform a retrieval request targeting that URI\n      // (a GET or HEAD request if using HTTP) […]\n      (statusCode === 303) && !/^(?:GET|HEAD)$/.test(this._options.method)) {\n    this._options.method = \"GET\";\n    // Drop a possible entity and headers related to it\n    this._requestBodyBuffers = [];\n    removeMatchingHeaders(/^content-/i, this._options.headers);\n  }\n\n  // Drop the Host header, as the redirect might lead to a different host\n  var currentHostHeader = removeMatchingHeaders(/^host$/i, this._options.headers);\n\n  // If the redirect is relative, carry over the host of the last request\n  var currentUrlParts = parseUrl(this._currentUrl);\n  var currentHost = currentHostHeader || currentUrlParts.host;\n  var currentUrl = /^\\w+:/.test(location) ? this._currentUrl :\n    url.format(Object.assign(currentUrlParts, { host: currentHost }));\n\n  // Create the redirected request\n  var redirectUrl = resolveUrl(location, currentUrl);\n  debug(\"redirecting to\", redirectUrl.href);\n  this._isRedirect = true;\n  spreadUrlObject(redirectUrl, this._options);\n\n  // Drop confidential headers when redirecting to a less secure protocol\n  // or to a different domain that is not a superdomain\n  if (redirectUrl.protocol !== currentUrlParts.protocol &&\n     redirectUrl.protocol !== \"https:\" ||\n     redirectUrl.host !== currentHost &&\n     !isSubdomain(redirectUrl.host, currentHost)) {\n    removeMatchingHeaders(/^(?:(?:proxy-)?authorization|cookie)$/i, this._options.headers);\n  }\n\n  // Evaluate the beforeRedirect callback\n  if (isFunction(beforeRedirect)) {\n    var responseDetails = {\n      headers: response.headers,\n      statusCode: statusCode,\n    };\n    var requestDetails = {\n      url: currentUrl,\n      method: method,\n      headers: requestHeaders,\n    };\n    beforeRedirect(this._options, responseDetails, requestDetails);\n    this._sanitizeOptions(this._options);\n  }\n\n  // Perform the redirected request\n  this._performRequest();\n};\n\n// Wraps the key/value object of protocols with redirect functionality\nfunction wrap(protocols) {\n  // Default settings\n  var exports = {\n    maxRedirects: 21,\n    maxBodyLength: 10 * 1024 * 1024,\n  };\n\n  // Wrap each protocol\n  var nativeProtocols = {};\n  Object.keys(protocols).forEach(function (scheme) {\n    var protocol = scheme + \":\";\n    var nativeProtocol = nativeProtocols[protocol] = protocols[scheme];\n    var wrappedProtocol = exports[scheme] = Object.create(nativeProtocol);\n\n    // Executes a request, following redirects\n    function request(input, options, callback) {\n      // Parse parameters, ensuring that input is an object\n      if (isURL(input)) {\n        input = spreadUrlObject(input);\n      }\n      else if (isString(input)) {\n        input = spreadUrlObject(parseUrl(input));\n      }\n      else {\n        callback = options;\n        options = validateUrl(input);\n        input = { protocol: protocol };\n      }\n      if (isFunction(options)) {\n        callback = options;\n        options = null;\n      }\n\n      // Set defaults\n      options = Object.assign({\n        maxRedirects: exports.maxRedirects,\n        maxBodyLength: exports.maxBodyLength,\n      }, input, options);\n      options.nativeProtocols = nativeProtocols;\n      if (!isString(options.host) && !isString(options.hostname)) {\n        options.hostname = \"::1\";\n      }\n\n      assert.equal(options.protocol, protocol, \"protocol mismatch\");\n      debug(\"options\", options);\n      return new RedirectableRequest(options, callback);\n    }\n\n    // Executes a GET request, following redirects\n    function get(input, options, callback) {\n      var wrappedRequest = wrappedProtocol.request(input, options, callback);\n      wrappedRequest.end();\n      return wrappedRequest;\n    }\n\n    // Expose the properties on the wrapped protocol\n    Object.defineProperties(wrappedProtocol, {\n      request: { value: request, configurable: true, enumerable: true, writable: true },\n      get: { value: get, configurable: true, enumerable: true, writable: true },\n    });\n  });\n  return exports;\n}\n\nfunction noop() { /* empty */ }\n\nfunction parseUrl(input) {\n  var parsed;\n  /* istanbul ignore else */\n  if (useNativeURL) {\n    parsed = new URL(input);\n  }\n  else {\n    // Ensure the URL is valid and absolute\n    parsed = validateUrl(url.parse(input));\n    if (!isString(parsed.protocol)) {\n      throw new InvalidUrlError({ input });\n    }\n  }\n  return parsed;\n}\n\nfunction resolveUrl(relative, base) {\n  /* istanbul ignore next */\n  return useNativeURL ? new URL(relative, base) : parseUrl(url.resolve(base, relative));\n}\n\nfunction validateUrl(input) {\n  if (/^\\[/.test(input.hostname) && !/^\\[[:0-9a-f]+\\]$/i.test(input.hostname)) {\n    throw new InvalidUrlError({ input: input.href || input });\n  }\n  if (/^\\[/.test(input.host) && !/^\\[[:0-9a-f]+\\](:\\d+)?$/i.test(input.host)) {\n    throw new InvalidUrlError({ input: input.href || input });\n  }\n  return input;\n}\n\nfunction spreadUrlObject(urlObject, target) {\n  var spread = target || {};\n  for (var key of preservedUrlFields) {\n    spread[key] = urlObject[key];\n  }\n\n  // Fix IPv6 hostname\n  if (spread.hostname.startsWith(\"[\")) {\n    spread.hostname = spread.hostname.slice(1, -1);\n  }\n  // Ensure port is a number\n  if (spread.port !== \"\") {\n    spread.port = Number(spread.port);\n  }\n  // Concatenate path\n  spread.path = spread.search ? spread.pathname + spread.search : spread.pathname;\n\n  return spread;\n}\n\nfunction removeMatchingHeaders(regex, headers) {\n  var lastValue;\n  for (var header in headers) {\n    if (regex.test(header)) {\n      lastValue = headers[header];\n      delete headers[header];\n    }\n  }\n  return (lastValue === null || typeof lastValue === \"undefined\") ?\n    undefined : String(lastValue).trim();\n}\n\nfunction createErrorType(code, message, baseClass) {\n  // Create constructor\n  function CustomError(properties) {\n    Error.captureStackTrace(this, this.constructor);\n    Object.assign(this, properties || {});\n    this.code = code;\n    this.message = this.cause ? message + \": \" + this.cause.message : message;\n  }\n\n  // Attach constructor and set default properties\n  CustomError.prototype = new (baseClass || Error)();\n  Object.defineProperties(CustomError.prototype, {\n    constructor: {\n      value: CustomError,\n      enumerable: false,\n    },\n    name: {\n      value: \"Error [\" + code + \"]\",\n      enumerable: false,\n    },\n  });\n  return CustomError;\n}\n\nfunction destroyRequest(request, error) {\n  for (var event of events) {\n    request.removeListener(event, eventHandlers[event]);\n  }\n  request.on(\"error\", noop);\n  request.destroy(error);\n}\n\nfunction isSubdomain(subdomain, domain) {\n  assert(isString(subdomain) && isString(domain));\n  var dot = subdomain.length - domain.length - 1;\n  return dot > 0 && subdomain[dot] === \".\" && subdomain.endsWith(domain);\n}\n\nfunction isString(value) {\n  return typeof value === \"string\" || value instanceof String;\n}\n\nfunction isFunction(value) {\n  return typeof value === \"function\";\n}\n\nfunction isBuffer(value) {\n  return typeof value === \"object\" && (\"length\" in value);\n}\n\nfunction isURL(value) {\n  return URL && value instanceof URL;\n}\n\n// Exports\nmodule.exports = wrap({ http: http, https: https });\nmodule.exports.wrap = wrap;\n","var debug;\n\nmodule.exports = function () {\n  if (!debug) {\n    try {\n      /* eslint global-require: off */\n      debug = require(\"debug\")(\"follow-redirects\");\n    }\n    catch (error) { /* */ }\n    if (typeof debug !== \"function\") {\n      debug = function () { /* */ };\n    }\n  }\n  debug.apply(null, arguments);\n};\n","'use strict';\n\nexport default function parseProtocol(url) {\n  const match = /^([-+\\w]{1,25})(:?\\/\\/|:)/.exec(url);\n  return match && match[1] || '';\n}\n","'use strict';\n\nimport AxiosError from '../core/AxiosError.js';\nimport parseProtocol from './parseProtocol.js';\nimport platform from '../platform/index.js';\n\nconst DATA_URL_PATTERN = /^(?:([^;]+);)?(?:[^;]+;)?(base64|),([\\s\\S]*)$/;\n\n/**\n * Parse data uri to a Buffer or Blob\n *\n * @param {String} uri\n * @param {?Boolean} asBlob\n * @param {?Object} options\n * @param {?Function} options.Blob\n *\n * @returns {Buffer|Blob}\n */\nexport default function fromDataURI(uri, asBlob, options) {\n  const _Blob = options && options.Blob || platform.classes.Blob;\n  const protocol = parseProtocol(uri);\n\n  if (asBlob === undefined && _Blob) {\n    asBlob = true;\n  }\n\n  if (protocol === 'data') {\n    uri = protocol.length ? uri.slice(protocol.length + 1) : uri;\n\n    const match = DATA_URL_PATTERN.exec(uri);\n\n    if (!match) {\n      throw new AxiosError('Invalid URL', AxiosError.ERR_INVALID_URL);\n    }\n\n    const mime = match[1];\n    const isBase64 = match[2];\n    const body = match[3];\n    const buffer = Buffer.from(decodeURIComponent(body), isBase64 ? 'base64' : 'utf8');\n\n    if (asBlob) {\n      if (!_Blob) {\n        throw new AxiosError('Blob is not supported', AxiosError.ERR_NOT_SUPPORT);\n      }\n\n      return new _Blob([buffer], {type: mime});\n    }\n\n    return buffer;\n  }\n\n  throw new AxiosError('Unsupported protocol ' + protocol, AxiosError.ERR_NOT_SUPPORT);\n}\n","'use strict';\n\nimport stream from 'stream';\nimport utils from '../utils.js';\n\nconst kInternals = Symbol('internals');\n\nclass AxiosTransformStream extends stream.Transform{\n  constructor(options) {\n    options = utils.toFlatObject(options, {\n      maxRate: 0,\n      chunkSize: 64 * 1024,\n      minChunkSize: 100,\n      timeWindow: 500,\n      ticksRate: 2,\n      samplesCount: 15\n    }, null, (prop, source) => {\n      return !utils.isUndefined(source[prop]);\n    });\n\n    super({\n      readableHighWaterMark: options.chunkSize\n    });\n\n    const internals = this[kInternals] = {\n      timeWindow: options.timeWindow,\n      chunkSize: options.chunkSize,\n      maxRate: options.maxRate,\n      minChunkSize: options.minChunkSize,\n      bytesSeen: 0,\n      isCaptured: false,\n      notifiedBytesLoaded: 0,\n      ts: Date.now(),\n      bytes: 0,\n      onReadCallback: null\n    };\n\n    this.on('newListener', event => {\n      if (event === 'progress') {\n        if (!internals.isCaptured) {\n          internals.isCaptured = true;\n        }\n      }\n    });\n  }\n\n  _read(size) {\n    const internals = this[kInternals];\n\n    if (internals.onReadCallback) {\n      internals.onReadCallback();\n    }\n\n    return super._read(size);\n  }\n\n  _transform(chunk, encoding, callback) {\n    const internals = this[kInternals];\n    const maxRate = internals.maxRate;\n\n    const readableHighWaterMark = this.readableHighWaterMark;\n\n    const timeWindow = internals.timeWindow;\n\n    const divider = 1000 / timeWindow;\n    const bytesThreshold = (maxRate / divider);\n    const minChunkSize = internals.minChunkSize !== false ? Math.max(internals.minChunkSize, bytesThreshold * 0.01) : 0;\n\n    const pushChunk = (_chunk, _callback) => {\n      const bytes = Buffer.byteLength(_chunk);\n      internals.bytesSeen += bytes;\n      internals.bytes += bytes;\n\n      internals.isCaptured && this.emit('progress', internals.bytesSeen);\n\n      if (this.push(_chunk)) {\n        process.nextTick(_callback);\n      } else {\n        internals.onReadCallback = () => {\n          internals.onReadCallback = null;\n          process.nextTick(_callback);\n        };\n      }\n    }\n\n    const transformChunk = (_chunk, _callback) => {\n      const chunkSize = Buffer.byteLength(_chunk);\n      let chunkRemainder = null;\n      let maxChunkSize = readableHighWaterMark;\n      let bytesLeft;\n      let passed = 0;\n\n      if (maxRate) {\n        const now = Date.now();\n\n        if (!internals.ts || (passed = (now - internals.ts)) >= timeWindow) {\n          internals.ts = now;\n          bytesLeft = bytesThreshold - internals.bytes;\n          internals.bytes = bytesLeft < 0 ? -bytesLeft : 0;\n          passed = 0;\n        }\n\n        bytesLeft = bytesThreshold - internals.bytes;\n      }\n\n      if (maxRate) {\n        if (bytesLeft <= 0) {\n          // next time window\n          return setTimeout(() => {\n            _callback(null, _chunk);\n          }, timeWindow - passed);\n        }\n\n        if (bytesLeft < maxChunkSize) {\n          maxChunkSize = bytesLeft;\n        }\n      }\n\n      if (maxChunkSize && chunkSize > maxChunkSize && (chunkSize - maxChunkSize) > minChunkSize) {\n        chunkRemainder = _chunk.subarray(maxChunkSize);\n        _chunk = _chunk.subarray(0, maxChunkSize);\n      }\n\n      pushChunk(_chunk, chunkRemainder ? () => {\n        process.nextTick(_callback, null, chunkRemainder);\n      } : _callback);\n    };\n\n    transformChunk(chunk, function transformNextChunk(err, _chunk) {\n      if (err) {\n        return callback(err);\n      }\n\n      if (_chunk) {\n        transformChunk(_chunk, transformNextChunk);\n      } else {\n        callback(null);\n      }\n    });\n  }\n}\n\nexport default AxiosTransformStream;\n","const {asyncIterator} = Symbol;\n\nconst readBlob = async function* (blob) {\n  if (blob.stream) {\n    yield* blob.stream()\n  } else if (blob.arrayBuffer) {\n    yield await blob.arrayBuffer()\n  } else if (blob[asyncIterator]) {\n    yield* blob[asyncIterator]();\n  } else {\n    yield blob;\n  }\n}\n\nexport default readBlob;\n","import util from 'util';\nimport {Readable} from 'stream';\nimport utils from \"../utils.js\";\nimport readBlob from \"./readBlob.js\";\nimport platform from \"../platform/index.js\";\n\nconst BOUNDARY_ALPHABET = platform.ALPHABET.ALPHA_DIGIT + '-_';\n\nconst textEncoder = typeof TextEncoder === 'function' ? new TextEncoder() : new util.TextEncoder();\n\nconst CRLF = '\\r\\n';\nconst CRLF_BYTES = textEncoder.encode(CRLF);\nconst CRLF_BYTES_COUNT = 2;\n\nclass FormDataPart {\n  constructor(name, value) {\n    const {escapeName} = this.constructor;\n    const isStringValue = utils.isString(value);\n\n    let headers = `Content-Disposition: form-data; name=\"${escapeName(name)}\"${\n      !isStringValue && value.name ? `; filename=\"${escapeName(value.name)}\"` : ''\n    }${CRLF}`;\n\n    if (isStringValue) {\n      value = textEncoder.encode(String(value).replace(/\\r?\\n|\\r\\n?/g, CRLF));\n    } else {\n      headers += `Content-Type: ${value.type || \"application/octet-stream\"}${CRLF}`\n    }\n\n    this.headers = textEncoder.encode(headers + CRLF);\n\n    this.contentLength = isStringValue ? value.byteLength : value.size;\n\n    this.size = this.headers.byteLength + this.contentLength + CRLF_BYTES_COUNT;\n\n    this.name = name;\n    this.value = value;\n  }\n\n  async *encode(){\n    yield this.headers;\n\n    const {value} = this;\n\n    if(utils.isTypedArray(value)) {\n      yield value;\n    } else {\n      yield* readBlob(value);\n    }\n\n    yield CRLF_BYTES;\n  }\n\n  static escapeName(name) {\n      return String(name).replace(/[\\r\\n\"]/g, (match) => ({\n        '\\r' : '%0D',\n        '\\n' : '%0A',\n        '\"' : '%22',\n      }[match]));\n  }\n}\n\nconst formDataToStream = (form, headersHandler, options) => {\n  const {\n    tag = 'form-data-boundary',\n    size = 25,\n    boundary = tag + '-' + platform.generateString(size, BOUNDARY_ALPHABET)\n  } = options || {};\n\n  if(!utils.isFormData(form)) {\n    throw TypeError('FormData instance required');\n  }\n\n  if (boundary.length < 1 || boundary.length > 70) {\n    throw Error('boundary must be 10-70 characters long')\n  }\n\n  const boundaryBytes = textEncoder.encode('--' + boundary + CRLF);\n  const footerBytes = textEncoder.encode('--' + boundary + '--' + CRLF + CRLF);\n  let contentLength = footerBytes.byteLength;\n\n  const parts = Array.from(form.entries()).map(([name, value]) => {\n    const part = new FormDataPart(name, value);\n    contentLength += part.size;\n    return part;\n  });\n\n  contentLength += boundaryBytes.byteLength * parts.length;\n\n  contentLength = utils.toFiniteNumber(contentLength);\n\n  const computedHeaders = {\n    'Content-Type': `multipart/form-data; boundary=${boundary}`\n  }\n\n  if (Number.isFinite(contentLength)) {\n    computedHeaders['Content-Length'] = contentLength;\n  }\n\n  headersHandler && headersHandler(computedHeaders);\n\n  return Readable.from((async function *() {\n    for(const part of parts) {\n      yield boundaryBytes;\n      yield* part.encode();\n    }\n\n    yield footerBytes;\n  })());\n};\n\nexport default formDataToStream;\n","\"use strict\";\n\nimport stream from \"stream\";\n\nclass ZlibHeaderTransformStream extends stream.Transform {\n  __transform(chunk, encoding, callback) {\n    this.push(chunk);\n    callback();\n  }\n\n  _transform(chunk, encoding, callback) {\n    if (chunk.length !== 0) {\n      this._transform = this.__transform;\n\n      // Add Default Compression headers if no zlib headers are present\n      if (chunk[0] !== 120) { // Hex: 78\n        const header = Buffer.alloc(2);\n        header[0] = 120; // Hex: 78\n        header[1] = 156; // Hex: 9C \n        this.push(header, encoding);\n      }\n    }\n\n    this.__transform(chunk, encoding, callback);\n  }\n}\n\nexport default ZlibHeaderTransformStream;\n","import utils from \"../utils.js\";\n\nconst callbackify = (fn, reducer) => {\n  return utils.isAsyncFn(fn) ? function (...args) {\n    const cb = args.pop();\n    fn.apply(this, args).then((value) => {\n      try {\n        reducer ? cb(null, ...reducer(value)) : cb(null, value);\n      } catch (err) {\n        cb(err);\n      }\n    }, cb);\n  } : fn;\n}\n\nexport default callbackify;\n","import speedometer from \"./speedometer.js\";\nimport throttle from \"./throttle.js\";\nimport utils from \"../utils.js\";\n\nexport const progressEventReducer = (listener, isDownloadStream, freq = 3) => {\n  let bytesNotified = 0;\n  const _speedometer = speedometer(50, 250);\n\n  return throttle(e => {\n    const loaded = e.loaded;\n    const total = e.lengthComputable ? e.total : undefined;\n    const progressBytes = loaded - bytesNotified;\n    const rate = _speedometer(progressBytes);\n    const inRange = loaded <= total;\n\n    bytesNotified = loaded;\n\n    const data = {\n      loaded,\n      total,\n      progress: total ? (loaded / total) : undefined,\n      bytes: progressBytes,\n      rate: rate ? rate : undefined,\n      estimated: rate && total && inRange ? (total - loaded) / rate : undefined,\n      event: e,\n      lengthComputable: total != null,\n      [isDownloadStream ? 'download' : 'upload']: true\n    };\n\n    listener(data);\n  }, freq);\n}\n\nexport const progressEventDecorator = (total, throttled) => {\n  const lengthComputable = total != null;\n\n  return [(loaded) => throttled[0]({\n    lengthComputable,\n    total,\n    loaded\n  }), throttled[1]];\n}\n\nexport const asyncDecorator = (fn) => (...args) => utils.asap(() => fn(...args));\n","'use strict';\n\n/**\n * Calculate data maxRate\n * @param {Number} [samplesCount= 10]\n * @param {Number} [min= 1000]\n * @returns {Function}\n */\nfunction speedometer(samplesCount, min) {\n  samplesCount = samplesCount || 10;\n  const bytes = new Array(samplesCount);\n  const timestamps = new Array(samplesCount);\n  let head = 0;\n  let tail = 0;\n  let firstSampleTS;\n\n  min = min !== undefined ? min : 1000;\n\n  return function push(chunkLength) {\n    const now = Date.now();\n\n    const startedAt = timestamps[tail];\n\n    if (!firstSampleTS) {\n      firstSampleTS = now;\n    }\n\n    bytes[head] = chunkLength;\n    timestamps[head] = now;\n\n    let i = tail;\n    let bytesCount = 0;\n\n    while (i !== head) {\n      bytesCount += bytes[i++];\n      i = i % samplesCount;\n    }\n\n    head = (head + 1) % samplesCount;\n\n    if (head === tail) {\n      tail = (tail + 1) % samplesCount;\n    }\n\n    if (now - firstSampleTS < min) {\n      return;\n    }\n\n    const passed = startedAt && now - startedAt;\n\n    return passed ? Math.round(bytesCount * 1000 / passed) : undefined;\n  };\n}\n\nexport default speedometer;\n","/**\n * Throttle decorator\n * @param {Function} fn\n * @param {Number} freq\n * @return {Function}\n */\nfunction throttle(fn, freq) {\n  let timestamp = 0;\n  let threshold = 1000 / freq;\n  let lastArgs;\n  let timer;\n\n  const invoke = (args, now = Date.now()) => {\n    timestamp = now;\n    lastArgs = null;\n    if (timer) {\n      clearTimeout(timer);\n      timer = null;\n    }\n    fn.apply(null, args);\n  }\n\n  const throttled = (...args) => {\n    const now = Date.now();\n    const passed = now - timestamp;\n    if ( passed >= threshold) {\n      invoke(args, now);\n    } else {\n      lastArgs = args;\n      if (!timer) {\n        timer = setTimeout(() => {\n          timer = null;\n          invoke(lastArgs)\n        }, threshold - passed);\n      }\n    }\n  }\n\n  const flush = () => lastArgs && invoke(lastArgs);\n\n  return [throttled, flush];\n}\n\nexport default throttle;\n","'use strict';\n\nimport utils from './../utils.js';\nimport settle from './../core/settle.js';\nimport buildFullPath from '../core/buildFullPath.js';\nimport buildURL from './../helpers/buildURL.js';\nimport proxyFromEnv from 'proxy-from-env';\nimport http from 'http';\nimport https from 'https';\nimport util from 'util';\nimport followRedirects from 'follow-redirects';\nimport zlib from 'zlib';\nimport {VERSION} from '../env/data.js';\nimport transitionalDefaults from '../defaults/transitional.js';\nimport AxiosError from '../core/AxiosError.js';\nimport CanceledError from '../cancel/CanceledError.js';\nimport platform from '../platform/index.js';\nimport fromDataURI from '../helpers/fromDataURI.js';\nimport stream from 'stream';\nimport AxiosHeaders from '../core/AxiosHeaders.js';\nimport AxiosTransformStream from '../helpers/AxiosTransformStream.js';\nimport {EventEmitter} from 'events';\nimport formDataToStream from \"../helpers/formDataToStream.js\";\nimport readBlob from \"../helpers/readBlob.js\";\nimport ZlibHeaderTransformStream from '../helpers/ZlibHeaderTransformStream.js';\nimport callbackify from \"../helpers/callbackify.js\";\nimport {progressEventReducer, progressEventDecorator, asyncDecorator} from \"../helpers/progressEventReducer.js\";\n\nconst zlibOptions = {\n  flush: zlib.constants.Z_SYNC_FLUSH,\n  finishFlush: zlib.constants.Z_SYNC_FLUSH\n};\n\nconst brotliOptions = {\n  flush: zlib.constants.BROTLI_OPERATION_FLUSH,\n  finishFlush: zlib.constants.BROTLI_OPERATION_FLUSH\n}\n\nconst isBrotliSupported = utils.isFunction(zlib.createBrotliDecompress);\n\nconst {http: httpFollow, https: httpsFollow} = followRedirects;\n\nconst isHttps = /https:?/;\n\nconst supportedProtocols = platform.protocols.map(protocol => {\n  return protocol + ':';\n});\n\nconst flushOnFinish = (stream, [throttled, flush]) => {\n  stream\n    .on('end', flush)\n    .on('error', flush);\n\n  return throttled;\n}\n\n/**\n * If the proxy or config beforeRedirects functions are defined, call them with the options\n * object.\n *\n * @param {Object<string, any>} options - The options object that was passed to the request.\n *\n * @returns {Object<string, any>}\n */\nfunction dispatchBeforeRedirect(options, responseDetails) {\n  if (options.beforeRedirects.proxy) {\n    options.beforeRedirects.proxy(options);\n  }\n  if (options.beforeRedirects.config) {\n    options.beforeRedirects.config(options, responseDetails);\n  }\n}\n\n/**\n * If the proxy or config afterRedirects functions are defined, call them with the options\n *\n * @param {http.ClientRequestArgs} options\n * @param {AxiosProxyConfig} configProxy configuration from Axios options object\n * @param {string} location\n *\n * @returns {http.ClientRequestArgs}\n */\nfunction setProxy(options, configProxy, location) {\n  let proxy = configProxy;\n  if (!proxy && proxy !== false) {\n    const proxyUrl = proxyFromEnv.getProxyForUrl(location);\n    if (proxyUrl) {\n      proxy = new URL(proxyUrl);\n    }\n  }\n  if (proxy) {\n    // Basic proxy authorization\n    if (proxy.username) {\n      proxy.auth = (proxy.username || '') + ':' + (proxy.password || '');\n    }\n\n    if (proxy.auth) {\n      // Support proxy auth object form\n      if (proxy.auth.username || proxy.auth.password) {\n        proxy.auth = (proxy.auth.username || '') + ':' + (proxy.auth.password || '');\n      }\n      const base64 = Buffer\n        .from(proxy.auth, 'utf8')\n        .toString('base64');\n      options.headers['Proxy-Authorization'] = 'Basic ' + base64;\n    }\n\n    options.headers.host = options.hostname + (options.port ? ':' + options.port : '');\n    const proxyHost = proxy.hostname || proxy.host;\n    options.hostname = proxyHost;\n    // Replace 'host' since options is not a URL object\n    options.host = proxyHost;\n    options.port = proxy.port;\n    options.path = location;\n    if (proxy.protocol) {\n      options.protocol = proxy.protocol.includes(':') ? proxy.protocol : `${proxy.protocol}:`;\n    }\n  }\n\n  options.beforeRedirects.proxy = function beforeRedirect(redirectOptions) {\n    // Configure proxy for redirected request, passing the original config proxy to apply\n    // the exact same logic as if the redirected request was performed by axios directly.\n    setProxy(redirectOptions, configProxy, redirectOptions.href);\n  };\n}\n\nconst isHttpAdapterSupported = typeof process !== 'undefined' && utils.kindOf(process) === 'process';\n\n// temporary hotfix\n\nconst wrapAsync = (asyncExecutor) => {\n  return new Promise((resolve, reject) => {\n    let onDone;\n    let isDone;\n\n    const done = (value, isRejected) => {\n      if (isDone) return;\n      isDone = true;\n      onDone && onDone(value, isRejected);\n    }\n\n    const _resolve = (value) => {\n      done(value);\n      resolve(value);\n    };\n\n    const _reject = (reason) => {\n      done(reason, true);\n      reject(reason);\n    }\n\n    asyncExecutor(_resolve, _reject, (onDoneHandler) => (onDone = onDoneHandler)).catch(_reject);\n  })\n};\n\nconst resolveFamily = ({address, family}) => {\n  if (!utils.isString(address)) {\n    throw TypeError('address must be a string');\n  }\n  return ({\n    address,\n    family: family || (address.indexOf('.') < 0 ? 6 : 4)\n  });\n}\n\nconst buildAddressEntry = (address, family) => resolveFamily(utils.isObject(address) ? address : {address, family});\n\n/*eslint consistent-return:0*/\nexport default isHttpAdapterSupported && function httpAdapter(config) {\n  return wrapAsync(async function dispatchHttpRequest(resolve, reject, onDone) {\n    let {data, lookup, family} = config;\n    const {responseType, responseEncoding} = config;\n    const method = config.method.toUpperCase();\n    let isDone;\n    let rejected = false;\n    let req;\n\n    if (lookup) {\n      const _lookup = callbackify(lookup, (value) => utils.isArray(value) ? value : [value]);\n      // hotfix to support opt.all option which is required for node 20.x\n      lookup = (hostname, opt, cb) => {\n        _lookup(hostname, opt, (err, arg0, arg1) => {\n          if (err) {\n            return cb(err);\n          }\n\n          const addresses = utils.isArray(arg0) ? arg0.map(addr => buildAddressEntry(addr)) : [buildAddressEntry(arg0, arg1)];\n\n          opt.all ? cb(err, addresses) : cb(err, addresses[0].address, addresses[0].family);\n        });\n      }\n    }\n\n    // temporary internal emitter until the AxiosRequest class will be implemented\n    const emitter = new EventEmitter();\n\n    const onFinished = () => {\n      if (config.cancelToken) {\n        config.cancelToken.unsubscribe(abort);\n      }\n\n      if (config.signal) {\n        config.signal.removeEventListener('abort', abort);\n      }\n\n      emitter.removeAllListeners();\n    }\n\n    onDone((value, isRejected) => {\n      isDone = true;\n      if (isRejected) {\n        rejected = true;\n        onFinished();\n      }\n    });\n\n    function abort(reason) {\n      emitter.emit('abort', !reason || reason.type ? new CanceledError(null, config, req) : reason);\n    }\n\n    emitter.once('abort', reject);\n\n    if (config.cancelToken || config.signal) {\n      config.cancelToken && config.cancelToken.subscribe(abort);\n      if (config.signal) {\n        config.signal.aborted ? abort() : config.signal.addEventListener('abort', abort);\n      }\n    }\n\n    // Parse url\n    const fullPath = buildFullPath(config.baseURL, config.url, config.allowAbsoluteUrls);\n    const parsed = new URL(fullPath, platform.hasBrowserEnv ? platform.origin : undefined);\n    const protocol = parsed.protocol || supportedProtocols[0];\n\n    if (protocol === 'data:') {\n      let convertedData;\n\n      if (method !== 'GET') {\n        return settle(resolve, reject, {\n          status: 405,\n          statusText: 'method not allowed',\n          headers: {},\n          config\n        });\n      }\n\n      try {\n        convertedData = fromDataURI(config.url, responseType === 'blob', {\n          Blob: config.env && config.env.Blob\n        });\n      } catch (err) {\n        throw AxiosError.from(err, AxiosError.ERR_BAD_REQUEST, config);\n      }\n\n      if (responseType === 'text') {\n        convertedData = convertedData.toString(responseEncoding);\n\n        if (!responseEncoding || responseEncoding === 'utf8') {\n          convertedData = utils.stripBOM(convertedData);\n        }\n      } else if (responseType === 'stream') {\n        convertedData = stream.Readable.from(convertedData);\n      }\n\n      return settle(resolve, reject, {\n        data: convertedData,\n        status: 200,\n        statusText: 'OK',\n        headers: new AxiosHeaders(),\n        config\n      });\n    }\n\n    if (supportedProtocols.indexOf(protocol) === -1) {\n      return reject(new AxiosError(\n        'Unsupported protocol ' + protocol,\n        AxiosError.ERR_BAD_REQUEST,\n        config\n      ));\n    }\n\n    const headers = AxiosHeaders.from(config.headers).normalize();\n\n    // Set User-Agent (required by some servers)\n    // See https://github.com/axios/axios/issues/69\n    // User-Agent is specified; handle case where no UA header is desired\n    // Only set header if it hasn't been set in config\n    headers.set('User-Agent', 'axios/' + VERSION, false);\n\n    const {onUploadProgress, onDownloadProgress} = config;\n    const maxRate = config.maxRate;\n    let maxUploadRate = undefined;\n    let maxDownloadRate = undefined;\n\n    // support for spec compliant FormData objects\n    if (utils.isSpecCompliantForm(data)) {\n      const userBoundary = headers.getContentType(/boundary=([-_\\w\\d]{10,70})/i);\n\n      data = formDataToStream(data, (formHeaders) => {\n        headers.set(formHeaders);\n      }, {\n        tag: `axios-${VERSION}-boundary`,\n        boundary: userBoundary && userBoundary[1] || undefined\n      });\n      // support for https://www.npmjs.com/package/form-data api\n    } else if (utils.isFormData(data) && utils.isFunction(data.getHeaders)) {\n      headers.set(data.getHeaders());\n\n      if (!headers.hasContentLength()) {\n        try {\n          const knownLength = await util.promisify(data.getLength).call(data);\n          Number.isFinite(knownLength) && knownLength >= 0 && headers.setContentLength(knownLength);\n          /*eslint no-empty:0*/\n        } catch (e) {\n        }\n      }\n    } else if (utils.isBlob(data) || utils.isFile(data)) {\n      data.size && headers.setContentType(data.type || 'application/octet-stream');\n      headers.setContentLength(data.size || 0);\n      data = stream.Readable.from(readBlob(data));\n    } else if (data && !utils.isStream(data)) {\n      if (Buffer.isBuffer(data)) {\n        // Nothing to do...\n      } else if (utils.isArrayBuffer(data)) {\n        data = Buffer.from(new Uint8Array(data));\n      } else if (utils.isString(data)) {\n        data = Buffer.from(data, 'utf-8');\n      } else {\n        return reject(new AxiosError(\n          'Data after transformation must be a string, an ArrayBuffer, a Buffer, or a Stream',\n          AxiosError.ERR_BAD_REQUEST,\n          config\n        ));\n      }\n\n      // Add Content-Length header if data exists\n      headers.setContentLength(data.length, false);\n\n      if (config.maxBodyLength > -1 && data.length > config.maxBodyLength) {\n        return reject(new AxiosError(\n          'Request body larger than maxBodyLength limit',\n          AxiosError.ERR_BAD_REQUEST,\n          config\n        ));\n      }\n    }\n\n    const contentLength = utils.toFiniteNumber(headers.getContentLength());\n\n    if (utils.isArray(maxRate)) {\n      maxUploadRate = maxRate[0];\n      maxDownloadRate = maxRate[1];\n    } else {\n      maxUploadRate = maxDownloadRate = maxRate;\n    }\n\n    if (data && (onUploadProgress || maxUploadRate)) {\n      if (!utils.isStream(data)) {\n        data = stream.Readable.from(data, {objectMode: false});\n      }\n\n      data = stream.pipeline([data, new AxiosTransformStream({\n        maxRate: utils.toFiniteNumber(maxUploadRate)\n      })], utils.noop);\n\n      onUploadProgress && data.on('progress', flushOnFinish(\n        data,\n        progressEventDecorator(\n          contentLength,\n          progressEventReducer(asyncDecorator(onUploadProgress), false, 3)\n        )\n      ));\n    }\n\n    // HTTP basic authentication\n    let auth = undefined;\n    if (config.auth) {\n      const username = config.auth.username || '';\n      const password = config.auth.password || '';\n      auth = username + ':' + password;\n    }\n\n    if (!auth && parsed.username) {\n      const urlUsername = parsed.username;\n      const urlPassword = parsed.password;\n      auth = urlUsername + ':' + urlPassword;\n    }\n\n    auth && headers.delete('authorization');\n\n    let path;\n\n    try {\n      path = buildURL(\n        parsed.pathname + parsed.search,\n        config.params,\n        config.paramsSerializer\n      ).replace(/^\\?/, '');\n    } catch (err) {\n      const customErr = new Error(err.message);\n      customErr.config = config;\n      customErr.url = config.url;\n      customErr.exists = true;\n      return reject(customErr);\n    }\n\n    headers.set(\n      'Accept-Encoding',\n      'gzip, compress, deflate' + (isBrotliSupported ? ', br' : ''), false\n      );\n\n    const options = {\n      path,\n      method: method,\n      headers: headers.toJSON(),\n      agents: { http: config.httpAgent, https: config.httpsAgent },\n      auth,\n      protocol,\n      family,\n      beforeRedirect: dispatchBeforeRedirect,\n      beforeRedirects: {}\n    };\n\n    // cacheable-lookup integration hotfix\n    !utils.isUndefined(lookup) && (options.lookup = lookup);\n\n    if (config.socketPath) {\n      options.socketPath = config.socketPath;\n    } else {\n      options.hostname = parsed.hostname.startsWith(\"[\") ? parsed.hostname.slice(1, -1) : parsed.hostname;\n      options.port = parsed.port;\n      setProxy(options, config.proxy, protocol + '//' + parsed.hostname + (parsed.port ? ':' + parsed.port : '') + options.path);\n    }\n\n    let transport;\n    const isHttpsRequest = isHttps.test(options.protocol);\n    options.agent = isHttpsRequest ? config.httpsAgent : config.httpAgent;\n    if (config.transport) {\n      transport = config.transport;\n    } else if (config.maxRedirects === 0) {\n      transport = isHttpsRequest ? https : http;\n    } else {\n      if (config.maxRedirects) {\n        options.maxRedirects = config.maxRedirects;\n      }\n      if (config.beforeRedirect) {\n        options.beforeRedirects.config = config.beforeRedirect;\n      }\n      transport = isHttpsRequest ? httpsFollow : httpFollow;\n    }\n\n    if (config.maxBodyLength > -1) {\n      options.maxBodyLength = config.maxBodyLength;\n    } else {\n      // follow-redirects does not skip comparison, so it should always succeed for axios -1 unlimited\n      options.maxBodyLength = Infinity;\n    }\n\n    if (config.insecureHTTPParser) {\n      options.insecureHTTPParser = config.insecureHTTPParser;\n    }\n\n    // Create the request\n    req = transport.request(options, function handleResponse(res) {\n      if (req.destroyed) return;\n\n      const streams = [res];\n\n      const responseLength = +res.headers['content-length'];\n\n      if (onDownloadProgress || maxDownloadRate) {\n        const transformStream = new AxiosTransformStream({\n          maxRate: utils.toFiniteNumber(maxDownloadRate)\n        });\n\n        onDownloadProgress && transformStream.on('progress', flushOnFinish(\n          transformStream,\n          progressEventDecorator(\n            responseLength,\n            progressEventReducer(asyncDecorator(onDownloadProgress), true, 3)\n          )\n        ));\n\n        streams.push(transformStream);\n      }\n\n      // decompress the response body transparently if required\n      let responseStream = res;\n\n      // return the last request in case of redirects\n      const lastRequest = res.req || req;\n\n      // if decompress disabled we should not decompress\n      if (config.decompress !== false && res.headers['content-encoding']) {\n        // if no content, but headers still say that it is encoded,\n        // remove the header not confuse downstream operations\n        if (method === 'HEAD' || res.statusCode === 204) {\n          delete res.headers['content-encoding'];\n        }\n\n        switch ((res.headers['content-encoding'] || '').toLowerCase()) {\n        /*eslint default-case:0*/\n        case 'gzip':\n        case 'x-gzip':\n        case 'compress':\n        case 'x-compress':\n          // add the unzipper to the body stream processing pipeline\n          streams.push(zlib.createUnzip(zlibOptions));\n\n          // remove the content-encoding in order to not confuse downstream operations\n          delete res.headers['content-encoding'];\n          break;\n        case 'deflate':\n          streams.push(new ZlibHeaderTransformStream());\n\n          // add the unzipper to the body stream processing pipeline\n          streams.push(zlib.createUnzip(zlibOptions));\n\n          // remove the content-encoding in order to not confuse downstream operations\n          delete res.headers['content-encoding'];\n          break;\n        case 'br':\n          if (isBrotliSupported) {\n            streams.push(zlib.createBrotliDecompress(brotliOptions));\n            delete res.headers['content-encoding'];\n          }\n        }\n      }\n\n      responseStream = streams.length > 1 ? stream.pipeline(streams, utils.noop) : streams[0];\n\n      const offListeners = stream.finished(responseStream, () => {\n        offListeners();\n        onFinished();\n      });\n\n      const response = {\n        status: res.statusCode,\n        statusText: res.statusMessage,\n        headers: new AxiosHeaders(res.headers),\n        config,\n        request: lastRequest\n      };\n\n      if (responseType === 'stream') {\n        response.data = responseStream;\n        settle(resolve, reject, response);\n      } else {\n        const responseBuffer = [];\n        let totalResponseBytes = 0;\n\n        responseStream.on('data', function handleStreamData(chunk) {\n          responseBuffer.push(chunk);\n          totalResponseBytes += chunk.length;\n\n          // make sure the content length is not over the maxContentLength if specified\n          if (config.maxContentLength > -1 && totalResponseBytes > config.maxContentLength) {\n            // stream.destroy() emit aborted event before calling reject() on Node.js v16\n            rejected = true;\n            responseStream.destroy();\n            reject(new AxiosError('maxContentLength size of ' + config.maxContentLength + ' exceeded',\n              AxiosError.ERR_BAD_RESPONSE, config, lastRequest));\n          }\n        });\n\n        responseStream.on('aborted', function handlerStreamAborted() {\n          if (rejected) {\n            return;\n          }\n\n          const err = new AxiosError(\n            'stream has been aborted',\n            AxiosError.ERR_BAD_RESPONSE,\n            config,\n            lastRequest\n          );\n          responseStream.destroy(err);\n          reject(err);\n        });\n\n        responseStream.on('error', function handleStreamError(err) {\n          if (req.destroyed) return;\n          reject(AxiosError.from(err, null, config, lastRequest));\n        });\n\n        responseStream.on('end', function handleStreamEnd() {\n          try {\n            let responseData = responseBuffer.length === 1 ? responseBuffer[0] : Buffer.concat(responseBuffer);\n            if (responseType !== 'arraybuffer') {\n              responseData = responseData.toString(responseEncoding);\n              if (!responseEncoding || responseEncoding === 'utf8') {\n                responseData = utils.stripBOM(responseData);\n              }\n            }\n            response.data = responseData;\n          } catch (err) {\n            return reject(AxiosError.from(err, null, config, response.request, response));\n          }\n          settle(resolve, reject, response);\n        });\n      }\n\n      emitter.once('abort', err => {\n        if (!responseStream.destroyed) {\n          responseStream.emit('error', err);\n          responseStream.destroy();\n        }\n      });\n    });\n\n    emitter.once('abort', err => {\n      reject(err);\n      req.destroy(err);\n    });\n\n    // Handle errors\n    req.on('error', function handleRequestError(err) {\n      // @todo remove\n      // if (req.aborted && err.code !== AxiosError.ERR_FR_TOO_MANY_REDIRECTS) return;\n      reject(AxiosError.from(err, null, config, req));\n    });\n\n    // set tcp keep alive to prevent drop connection by peer\n    req.on('socket', function handleRequestSocket(socket) {\n      // default interval of sending ack packet is 1 minute\n      socket.setKeepAlive(true, 1000 * 60);\n    });\n\n    // Handle request timeout\n    if (config.timeout) {\n      // This is forcing a int timeout to avoid problems if the `req` interface doesn't handle other types.\n      const timeout = parseInt(config.timeout, 10);\n\n      if (Number.isNaN(timeout)) {\n        reject(new AxiosError(\n          'error trying to parse `config.timeout` to int',\n          AxiosError.ERR_BAD_OPTION_VALUE,\n          config,\n          req\n        ));\n\n        return;\n      }\n\n      // Sometime, the response will be very slow, and does not respond, the connect event will be block by event loop system.\n      // And timer callback will be fired, and abort() will be invoked before connection, then get \"socket hang up\" and code ECONNRESET.\n      // At this time, if we have a large number of request, nodejs will hang up some socket on background. and the number will up and up.\n      // And then these socket which be hang up will devouring CPU little by little.\n      // ClientRequest.setTimeout will be fired on the specify milliseconds, and can make sure that abort() will be fired after connect.\n      req.setTimeout(timeout, function handleRequestTimeout() {\n        if (isDone) return;\n        let timeoutErrorMessage = config.timeout ? 'timeout of ' + config.timeout + 'ms exceeded' : 'timeout exceeded';\n        const transitional = config.transitional || transitionalDefaults;\n        if (config.timeoutErrorMessage) {\n          timeoutErrorMessage = config.timeoutErrorMessage;\n        }\n        reject(new AxiosError(\n          timeoutErrorMessage,\n          transitional.clarifyTimeoutError ? AxiosError.ETIMEDOUT : AxiosError.ECONNABORTED,\n          config,\n          req\n        ));\n        abort();\n      });\n    }\n\n\n    // Send the request\n    if (utils.isStream(data)) {\n      let ended = false;\n      let errored = false;\n\n      data.on('end', () => {\n        ended = true;\n      });\n\n      data.once('error', err => {\n        errored = true;\n        req.destroy(err);\n      });\n\n      data.on('close', () => {\n        if (!ended && !errored) {\n          abort(new CanceledError('Request stream has been aborted', config, req));\n        }\n      });\n\n      data.pipe(req);\n    } else {\n      req.end(data);\n    }\n  });\n}\n\nexport const __setProxy = setProxy;\n","import platform from '../platform/index.js';\n\nexport default platform.hasStandardBrowserEnv ? ((origin, isMSIE) => (url) => {\n  url = new URL(url, platform.origin);\n\n  return (\n    origin.protocol === url.protocol &&\n    origin.host === url.host &&\n    (isMSIE || origin.port === url.port)\n  );\n})(\n  new URL(platform.origin),\n  platform.navigator && /(msie|trident)/i.test(platform.navigator.userAgent)\n) : () => true;\n","import utils from './../utils.js';\nimport platform from '../platform/index.js';\n\nexport default platform.hasStandardBrowserEnv ?\n\n  // Standard browser envs support document.cookie\n  {\n    write(name, value, expires, path, domain, secure) {\n      const cookie = [name + '=' + encodeURIComponent(value)];\n\n      utils.isNumber(expires) && cookie.push('expires=' + new Date(expires).toGMTString());\n\n      utils.isString(path) && cookie.push('path=' + path);\n\n      utils.isString(domain) && cookie.push('domain=' + domain);\n\n      secure === true && cookie.push('secure');\n\n      document.cookie = cookie.join('; ');\n    },\n\n    read(name) {\n      const match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n      return (match ? decodeURIComponent(match[3]) : null);\n    },\n\n    remove(name) {\n      this.write(name, '', Date.now() - 86400000);\n    }\n  }\n\n  :\n\n  // Non-standard browser env (web workers, react-native) lack needed support.\n  {\n    write() {},\n    read() {\n      return null;\n    },\n    remove() {}\n  };\n\n","'use strict';\n\nimport utils from '../utils.js';\nimport AxiosHeaders from \"./AxiosHeaders.js\";\n\nconst headersToObject = (thing) => thing instanceof AxiosHeaders ? { ...thing } : thing;\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n *\n * @returns {Object} New object resulting from merging config2 to config1\n */\nexport default function mergeConfig(config1, config2) {\n  // eslint-disable-next-line no-param-reassign\n  config2 = config2 || {};\n  const config = {};\n\n  function getMergedValue(target, source, prop, caseless) {\n    if (utils.isPlainObject(target) && utils.isPlainObject(source)) {\n      return utils.merge.call({caseless}, target, source);\n    } else if (utils.isPlainObject(source)) {\n      return utils.merge({}, source);\n    } else if (utils.isArray(source)) {\n      return source.slice();\n    }\n    return source;\n  }\n\n  // eslint-disable-next-line consistent-return\n  function mergeDeepProperties(a, b, prop , caseless) {\n    if (!utils.isUndefined(b)) {\n      return getMergedValue(a, b, prop , caseless);\n    } else if (!utils.isUndefined(a)) {\n      return getMergedValue(undefined, a, prop , caseless);\n    }\n  }\n\n  // eslint-disable-next-line consistent-return\n  function valueFromConfig2(a, b) {\n    if (!utils.isUndefined(b)) {\n      return getMergedValue(undefined, b);\n    }\n  }\n\n  // eslint-disable-next-line consistent-return\n  function defaultToConfig2(a, b) {\n    if (!utils.isUndefined(b)) {\n      return getMergedValue(undefined, b);\n    } else if (!utils.isUndefined(a)) {\n      return getMergedValue(undefined, a);\n    }\n  }\n\n  // eslint-disable-next-line consistent-return\n  function mergeDirectKeys(a, b, prop) {\n    if (prop in config2) {\n      return getMergedValue(a, b);\n    } else if (prop in config1) {\n      return getMergedValue(undefined, a);\n    }\n  }\n\n  const mergeMap = {\n    url: valueFromConfig2,\n    method: valueFromConfig2,\n    data: valueFromConfig2,\n    baseURL: defaultToConfig2,\n    transformRequest: defaultToConfig2,\n    transformResponse: defaultToConfig2,\n    paramsSerializer: defaultToConfig2,\n    timeout: defaultToConfig2,\n    timeoutMessage: defaultToConfig2,\n    withCredentials: defaultToConfig2,\n    withXSRFToken: defaultToConfig2,\n    adapter: defaultToConfig2,\n    responseType: defaultToConfig2,\n    xsrfCookieName: defaultToConfig2,\n    xsrfHeaderName: defaultToConfig2,\n    onUploadProgress: defaultToConfig2,\n    onDownloadProgress: defaultToConfig2,\n    decompress: defaultToConfig2,\n    maxContentLength: defaultToConfig2,\n    maxBodyLength: defaultToConfig2,\n    beforeRedirect: defaultToConfig2,\n    transport: defaultToConfig2,\n    httpAgent: defaultToConfig2,\n    httpsAgent: defaultToConfig2,\n    cancelToken: defaultToConfig2,\n    socketPath: defaultToConfig2,\n    responseEncoding: defaultToConfig2,\n    validateStatus: mergeDirectKeys,\n    headers: (a, b , prop) => mergeDeepProperties(headersToObject(a), headersToObject(b),prop, true)\n  };\n\n  utils.forEach(Object.keys(Object.assign({}, config1, config2)), function computeConfigValue(prop) {\n    const merge = mergeMap[prop] || mergeDeepProperties;\n    const configValue = merge(config1[prop], config2[prop], prop);\n    (utils.isUndefined(configValue) && merge !== mergeDirectKeys) || (config[prop] = configValue);\n  });\n\n  return config;\n}\n","import platform from \"../platform/index.js\";\nimport utils from \"../utils.js\";\nimport isURLSameOrigin from \"./isURLSameOrigin.js\";\nimport cookies from \"./cookies.js\";\nimport buildFullPath from \"../core/buildFullPath.js\";\nimport mergeConfig from \"../core/mergeConfig.js\";\nimport AxiosHeaders from \"../core/AxiosHeaders.js\";\nimport buildURL from \"./buildURL.js\";\n\nexport default (config) => {\n  const newConfig = mergeConfig({}, config);\n\n  let {data, withXSRFToken, xsrfHeaderName, xsrfCookieName, headers, auth} = newConfig;\n\n  newConfig.headers = headers = AxiosHeaders.from(headers);\n\n  newConfig.url = buildURL(buildFullPath(newConfig.baseURL, newConfig.url, newConfig.allowAbsoluteUrls), config.params, config.paramsSerializer);\n\n  // HTTP basic authentication\n  if (auth) {\n    headers.set('Authorization', 'Basic ' +\n      btoa((auth.username || '') + ':' + (auth.password ? unescape(encodeURIComponent(auth.password)) : ''))\n    );\n  }\n\n  let contentType;\n\n  if (utils.isFormData(data)) {\n    if (platform.hasStandardBrowserEnv || platform.hasStandardBrowserWebWorkerEnv) {\n      headers.setContentType(undefined); // Let the browser set it\n    } else if ((contentType = headers.getContentType()) !== false) {\n      // fix semicolon duplication issue for ReactNative FormData implementation\n      const [type, ...tokens] = contentType ? contentType.split(';').map(token => token.trim()).filter(Boolean) : [];\n      headers.setContentType([type || 'multipart/form-data', ...tokens].join('; '));\n    }\n  }\n\n  // Add xsrf header\n  // This is only done if running in a standard browser environment.\n  // Specifically not if we're in a web worker, or react-native.\n\n  if (platform.hasStandardBrowserEnv) {\n    withXSRFToken && utils.isFunction(withXSRFToken) && (withXSRFToken = withXSRFToken(newConfig));\n\n    if (withXSRFToken || (withXSRFToken !== false && isURLSameOrigin(newConfig.url))) {\n      // Add xsrf header\n      const xsrfValue = xsrfHeaderName && xsrfCookieName && cookies.read(xsrfCookieName);\n\n      if (xsrfValue) {\n        headers.set(xsrfHeaderName, xsrfValue);\n      }\n    }\n  }\n\n  return newConfig;\n}\n\n","import utils from './../utils.js';\nimport settle from './../core/settle.js';\nimport transitionalDefaults from '../defaults/transitional.js';\nimport AxiosError from '../core/AxiosError.js';\nimport CanceledError from '../cancel/CanceledError.js';\nimport parseProtocol from '../helpers/parseProtocol.js';\nimport platform from '../platform/index.js';\nimport AxiosHeaders from '../core/AxiosHeaders.js';\nimport {progressEventReducer} from '../helpers/progressEventReducer.js';\nimport resolveConfig from \"../helpers/resolveConfig.js\";\n\nconst isXHRAdapterSupported = typeof XMLHttpRequest !== 'undefined';\n\nexport default isXHRAdapterSupported && function (config) {\n  return new Promise(function dispatchXhrRequest(resolve, reject) {\n    const _config = resolveConfig(config);\n    let requestData = _config.data;\n    const requestHeaders = AxiosHeaders.from(_config.headers).normalize();\n    let {responseType, onUploadProgress, onDownloadProgress} = _config;\n    let onCanceled;\n    let uploadThrottled, downloadThrottled;\n    let flushUpload, flushDownload;\n\n    function done() {\n      flushUpload && flushUpload(); // flush events\n      flushDownload && flushDownload(); // flush events\n\n      _config.cancelToken && _config.cancelToken.unsubscribe(onCanceled);\n\n      _config.signal && _config.signal.removeEventListener('abort', onCanceled);\n    }\n\n    let request = new XMLHttpRequest();\n\n    request.open(_config.method.toUpperCase(), _config.url, true);\n\n    // Set the request timeout in MS\n    request.timeout = _config.timeout;\n\n    function onloadend() {\n      if (!request) {\n        return;\n      }\n      // Prepare the response\n      const responseHeaders = AxiosHeaders.from(\n        'getAllResponseHeaders' in request && request.getAllResponseHeaders()\n      );\n      const responseData = !responseType || responseType === 'text' || responseType === 'json' ?\n        request.responseText : request.response;\n      const response = {\n        data: responseData,\n        status: request.status,\n        statusText: request.statusText,\n        headers: responseHeaders,\n        config,\n        request\n      };\n\n      settle(function _resolve(value) {\n        resolve(value);\n        done();\n      }, function _reject(err) {\n        reject(err);\n        done();\n      }, response);\n\n      // Clean up request\n      request = null;\n    }\n\n    if ('onloadend' in request) {\n      // Use onloadend if available\n      request.onloadend = onloadend;\n    } else {\n      // Listen for ready state to emulate onloadend\n      request.onreadystatechange = function handleLoad() {\n        if (!request || request.readyState !== 4) {\n          return;\n        }\n\n        // The request errored out and we didn't get a response, this will be\n        // handled by onerror instead\n        // With one exception: request that using file: protocol, most browsers\n        // will return status as 0 even though it's a successful request\n        if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n          return;\n        }\n        // readystate handler is calling before onerror or ontimeout handlers,\n        // so we should call onloadend on the next 'tick'\n        setTimeout(onloadend);\n      };\n    }\n\n    // Handle browser request cancellation (as opposed to a manual cancellation)\n    request.onabort = function handleAbort() {\n      if (!request) {\n        return;\n      }\n\n      reject(new AxiosError('Request aborted', AxiosError.ECONNABORTED, config, request));\n\n      // Clean up request\n      request = null;\n    };\n\n    // Handle low level network errors\n    request.onerror = function handleError() {\n      // Real errors are hidden from us by the browser\n      // onerror should only fire if it's a network error\n      reject(new AxiosError('Network Error', AxiosError.ERR_NETWORK, config, request));\n\n      // Clean up request\n      request = null;\n    };\n\n    // Handle timeout\n    request.ontimeout = function handleTimeout() {\n      let timeoutErrorMessage = _config.timeout ? 'timeout of ' + _config.timeout + 'ms exceeded' : 'timeout exceeded';\n      const transitional = _config.transitional || transitionalDefaults;\n      if (_config.timeoutErrorMessage) {\n        timeoutErrorMessage = _config.timeoutErrorMessage;\n      }\n      reject(new AxiosError(\n        timeoutErrorMessage,\n        transitional.clarifyTimeoutError ? AxiosError.ETIMEDOUT : AxiosError.ECONNABORTED,\n        config,\n        request));\n\n      // Clean up request\n      request = null;\n    };\n\n    // Remove Content-Type if data is undefined\n    requestData === undefined && requestHeaders.setContentType(null);\n\n    // Add headers to the request\n    if ('setRequestHeader' in request) {\n      utils.forEach(requestHeaders.toJSON(), function setRequestHeader(val, key) {\n        request.setRequestHeader(key, val);\n      });\n    }\n\n    // Add withCredentials to request if needed\n    if (!utils.isUndefined(_config.withCredentials)) {\n      request.withCredentials = !!_config.withCredentials;\n    }\n\n    // Add responseType to request if needed\n    if (responseType && responseType !== 'json') {\n      request.responseType = _config.responseType;\n    }\n\n    // Handle progress if needed\n    if (onDownloadProgress) {\n      ([downloadThrottled, flushDownload] = progressEventReducer(onDownloadProgress, true));\n      request.addEventListener('progress', downloadThrottled);\n    }\n\n    // Not all browsers support upload events\n    if (onUploadProgress && request.upload) {\n      ([uploadThrottled, flushUpload] = progressEventReducer(onUploadProgress));\n\n      request.upload.addEventListener('progress', uploadThrottled);\n\n      request.upload.addEventListener('loadend', flushUpload);\n    }\n\n    if (_config.cancelToken || _config.signal) {\n      // Handle cancellation\n      // eslint-disable-next-line func-names\n      onCanceled = cancel => {\n        if (!request) {\n          return;\n        }\n        reject(!cancel || cancel.type ? new CanceledError(null, config, request) : cancel);\n        request.abort();\n        request = null;\n      };\n\n      _config.cancelToken && _config.cancelToken.subscribe(onCanceled);\n      if (_config.signal) {\n        _config.signal.aborted ? onCanceled() : _config.signal.addEventListener('abort', onCanceled);\n      }\n    }\n\n    const protocol = parseProtocol(_config.url);\n\n    if (protocol && platform.protocols.indexOf(protocol) === -1) {\n      reject(new AxiosError('Unsupported protocol ' + protocol + ':', AxiosError.ERR_BAD_REQUEST, config));\n      return;\n    }\n\n\n    // Send the request\n    request.send(requestData || null);\n  });\n}\n","import CanceledError from \"../cancel/CanceledError.js\";\nimport AxiosError from \"../core/AxiosError.js\";\nimport utils from '../utils.js';\n\nconst composeSignals = (signals, timeout) => {\n  const {length} = (signals = signals ? signals.filter(Boolean) : []);\n\n  if (timeout || length) {\n    let controller = new AbortController();\n\n    let aborted;\n\n    const onabort = function (reason) {\n      if (!aborted) {\n        aborted = true;\n        unsubscribe();\n        const err = reason instanceof Error ? reason : this.reason;\n        controller.abort(err instanceof AxiosError ? err : new CanceledError(err instanceof Error ? err.message : err));\n      }\n    }\n\n    let timer = timeout && setTimeout(() => {\n      timer = null;\n      onabort(new AxiosError(`timeout ${timeout} of ms exceeded`, AxiosError.ETIMEDOUT))\n    }, timeout)\n\n    const unsubscribe = () => {\n      if (signals) {\n        timer && clearTimeout(timer);\n        timer = null;\n        signals.forEach(signal => {\n          signal.unsubscribe ? signal.unsubscribe(onabort) : signal.removeEventListener('abort', onabort);\n        });\n        signals = null;\n      }\n    }\n\n    signals.forEach((signal) => signal.addEventListener('abort', onabort));\n\n    const {signal} = controller;\n\n    signal.unsubscribe = () => utils.asap(unsubscribe);\n\n    return signal;\n  }\n}\n\nexport default composeSignals;\n","\nexport const streamChunk = function* (chunk, chunkSize) {\n  let len = chunk.byteLength;\n\n  if (!chunkSize || len < chunkSize) {\n    yield chunk;\n    return;\n  }\n\n  let pos = 0;\n  let end;\n\n  while (pos < len) {\n    end = pos + chunkSize;\n    yield chunk.slice(pos, end);\n    pos = end;\n  }\n}\n\nexport const readBytes = async function* (iterable, chunkSize) {\n  for await (const chunk of readStream(iterable)) {\n    yield* streamChunk(chunk, chunkSize);\n  }\n}\n\nconst readStream = async function* (stream) {\n  if (stream[Symbol.asyncIterator]) {\n    yield* stream;\n    return;\n  }\n\n  const reader = stream.getReader();\n  try {\n    for (;;) {\n      const {done, value} = await reader.read();\n      if (done) {\n        break;\n      }\n      yield value;\n    }\n  } finally {\n    await reader.cancel();\n  }\n}\n\nexport const trackStream = (stream, chunkSize, onProgress, onFinish) => {\n  const iterator = readBytes(stream, chunkSize);\n\n  let bytes = 0;\n  let done;\n  let _onFinish = (e) => {\n    if (!done) {\n      done = true;\n      onFinish && onFinish(e);\n    }\n  }\n\n  return new ReadableStream({\n    async pull(controller) {\n      try {\n        const {done, value} = await iterator.next();\n\n        if (done) {\n         _onFinish();\n          controller.close();\n          return;\n        }\n\n        let len = value.byteLength;\n        if (onProgress) {\n          let loadedBytes = bytes += len;\n          onProgress(loadedBytes);\n        }\n        controller.enqueue(new Uint8Array(value));\n      } catch (err) {\n        _onFinish(err);\n        throw err;\n      }\n    },\n    cancel(reason) {\n      _onFinish(reason);\n      return iterator.return();\n    }\n  }, {\n    highWaterMark: 2\n  })\n}\n","import platform from \"../platform/index.js\";\nimport utils from \"../utils.js\";\nimport AxiosError from \"../core/AxiosError.js\";\nimport composeSignals from \"../helpers/composeSignals.js\";\nimport {trackStream} from \"../helpers/trackStream.js\";\nimport AxiosHeaders from \"../core/AxiosHeaders.js\";\nimport {progressEventReducer, progressEventDecorator, asyncDecorator} from \"../helpers/progressEventReducer.js\";\nimport resolveConfig from \"../helpers/resolveConfig.js\";\nimport settle from \"../core/settle.js\";\n\nconst isFetchSupported = typeof fetch === 'function' && typeof Request === 'function' && typeof Response === 'function';\nconst isReadableStreamSupported = isFetchSupported && typeof ReadableStream === 'function';\n\n// used only inside the fetch adapter\nconst encodeText = isFetchSupported && (typeof TextEncoder === 'function' ?\n    ((encoder) => (str) => encoder.encode(str))(new TextEncoder()) :\n    async (str) => new Uint8Array(await new Response(str).arrayBuffer())\n);\n\nconst test = (fn, ...args) => {\n  try {\n    return !!fn(...args);\n  } catch (e) {\n    return false\n  }\n}\n\nconst supportsRequestStream = isReadableStreamSupported && test(() => {\n  let duplexAccessed = false;\n\n  const hasContentType = new Request(platform.origin, {\n    body: new ReadableStream(),\n    method: 'POST',\n    get duplex() {\n      duplexAccessed = true;\n      return 'half';\n    },\n  }).headers.has('Content-Type');\n\n  return duplexAccessed && !hasContentType;\n});\n\nconst DEFAULT_CHUNK_SIZE = 64 * 1024;\n\nconst supportsResponseStream = isReadableStreamSupported &&\n  test(() => utils.isReadableStream(new Response('').body));\n\n\nconst resolvers = {\n  stream: supportsResponseStream && ((res) => res.body)\n};\n\nisFetchSupported && (((res) => {\n  ['text', 'arrayBuffer', 'blob', 'formData', 'stream'].forEach(type => {\n    !resolvers[type] && (resolvers[type] = utils.isFunction(res[type]) ? (res) => res[type]() :\n      (_, config) => {\n        throw new AxiosError(`Response type '${type}' is not supported`, AxiosError.ERR_NOT_SUPPORT, config);\n      })\n  });\n})(new Response));\n\nconst getBodyLength = async (body) => {\n  if (body == null) {\n    return 0;\n  }\n\n  if(utils.isBlob(body)) {\n    return body.size;\n  }\n\n  if(utils.isSpecCompliantForm(body)) {\n    const _request = new Request(platform.origin, {\n      method: 'POST',\n      body,\n    });\n    return (await _request.arrayBuffer()).byteLength;\n  }\n\n  if(utils.isArrayBufferView(body) || utils.isArrayBuffer(body)) {\n    return body.byteLength;\n  }\n\n  if(utils.isURLSearchParams(body)) {\n    body = body + '';\n  }\n\n  if(utils.isString(body)) {\n    return (await encodeText(body)).byteLength;\n  }\n}\n\nconst resolveBodyLength = async (headers, body) => {\n  const length = utils.toFiniteNumber(headers.getContentLength());\n\n  return length == null ? getBodyLength(body) : length;\n}\n\nexport default isFetchSupported && (async (config) => {\n  let {\n    url,\n    method,\n    data,\n    signal,\n    cancelToken,\n    timeout,\n    onDownloadProgress,\n    onUploadProgress,\n    responseType,\n    headers,\n    withCredentials = 'same-origin',\n    fetchOptions\n  } = resolveConfig(config);\n\n  responseType = responseType ? (responseType + '').toLowerCase() : 'text';\n\n  let composedSignal = composeSignals([signal, cancelToken && cancelToken.toAbortSignal()], timeout);\n\n  let request;\n\n  const unsubscribe = composedSignal && composedSignal.unsubscribe && (() => {\n      composedSignal.unsubscribe();\n  });\n\n  let requestContentLength;\n\n  try {\n    if (\n      onUploadProgress && supportsRequestStream && method !== 'get' && method !== 'head' &&\n      (requestContentLength = await resolveBodyLength(headers, data)) !== 0\n    ) {\n      let _request = new Request(url, {\n        method: 'POST',\n        body: data,\n        duplex: \"half\"\n      });\n\n      let contentTypeHeader;\n\n      if (utils.isFormData(data) && (contentTypeHeader = _request.headers.get('content-type'))) {\n        headers.setContentType(contentTypeHeader)\n      }\n\n      if (_request.body) {\n        const [onProgress, flush] = progressEventDecorator(\n          requestContentLength,\n          progressEventReducer(asyncDecorator(onUploadProgress))\n        );\n\n        data = trackStream(_request.body, DEFAULT_CHUNK_SIZE, onProgress, flush);\n      }\n    }\n\n    if (!utils.isString(withCredentials)) {\n      withCredentials = withCredentials ? 'include' : 'omit';\n    }\n\n    // Cloudflare Workers throws when credentials are defined\n    // see https://github.com/cloudflare/workerd/issues/902\n    const isCredentialsSupported = \"credentials\" in Request.prototype;\n    request = new Request(url, {\n      ...fetchOptions,\n      signal: composedSignal,\n      method: method.toUpperCase(),\n      headers: headers.normalize().toJSON(),\n      body: data,\n      duplex: \"half\",\n      credentials: isCredentialsSupported ? withCredentials : undefined\n    });\n\n    let response = await fetch(request);\n\n    const isStreamResponse = supportsResponseStream && (responseType === 'stream' || responseType === 'response');\n\n    if (supportsResponseStream && (onDownloadProgress || (isStreamResponse && unsubscribe))) {\n      const options = {};\n\n      ['status', 'statusText', 'headers'].forEach(prop => {\n        options[prop] = response[prop];\n      });\n\n      const responseContentLength = utils.toFiniteNumber(response.headers.get('content-length'));\n\n      const [onProgress, flush] = onDownloadProgress && progressEventDecorator(\n        responseContentLength,\n        progressEventReducer(asyncDecorator(onDownloadProgress), true)\n      ) || [];\n\n      response = new Response(\n        trackStream(response.body, DEFAULT_CHUNK_SIZE, onProgress, () => {\n          flush && flush();\n          unsubscribe && unsubscribe();\n        }),\n        options\n      );\n    }\n\n    responseType = responseType || 'text';\n\n    let responseData = await resolvers[utils.findKey(resolvers, responseType) || 'text'](response, config);\n\n    !isStreamResponse && unsubscribe && unsubscribe();\n\n    return await new Promise((resolve, reject) => {\n      settle(resolve, reject, {\n        data: responseData,\n        headers: AxiosHeaders.from(response.headers),\n        status: response.status,\n        statusText: response.statusText,\n        config,\n        request\n      })\n    })\n  } catch (err) {\n    unsubscribe && unsubscribe();\n\n    if (err && err.name === 'TypeError' && /fetch/i.test(err.message)) {\n      throw Object.assign(\n        new AxiosError('Network Error', AxiosError.ERR_NETWORK, config, request),\n        {\n          cause: err.cause || err\n        }\n      )\n    }\n\n    throw AxiosError.from(err, err && err.code, config, request);\n  }\n});\n\n\n","import utils from '../utils.js';\nimport httpAdapter from './http.js';\nimport xhrAdapter from './xhr.js';\nimport fetchAdapter from './fetch.js';\nimport AxiosError from \"../core/AxiosError.js\";\n\nconst knownAdapters = {\n  http: httpAdapter,\n  xhr: xhrAdapter,\n  fetch: fetchAdapter\n}\n\nutils.forEach(knownAdapters, (fn, value) => {\n  if (fn) {\n    try {\n      Object.defineProperty(fn, 'name', {value});\n    } catch (e) {\n      // eslint-disable-next-line no-empty\n    }\n    Object.defineProperty(fn, 'adapterName', {value});\n  }\n});\n\nconst renderReason = (reason) => `- ${reason}`;\n\nconst isResolvedHandle = (adapter) => utils.isFunction(adapter) || adapter === null || adapter === false;\n\nexport default {\n  getAdapter: (adapters) => {\n    adapters = utils.isArray(adapters) ? adapters : [adapters];\n\n    const {length} = adapters;\n    let nameOrAdapter;\n    let adapter;\n\n    const rejectedReasons = {};\n\n    for (let i = 0; i < length; i++) {\n      nameOrAdapter = adapters[i];\n      let id;\n\n      adapter = nameOrAdapter;\n\n      if (!isResolvedHandle(nameOrAdapter)) {\n        adapter = knownAdapters[(id = String(nameOrAdapter)).toLowerCase()];\n\n        if (adapter === undefined) {\n          throw new AxiosError(`Unknown adapter '${id}'`);\n        }\n      }\n\n      if (adapter) {\n        break;\n      }\n\n      rejectedReasons[id || '#' + i] = adapter;\n    }\n\n    if (!adapter) {\n\n      const reasons = Object.entries(rejectedReasons)\n        .map(([id, state]) => `adapter ${id} ` +\n          (state === false ? 'is not supported by the environment' : 'is not available in the build')\n        );\n\n      let s = length ?\n        (reasons.length > 1 ? 'since :\\n' + reasons.map(renderReason).join('\\n') : ' ' + renderReason(reasons[0])) :\n        'as no adapter specified';\n\n      throw new AxiosError(\n        `There is no suitable adapter to dispatch the request ` + s,\n        'ERR_NOT_SUPPORT'\n      );\n    }\n\n    return adapter;\n  },\n  adapters: knownAdapters\n}\n","'use strict';\n\nimport transformData from './transformData.js';\nimport isCancel from '../cancel/isCancel.js';\nimport defaults from '../defaults/index.js';\nimport CanceledError from '../cancel/CanceledError.js';\nimport AxiosHeaders from '../core/AxiosHeaders.js';\nimport adapters from \"../adapters/adapters.js\";\n\n/**\n * Throws a `CanceledError` if cancellation has been requested.\n *\n * @param {Object} config The config that is to be used for the request\n *\n * @returns {void}\n */\nfunction throwIfCancellationRequested(config) {\n  if (config.cancelToken) {\n    config.cancelToken.throwIfRequested();\n  }\n\n  if (config.signal && config.signal.aborted) {\n    throw new CanceledError(null, config);\n  }\n}\n\n/**\n * Dispatch a request to the server using the configured adapter.\n *\n * @param {object} config The config that is to be used for the request\n *\n * @returns {Promise} The Promise to be fulfilled\n */\nexport default function dispatchRequest(config) {\n  throwIfCancellationRequested(config);\n\n  config.headers = AxiosHeaders.from(config.headers);\n\n  // Transform request data\n  config.data = transformData.call(\n    config,\n    config.transformRequest\n  );\n\n  if (['post', 'put', 'patch'].indexOf(config.method) !== -1) {\n    config.headers.setContentType('application/x-www-form-urlencoded', false);\n  }\n\n  const adapter = adapters.getAdapter(config.adapter || defaults.adapter);\n\n  return adapter(config).then(function onAdapterResolution(response) {\n    throwIfCancellationRequested(config);\n\n    // Transform response data\n    response.data = transformData.call(\n      config,\n      config.transformResponse,\n      response\n    );\n\n    response.headers = AxiosHeaders.from(response.headers);\n\n    return response;\n  }, function onAdapterRejection(reason) {\n    if (!isCancel(reason)) {\n      throwIfCancellationRequested(config);\n\n      // Transform response data\n      if (reason && reason.response) {\n        reason.response.data = transformData.call(\n          config,\n          config.transformResponse,\n          reason.response\n        );\n        reason.response.headers = AxiosHeaders.from(reason.response.headers);\n      }\n    }\n\n    return Promise.reject(reason);\n  });\n}\n","'use strict';\n\nimport {VERSION} from '../env/data.js';\nimport AxiosError from '../core/AxiosError.js';\n\nconst validators = {};\n\n// eslint-disable-next-line func-names\n['object', 'boolean', 'number', 'function', 'string', 'symbol'].forEach((type, i) => {\n  validators[type] = function validator(thing) {\n    return typeof thing === type || 'a' + (i < 1 ? 'n ' : ' ') + type;\n  };\n});\n\nconst deprecatedWarnings = {};\n\n/**\n * Transitional option validator\n *\n * @param {function|boolean?} validator - set to false if the transitional option has been removed\n * @param {string?} version - deprecated version / removed since version\n * @param {string?} message - some message with additional info\n *\n * @returns {function}\n */\nvalidators.transitional = function transitional(validator, version, message) {\n  function formatMessage(opt, desc) {\n    return '[Axios v' + VERSION + '] Transitional option \\'' + opt + '\\'' + desc + (message ? '. ' + message : '');\n  }\n\n  // eslint-disable-next-line func-names\n  return (value, opt, opts) => {\n    if (validator === false) {\n      throw new AxiosError(\n        formatMessage(opt, ' has been removed' + (version ? ' in ' + version : '')),\n        AxiosError.ERR_DEPRECATED\n      );\n    }\n\n    if (version && !deprecatedWarnings[opt]) {\n      deprecatedWarnings[opt] = true;\n      // eslint-disable-next-line no-console\n      console.warn(\n        formatMessage(\n          opt,\n          ' has been deprecated since v' + version + ' and will be removed in the near future'\n        )\n      );\n    }\n\n    return validator ? validator(value, opt, opts) : true;\n  };\n};\n\nvalidators.spelling = function spelling(correctSpelling) {\n  return (value, opt) => {\n    // eslint-disable-next-line no-console\n    console.warn(`${opt} is likely a misspelling of ${correctSpelling}`);\n    return true;\n  }\n};\n\n/**\n * Assert object's properties type\n *\n * @param {object} options\n * @param {object} schema\n * @param {boolean?} allowUnknown\n *\n * @returns {object}\n */\n\nfunction assertOptions(options, schema, allowUnknown) {\n  if (typeof options !== 'object') {\n    throw new AxiosError('options must be an object', AxiosError.ERR_BAD_OPTION_VALUE);\n  }\n  const keys = Object.keys(options);\n  let i = keys.length;\n  while (i-- > 0) {\n    const opt = keys[i];\n    const validator = schema[opt];\n    if (validator) {\n      const value = options[opt];\n      const result = value === undefined || validator(value, opt, options);\n      if (result !== true) {\n        throw new AxiosError('option ' + opt + ' must be ' + result, AxiosError.ERR_BAD_OPTION_VALUE);\n      }\n      continue;\n    }\n    if (allowUnknown !== true) {\n      throw new AxiosError('Unknown option ' + opt, AxiosError.ERR_BAD_OPTION);\n    }\n  }\n}\n\nexport default {\n  assertOptions,\n  validators\n};\n","'use strict';\n\nimport utils from './../utils.js';\nimport buildURL from '../helpers/buildURL.js';\nimport InterceptorManager from './InterceptorManager.js';\nimport dispatchRequest from './dispatchRequest.js';\nimport mergeConfig from './mergeConfig.js';\nimport buildFullPath from './buildFullPath.js';\nimport validator from '../helpers/validator.js';\nimport AxiosHeaders from './AxiosHeaders.js';\n\nconst validators = validator.validators;\n\n/**\n * Create a new instance of Axios\n *\n * @param {Object} instanceConfig The default config for the instance\n *\n * @return {Axios} A new instance of Axios\n */\nclass Axios {\n  constructor(instanceConfig) {\n    this.defaults = instanceConfig;\n    this.interceptors = {\n      request: new InterceptorManager(),\n      response: new InterceptorManager()\n    };\n  }\n\n  /**\n   * Dispatch a request\n   *\n   * @param {String|Object} configOrUrl The config specific for this request (merged with this.defaults)\n   * @param {?Object} config\n   *\n   * @returns {Promise} The Promise to be fulfilled\n   */\n  async request(configOrUrl, config) {\n    try {\n      return await this._request(configOrUrl, config);\n    } catch (err) {\n      if (err instanceof Error) {\n        let dummy = {};\n\n        Error.captureStackTrace ? Error.captureStackTrace(dummy) : (dummy = new Error());\n\n        // slice off the Error: ... line\n        const stack = dummy.stack ? dummy.stack.replace(/^.+\\n/, '') : '';\n        try {\n          if (!err.stack) {\n            err.stack = stack;\n            // match without the 2 top stack lines\n          } else if (stack && !String(err.stack).endsWith(stack.replace(/^.+\\n.+\\n/, ''))) {\n            err.stack += '\\n' + stack\n          }\n        } catch (e) {\n          // ignore the case where \"stack\" is an un-writable property\n        }\n      }\n\n      throw err;\n    }\n  }\n\n  _request(configOrUrl, config) {\n    /*eslint no-param-reassign:0*/\n    // Allow for axios('example/url'[, config]) a la fetch API\n    if (typeof configOrUrl === 'string') {\n      config = config || {};\n      config.url = configOrUrl;\n    } else {\n      config = configOrUrl || {};\n    }\n\n    config = mergeConfig(this.defaults, config);\n\n    const {transitional, paramsSerializer, headers} = config;\n\n    if (transitional !== undefined) {\n      validator.assertOptions(transitional, {\n        silentJSONParsing: validators.transitional(validators.boolean),\n        forcedJSONParsing: validators.transitional(validators.boolean),\n        clarifyTimeoutError: validators.transitional(validators.boolean)\n      }, false);\n    }\n\n    if (paramsSerializer != null) {\n      if (utils.isFunction(paramsSerializer)) {\n        config.paramsSerializer = {\n          serialize: paramsSerializer\n        }\n      } else {\n        validator.assertOptions(paramsSerializer, {\n          encode: validators.function,\n          serialize: validators.function\n        }, true);\n      }\n    }\n\n    // Set config.allowAbsoluteUrls\n    if (config.allowAbsoluteUrls !== undefined) {\n      // do nothing\n    } else if (this.defaults.allowAbsoluteUrls !== undefined) {\n      config.allowAbsoluteUrls = this.defaults.allowAbsoluteUrls;\n    } else {\n      config.allowAbsoluteUrls = true;\n    }\n\n    validator.assertOptions(config, {\n      baseUrl: validators.spelling('baseURL'),\n      withXsrfToken: validators.spelling('withXSRFToken')\n    }, true);\n\n    // Set config.method\n    config.method = (config.method || this.defaults.method || 'get').toLowerCase();\n\n    // Flatten headers\n    let contextHeaders = headers && utils.merge(\n      headers.common,\n      headers[config.method]\n    );\n\n    headers && utils.forEach(\n      ['delete', 'get', 'head', 'post', 'put', 'patch', 'common'],\n      (method) => {\n        delete headers[method];\n      }\n    );\n\n    config.headers = AxiosHeaders.concat(contextHeaders, headers);\n\n    // filter out skipped interceptors\n    const requestInterceptorChain = [];\n    let synchronousRequestInterceptors = true;\n    this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {\n      if (typeof interceptor.runWhen === 'function' && interceptor.runWhen(config) === false) {\n        return;\n      }\n\n      synchronousRequestInterceptors = synchronousRequestInterceptors && interceptor.synchronous;\n\n      requestInterceptorChain.unshift(interceptor.fulfilled, interceptor.rejected);\n    });\n\n    const responseInterceptorChain = [];\n    this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {\n      responseInterceptorChain.push(interceptor.fulfilled, interceptor.rejected);\n    });\n\n    let promise;\n    let i = 0;\n    let len;\n\n    if (!synchronousRequestInterceptors) {\n      const chain = [dispatchRequest.bind(this), undefined];\n      chain.unshift.apply(chain, requestInterceptorChain);\n      chain.push.apply(chain, responseInterceptorChain);\n      len = chain.length;\n\n      promise = Promise.resolve(config);\n\n      while (i < len) {\n        promise = promise.then(chain[i++], chain[i++]);\n      }\n\n      return promise;\n    }\n\n    len = requestInterceptorChain.length;\n\n    let newConfig = config;\n\n    i = 0;\n\n    while (i < len) {\n      const onFulfilled = requestInterceptorChain[i++];\n      const onRejected = requestInterceptorChain[i++];\n      try {\n        newConfig = onFulfilled(newConfig);\n      } catch (error) {\n        onRejected.call(this, error);\n        break;\n      }\n    }\n\n    try {\n      promise = dispatchRequest.call(this, newConfig);\n    } catch (error) {\n      return Promise.reject(error);\n    }\n\n    i = 0;\n    len = responseInterceptorChain.length;\n\n    while (i < len) {\n      promise = promise.then(responseInterceptorChain[i++], responseInterceptorChain[i++]);\n    }\n\n    return promise;\n  }\n\n  getUri(config) {\n    config = mergeConfig(this.defaults, config);\n    const fullPath = buildFullPath(config.baseURL, config.url, config.allowAbsoluteUrls);\n    return buildURL(fullPath, config.params, config.paramsSerializer);\n  }\n}\n\n// Provide aliases for supported request methods\nutils.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {\n  /*eslint func-names:0*/\n  Axios.prototype[method] = function(url, config) {\n    return this.request(mergeConfig(config || {}, {\n      method,\n      url,\n      data: (config || {}).data\n    }));\n  };\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n  /*eslint func-names:0*/\n\n  function generateHTTPMethod(isForm) {\n    return function httpMethod(url, data, config) {\n      return this.request(mergeConfig(config || {}, {\n        method,\n        headers: isForm ? {\n          'Content-Type': 'multipart/form-data'\n        } : {},\n        url,\n        data\n      }));\n    };\n  }\n\n  Axios.prototype[method] = generateHTTPMethod();\n\n  Axios.prototype[method + 'Form'] = generateHTTPMethod(true);\n});\n\nexport default Axios;\n","'use strict';\n\nimport CanceledError from './CanceledError.js';\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @param {Function} executor The executor function.\n *\n * @returns {CancelToken}\n */\nclass CancelToken {\n  constructor(executor) {\n    if (typeof executor !== 'function') {\n      throw new TypeError('executor must be a function.');\n    }\n\n    let resolvePromise;\n\n    this.promise = new Promise(function promiseExecutor(resolve) {\n      resolvePromise = resolve;\n    });\n\n    const token = this;\n\n    // eslint-disable-next-line func-names\n    this.promise.then(cancel => {\n      if (!token._listeners) return;\n\n      let i = token._listeners.length;\n\n      while (i-- > 0) {\n        token._listeners[i](cancel);\n      }\n      token._listeners = null;\n    });\n\n    // eslint-disable-next-line func-names\n    this.promise.then = onfulfilled => {\n      let _resolve;\n      // eslint-disable-next-line func-names\n      const promise = new Promise(resolve => {\n        token.subscribe(resolve);\n        _resolve = resolve;\n      }).then(onfulfilled);\n\n      promise.cancel = function reject() {\n        token.unsubscribe(_resolve);\n      };\n\n      return promise;\n    };\n\n    executor(function cancel(message, config, request) {\n      if (token.reason) {\n        // Cancellation has already been requested\n        return;\n      }\n\n      token.reason = new CanceledError(message, config, request);\n      resolvePromise(token.reason);\n    });\n  }\n\n  /**\n   * Throws a `CanceledError` if cancellation has been requested.\n   */\n  throwIfRequested() {\n    if (this.reason) {\n      throw this.reason;\n    }\n  }\n\n  /**\n   * Subscribe to the cancel signal\n   */\n\n  subscribe(listener) {\n    if (this.reason) {\n      listener(this.reason);\n      return;\n    }\n\n    if (this._listeners) {\n      this._listeners.push(listener);\n    } else {\n      this._listeners = [listener];\n    }\n  }\n\n  /**\n   * Unsubscribe from the cancel signal\n   */\n\n  unsubscribe(listener) {\n    if (!this._listeners) {\n      return;\n    }\n    const index = this._listeners.indexOf(listener);\n    if (index !== -1) {\n      this._listeners.splice(index, 1);\n    }\n  }\n\n  toAbortSignal() {\n    const controller = new AbortController();\n\n    const abort = (err) => {\n      controller.abort(err);\n    };\n\n    this.subscribe(abort);\n\n    controller.signal.unsubscribe = () => this.unsubscribe(abort);\n\n    return controller.signal;\n  }\n\n  /**\n   * Returns an object that contains a new `CancelToken` and a function that, when called,\n   * cancels the `CancelToken`.\n   */\n  static source() {\n    let cancel;\n    const token = new CancelToken(function executor(c) {\n      cancel = c;\n    });\n    return {\n      token,\n      cancel\n    };\n  }\n}\n\nexport default CancelToken;\n","const HttpStatusCode = {\n  Continue: 100,\n  SwitchingProtocols: 101,\n  Processing: 102,\n  EarlyHints: 103,\n  Ok: 200,\n  Created: 201,\n  Accepted: 202,\n  NonAuthoritativeInformation: 203,\n  NoContent: 204,\n  ResetContent: 205,\n  PartialContent: 206,\n  MultiStatus: 207,\n  AlreadyReported: 208,\n  ImUsed: 226,\n  MultipleChoices: 300,\n  MovedPermanently: 301,\n  Found: 302,\n  SeeOther: 303,\n  NotModified: 304,\n  UseProxy: 305,\n  Unused: 306,\n  TemporaryRedirect: 307,\n  PermanentRedirect: 308,\n  BadRequest: 400,\n  Unauthorized: 401,\n  PaymentRequired: 402,\n  Forbidden: 403,\n  NotFound: 404,\n  MethodNotAllowed: 405,\n  NotAcceptable: 406,\n  ProxyAuthenticationRequired: 407,\n  RequestTimeout: 408,\n  Conflict: 409,\n  Gone: 410,\n  LengthRequired: 411,\n  PreconditionFailed: 412,\n  PayloadTooLarge: 413,\n  UriTooLong: 414,\n  UnsupportedMediaType: 415,\n  RangeNotSatisfiable: 416,\n  ExpectationFailed: 417,\n  ImATeapot: 418,\n  MisdirectedRequest: 421,\n  UnprocessableEntity: 422,\n  Locked: 423,\n  FailedDependency: 424,\n  TooEarly: 425,\n  UpgradeRequired: 426,\n  PreconditionRequired: 428,\n  TooManyRequests: 429,\n  RequestHeaderFieldsTooLarge: 431,\n  UnavailableForLegalReasons: 451,\n  InternalServerError: 500,\n  NotImplemented: 501,\n  BadGateway: 502,\n  ServiceUnavailable: 503,\n  GatewayTimeout: 504,\n  HttpVersionNotSupported: 505,\n  VariantAlsoNegotiates: 506,\n  InsufficientStorage: 507,\n  LoopDetected: 508,\n  NotExtended: 510,\n  NetworkAuthenticationRequired: 511,\n};\n\nObject.entries(HttpStatusCode).forEach(([key, value]) => {\n  HttpStatusCode[value] = key;\n});\n\nexport default HttpStatusCode;\n","'use strict';\n\nimport utils from './utils.js';\nimport bind from './helpers/bind.js';\nimport Axios from './core/Axios.js';\nimport mergeConfig from './core/mergeConfig.js';\nimport defaults from './defaults/index.js';\nimport formDataToJSON from './helpers/formDataToJSON.js';\nimport CanceledError from './cancel/CanceledError.js';\nimport CancelToken from './cancel/CancelToken.js';\nimport isCancel from './cancel/isCancel.js';\nimport {VERSION} from './env/data.js';\nimport toFormData from './helpers/toFormData.js';\nimport AxiosError from './core/AxiosError.js';\nimport spread from './helpers/spread.js';\nimport isAxiosError from './helpers/isAxiosError.js';\nimport AxiosHeaders from \"./core/AxiosHeaders.js\";\nimport adapters from './adapters/adapters.js';\nimport HttpStatusCode from './helpers/HttpStatusCode.js';\n\n/**\n * Create an instance of Axios\n *\n * @param {Object} defaultConfig The default config for the instance\n *\n * @returns {Axios} A new instance of Axios\n */\nfunction createInstance(defaultConfig) {\n  const context = new Axios(defaultConfig);\n  const instance = bind(Axios.prototype.request, context);\n\n  // Copy axios.prototype to instance\n  utils.extend(instance, Axios.prototype, context, {allOwnKeys: true});\n\n  // Copy context to instance\n  utils.extend(instance, context, null, {allOwnKeys: true});\n\n  // Factory for creating new instances\n  instance.create = function create(instanceConfig) {\n    return createInstance(mergeConfig(defaultConfig, instanceConfig));\n  };\n\n  return instance;\n}\n\n// Create the default instance to be exported\nconst axios = createInstance(defaults);\n\n// Expose Axios class to allow class inheritance\naxios.Axios = Axios;\n\n// Expose Cancel & CancelToken\naxios.CanceledError = CanceledError;\naxios.CancelToken = CancelToken;\naxios.isCancel = isCancel;\naxios.VERSION = VERSION;\naxios.toFormData = toFormData;\n\n// Expose AxiosError class\naxios.AxiosError = AxiosError;\n\n// alias for CanceledError for backward compatibility\naxios.Cancel = axios.CanceledError;\n\n// Expose all/spread\naxios.all = function all(promises) {\n  return Promise.all(promises);\n};\n\naxios.spread = spread;\n\n// Expose isAxiosError\naxios.isAxiosError = isAxiosError;\n\n// Expose mergeConfig\naxios.mergeConfig = mergeConfig;\n\naxios.AxiosHeaders = AxiosHeaders;\n\naxios.formToJSON = thing => formDataToJSON(utils.isHTMLForm(thing) ? new FormData(thing) : thing);\n\naxios.getAdapter = adapters.getAdapter;\n\naxios.HttpStatusCode = HttpStatusCode;\n\naxios.default = axios;\n\n// this module should only have a default export\nexport default axios\n","export const VERSION = \"1.8.4\";","'use strict';\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n *  ```js\n *  function f(x, y, z) {}\n *  var args = [1, 2, 3];\n *  f.apply(null, args);\n *  ```\n *\n * With `spread` this example can be re-written.\n *\n *  ```js\n *  spread(function(x, y, z) {})([1, 2, 3]);\n *  ```\n *\n * @param {Function} callback\n *\n * @returns {Function}\n */\nexport default function spread(callback) {\n  return function wrap(arr) {\n    return callback.apply(null, arr);\n  };\n}\n","'use strict';\n\nimport utils from './../utils.js';\n\n/**\n * Determines whether the payload is an error thrown by Axios\n *\n * @param {*} payload The value to test\n *\n * @returns {boolean} True if the payload is an error thrown by Axios, otherwise false\n */\nexport default function isAxiosError(payload) {\n  return utils.isObject(payload) && (payload.isAxiosError === true);\n}\n","import { HttpClient, HttpClientConfig } from '@Interfaces';\nimport axios, { AxiosInstance } from 'axios';\n\nclass AxiosHttpClient implements HttpClient<AxiosInstance> {\n    create(config: HttpClientConfig): AxiosInstance {\n        return axios.create({\n            headers: config.headers,\n            httpsAgent: config.agent,\n            timeout: config.timeout,\n        });\n    }\n}\n\nexport default AxiosHttpClient;","import { NFeWizardProps } from '@Types';\nimport https from 'https';\nimport { HttpClient } from '@Interfaces';\n\nclass HttpClientBuilder<T> {\n    private config: NFeWizardProps;\n    private agent: https.Agent;\n    private httpClient: HttpClient<T>;\n\n    constructor(config: NFeWizardProps, agent: https.Agent, httpClient: HttpClient<T>) {\n        this.config = config;\n        this.agent = agent;\n        this.httpClient = httpClient;\n    }\n    createHttpClient(): T {\n        try {\n            const axiosConfig = {\n                headers: {\n                    'Content-Type': 'text/xml; charset=utf-8',\n                },\n                httpsAgent: this.agent,\n                timeout: this.config.lib?.connection?.timeout || 60000, // Timeout padrão de 60 segundos se não for configurado\n            };\n\n            return this.httpClient.create(axiosConfig);\n        } catch (error: any) {\n            throw new Error(error.message);\n        }\n    }\n}\n\nexport default HttpClientBuilder;","import { NFeWizardProps } from '@Types';\n\nclass ValidateEnvironment {\n    checkRequiredSettings(config: NFeWizardProps) {\n        try {\n            const requiredConfigFields: { [K in keyof NFeWizardProps]: string[] } = {\n                dfe: ['pathCertificado', 'senhaCertificado'],\n                nfe: ['ambiente']\n            };\n\n            let missingConfigurations: any = {\n                dfe: [],\n                nfe: []\n            };\n\n            let errors: string[] = [];\n            let tableData: any[] = [];\n\n            (Object.keys(requiredConfigFields) as (keyof NFeWizardProps)[]).forEach((categoryKey) => {\n                const category = config[categoryKey as keyof typeof config];\n\n                // Verifica se a chave principal existe\n                if (!category) {\n                    errors.push(`Chave principal faltando: '${categoryKey}'.`);\n                    tableData.push({ Categoria: categoryKey, Faltando: `Chave principal faltando` });\n                } else {\n                    const fields = requiredConfigFields[categoryKey];\n                    if (fields) {\n                        fields.forEach((fieldKey) => {\n                            // Garante que missingConfigurations[categoryKey] é um array\n                            if (!missingConfigurations[categoryKey]) {\n                                missingConfigurations[categoryKey] = [];\n                            }\n\n                            // Verifica se o campo está presente\n                            if (category[fieldKey as keyof typeof category] === undefined) {\n                                // Garante que a propriedade está definida\n                                if (!missingConfigurations[categoryKey]) {\n                                    missingConfigurations[categoryKey] = [];\n                                }\n                                missingConfigurations[categoryKey].push(fieldKey);\n                            }\n                        });\n\n                        // Garante que missingConfigurations[categoryKey] é um array\n                        const missingConfig = missingConfigurations[categoryKey];\n                        if (missingConfig && missingConfig.length > 0) {\n                            errors.push(`Configurações faltando em '${categoryKey}': [${missingConfig.join(', ')}].`);\n                            tableData.push({ Categoria: categoryKey, Faltando: missingConfig.join(', ') });\n                        }\n                    }\n                }\n            });\n\n            if (errors.length > 0) {\n                console.log(\"Configurações necessárias faltando:\");\n                console.table(tableData);\n                throw new Error(`Erro ao validar configurações: ${errors.join(' ')}`);\n            }\n\n            return {\n                missingConfigurations,\n                message: 'Todas as configurações necessárias estão presentes.',\n                success: true,\n            };\n        } catch (error: any) {\n            throw new Error(`Erro ao validar configurações: ${error.message}`);\n        }\n    }\n}\n\nexport default ValidateEnvironment;","/**\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 * 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 * 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 * 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 * Advanced Encryption Standard (AES) implementation.\n *\n * This implementation is based on the public domain library 'jscrypto' which\n * was written by:\n *\n * Emily Stark (estark@stanford.edu)\n * Mike Hamburg (mhamburg@stanford.edu)\n * Dan Boneh (dabo@cs.stanford.edu)\n *\n * Parts of this code are based on the OpenSSL implementation of AES:\n * http://www.openssl.org\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./cipher');\nrequire('./cipherModes');\nrequire('./util');\n\n/* AES API */\nmodule.exports = forge.aes = forge.aes || {};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('AES-<mode>', key);\n * cipher.start({iv: iv});\n *\n * Creates an AES cipher object to encrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as a string of bytes, an array of bytes,\n * a byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.startEncrypting = function(key, iv, output, mode) {\n  var cipher = _createCipher({\n    key: key,\n    output: output,\n    decrypt: false,\n    mode: mode\n  });\n  cipher.start(iv);\n  return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('AES-<mode>', key);\n *\n * Creates an AES cipher object to encrypt data using the given symmetric key.\n *\n * The key may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.createEncryptionCipher = function(key, mode) {\n  return _createCipher({\n    key: key,\n    output: null,\n    decrypt: false,\n    mode: mode\n  });\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('AES-<mode>', key);\n * decipher.start({iv: iv});\n *\n * Creates an AES cipher object to decrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as a string of bytes, an array of bytes,\n * a byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.startDecrypting = function(key, iv, output, mode) {\n  var cipher = _createCipher({\n    key: key,\n    output: output,\n    decrypt: true,\n    mode: mode\n  });\n  cipher.start(iv);\n  return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('AES-<mode>', key);\n *\n * Creates an AES cipher object to decrypt data using the given symmetric key.\n *\n * The key may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param key the symmetric key to use.\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.aes.createDecryptionCipher = function(key, mode) {\n  return _createCipher({\n    key: key,\n    output: null,\n    decrypt: true,\n    mode: mode\n  });\n};\n\n/**\n * Creates a new AES cipher algorithm object.\n *\n * @param name the name of the algorithm.\n * @param mode the mode factory function.\n *\n * @return the AES algorithm object.\n */\nforge.aes.Algorithm = function(name, mode) {\n  if(!init) {\n    initialize();\n  }\n  var self = this;\n  self.name = name;\n  self.mode = new mode({\n    blockSize: 16,\n    cipher: {\n      encrypt: function(inBlock, outBlock) {\n        return _updateBlock(self._w, inBlock, outBlock, false);\n      },\n      decrypt: function(inBlock, outBlock) {\n        return _updateBlock(self._w, inBlock, outBlock, true);\n      }\n    }\n  });\n  self._init = false;\n};\n\n/**\n * Initializes this AES algorithm by expanding its key.\n *\n * @param options the options to use.\n *          key the key to use with this algorithm.\n *          decrypt true if the algorithm should be initialized for decryption,\n *            false for encryption.\n */\nforge.aes.Algorithm.prototype.initialize = function(options) {\n  if(this._init) {\n    return;\n  }\n\n  var key = options.key;\n  var tmp;\n\n  /* Note: The key may be a string of bytes, an array of bytes, a byte\n    buffer, or an array of 32-bit integers. If the key is in bytes, then\n    it must be 16, 24, or 32 bytes in length. If it is in 32-bit\n    integers, it must be 4, 6, or 8 integers long. */\n\n  if(typeof key === 'string' &&\n    (key.length === 16 || key.length === 24 || key.length === 32)) {\n    // convert key string into byte buffer\n    key = forge.util.createBuffer(key);\n  } else if(forge.util.isArray(key) &&\n    (key.length === 16 || key.length === 24 || key.length === 32)) {\n    // convert key integer array into byte buffer\n    tmp = key;\n    key = forge.util.createBuffer();\n    for(var i = 0; i < tmp.length; ++i) {\n      key.putByte(tmp[i]);\n    }\n  }\n\n  // convert key byte buffer into 32-bit integer array\n  if(!forge.util.isArray(key)) {\n    tmp = key;\n    key = [];\n\n    // key lengths of 16, 24, 32 bytes allowed\n    var len = tmp.length();\n    if(len === 16 || len === 24 || len === 32) {\n      len = len >>> 2;\n      for(var i = 0; i < len; ++i) {\n        key.push(tmp.getInt32());\n      }\n    }\n  }\n\n  // key must be an array of 32-bit integers by now\n  if(!forge.util.isArray(key) ||\n    !(key.length === 4 || key.length === 6 || key.length === 8)) {\n    throw new Error('Invalid key parameter.');\n  }\n\n  // encryption operation is always used for these modes\n  var mode = this.mode.name;\n  var encryptOp = (['CFB', 'OFB', 'CTR', 'GCM'].indexOf(mode) !== -1);\n\n  // do key expansion\n  this._w = _expandKey(key, options.decrypt && !encryptOp);\n  this._init = true;\n};\n\n/**\n * Expands a key. Typically only used for testing.\n *\n * @param key the symmetric key to expand, as an array of 32-bit words.\n * @param decrypt true to expand for decryption, false for encryption.\n *\n * @return the expanded key.\n */\nforge.aes._expandKey = function(key, decrypt) {\n  if(!init) {\n    initialize();\n  }\n  return _expandKey(key, decrypt);\n};\n\n/**\n * Updates a single block. Typically only used for testing.\n *\n * @param w the expanded key to use.\n * @param input an array of block-size 32-bit words.\n * @param output an array of block-size 32-bit words.\n * @param decrypt true to decrypt, false to encrypt.\n */\nforge.aes._updateBlock = _updateBlock;\n\n/** Register AES algorithms **/\n\nregisterAlgorithm('AES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('AES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('AES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('AES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('AES-CTR', forge.cipher.modes.ctr);\nregisterAlgorithm('AES-GCM', forge.cipher.modes.gcm);\n\nfunction registerAlgorithm(name, mode) {\n  var factory = function() {\n    return new forge.aes.Algorithm(name, mode);\n  };\n  forge.cipher.registerAlgorithm(name, factory);\n}\n\n/** AES implementation **/\n\nvar init = false; // not yet initialized\nvar Nb = 4;       // number of words comprising the state (AES = 4)\nvar sbox;         // non-linear substitution table used in key expansion\nvar isbox;        // inversion of sbox\nvar rcon;         // round constant word array\nvar mix;          // mix-columns table\nvar imix;         // inverse mix-columns table\n\n/**\n * Performs initialization, ie: precomputes tables to optimize for speed.\n *\n * One way to understand how AES works is to imagine that 'addition' and\n * 'multiplication' are interfaces that require certain mathematical\n * properties to hold true (ie: they are associative) but they might have\n * different implementations and produce different kinds of results ...\n * provided that their mathematical properties remain true. AES defines\n * its own methods of addition and multiplication but keeps some important\n * properties the same, ie: associativity and distributivity. The\n * explanation below tries to shed some light on how AES defines addition\n * and multiplication of bytes and 32-bit words in order to perform its\n * encryption and decryption algorithms.\n *\n * The basics:\n *\n * The AES algorithm views bytes as binary representations of polynomials\n * that have either 1 or 0 as the coefficients. It defines the addition\n * or subtraction of two bytes as the XOR operation. It also defines the\n * multiplication of two bytes as a finite field referred to as GF(2^8)\n * (Note: 'GF' means \"Galois Field\" which is a field that contains a finite\n * number of elements so GF(2^8) has 256 elements).\n *\n * This means that any two bytes can be represented as binary polynomials;\n * when they multiplied together and modularly reduced by an irreducible\n * polynomial of the 8th degree, the results are the field GF(2^8). The\n * specific irreducible polynomial that AES uses in hexadecimal is 0x11b.\n * This multiplication is associative with 0x01 as the identity:\n *\n * (b * 0x01 = GF(b, 0x01) = b).\n *\n * The operation GF(b, 0x02) can be performed at the byte level by left\n * shifting b once and then XOR'ing it (to perform the modular reduction)\n * with 0x11b if b is >= 128. Repeated application of the multiplication\n * of 0x02 can be used to implement the multiplication of any two bytes.\n *\n * For instance, multiplying 0x57 and 0x13, denoted as GF(0x57, 0x13), can\n * be performed by factoring 0x13 into 0x01, 0x02, and 0x10. Then these\n * factors can each be multiplied by 0x57 and then added together. To do\n * the multiplication, values for 0x57 multiplied by each of these 3 factors\n * can be precomputed and stored in a table. To add them, the values from\n * the table are XOR'd together.\n *\n * AES also defines addition and multiplication of words, that is 4-byte\n * numbers represented as polynomials of 3 degrees where the coefficients\n * are the values of the bytes.\n *\n * The word [a0, a1, a2, a3] is a polynomial a3x^3 + a2x^2 + a1x + a0.\n *\n * Addition is performed by XOR'ing like powers of x. Multiplication\n * is performed in two steps, the first is an algebriac expansion as\n * you would do normally (where addition is XOR). But the result is\n * a polynomial larger than 3 degrees and thus it cannot fit in a word. So\n * next the result is modularly reduced by an AES-specific polynomial of\n * degree 4 which will always produce a polynomial of less than 4 degrees\n * such that it will fit in a word. In AES, this polynomial is x^4 + 1.\n *\n * The modular product of two polynomials 'a' and 'b' is thus:\n *\n * d(x) = d3x^3 + d2x^2 + d1x + d0\n * with\n * d0 = GF(a0, b0) ^ GF(a3, b1) ^ GF(a2, b2) ^ GF(a1, b3)\n * d1 = GF(a1, b0) ^ GF(a0, b1) ^ GF(a3, b2) ^ GF(a2, b3)\n * d2 = GF(a2, b0) ^ GF(a1, b1) ^ GF(a0, b2) ^ GF(a3, b3)\n * d3 = GF(a3, b0) ^ GF(a2, b1) ^ GF(a1, b2) ^ GF(a0, b3)\n *\n * As a matrix:\n *\n * [d0] = [a0 a3 a2 a1][b0]\n * [d1]   [a1 a0 a3 a2][b1]\n * [d2]   [a2 a1 a0 a3][b2]\n * [d3]   [a3 a2 a1 a0][b3]\n *\n * Special polynomials defined by AES (0x02 == {02}):\n * a(x)    = {03}x^3 + {01}x^2 + {01}x + {02}\n * a^-1(x) = {0b}x^3 + {0d}x^2 + {09}x + {0e}.\n *\n * These polynomials are used in the MixColumns() and InverseMixColumns()\n * operations, respectively, to cause each element in the state to affect\n * the output (referred to as diffusing).\n *\n * RotWord() uses: a0 = a1 = a2 = {00} and a3 = {01}, which is the\n * polynomial x3.\n *\n * The ShiftRows() method modifies the last 3 rows in the state (where\n * the state is 4 words with 4 bytes per word) by shifting bytes cyclically.\n * The 1st byte in the second row is moved to the end of the row. The 1st\n * and 2nd bytes in the third row are moved to the end of the row. The 1st,\n * 2nd, and 3rd bytes are moved in the fourth row.\n *\n * More details on how AES arithmetic works:\n *\n * In the polynomial representation of binary numbers, XOR performs addition\n * and subtraction and multiplication in GF(2^8) denoted as GF(a, b)\n * corresponds with the multiplication of polynomials modulo an irreducible\n * polynomial of degree 8. In other words, for AES, GF(a, b) will multiply\n * polynomial 'a' with polynomial 'b' and then do a modular reduction by\n * an AES-specific irreducible polynomial of degree 8.\n *\n * A polynomial is irreducible if its only divisors are one and itself. For\n * the AES algorithm, this irreducible polynomial is:\n *\n * m(x) = x^8 + x^4 + x^3 + x + 1,\n *\n * or {01}{1b} in hexadecimal notation, where each coefficient is a bit:\n * 100011011 = 283 = 0x11b.\n *\n * For example, GF(0x57, 0x83) = 0xc1 because\n *\n * 0x57 = 87  = 01010111 = x^6 + x^4 + x^2 + x + 1\n * 0x85 = 131 = 10000101 = x^7 + x + 1\n *\n * (x^6 + x^4 + x^2 + x + 1) * (x^7 + x + 1)\n * =  x^13 + x^11 + x^9 + x^8 + x^7 +\n *    x^7 + x^5 + x^3 + x^2 + x +\n *    x^6 + x^4 + x^2 + x + 1\n * =  x^13 + x^11 + x^9 + x^8 + x^6 + x^5 + x^4 + x^3 + 1 = y\n *    y modulo (x^8 + x^4 + x^3 + x + 1)\n * =  x^7 + x^6 + 1.\n *\n * The modular reduction by m(x) guarantees the result will be a binary\n * polynomial of less than degree 8, so that it can fit in a byte.\n *\n * The operation to multiply a binary polynomial b with x (the polynomial\n * x in binary representation is 00000010) is:\n *\n * b_7x^8 + b_6x^7 + b_5x^6 + b_4x^5 + b_3x^4 + b_2x^3 + b_1x^2 + b_0x^1\n *\n * To get GF(b, x) we must reduce that by m(x). If b_7 is 0 (that is the\n * most significant bit is 0 in b) then the result is already reduced. If\n * it is 1, then we can reduce it by subtracting m(x) via an XOR.\n *\n * It follows that multiplication by x (00000010 or 0x02) can be implemented\n * by performing a left shift followed by a conditional bitwise XOR with\n * 0x1b. This operation on bytes is denoted by xtime(). Multiplication by\n * higher powers of x can be implemented by repeated application of xtime().\n *\n * By adding intermediate results, multiplication by any constant can be\n * implemented. For instance:\n *\n * GF(0x57, 0x13) = 0xfe because:\n *\n * xtime(b) = (b & 128) ? (b << 1 ^ 0x11b) : (b << 1)\n *\n * Note: We XOR with 0x11b instead of 0x1b because in javascript our\n * datatype for b can be larger than 1 byte, so a left shift will not\n * automatically eliminate bits that overflow a byte ... by XOR'ing the\n * overflow bit with 1 (the extra one from 0x11b) we zero it out.\n *\n * GF(0x57, 0x02) = xtime(0x57) = 0xae\n * GF(0x57, 0x04) = xtime(0xae) = 0x47\n * GF(0x57, 0x08) = xtime(0x47) = 0x8e\n * GF(0x57, 0x10) = xtime(0x8e) = 0x07\n *\n * GF(0x57, 0x13) = GF(0x57, (0x01 ^ 0x02 ^ 0x10))\n *\n * And by the distributive property (since XOR is addition and GF() is\n * multiplication):\n *\n * = GF(0x57, 0x01) ^ GF(0x57, 0x02) ^ GF(0x57, 0x10)\n * = 0x57 ^ 0xae ^ 0x07\n * = 0xfe.\n */\nfunction initialize() {\n  init = true;\n\n  /* Populate the Rcon table. These are the values given by\n    [x^(i-1),{00},{00},{00}] where x^(i-1) are powers of x (and x = 0x02)\n    in the field of GF(2^8), where i starts at 1.\n\n    rcon[0] = [0x00, 0x00, 0x00, 0x00]\n    rcon[1] = [0x01, 0x00, 0x00, 0x00] 2^(1-1) = 2^0 = 1\n    rcon[2] = [0x02, 0x00, 0x00, 0x00] 2^(2-1) = 2^1 = 2\n    ...\n    rcon[9]  = [0x1B, 0x00, 0x00, 0x00] 2^(9-1)  = 2^8 = 0x1B\n    rcon[10] = [0x36, 0x00, 0x00, 0x00] 2^(10-1) = 2^9 = 0x36\n\n    We only store the first byte because it is the only one used.\n  */\n  rcon = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1B, 0x36];\n\n  // compute xtime table which maps i onto GF(i, 0x02)\n  var xtime = new Array(256);\n  for(var i = 0; i < 128; ++i) {\n    xtime[i] = i << 1;\n    xtime[i + 128] = (i + 128) << 1 ^ 0x11B;\n  }\n\n  // compute all other tables\n  sbox = new Array(256);\n  isbox = new Array(256);\n  mix = new Array(4);\n  imix = new Array(4);\n  for(var i = 0; i < 4; ++i) {\n    mix[i] = new Array(256);\n    imix[i] = new Array(256);\n  }\n  var e = 0, ei = 0, e2, e4, e8, sx, sx2, me, ime;\n  for(var i = 0; i < 256; ++i) {\n    /* We need to generate the SubBytes() sbox and isbox tables so that\n      we can perform byte substitutions. This requires us to traverse\n      all of the elements in GF, find their multiplicative inverses,\n      and apply to each the following affine transformation:\n\n      bi' = bi ^ b(i + 4) mod 8 ^ b(i + 5) mod 8 ^ b(i + 6) mod 8 ^\n            b(i + 7) mod 8 ^ ci\n      for 0 <= i < 8, where bi is the ith bit of the byte, and ci is the\n      ith bit of a byte c with the value {63} or {01100011}.\n\n      It is possible to traverse every possible value in a Galois field\n      using what is referred to as a 'generator'. There are many\n      generators (128 out of 256): 3,5,6,9,11,82 to name a few. To fully\n      traverse GF we iterate 255 times, multiplying by our generator\n      each time.\n\n      On each iteration we can determine the multiplicative inverse for\n      the current element.\n\n      Suppose there is an element in GF 'e'. For a given generator 'g',\n      e = g^x. The multiplicative inverse of e is g^(255 - x). It turns\n      out that if use the inverse of a generator as another generator\n      it will produce all of the corresponding multiplicative inverses\n      at the same time. For this reason, we choose 5 as our inverse\n      generator because it only requires 2 multiplies and 1 add and its\n      inverse, 82, requires relatively few operations as well.\n\n      In order to apply the affine transformation, the multiplicative\n      inverse 'ei' of 'e' can be repeatedly XOR'd (4 times) with a\n      bit-cycling of 'ei'. To do this 'ei' is first stored in 's' and\n      'x'. Then 's' is left shifted and the high bit of 's' is made the\n      low bit. The resulting value is stored in 's'. Then 'x' is XOR'd\n      with 's' and stored in 'x'. On each subsequent iteration the same\n      operation is performed. When 4 iterations are complete, 'x' is\n      XOR'd with 'c' (0x63) and the transformed value is stored in 'x'.\n      For example:\n\n      s = 01000001\n      x = 01000001\n\n      iteration 1: s = 10000010, x ^= s\n      iteration 2: s = 00000101, x ^= s\n      iteration 3: s = 00001010, x ^= s\n      iteration 4: s = 00010100, x ^= s\n      x ^= 0x63\n\n      This can be done with a loop where s = (s << 1) | (s >> 7). However,\n      it can also be done by using a single 16-bit (in this case 32-bit)\n      number 'sx'. Since XOR is an associative operation, we can set 'sx'\n      to 'ei' and then XOR it with 'sx' left-shifted 1,2,3, and 4 times.\n      The most significant bits will flow into the high 8 bit positions\n      and be correctly XOR'd with one another. All that remains will be\n      to cycle the high 8 bits by XOR'ing them all with the lower 8 bits\n      afterwards.\n\n      At the same time we're populating sbox and isbox we can precompute\n      the multiplication we'll need to do to do MixColumns() later.\n    */\n\n    // apply affine transformation\n    sx = ei ^ (ei << 1) ^ (ei << 2) ^ (ei << 3) ^ (ei << 4);\n    sx = (sx >> 8) ^ (sx & 255) ^ 0x63;\n\n    // update tables\n    sbox[e] = sx;\n    isbox[sx] = e;\n\n    /* Mixing columns is done using matrix multiplication. The columns\n      that are to be mixed are each a single word in the current state.\n      The state has Nb columns (4 columns). Therefore each column is a\n      4 byte word. So to mix the columns in a single column 'c' where\n      its rows are r0, r1, r2, and r3, we use the following matrix\n      multiplication:\n\n      [2 3 1 1]*[r0,c]=[r'0,c]\n      [1 2 3 1] [r1,c] [r'1,c]\n      [1 1 2 3] [r2,c] [r'2,c]\n      [3 1 1 2] [r3,c] [r'3,c]\n\n      r0, r1, r2, and r3 are each 1 byte of one of the words in the\n      state (a column). To do matrix multiplication for each mixed\n      column c' we multiply the corresponding row from the left matrix\n      with the corresponding column from the right matrix. In total, we\n      get 4 equations:\n\n      r0,c' = 2*r0,c + 3*r1,c + 1*r2,c + 1*r3,c\n      r1,c' = 1*r0,c + 2*r1,c + 3*r2,c + 1*r3,c\n      r2,c' = 1*r0,c + 1*r1,c + 2*r2,c + 3*r3,c\n      r3,c' = 3*r0,c + 1*r1,c + 1*r2,c + 2*r3,c\n\n      As usual, the multiplication is as previously defined and the\n      addition is XOR. In order to optimize mixing columns we can store\n      the multiplication results in tables. If you think of the whole\n      column as a word (it might help to visualize by mentally rotating\n      the equations above by counterclockwise 90 degrees) then you can\n      see that it would be useful to map the multiplications performed on\n      each byte (r0, r1, r2, r3) onto a word as well. For instance, we\n      could map 2*r0,1*r0,1*r0,3*r0 onto a word by storing 2*r0 in the\n      highest 8 bits and 3*r0 in the lowest 8 bits (with the other two\n      respectively in the middle). This means that a table can be\n      constructed that uses r0 as an index to the word. We can do the\n      same with r1, r2, and r3, creating a total of 4 tables.\n\n      To construct a full c', we can just look up each byte of c in\n      their respective tables and XOR the results together.\n\n      Also, to build each table we only have to calculate the word\n      for 2,1,1,3 for every byte ... which we can do on each iteration\n      of this loop since we will iterate over every byte. After we have\n      calculated 2,1,1,3 we can get the results for the other tables\n      by cycling the byte at the end to the beginning. For instance\n      we can take the result of table 2,1,1,3 and produce table 3,2,1,1\n      by moving the right most byte to the left most position just like\n      how you can imagine the 3 moved out of 2,1,1,3 and to the front\n      to produce 3,2,1,1.\n\n      There is another optimization in that the same multiples of\n      the current element we need in order to advance our generator\n      to the next iteration can be reused in performing the 2,1,1,3\n      calculation. We also calculate the inverse mix column tables,\n      with e,9,d,b being the inverse of 2,1,1,3.\n\n      When we're done, and we need to actually mix columns, the first\n      byte of each state word should be put through mix[0] (2,1,1,3),\n      the second through mix[1] (3,2,1,1) and so forth. Then they should\n      be XOR'd together to produce the fully mixed column.\n    */\n\n    // calculate mix and imix table values\n    sx2 = xtime[sx];\n    e2 = xtime[e];\n    e4 = xtime[e2];\n    e8 = xtime[e4];\n    me =\n      (sx2 << 24) ^  // 2\n      (sx << 16) ^   // 1\n      (sx << 8) ^    // 1\n      (sx ^ sx2);    // 3\n    ime =\n      (e2 ^ e4 ^ e8) << 24 ^  // E (14)\n      (e ^ e8) << 16 ^        // 9\n      (e ^ e4 ^ e8) << 8 ^    // D (13)\n      (e ^ e2 ^ e8);          // B (11)\n    // produce each of the mix tables by rotating the 2,1,1,3 value\n    for(var n = 0; n < 4; ++n) {\n      mix[n][e] = me;\n      imix[n][sx] = ime;\n      // cycle the right most byte to the left most position\n      // ie: 2,1,1,3 becomes 3,2,1,1\n      me = me << 24 | me >>> 8;\n      ime = ime << 24 | ime >>> 8;\n    }\n\n    // get next element and inverse\n    if(e === 0) {\n      // 1 is the inverse of 1\n      e = ei = 1;\n    } else {\n      // e = 2e + 2*2*2*(10e)) = multiply e by 82 (chosen generator)\n      // ei = ei + 2*2*ei = multiply ei by 5 (inverse generator)\n      e = e2 ^ xtime[xtime[xtime[e2 ^ e8]]];\n      ei ^= xtime[xtime[ei]];\n    }\n  }\n}\n\n/**\n * Generates a key schedule using the AES key expansion algorithm.\n *\n * The AES algorithm takes the Cipher Key, K, and performs a Key Expansion\n * routine to generate a key schedule. The Key Expansion generates a total\n * of Nb*(Nr + 1) words: the algorithm requires an initial set of Nb words,\n * and each of the Nr rounds requires Nb words of key data. The resulting\n * key schedule consists of a linear array of 4-byte words, denoted [wi ],\n * with i in the range 0 <= i < Nb(Nr + 1).\n *\n * KeyExpansion(byte key[4*Nk], word w[Nb*(Nr+1)], Nk)\n * AES-128 (Nb=4, Nk=4, Nr=10)\n * AES-192 (Nb=4, Nk=6, Nr=12)\n * AES-256 (Nb=4, Nk=8, Nr=14)\n * Note: Nr=Nk+6.\n *\n * Nb is the number of columns (32-bit words) comprising the State (or\n * number of bytes in a block). For AES, Nb=4.\n *\n * @param key the key to schedule (as an array of 32-bit words).\n * @param decrypt true to modify the key schedule to decrypt, false not to.\n *\n * @return the generated key schedule.\n */\nfunction _expandKey(key, decrypt) {\n  // copy the key's words to initialize the key schedule\n  var w = key.slice(0);\n\n  /* RotWord() will rotate a word, moving the first byte to the last\n    byte's position (shifting the other bytes left).\n\n    We will be getting the value of Rcon at i / Nk. 'i' will iterate\n    from Nk to (Nb * Nr+1). Nk = 4 (4 byte key), Nb = 4 (4 words in\n    a block), Nr = Nk + 6 (10). Therefore 'i' will iterate from\n    4 to 44 (exclusive). Each time we iterate 4 times, i / Nk will\n    increase by 1. We use a counter iNk to keep track of this.\n   */\n\n  // go through the rounds expanding the key\n  var temp, iNk = 1;\n  var Nk = w.length;\n  var Nr1 = Nk + 6 + 1;\n  var end = Nb * Nr1;\n  for(var i = Nk; i < end; ++i) {\n    temp = w[i - 1];\n    if(i % Nk === 0) {\n      // temp = SubWord(RotWord(temp)) ^ Rcon[i / Nk]\n      temp =\n        sbox[temp >>> 16 & 255] << 24 ^\n        sbox[temp >>> 8 & 255] << 16 ^\n        sbox[temp & 255] << 8 ^\n        sbox[temp >>> 24] ^ (rcon[iNk] << 24);\n      iNk++;\n    } else if(Nk > 6 && (i % Nk === 4)) {\n      // temp = SubWord(temp)\n      temp =\n        sbox[temp >>> 24] << 24 ^\n        sbox[temp >>> 16 & 255] << 16 ^\n        sbox[temp >>> 8 & 255] << 8 ^\n        sbox[temp & 255];\n    }\n    w[i] = w[i - Nk] ^ temp;\n  }\n\n  /* When we are updating a cipher block we always use the code path for\n     encryption whether we are decrypting or not (to shorten code and\n     simplify the generation of look up tables). However, because there\n     are differences in the decryption algorithm, other than just swapping\n     in different look up tables, we must transform our key schedule to\n     account for these changes:\n\n     1. The decryption algorithm gets its key rounds in reverse order.\n     2. The decryption algorithm adds the round key before mixing columns\n       instead of afterwards.\n\n     We don't need to modify our key schedule to handle the first case,\n     we can just traverse the key schedule in reverse order when decrypting.\n\n     The second case requires a little work.\n\n     The tables we built for performing rounds will take an input and then\n     perform SubBytes() and MixColumns() or, for the decrypt version,\n     InvSubBytes() and InvMixColumns(). But the decrypt algorithm requires\n     us to AddRoundKey() before InvMixColumns(). This means we'll need to\n     apply some transformations to the round key to inverse-mix its columns\n     so they'll be correct for moving AddRoundKey() to after the state has\n     had its columns inverse-mixed.\n\n     To inverse-mix the columns of the state when we're decrypting we use a\n     lookup table that will apply InvSubBytes() and InvMixColumns() at the\n     same time. However, the round key's bytes are not inverse-substituted\n     in the decryption algorithm. To get around this problem, we can first\n     substitute the bytes in the round key so that when we apply the\n     transformation via the InvSubBytes()+InvMixColumns() table, it will\n     undo our substitution leaving us with the original value that we\n     want -- and then inverse-mix that value.\n\n     This change will correctly alter our key schedule so that we can XOR\n     each round key with our already transformed decryption state. This\n     allows us to use the same code path as the encryption algorithm.\n\n     We make one more change to the decryption key. Since the decryption\n     algorithm runs in reverse from the encryption algorithm, we reverse\n     the order of the round keys to avoid having to iterate over the key\n     schedule backwards when running the encryption algorithm later in\n     decryption mode. In addition to reversing the order of the round keys,\n     we also swap each round key's 2nd and 4th rows. See the comments\n     section where rounds are performed for more details about why this is\n     done. These changes are done inline with the other substitution\n     described above.\n  */\n  if(decrypt) {\n    var tmp;\n    var m0 = imix[0];\n    var m1 = imix[1];\n    var m2 = imix[2];\n    var m3 = imix[3];\n    var wnew = w.slice(0);\n    end = w.length;\n    for(var i = 0, wi = end - Nb; i < end; i += Nb, wi -= Nb) {\n      // do not sub the first or last round key (round keys are Nb\n      // words) as no column mixing is performed before they are added,\n      // but do change the key order\n      if(i === 0 || i === (end - Nb)) {\n        wnew[i] = w[wi];\n        wnew[i + 1] = w[wi + 3];\n        wnew[i + 2] = w[wi + 2];\n        wnew[i + 3] = w[wi + 1];\n      } else {\n        // substitute each round key byte because the inverse-mix\n        // table will inverse-substitute it (effectively cancel the\n        // substitution because round key bytes aren't sub'd in\n        // decryption mode) and swap indexes 3 and 1\n        for(var n = 0; n < Nb; ++n) {\n          tmp = w[wi + n];\n          wnew[i + (3&-n)] =\n            m0[sbox[tmp >>> 24]] ^\n            m1[sbox[tmp >>> 16 & 255]] ^\n            m2[sbox[tmp >>> 8 & 255]] ^\n            m3[sbox[tmp & 255]];\n        }\n      }\n    }\n    w = wnew;\n  }\n\n  return w;\n}\n\n/**\n * Updates a single block (16 bytes) using AES. The update will either\n * encrypt or decrypt the block.\n *\n * @param w the key schedule.\n * @param input the input block (an array of 32-bit words).\n * @param output the updated output block.\n * @param decrypt true to decrypt the block, false to encrypt it.\n */\nfunction _updateBlock(w, input, output, decrypt) {\n  /*\n  Cipher(byte in[4*Nb], byte out[4*Nb], word w[Nb*(Nr+1)])\n  begin\n    byte state[4,Nb]\n    state = in\n    AddRoundKey(state, w[0, Nb-1])\n    for round = 1 step 1 to Nr-1\n      SubBytes(state)\n      ShiftRows(state)\n      MixColumns(state)\n      AddRoundKey(state, w[round*Nb, (round+1)*Nb-1])\n    end for\n    SubBytes(state)\n    ShiftRows(state)\n    AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n    out = state\n  end\n\n  InvCipher(byte in[4*Nb], byte out[4*Nb], word w[Nb*(Nr+1)])\n  begin\n    byte state[4,Nb]\n    state = in\n    AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n    for round = Nr-1 step -1 downto 1\n      InvShiftRows(state)\n      InvSubBytes(state)\n      AddRoundKey(state, w[round*Nb, (round+1)*Nb-1])\n      InvMixColumns(state)\n    end for\n    InvShiftRows(state)\n    InvSubBytes(state)\n    AddRoundKey(state, w[0, Nb-1])\n    out = state\n  end\n  */\n\n  // Encrypt: AddRoundKey(state, w[0, Nb-1])\n  // Decrypt: AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n  var Nr = w.length / 4 - 1;\n  var m0, m1, m2, m3, sub;\n  if(decrypt) {\n    m0 = imix[0];\n    m1 = imix[1];\n    m2 = imix[2];\n    m3 = imix[3];\n    sub = isbox;\n  } else {\n    m0 = mix[0];\n    m1 = mix[1];\n    m2 = mix[2];\n    m3 = mix[3];\n    sub = sbox;\n  }\n  var a, b, c, d, a2, b2, c2;\n  a = input[0] ^ w[0];\n  b = input[decrypt ? 3 : 1] ^ w[1];\n  c = input[2] ^ w[2];\n  d = input[decrypt ? 1 : 3] ^ w[3];\n  var i = 3;\n\n  /* In order to share code we follow the encryption algorithm when both\n    encrypting and decrypting. To account for the changes required in the\n    decryption algorithm, we use different lookup tables when decrypting\n    and use a modified key schedule to account for the difference in the\n    order of transformations applied when performing rounds. We also get\n    key rounds in reverse order (relative to encryption). */\n  for(var round = 1; round < Nr; ++round) {\n    /* As described above, we'll be using table lookups to perform the\n      column mixing. Each column is stored as a word in the state (the\n      array 'input' has one column as a word at each index). In order to\n      mix a column, we perform these transformations on each row in c,\n      which is 1 byte in each word. The new column for c0 is c'0:\n\n               m0      m1      m2      m3\n      r0,c'0 = 2*r0,c0 + 3*r1,c0 + 1*r2,c0 + 1*r3,c0\n      r1,c'0 = 1*r0,c0 + 2*r1,c0 + 3*r2,c0 + 1*r3,c0\n      r2,c'0 = 1*r0,c0 + 1*r1,c0 + 2*r2,c0 + 3*r3,c0\n      r3,c'0 = 3*r0,c0 + 1*r1,c0 + 1*r2,c0 + 2*r3,c0\n\n      So using mix tables where c0 is a word with r0 being its upper\n      8 bits and r3 being its lower 8 bits:\n\n      m0[c0 >> 24] will yield this word: [2*r0,1*r0,1*r0,3*r0]\n      ...\n      m3[c0 & 255] will yield this word: [1*r3,1*r3,3*r3,2*r3]\n\n      Therefore to mix the columns in each word in the state we\n      do the following (& 255 omitted for brevity):\n      c'0,r0 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n      c'0,r1 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n      c'0,r2 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n      c'0,r3 = m0[c0 >> 24] ^ m1[c1 >> 16] ^ m2[c2 >> 8] ^ m3[c3]\n\n      However, before mixing, the algorithm requires us to perform\n      ShiftRows(). The ShiftRows() transformation cyclically shifts the\n      last 3 rows of the state over different offsets. The first row\n      (r = 0) is not shifted.\n\n      s'_r,c = s_r,(c + shift(r, Nb) mod Nb\n      for 0 < r < 4 and 0 <= c < Nb and\n      shift(1, 4) = 1\n      shift(2, 4) = 2\n      shift(3, 4) = 3.\n\n      This causes the first byte in r = 1 to be moved to the end of\n      the row, the first 2 bytes in r = 2 to be moved to the end of\n      the row, the first 3 bytes in r = 3 to be moved to the end of\n      the row:\n\n      r1: [c0 c1 c2 c3] => [c1 c2 c3 c0]\n      r2: [c0 c1 c2 c3]    [c2 c3 c0 c1]\n      r3: [c0 c1 c2 c3]    [c3 c0 c1 c2]\n\n      We can make these substitutions inline with our column mixing to\n      generate an updated set of equations to produce each word in the\n      state (note the columns have changed positions):\n\n      c0 c1 c2 c3 => c0 c1 c2 c3\n      c0 c1 c2 c3    c1 c2 c3 c0  (cycled 1 byte)\n      c0 c1 c2 c3    c2 c3 c0 c1  (cycled 2 bytes)\n      c0 c1 c2 c3    c3 c0 c1 c2  (cycled 3 bytes)\n\n      Therefore:\n\n      c'0 = 2*r0,c0 + 3*r1,c1 + 1*r2,c2 + 1*r3,c3\n      c'0 = 1*r0,c0 + 2*r1,c1 + 3*r2,c2 + 1*r3,c3\n      c'0 = 1*r0,c0 + 1*r1,c1 + 2*r2,c2 + 3*r3,c3\n      c'0 = 3*r0,c0 + 1*r1,c1 + 1*r2,c2 + 2*r3,c3\n\n      c'1 = 2*r0,c1 + 3*r1,c2 + 1*r2,c3 + 1*r3,c0\n      c'1 = 1*r0,c1 + 2*r1,c2 + 3*r2,c3 + 1*r3,c0\n      c'1 = 1*r0,c1 + 1*r1,c2 + 2*r2,c3 + 3*r3,c0\n      c'1 = 3*r0,c1 + 1*r1,c2 + 1*r2,c3 + 2*r3,c0\n\n      ... and so forth for c'2 and c'3. The important distinction is\n      that the columns are cycling, with c0 being used with the m0\n      map when calculating c0, but c1 being used with the m0 map when\n      calculating c1 ... and so forth.\n\n      When performing the inverse we transform the mirror image and\n      skip the bottom row, instead of the top one, and move upwards:\n\n      c3 c2 c1 c0 => c0 c3 c2 c1  (cycled 3 bytes) *same as encryption\n      c3 c2 c1 c0    c1 c0 c3 c2  (cycled 2 bytes)\n      c3 c2 c1 c0    c2 c1 c0 c3  (cycled 1 byte)  *same as encryption\n      c3 c2 c1 c0    c3 c2 c1 c0\n\n      If you compare the resulting matrices for ShiftRows()+MixColumns()\n      and for InvShiftRows()+InvMixColumns() the 2nd and 4th columns are\n      different (in encrypt mode vs. decrypt mode). So in order to use\n      the same code to handle both encryption and decryption, we will\n      need to do some mapping.\n\n      If in encryption mode we let a=c0, b=c1, c=c2, d=c3, and r<N> be\n      a row number in the state, then the resulting matrix in encryption\n      mode for applying the above transformations would be:\n\n      r1: a b c d\n      r2: b c d a\n      r3: c d a b\n      r4: d a b c\n\n      If we did the same in decryption mode we would get:\n\n      r1: a d c b\n      r2: b a d c\n      r3: c b a d\n      r4: d c b a\n\n      If instead we swap d and b (set b=c3 and d=c1), then we get:\n\n      r1: a b c d\n      r2: d a b c\n      r3: c d a b\n      r4: b c d a\n\n      Now the 1st and 3rd rows are the same as the encryption matrix. All\n      we need to do then to make the mapping exactly the same is to swap\n      the 2nd and 4th rows when in decryption mode. To do this without\n      having to do it on each iteration, we swapped the 2nd and 4th rows\n      in the decryption key schedule. We also have to do the swap above\n      when we first pull in the input and when we set the final output. */\n    a2 =\n      m0[a >>> 24] ^\n      m1[b >>> 16 & 255] ^\n      m2[c >>> 8 & 255] ^\n      m3[d & 255] ^ w[++i];\n    b2 =\n      m0[b >>> 24] ^\n      m1[c >>> 16 & 255] ^\n      m2[d >>> 8 & 255] ^\n      m3[a & 255] ^ w[++i];\n    c2 =\n      m0[c >>> 24] ^\n      m1[d >>> 16 & 255] ^\n      m2[a >>> 8 & 255] ^\n      m3[b & 255] ^ w[++i];\n    d =\n      m0[d >>> 24] ^\n      m1[a >>> 16 & 255] ^\n      m2[b >>> 8 & 255] ^\n      m3[c & 255] ^ w[++i];\n    a = a2;\n    b = b2;\n    c = c2;\n  }\n\n  /*\n    Encrypt:\n    SubBytes(state)\n    ShiftRows(state)\n    AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])\n\n    Decrypt:\n    InvShiftRows(state)\n    InvSubBytes(state)\n    AddRoundKey(state, w[0, Nb-1])\n   */\n  // Note: rows are shifted inline\n  output[0] =\n    (sub[a >>> 24] << 24) ^\n    (sub[b >>> 16 & 255] << 16) ^\n    (sub[c >>> 8 & 255] << 8) ^\n    (sub[d & 255]) ^ w[++i];\n  output[decrypt ? 3 : 1] =\n    (sub[b >>> 24] << 24) ^\n    (sub[c >>> 16 & 255] << 16) ^\n    (sub[d >>> 8 & 255] << 8) ^\n    (sub[a & 255]) ^ w[++i];\n  output[2] =\n    (sub[c >>> 24] << 24) ^\n    (sub[d >>> 16 & 255] << 16) ^\n    (sub[a >>> 8 & 255] << 8) ^\n    (sub[b & 255]) ^ w[++i];\n  output[decrypt ? 1 : 3] =\n    (sub[d >>> 24] << 24) ^\n    (sub[a >>> 16 & 255] << 16) ^\n    (sub[b >>> 8 & 255] << 8) ^\n    (sub[c & 255]) ^ w[++i];\n}\n\n/**\n * Deprecated. Instead, use:\n *\n * forge.cipher.createCipher('AES-<mode>', key);\n * forge.cipher.createDecipher('AES-<mode>', key);\n *\n * Creates a deprecated AES cipher object. This object's mode will default to\n * CBC (cipher-block-chaining).\n *\n * The key and iv may be given as a string of bytes, an array of bytes, a\n * byte buffer, or an array of 32-bit words.\n *\n * @param options the options to use.\n *          key the symmetric key to use.\n *          output the buffer to write to.\n *          decrypt true for decryption, false for encryption.\n *          mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nfunction _createCipher(options) {\n  options = options || {};\n  var mode = (options.mode || 'CBC').toUpperCase();\n  var algorithm = 'AES-' + mode;\n\n  var cipher;\n  if(options.decrypt) {\n    cipher = forge.cipher.createDecipher(algorithm, options.key);\n  } else {\n    cipher = forge.cipher.createCipher(algorithm, options.key);\n  }\n\n  // backwards compatible start API\n  var start = cipher.start;\n  cipher.start = function(iv, options) {\n    // backwards compatibility: support second arg as output buffer\n    var output = null;\n    if(options instanceof forge.util.ByteBuffer) {\n      output = options;\n      options = {};\n    }\n    options = options || {};\n    options.output = output;\n    options.iv = iv;\n    start.call(cipher, options);\n  };\n\n  return cipher;\n}\n","/**\n * Object IDs for ASN.1.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\n\nforge.pki = forge.pki || {};\nvar oids = module.exports = forge.pki.oids = forge.oids = forge.oids || {};\n\n// set id to name mapping and name to id mapping\nfunction _IN(id, name) {\n  oids[id] = name;\n  oids[name] = id;\n}\n// set id to name mapping only\nfunction _I_(id, name) {\n  oids[id] = name;\n}\n\n// algorithm OIDs\n_IN('1.2.840.113549.1.1.1', 'rsaEncryption');\n// Note: md2 & md4 not implemented\n//_IN('1.2.840.113549.1.1.2', 'md2WithRSAEncryption');\n//_IN('1.2.840.113549.1.1.3', 'md4WithRSAEncryption');\n_IN('1.2.840.113549.1.1.4', 'md5WithRSAEncryption');\n_IN('1.2.840.113549.1.1.5', 'sha1WithRSAEncryption');\n_IN('1.2.840.113549.1.1.7', 'RSAES-OAEP');\n_IN('1.2.840.113549.1.1.8', 'mgf1');\n_IN('1.2.840.113549.1.1.9', 'pSpecified');\n_IN('1.2.840.113549.1.1.10', 'RSASSA-PSS');\n_IN('1.2.840.113549.1.1.11', 'sha256WithRSAEncryption');\n_IN('1.2.840.113549.1.1.12', 'sha384WithRSAEncryption');\n_IN('1.2.840.113549.1.1.13', 'sha512WithRSAEncryption');\n// Edwards-curve Digital Signature Algorithm (EdDSA) Ed25519\n_IN('1.3.101.112', 'EdDSA25519');\n\n_IN('1.2.840.10040.4.3', 'dsa-with-sha1');\n\n_IN('1.3.14.3.2.7', 'desCBC');\n\n_IN('1.3.14.3.2.26', 'sha1');\n// 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 * 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 * 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 * Hash-based Message Authentication Code implementation. Requires a message\n * digest object that can be obtained, for example, from forge.md.sha1 or\n * forge.md.md5.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2012 Digital Bazaar, Inc. All rights reserved.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\n/* HMAC API */\nvar hmac = module.exports = forge.hmac = forge.hmac || {};\n\n/**\n * Creates an HMAC object that uses the given message digest object.\n *\n * @return an HMAC object.\n */\nhmac.create = function() {\n  // the hmac key to use\n  var _key = null;\n\n  // the message digest to use\n  var _md = null;\n\n  // the inner padding\n  var _ipadding = null;\n\n  // the outer padding\n  var _opadding = null;\n\n  // hmac context\n  var ctx = {};\n\n  /**\n   * Starts or restarts the HMAC with the given key and message digest.\n   *\n   * @param md the message digest to use, null to reuse the previous one,\n   *           a string to use builtin 'sha1', 'md5', 'sha256'.\n   * @param key the key to use as a string, array of bytes, byte buffer,\n   *           or null to reuse the previous key.\n   */\n  ctx.start = function(md, key) {\n    if(md !== null) {\n      if(typeof md === 'string') {\n        // create builtin message digest\n        md = md.toLowerCase();\n        if(md in forge.md.algorithms) {\n          _md = forge.md.algorithms[md].create();\n        } else {\n          throw new Error('Unknown hash algorithm \"' + md + '\"');\n        }\n      } else {\n        // store message digest\n        _md = md;\n      }\n    }\n\n    if(key === null) {\n      // reuse previous key\n      key = _key;\n    } else {\n      if(typeof key === 'string') {\n        // convert string into byte buffer\n        key = forge.util.createBuffer(key);\n      } else if(forge.util.isArray(key)) {\n        // convert byte array into byte buffer\n        var tmp = key;\n        key = forge.util.createBuffer();\n        for(var i = 0; i < tmp.length; ++i) {\n          key.putByte(tmp[i]);\n        }\n      }\n\n      // if key is longer than blocksize, hash it\n      var keylen = key.length();\n      if(keylen > _md.blockLength) {\n        _md.start();\n        _md.update(key.bytes());\n        key = _md.digest();\n      }\n\n      // mix key into inner and outer padding\n      // ipadding = [0x36 * blocksize] ^ key\n      // opadding = [0x5C * blocksize] ^ key\n      _ipadding = forge.util.createBuffer();\n      _opadding = forge.util.createBuffer();\n      keylen = key.length();\n      for(var i = 0; i < keylen; ++i) {\n        var tmp = key.at(i);\n        _ipadding.putByte(0x36 ^ tmp);\n        _opadding.putByte(0x5C ^ tmp);\n      }\n\n      // if key is shorter than blocksize, add additional padding\n      if(keylen < _md.blockLength) {\n        var tmp = _md.blockLength - keylen;\n        for(var i = 0; i < tmp; ++i) {\n          _ipadding.putByte(0x36);\n          _opadding.putByte(0x5C);\n        }\n      }\n      _key = key;\n      _ipadding = _ipadding.bytes();\n      _opadding = _opadding.bytes();\n    }\n\n    // digest is done like so: hash(opadding | hash(ipadding | message))\n\n    // prepare to do inner hash\n    // hash(ipadding | message)\n    _md.start();\n    _md.update(_ipadding);\n  };\n\n  /**\n   * Updates the HMAC with the given message bytes.\n   *\n   * @param bytes the bytes to update with.\n   */\n  ctx.update = function(bytes) {\n    _md.update(bytes);\n  };\n\n  /**\n   * Produces the Message Authentication Code (MAC).\n   *\n   * @return a byte buffer containing the digest value.\n   */\n  ctx.getMac = function() {\n    // digest is done like so: hash(opadding | hash(ipadding | message))\n    // here we do the outer hashing\n    var inner = _md.digest().bytes();\n    _md.start();\n    _md.update(_opadding);\n    _md.update(inner);\n    return _md.digest();\n  };\n  // alias for getMac\n  ctx.digest = ctx.getMac;\n\n  return ctx;\n};\n","/**\n * Message Digest Algorithm 5 with 128-bit digest (MD5) implementation.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar md5 = module.exports = forge.md5 = forge.md5 || {};\nforge.md.md5 = forge.md.algorithms.md5 = md5;\n\n/**\n * Creates an MD5 message digest object.\n *\n * @return a message digest object.\n */\nmd5.create = function() {\n  // do initialization as necessary\n  if(!_initialized) {\n    _init();\n  }\n\n  // MD5 state contains four 32-bit integers\n  var _state = null;\n\n  // input buffer\n  var _input = forge.util.createBuffer();\n\n  // used for word storage\n  var _w = new Array(16);\n\n  // message digest object\n  var md = {\n    algorithm: 'md5',\n    blockLength: 64,\n    digestLength: 16,\n    // 56-bit length of message so far (does not including padding)\n    messageLength: 0,\n    // true message length\n    fullMessageLength: null,\n    // size of message length in bytes\n    messageLengthSize: 8\n  };\n\n  /**\n   * Starts the digest.\n   *\n   * @return this digest object.\n   */\n  md.start = function() {\n    // up to 56-bit message length for convenience\n    md.messageLength = 0;\n\n    // full message length (set md.messageLength64 for backwards-compatibility)\n    md.fullMessageLength = md.messageLength64 = [];\n    var int32s = md.messageLengthSize / 4;\n    for(var i = 0; i < int32s; ++i) {\n      md.fullMessageLength.push(0);\n    }\n    _input = forge.util.createBuffer();\n    _state = {\n      h0: 0x67452301,\n      h1: 0xEFCDAB89,\n      h2: 0x98BADCFE,\n      h3: 0x10325476\n    };\n    return md;\n  };\n  // start digest automatically for first time\n  md.start();\n\n  /**\n   * Updates the digest with the given message input. The given input can\n   * treated as raw input (no encoding will be applied) or an encoding of\n   * 'utf8' maybe given to encode the input using UTF-8.\n   *\n   * @param msg the message input to update with.\n   * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n   *\n   * @return this digest object.\n   */\n  md.update = function(msg, encoding) {\n    if(encoding === 'utf8') {\n      msg = forge.util.encodeUtf8(msg);\n    }\n\n    // update message length\n    var len = msg.length;\n    md.messageLength += len;\n    len = [(len / 0x100000000) >>> 0, len >>> 0];\n    for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n      md.fullMessageLength[i] += len[1];\n      len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n      md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n      len[0] = (len[1] / 0x100000000) >>> 0;\n    }\n\n    // add bytes to input buffer\n    _input.putBytes(msg);\n\n    // process bytes\n    _update(_state, _w, _input);\n\n    // compact input buffer every 2K or if empty\n    if(_input.read > 2048 || _input.length() === 0) {\n      _input.compact();\n    }\n\n    return md;\n  };\n\n  /**\n   * Produces the digest.\n   *\n   * @return a byte buffer containing the digest value.\n   */\n  md.digest = function() {\n    /* Note: Here we copy the remaining bytes in the input buffer and\n    add the appropriate MD5 padding. Then we do the final update\n    on a copy of the state so that if the user wants to get\n    intermediate digests they can do so. */\n\n    /* Determine the number of bytes that must be added to the message\n    to ensure its length is congruent to 448 mod 512. In other words,\n    the data to be digested must be a multiple of 512 bits (or 128 bytes).\n    This data includes the message, some padding, and the length of the\n    message. Since the length of the message will be encoded as 8 bytes (64\n    bits), that means that the last segment of the data must have 56 bytes\n    (448 bits) of message and padding. Therefore, the length of the message\n    plus the padding must be congruent to 448 mod 512 because\n    512 - 128 = 448.\n\n    In order to fill up the message length it must be filled with\n    padding that begins with 1 bit followed by all 0 bits. Padding\n    must *always* be present, so if the message length is already\n    congruent to 448 mod 512, then 512 padding bits must be added. */\n\n    var finalBlock = forge.util.createBuffer();\n    finalBlock.putBytes(_input.bytes());\n\n    // compute remaining size to be digested (include message length size)\n    var remaining = (\n      md.fullMessageLength[md.fullMessageLength.length - 1] +\n      md.messageLengthSize);\n\n    // add padding for overflow blockSize - overflow\n    // _padding starts with 1 byte with first bit is set (byte value 128), then\n    // there may be up to (blockSize - 1) other pad bytes\n    var overflow = remaining & (md.blockLength - 1);\n    finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n    // serialize message length in bits in little-endian order; since length\n    // is stored in bytes we multiply by 8 and add carry\n    var bits, carry = 0;\n    for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n      bits = md.fullMessageLength[i] * 8 + carry;\n      carry = (bits / 0x100000000) >>> 0;\n      finalBlock.putInt32Le(bits >>> 0);\n    }\n\n    var s2 = {\n      h0: _state.h0,\n      h1: _state.h1,\n      h2: _state.h2,\n      h3: _state.h3\n    };\n    _update(s2, _w, finalBlock);\n    var rval = forge.util.createBuffer();\n    rval.putInt32Le(s2.h0);\n    rval.putInt32Le(s2.h1);\n    rval.putInt32Le(s2.h2);\n    rval.putInt32Le(s2.h3);\n    return rval;\n  };\n\n  return md;\n};\n\n// padding, constant tables for calculating md5\nvar _padding = null;\nvar _g = null;\nvar _r = null;\nvar _k = null;\nvar _initialized = false;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n  // create padding\n  _padding = String.fromCharCode(128);\n  _padding += forge.util.fillString(String.fromCharCode(0x00), 64);\n\n  // g values\n  _g = [\n    0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n    1, 6, 11, 0, 5, 10, 15, 4, 9, 14, 3, 8, 13, 2, 7, 12,\n    5, 8, 11, 14, 1, 4, 7, 10, 13, 0, 3, 6, 9, 12, 15, 2,\n    0, 7, 14, 5, 12, 3, 10, 1, 8, 15, 6, 13, 4, 11, 2, 9];\n\n  // rounds table\n  _r = [\n    7, 12, 17, 22,  7, 12, 17, 22,  7, 12, 17, 22,  7, 12, 17, 22,\n    5,  9, 14, 20,  5,  9, 14, 20,  5,  9, 14, 20,  5,  9, 14, 20,\n    4, 11, 16, 23,  4, 11, 16, 23,  4, 11, 16, 23,  4, 11, 16, 23,\n    6, 10, 15, 21,  6, 10, 15, 21,  6, 10, 15, 21,  6, 10, 15, 21];\n\n  // get the result of abs(sin(i + 1)) as a 32-bit integer\n  _k = new Array(64);\n  for(var i = 0; i < 64; ++i) {\n    _k[i] = Math.floor(Math.abs(Math.sin(i + 1)) * 0x100000000);\n  }\n\n  // now initialized\n  _initialized = true;\n}\n\n/**\n * Updates an MD5 state with the given byte buffer.\n *\n * @param s the MD5 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n  // consume 512 bit (64 byte) chunks\n  var t, a, b, c, d, f, r, i;\n  var len = bytes.length();\n  while(len >= 64) {\n    // initialize hash value for this chunk\n    a = s.h0;\n    b = s.h1;\n    c = s.h2;\n    d = s.h3;\n\n    // round 1\n    for(i = 0; i < 16; ++i) {\n      w[i] = bytes.getInt32Le();\n      f = d ^ (b & (c ^ d));\n      t = (a + f + _k[i] + w[i]);\n      r = _r[i];\n      a = d;\n      d = c;\n      c = b;\n      b += (t << r) | (t >>> (32 - r));\n    }\n    // round 2\n    for(; i < 32; ++i) {\n      f = c ^ (d & (b ^ c));\n      t = (a + f + _k[i] + w[_g[i]]);\n      r = _r[i];\n      a = d;\n      d = c;\n      c = b;\n      b += (t << r) | (t >>> (32 - r));\n    }\n    // round 3\n    for(; i < 48; ++i) {\n      f = b ^ c ^ d;\n      t = (a + f + _k[i] + w[_g[i]]);\n      r = _r[i];\n      a = d;\n      d = c;\n      c = b;\n      b += (t << r) | (t >>> (32 - r));\n    }\n    // round 4\n    for(; i < 64; ++i) {\n      f = c ^ (b | ~d);\n      t = (a + f + _k[i] + w[_g[i]]);\n      r = _r[i];\n      a = d;\n      d = c;\n      c = b;\n      b += (t << r) | (t >>> (32 - r));\n    }\n\n    // update hash state\n    s.h0 = (s.h0 + a) | 0;\n    s.h1 = (s.h1 + b) | 0;\n    s.h2 = (s.h2 + c) | 0;\n    s.h3 = (s.h3 + d) | 0;\n\n    len -= 64;\n  }\n}\n","/**\n * Javascript implementation of 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 * DES (Data Encryption Standard) implementation.\n *\n * This implementation supports DES as well as 3DES-EDE in ECB and CBC mode.\n * It is based on the BSD-licensed implementation by Paul Tero:\n *\n * Paul Tero, July 2001\n * http://www.tero.co.uk/des/\n *\n * Optimised for performance with large blocks by\n * Michael Hayworth, November 2001\n * http://www.netdealing.com\n *\n * THIS SOFTWARE IS PROVIDED \"AS IS\" AND\n * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE\n * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\n * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS\n * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\n * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT\n * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY\n * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF\n * SUCH DAMAGE.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2012-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./cipher');\nrequire('./cipherModes');\nrequire('./util');\n\n/* DES API */\nmodule.exports = forge.des = forge.des || {};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('DES-<mode>', key);\n * cipher.start({iv: iv});\n *\n * Creates an DES cipher object to encrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as binary-encoded strings of bytes or\n * byte buffers.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC' if IV is\n *          given, 'ECB' if null).\n *\n * @return the cipher.\n */\nforge.des.startEncrypting = function(key, iv, output, mode) {\n  var cipher = _createCipher({\n    key: key,\n    output: output,\n    decrypt: false,\n    mode: mode || (iv === null ? 'ECB' : 'CBC')\n  });\n  cipher.start(iv);\n  return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var cipher = forge.cipher.createCipher('DES-<mode>', key);\n *\n * Creates an DES cipher object to encrypt data using the given symmetric key.\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.des.createEncryptionCipher = function(key, mode) {\n  return _createCipher({\n    key: key,\n    output: null,\n    decrypt: false,\n    mode: mode\n  });\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('DES-<mode>', key);\n * decipher.start({iv: iv});\n *\n * Creates an DES cipher object to decrypt data using the given symmetric key.\n * The output will be stored in the 'output' member of the returned cipher.\n *\n * The key and iv may be given as binary-encoded strings of bytes or\n * byte buffers.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n * @param mode the cipher mode to use (default: 'CBC' if IV is\n *          given, 'ECB' if null).\n *\n * @return the cipher.\n */\nforge.des.startDecrypting = function(key, iv, output, mode) {\n  var cipher = _createCipher({\n    key: key,\n    output: output,\n    decrypt: true,\n    mode: mode || (iv === null ? 'ECB' : 'CBC')\n  });\n  cipher.start(iv);\n  return cipher;\n};\n\n/**\n * Deprecated. Instead, use:\n *\n * var decipher = forge.cipher.createDecipher('DES-<mode>', key);\n *\n * Creates an DES cipher object to decrypt data using the given symmetric key.\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param key the symmetric key to use (64 or 192 bits).\n * @param mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nforge.des.createDecryptionCipher = function(key, mode) {\n  return _createCipher({\n    key: key,\n    output: null,\n    decrypt: true,\n    mode: mode\n  });\n};\n\n/**\n * Creates a new DES cipher algorithm object.\n *\n * @param name the name of the algorithm.\n * @param mode the mode factory function.\n *\n * @return the DES algorithm object.\n */\nforge.des.Algorithm = function(name, mode) {\n  var self = this;\n  self.name = name;\n  self.mode = new mode({\n    blockSize: 8,\n    cipher: {\n      encrypt: function(inBlock, outBlock) {\n        return _updateBlock(self._keys, inBlock, outBlock, false);\n      },\n      decrypt: function(inBlock, outBlock) {\n        return _updateBlock(self._keys, inBlock, outBlock, true);\n      }\n    }\n  });\n  self._init = false;\n};\n\n/**\n * Initializes this DES algorithm by expanding its key.\n *\n * @param options the options to use.\n *          key the key to use with this algorithm.\n *          decrypt true if the algorithm should be initialized for decryption,\n *            false for encryption.\n */\nforge.des.Algorithm.prototype.initialize = function(options) {\n  if(this._init) {\n    return;\n  }\n\n  var key = forge.util.createBuffer(options.key);\n  if(this.name.indexOf('3DES') === 0) {\n    if(key.length() !== 24) {\n      throw new Error('Invalid Triple-DES key size: ' + key.length() * 8);\n    }\n  }\n\n  // do key expansion to 16 or 48 subkeys (single or triple DES)\n  this._keys = _createKeys(key);\n  this._init = true;\n};\n\n/** Register DES algorithms **/\n\nregisterAlgorithm('DES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('DES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('DES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('DES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('DES-CTR', forge.cipher.modes.ctr);\n\nregisterAlgorithm('3DES-ECB', forge.cipher.modes.ecb);\nregisterAlgorithm('3DES-CBC', forge.cipher.modes.cbc);\nregisterAlgorithm('3DES-CFB', forge.cipher.modes.cfb);\nregisterAlgorithm('3DES-OFB', forge.cipher.modes.ofb);\nregisterAlgorithm('3DES-CTR', forge.cipher.modes.ctr);\n\nfunction registerAlgorithm(name, mode) {\n  var factory = function() {\n    return new forge.des.Algorithm(name, mode);\n  };\n  forge.cipher.registerAlgorithm(name, factory);\n}\n\n/** DES implementation **/\n\nvar spfunction1 = [0x1010400,0,0x10000,0x1010404,0x1010004,0x10404,0x4,0x10000,0x400,0x1010400,0x1010404,0x400,0x1000404,0x1010004,0x1000000,0x4,0x404,0x1000400,0x1000400,0x10400,0x10400,0x1010000,0x1010000,0x1000404,0x10004,0x1000004,0x1000004,0x10004,0,0x404,0x10404,0x1000000,0x10000,0x1010404,0x4,0x1010000,0x1010400,0x1000000,0x1000000,0x400,0x1010004,0x10000,0x10400,0x1000004,0x400,0x4,0x1000404,0x10404,0x1010404,0x10004,0x1010000,0x1000404,0x1000004,0x404,0x10404,0x1010400,0x404,0x1000400,0x1000400,0,0x10004,0x10400,0,0x1010004];\nvar spfunction2 = [-0x7fef7fe0,-0x7fff8000,0x8000,0x108020,0x100000,0x20,-0x7fefffe0,-0x7fff7fe0,-0x7fffffe0,-0x7fef7fe0,-0x7fef8000,-0x80000000,-0x7fff8000,0x100000,0x20,-0x7fefffe0,0x108000,0x100020,-0x7fff7fe0,0,-0x80000000,0x8000,0x108020,-0x7ff00000,0x100020,-0x7fffffe0,0,0x108000,0x8020,-0x7fef8000,-0x7ff00000,0x8020,0,0x108020,-0x7fefffe0,0x100000,-0x7fff7fe0,-0x7ff00000,-0x7fef8000,0x8000,-0x7ff00000,-0x7fff8000,0x20,-0x7fef7fe0,0x108020,0x20,0x8000,-0x80000000,0x8020,-0x7fef8000,0x100000,-0x7fffffe0,0x100020,-0x7fff7fe0,-0x7fffffe0,0x100020,0x108000,0,-0x7fff8000,0x8020,-0x80000000,-0x7fefffe0,-0x7fef7fe0,0x108000];\nvar spfunction3 = [0x208,0x8020200,0,0x8020008,0x8000200,0,0x20208,0x8000200,0x20008,0x8000008,0x8000008,0x20000,0x8020208,0x20008,0x8020000,0x208,0x8000000,0x8,0x8020200,0x200,0x20200,0x8020000,0x8020008,0x20208,0x8000208,0x20200,0x20000,0x8000208,0x8,0x8020208,0x200,0x8000000,0x8020200,0x8000000,0x20008,0x208,0x20000,0x8020200,0x8000200,0,0x200,0x20008,0x8020208,0x8000200,0x8000008,0x200,0,0x8020008,0x8000208,0x20000,0x8000000,0x8020208,0x8,0x20208,0x20200,0x8000008,0x8020000,0x8000208,0x208,0x8020000,0x20208,0x8,0x8020008,0x20200];\nvar spfunction4 = [0x802001,0x2081,0x2081,0x80,0x802080,0x800081,0x800001,0x2001,0,0x802000,0x802000,0x802081,0x81,0,0x800080,0x800001,0x1,0x2000,0x800000,0x802001,0x80,0x800000,0x2001,0x2080,0x800081,0x1,0x2080,0x800080,0x2000,0x802080,0x802081,0x81,0x800080,0x800001,0x802000,0x802081,0x81,0,0,0x802000,0x2080,0x800080,0x800081,0x1,0x802001,0x2081,0x2081,0x80,0x802081,0x81,0x1,0x2000,0x800001,0x2001,0x802080,0x800081,0x2001,0x2080,0x800000,0x802001,0x80,0x800000,0x2000,0x802080];\nvar spfunction5 = [0x100,0x2080100,0x2080000,0x42000100,0x80000,0x100,0x40000000,0x2080000,0x40080100,0x80000,0x2000100,0x40080100,0x42000100,0x42080000,0x80100,0x40000000,0x2000000,0x40080000,0x40080000,0,0x40000100,0x42080100,0x42080100,0x2000100,0x42080000,0x40000100,0,0x42000000,0x2080100,0x2000000,0x42000000,0x80100,0x80000,0x42000100,0x100,0x2000000,0x40000000,0x2080000,0x42000100,0x40080100,0x2000100,0x40000000,0x42080000,0x2080100,0x40080100,0x100,0x2000000,0x42080000,0x42080100,0x80100,0x42000000,0x42080100,0x2080000,0,0x40080000,0x42000000,0x80100,0x2000100,0x40000100,0x80000,0,0x40080000,0x2080100,0x40000100];\nvar spfunction6 = [0x20000010,0x20400000,0x4000,0x20404010,0x20400000,0x10,0x20404010,0x400000,0x20004000,0x404010,0x400000,0x20000010,0x400010,0x20004000,0x20000000,0x4010,0,0x400010,0x20004010,0x4000,0x404000,0x20004010,0x10,0x20400010,0x20400010,0,0x404010,0x20404000,0x4010,0x404000,0x20404000,0x20000000,0x20004000,0x10,0x20400010,0x404000,0x20404010,0x400000,0x4010,0x20000010,0x400000,0x20004000,0x20000000,0x4010,0x20000010,0x20404010,0x404000,0x20400000,0x404010,0x20404000,0,0x20400010,0x10,0x4000,0x20400000,0x404010,0x4000,0x400010,0x20004010,0,0x20404000,0x20000000,0x400010,0x20004010];\nvar spfunction7 = [0x200000,0x4200002,0x4000802,0,0x800,0x4000802,0x200802,0x4200800,0x4200802,0x200000,0,0x4000002,0x2,0x4000000,0x4200002,0x802,0x4000800,0x200802,0x200002,0x4000800,0x4000002,0x4200000,0x4200800,0x200002,0x4200000,0x800,0x802,0x4200802,0x200800,0x2,0x4000000,0x200800,0x4000000,0x200800,0x200000,0x4000802,0x4000802,0x4200002,0x4200002,0x2,0x200002,0x4000000,0x4000800,0x200000,0x4200800,0x802,0x200802,0x4200800,0x802,0x4000002,0x4200802,0x4200000,0x200800,0,0x2,0x4200802,0,0x200802,0x4200000,0x800,0x4000002,0x4000800,0x800,0x200002];\nvar spfunction8 = [0x10001040,0x1000,0x40000,0x10041040,0x10000000,0x10001040,0x40,0x10000000,0x40040,0x10040000,0x10041040,0x41000,0x10041000,0x41040,0x1000,0x40,0x10040000,0x10000040,0x10001000,0x1040,0x41000,0x40040,0x10040040,0x10041000,0x1040,0,0,0x10040040,0x10000040,0x10001000,0x41040,0x40000,0x41040,0x40000,0x10041000,0x1000,0x40,0x10040040,0x1000,0x41040,0x10001000,0x40,0x10000040,0x10040000,0x10040040,0x10000000,0x40000,0x10001040,0,0x10041040,0x40040,0x10000040,0x10040000,0x10001000,0x10001040,0,0x10041040,0x41000,0x41000,0x1040,0x1040,0x40040,0x10000000,0x10041000];\n\n/**\n * Create necessary sub keys.\n *\n * @param key the 64-bit or 192-bit key.\n *\n * @return the expanded keys.\n */\nfunction _createKeys(key) {\n  var pc2bytes0  = [0,0x4,0x20000000,0x20000004,0x10000,0x10004,0x20010000,0x20010004,0x200,0x204,0x20000200,0x20000204,0x10200,0x10204,0x20010200,0x20010204],\n      pc2bytes1  = [0,0x1,0x100000,0x100001,0x4000000,0x4000001,0x4100000,0x4100001,0x100,0x101,0x100100,0x100101,0x4000100,0x4000101,0x4100100,0x4100101],\n      pc2bytes2  = [0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808,0,0x8,0x800,0x808,0x1000000,0x1000008,0x1000800,0x1000808],\n      pc2bytes3  = [0,0x200000,0x8000000,0x8200000,0x2000,0x202000,0x8002000,0x8202000,0x20000,0x220000,0x8020000,0x8220000,0x22000,0x222000,0x8022000,0x8222000],\n      pc2bytes4  = [0,0x40000,0x10,0x40010,0,0x40000,0x10,0x40010,0x1000,0x41000,0x1010,0x41010,0x1000,0x41000,0x1010,0x41010],\n      pc2bytes5  = [0,0x400,0x20,0x420,0,0x400,0x20,0x420,0x2000000,0x2000400,0x2000020,0x2000420,0x2000000,0x2000400,0x2000020,0x2000420],\n      pc2bytes6  = [0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002,0,0x10000000,0x80000,0x10080000,0x2,0x10000002,0x80002,0x10080002],\n      pc2bytes7  = [0,0x10000,0x800,0x10800,0x20000000,0x20010000,0x20000800,0x20010800,0x20000,0x30000,0x20800,0x30800,0x20020000,0x20030000,0x20020800,0x20030800],\n      pc2bytes8  = [0,0x40000,0,0x40000,0x2,0x40002,0x2,0x40002,0x2000000,0x2040000,0x2000000,0x2040000,0x2000002,0x2040002,0x2000002,0x2040002],\n      pc2bytes9  = [0,0x10000000,0x8,0x10000008,0,0x10000000,0x8,0x10000008,0x400,0x10000400,0x408,0x10000408,0x400,0x10000400,0x408,0x10000408],\n      pc2bytes10 = [0,0x20,0,0x20,0x100000,0x100020,0x100000,0x100020,0x2000,0x2020,0x2000,0x2020,0x102000,0x102020,0x102000,0x102020],\n      pc2bytes11 = [0,0x1000000,0x200,0x1000200,0x200000,0x1200000,0x200200,0x1200200,0x4000000,0x5000000,0x4000200,0x5000200,0x4200000,0x5200000,0x4200200,0x5200200],\n      pc2bytes12 = [0,0x1000,0x8000000,0x8001000,0x80000,0x81000,0x8080000,0x8081000,0x10,0x1010,0x8000010,0x8001010,0x80010,0x81010,0x8080010,0x8081010],\n      pc2bytes13 = [0,0x4,0x100,0x104,0,0x4,0x100,0x104,0x1,0x5,0x101,0x105,0x1,0x5,0x101,0x105];\n\n  // how many iterations (1 for des, 3 for triple des)\n  // changed by Paul 16/6/2007 to use Triple DES for 9+ byte keys\n  var iterations = key.length() > 8 ? 3 : 1;\n\n  // stores the return keys\n  var keys = [];\n\n  // now define the left shifts which need to be done\n  var shifts = [0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1, 0];\n\n  var n = 0, tmp;\n  for(var j = 0; j < iterations; j++) {\n    var left = key.getInt32();\n    var right = key.getInt32();\n\n    tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n    right ^= tmp;\n    left ^= (tmp << 4);\n\n    tmp = ((right >>> -16) ^ left) & 0x0000ffff;\n    left ^= tmp;\n    right ^= (tmp << -16);\n\n    tmp = ((left >>> 2) ^ right) & 0x33333333;\n    right ^= tmp;\n    left ^= (tmp << 2);\n\n    tmp = ((right >>> -16) ^ left) & 0x0000ffff;\n    left ^= tmp;\n    right ^= (tmp << -16);\n\n    tmp = ((left >>> 1) ^ right) & 0x55555555;\n    right ^= tmp;\n    left ^= (tmp << 1);\n\n    tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n    left ^= tmp;\n    right ^= (tmp << 8);\n\n    tmp = ((left >>> 1) ^ right) & 0x55555555;\n    right ^= tmp;\n    left ^= (tmp << 1);\n\n    // right needs to be shifted and OR'd with last four bits of left\n    tmp = (left << 8) | ((right >>> 20) & 0x000000f0);\n\n    // left needs to be put upside down\n    left = ((right << 24) | ((right << 8) & 0xff0000) |\n      ((right >>> 8) & 0xff00) | ((right >>> 24) & 0xf0));\n    right = tmp;\n\n    // now go through and perform these shifts on the left and right keys\n    for(var i = 0; i < shifts.length; ++i) {\n      //shift the keys either one or two bits to the left\n      if(shifts[i]) {\n        left = (left << 2) | (left >>> 26);\n        right = (right << 2) | (right >>> 26);\n      } else {\n        left = (left << 1) | (left >>> 27);\n        right = (right << 1) | (right >>> 27);\n      }\n      left &= -0xf;\n      right &= -0xf;\n\n      // now apply PC-2, in such a way that E is easier when encrypting or\n      // decrypting this conversion will look like PC-2 except only the last 6\n      // bits of each byte are used rather than 48 consecutive bits and the\n      // order of lines will be according to how the S selection functions will\n      // be applied: S2, S4, S6, S8, S1, S3, S5, S7\n      var lefttmp = (\n        pc2bytes0[left >>> 28] | pc2bytes1[(left >>> 24) & 0xf] |\n        pc2bytes2[(left >>> 20) & 0xf] | pc2bytes3[(left >>> 16) & 0xf] |\n        pc2bytes4[(left >>> 12) & 0xf] | pc2bytes5[(left >>> 8) & 0xf] |\n        pc2bytes6[(left >>> 4) & 0xf]);\n      var righttmp = (\n        pc2bytes7[right >>> 28] | pc2bytes8[(right >>> 24) & 0xf] |\n        pc2bytes9[(right >>> 20) & 0xf] | pc2bytes10[(right >>> 16) & 0xf] |\n        pc2bytes11[(right >>> 12) & 0xf] | pc2bytes12[(right >>> 8) & 0xf] |\n        pc2bytes13[(right >>> 4) & 0xf]);\n      tmp = ((righttmp >>> 16) ^ lefttmp) & 0x0000ffff;\n      keys[n++] = lefttmp ^ tmp;\n      keys[n++] = righttmp ^ (tmp << 16);\n    }\n  }\n\n  return keys;\n}\n\n/**\n * Updates a single block (1 byte) using DES. The update will either\n * encrypt or decrypt the block.\n *\n * @param keys the expanded keys.\n * @param input the input block (an array of 32-bit words).\n * @param output the updated output block.\n * @param decrypt true to decrypt the block, false to encrypt it.\n */\nfunction _updateBlock(keys, input, output, decrypt) {\n  // set up loops for single or triple DES\n  var iterations = keys.length === 32 ? 3 : 9;\n  var looping;\n  if(iterations === 3) {\n    looping = decrypt ? [30, -2, -2] : [0, 32, 2];\n  } else {\n    looping = (decrypt ?\n      [94, 62, -2, 32, 64, 2, 30, -2, -2] :\n      [0, 32, 2, 62, 30, -2, 64, 96, 2]);\n  }\n\n  var tmp;\n\n  var left = input[0];\n  var right = input[1];\n\n  // first each 64 bit chunk of the message must be permuted according to IP\n  tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n  right ^= tmp;\n  left ^= (tmp << 4);\n\n  tmp = ((left >>> 16) ^ right) & 0x0000ffff;\n  right ^= tmp;\n  left ^= (tmp << 16);\n\n  tmp = ((right >>> 2) ^ left) & 0x33333333;\n  left ^= tmp;\n  right ^= (tmp << 2);\n\n  tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n  left ^= tmp;\n  right ^= (tmp << 8);\n\n  tmp = ((left >>> 1) ^ right) & 0x55555555;\n  right ^= tmp;\n  left ^= (tmp << 1);\n\n  // rotate left 1 bit\n  left = ((left << 1) | (left >>> 31));\n  right = ((right << 1) | (right >>> 31));\n\n  for(var j = 0; j < iterations; j += 3) {\n    var endloop = looping[j + 1];\n    var loopinc = looping[j + 2];\n\n    // now go through and perform the encryption or decryption\n    for(var i = looping[j]; i != endloop; i += loopinc) {\n      var right1 = right ^ keys[i];\n      var right2 = ((right >>> 4) | (right << 28)) ^ keys[i + 1];\n\n      // passing these bytes through the S selection functions\n      tmp = left;\n      left = right;\n      right = tmp ^ (\n        spfunction2[(right1 >>> 24) & 0x3f] |\n        spfunction4[(right1 >>> 16) & 0x3f] |\n        spfunction6[(right1 >>>  8) & 0x3f] |\n        spfunction8[right1 & 0x3f] |\n        spfunction1[(right2 >>> 24) & 0x3f] |\n        spfunction3[(right2 >>> 16) & 0x3f] |\n        spfunction5[(right2 >>>  8) & 0x3f] |\n        spfunction7[right2 & 0x3f]);\n    }\n    // unreverse left and right\n    tmp = left;\n    left = right;\n    right = tmp;\n  }\n\n  // rotate right 1 bit\n  left = ((left >>> 1) | (left << 31));\n  right = ((right >>> 1) | (right << 31));\n\n  // now perform IP-1, which is IP in the opposite direction\n  tmp = ((left >>> 1) ^ right) & 0x55555555;\n  right ^= tmp;\n  left ^= (tmp << 1);\n\n  tmp = ((right >>> 8) ^ left) & 0x00ff00ff;\n  left ^= tmp;\n  right ^= (tmp << 8);\n\n  tmp = ((right >>> 2) ^ left) & 0x33333333;\n  left ^= tmp;\n  right ^= (tmp << 2);\n\n  tmp = ((left >>> 16) ^ right) & 0x0000ffff;\n  right ^= tmp;\n  left ^= (tmp << 16);\n\n  tmp = ((left >>> 4) ^ right) & 0x0f0f0f0f;\n  right ^= tmp;\n  left ^= (tmp << 4);\n\n  output[0] = left;\n  output[1] = right;\n}\n\n/**\n * Deprecated. Instead, use:\n *\n * forge.cipher.createCipher('DES-<mode>', key);\n * forge.cipher.createDecipher('DES-<mode>', key);\n *\n * Creates a deprecated DES cipher object. This object's mode will default to\n * CBC (cipher-block-chaining).\n *\n * The key may be given as a binary-encoded string of bytes or a byte buffer.\n *\n * @param options the options to use.\n *          key the symmetric key to use (64 or 192 bits).\n *          output the buffer to write to.\n *          decrypt true for decryption, false for encryption.\n *          mode the cipher mode to use (default: 'CBC').\n *\n * @return the cipher.\n */\nfunction _createCipher(options) {\n  options = options || {};\n  var mode = (options.mode || 'CBC').toUpperCase();\n  var algorithm = 'DES-' + mode;\n\n  var cipher;\n  if(options.decrypt) {\n    cipher = forge.cipher.createDecipher(algorithm, options.key);\n  } else {\n    cipher = forge.cipher.createCipher(algorithm, options.key);\n  }\n\n  // backwards compatible start API\n  var start = cipher.start;\n  cipher.start = function(iv, options) {\n    // backwards compatibility: support second arg as output buffer\n    var output = null;\n    if(options instanceof forge.util.ByteBuffer) {\n      output = options;\n      options = {};\n    }\n    options = options || {};\n    options.output = output;\n    options.iv = iv;\n    start.call(cipher, options);\n  };\n\n  return cipher;\n}\n","/**\n * 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 * Secure Hash Algorithm with 256-bit digest (SHA-256) implementation.\n *\n * See FIPS 180-2 for details.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2015 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./md');\nrequire('./util');\n\nvar sha256 = module.exports = forge.sha256 = forge.sha256 || {};\nforge.md.sha256 = forge.md.algorithms.sha256 = sha256;\n\n/**\n * Creates a SHA-256 message digest object.\n *\n * @return a message digest object.\n */\nsha256.create = function() {\n  // do initialization as necessary\n  if(!_initialized) {\n    _init();\n  }\n\n  // SHA-256 state contains eight 32-bit integers\n  var _state = null;\n\n  // input buffer\n  var _input = forge.util.createBuffer();\n\n  // used for word storage\n  var _w = new Array(64);\n\n  // message digest object\n  var md = {\n    algorithm: 'sha256',\n    blockLength: 64,\n    digestLength: 32,\n    // 56-bit length of message so far (does not including padding)\n    messageLength: 0,\n    // true message length\n    fullMessageLength: null,\n    // size of message length in bytes\n    messageLengthSize: 8\n  };\n\n  /**\n   * Starts the digest.\n   *\n   * @return this digest object.\n   */\n  md.start = function() {\n    // up to 56-bit message length for convenience\n    md.messageLength = 0;\n\n    // full message length (set md.messageLength64 for backwards-compatibility)\n    md.fullMessageLength = md.messageLength64 = [];\n    var int32s = md.messageLengthSize / 4;\n    for(var i = 0; i < int32s; ++i) {\n      md.fullMessageLength.push(0);\n    }\n    _input = forge.util.createBuffer();\n    _state = {\n      h0: 0x6A09E667,\n      h1: 0xBB67AE85,\n      h2: 0x3C6EF372,\n      h3: 0xA54FF53A,\n      h4: 0x510E527F,\n      h5: 0x9B05688C,\n      h6: 0x1F83D9AB,\n      h7: 0x5BE0CD19\n    };\n    return md;\n  };\n  // start digest automatically for first time\n  md.start();\n\n  /**\n   * Updates the digest with the given message input. The given input can\n   * treated as raw input (no encoding will be applied) or an encoding of\n   * 'utf8' maybe given to encode the input using UTF-8.\n   *\n   * @param msg the message input to update with.\n   * @param encoding the encoding to use (default: 'raw', other: 'utf8').\n   *\n   * @return this digest object.\n   */\n  md.update = function(msg, encoding) {\n    if(encoding === 'utf8') {\n      msg = forge.util.encodeUtf8(msg);\n    }\n\n    // update message length\n    var len = msg.length;\n    md.messageLength += len;\n    len = [(len / 0x100000000) >>> 0, len >>> 0];\n    for(var i = md.fullMessageLength.length - 1; i >= 0; --i) {\n      md.fullMessageLength[i] += len[1];\n      len[1] = len[0] + ((md.fullMessageLength[i] / 0x100000000) >>> 0);\n      md.fullMessageLength[i] = md.fullMessageLength[i] >>> 0;\n      len[0] = ((len[1] / 0x100000000) >>> 0);\n    }\n\n    // add bytes to input buffer\n    _input.putBytes(msg);\n\n    // process bytes\n    _update(_state, _w, _input);\n\n    // compact input buffer every 2K or if empty\n    if(_input.read > 2048 || _input.length() === 0) {\n      _input.compact();\n    }\n\n    return md;\n  };\n\n  /**\n   * Produces the digest.\n   *\n   * @return a byte buffer containing the digest value.\n   */\n  md.digest = function() {\n    /* Note: Here we copy the remaining bytes in the input buffer and\n    add the appropriate SHA-256 padding. Then we do the final update\n    on a copy of the state so that if the user wants to get\n    intermediate digests they can do so. */\n\n    /* Determine the number of bytes that must be added to the message\n    to ensure its length is congruent to 448 mod 512. In other words,\n    the data to be digested must be a multiple of 512 bits (or 128 bytes).\n    This data includes the message, some padding, and the length of the\n    message. Since the length of the message will be encoded as 8 bytes (64\n    bits), that means that the last segment of the data must have 56 bytes\n    (448 bits) of message and padding. Therefore, the length of the message\n    plus the padding must be congruent to 448 mod 512 because\n    512 - 128 = 448.\n\n    In order to fill up the message length it must be filled with\n    padding that begins with 1 bit followed by all 0 bits. Padding\n    must *always* be present, so if the message length is already\n    congruent to 448 mod 512, then 512 padding bits must be added. */\n\n    var finalBlock = forge.util.createBuffer();\n    finalBlock.putBytes(_input.bytes());\n\n    // compute remaining size to be digested (include message length size)\n    var remaining = (\n      md.fullMessageLength[md.fullMessageLength.length - 1] +\n      md.messageLengthSize);\n\n    // add padding for overflow blockSize - overflow\n    // _padding starts with 1 byte with first bit is set (byte value 128), then\n    // there may be up to (blockSize - 1) other pad bytes\n    var overflow = remaining & (md.blockLength - 1);\n    finalBlock.putBytes(_padding.substr(0, md.blockLength - overflow));\n\n    // serialize message length in bits in big-endian order; since length\n    // is stored in bytes we multiply by 8 and add carry from next int\n    var next, carry;\n    var bits = md.fullMessageLength[0] * 8;\n    for(var i = 0; i < md.fullMessageLength.length - 1; ++i) {\n      next = md.fullMessageLength[i + 1] * 8;\n      carry = (next / 0x100000000) >>> 0;\n      bits += carry;\n      finalBlock.putInt32(bits >>> 0);\n      bits = next >>> 0;\n    }\n    finalBlock.putInt32(bits);\n\n    var s2 = {\n      h0: _state.h0,\n      h1: _state.h1,\n      h2: _state.h2,\n      h3: _state.h3,\n      h4: _state.h4,\n      h5: _state.h5,\n      h6: _state.h6,\n      h7: _state.h7\n    };\n    _update(s2, _w, finalBlock);\n    var rval = forge.util.createBuffer();\n    rval.putInt32(s2.h0);\n    rval.putInt32(s2.h1);\n    rval.putInt32(s2.h2);\n    rval.putInt32(s2.h3);\n    rval.putInt32(s2.h4);\n    rval.putInt32(s2.h5);\n    rval.putInt32(s2.h6);\n    rval.putInt32(s2.h7);\n    return rval;\n  };\n\n  return md;\n};\n\n// sha-256 padding bytes not initialized yet\nvar _padding = null;\nvar _initialized = false;\n\n// table of constants\nvar _k = null;\n\n/**\n * Initializes the constant tables.\n */\nfunction _init() {\n  // create padding\n  _padding = String.fromCharCode(128);\n  _padding += forge.util.fillString(String.fromCharCode(0x00), 64);\n\n  // create K table for SHA-256\n  _k = [\n    0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n    0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n    0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n    0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n    0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n    0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n    0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n    0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n    0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n    0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n    0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n    0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n    0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n    0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n    0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n    0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2];\n\n  // now initialized\n  _initialized = true;\n}\n\n/**\n * Updates a SHA-256 state with the given byte buffer.\n *\n * @param s the SHA-256 state to update.\n * @param w the array to use to store words.\n * @param bytes the byte buffer to update with.\n */\nfunction _update(s, w, bytes) {\n  // consume 512 bit (64 byte) chunks\n  var t1, t2, s0, s1, ch, maj, i, a, b, c, d, e, f, g, h;\n  var len = bytes.length();\n  while(len >= 64) {\n    // the w array will be populated with sixteen 32-bit big-endian words\n    // and then extended into 64 32-bit words according to SHA-256\n    for(i = 0; i < 16; ++i) {\n      w[i] = bytes.getInt32();\n    }\n    for(; i < 64; ++i) {\n      // XOR word 2 words ago rot right 17, rot right 19, shft right 10\n      t1 = w[i - 2];\n      t1 =\n        ((t1 >>> 17) | (t1 << 15)) ^\n        ((t1 >>> 19) | (t1 << 13)) ^\n        (t1 >>> 10);\n      // XOR word 15 words ago rot right 7, rot right 18, shft right 3\n      t2 = w[i - 15];\n      t2 =\n        ((t2 >>> 7) | (t2 << 25)) ^\n        ((t2 >>> 18) | (t2 << 14)) ^\n        (t2 >>> 3);\n      // sum(t1, word 7 ago, t2, word 16 ago) modulo 2^32\n      w[i] = (t1 + w[i - 7] + t2 + w[i - 16]) | 0;\n    }\n\n    // initialize hash value for this chunk\n    a = s.h0;\n    b = s.h1;\n    c = s.h2;\n    d = s.h3;\n    e = s.h4;\n    f = s.h5;\n    g = s.h6;\n    h = s.h7;\n\n    // round function\n    for(i = 0; i < 64; ++i) {\n      // Sum1(e)\n      s1 =\n        ((e >>> 6) | (e << 26)) ^\n        ((e >>> 11) | (e << 21)) ^\n        ((e >>> 25) | (e << 7));\n      // Ch(e, f, g) (optimized the same way as SHA-1)\n      ch = g ^ (e & (f ^ g));\n      // Sum0(a)\n      s0 =\n        ((a >>> 2) | (a << 30)) ^\n        ((a >>> 13) | (a << 19)) ^\n        ((a >>> 22) | (a << 10));\n      // Maj(a, b, c) (optimized the same way as SHA-1)\n      maj = (a & b) | (c & (a ^ b));\n\n      // main algorithm\n      t1 = h + s1 + ch + _k[i] + w[i];\n      t2 = s0 + maj;\n      h = g;\n      g = f;\n      f = e;\n      // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n      // can't truncate with `| 0`\n      e = (d + t1) >>> 0;\n      d = c;\n      c = b;\n      b = a;\n      // `>>> 0` necessary to avoid iOS/Safari 10 optimization bug\n      // can't truncate with `| 0`\n      a = (t1 + t2) >>> 0;\n    }\n\n    // update hash state\n    s.h0 = (s.h0 + a) | 0;\n    s.h1 = (s.h1 + b) | 0;\n    s.h2 = (s.h2 + c) | 0;\n    s.h3 = (s.h3 + d) | 0;\n    s.h4 = (s.h4 + e) | 0;\n    s.h5 = (s.h5 + f) | 0;\n    s.h6 = (s.h6 + g) | 0;\n    s.h7 = (s.h7 + h) | 0;\n    len -= 64;\n  }\n}\n","/**\n * A javascript implementation of a cryptographically-secure\n * Pseudo Random Number Generator (PRNG). The Fortuna algorithm is followed\n * here though the use of SHA-256 is not enforced; when generating an\n * a PRNG context, the hashing algorithm and block cipher used for\n * the generator are specified via a plugin.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nvar _crypto = null;\nif(forge.util.isNodejs && !forge.options.usePureJavaScript &&\n  !process.versions['node-webkit']) {\n  _crypto = require('crypto');\n}\n\n/* PRNG API */\nvar prng = module.exports = forge.prng = forge.prng || {};\n\n/**\n * Creates a new PRNG context.\n *\n * A PRNG plugin must be passed in that will provide:\n *\n * 1. A function that initializes the key and seed of a PRNG context. It\n *   will be given a 16 byte key and a 16 byte seed. Any key expansion\n *   or transformation of the seed from a byte string into an array of\n *   integers (or similar) should be performed.\n * 2. The cryptographic function used by the generator. It takes a key and\n *   a seed.\n * 3. A seed increment function. It takes the seed and returns seed + 1.\n * 4. An api to create a message digest.\n *\n * For an example, see random.js.\n *\n * @param plugin the PRNG plugin to use.\n */\nprng.create = function(plugin) {\n  var ctx = {\n    plugin: plugin,\n    key: null,\n    seed: null,\n    time: null,\n    // number of reseeds so far\n    reseeds: 0,\n    // amount of data generated so far\n    generated: 0,\n    // no initial key bytes\n    keyBytes: ''\n  };\n\n  // create 32 entropy pools (each is a message digest)\n  var md = plugin.md;\n  var pools = new Array(32);\n  for(var i = 0; i < 32; ++i) {\n    pools[i] = md.create();\n  }\n  ctx.pools = pools;\n\n  // entropy pools are written to cyclically, starting at index 0\n  ctx.pool = 0;\n\n  /**\n   * Generates random bytes. The bytes may be generated synchronously or\n   * asynchronously. Web workers must use the asynchronous interface or\n   * else the behavior is undefined.\n   *\n   * @param count the number of random bytes to generate.\n   * @param [callback(err, bytes)] called once the operation completes.\n   *\n   * @return count random bytes as a string.\n   */\n  ctx.generate = function(count, callback) {\n    // do synchronously\n    if(!callback) {\n      return ctx.generateSync(count);\n    }\n\n    // simple generator using counter-based CBC\n    var cipher = ctx.plugin.cipher;\n    var increment = ctx.plugin.increment;\n    var formatKey = ctx.plugin.formatKey;\n    var formatSeed = ctx.plugin.formatSeed;\n    var b = forge.util.createBuffer();\n\n    // paranoid deviation from Fortuna:\n    // reset key for every request to protect previously\n    // generated random bytes should the key be discovered;\n    // there is no 100ms based reseeding because of this\n    // forced reseed for every `generate` call\n    ctx.key = null;\n\n    generate();\n\n    function generate(err) {\n      if(err) {\n        return callback(err);\n      }\n\n      // sufficient bytes generated\n      if(b.length() >= count) {\n        return callback(null, b.getBytes(count));\n      }\n\n      // if amount of data generated is greater than 1 MiB, trigger reseed\n      if(ctx.generated > 0xfffff) {\n        ctx.key = null;\n      }\n\n      if(ctx.key === null) {\n        // prevent stack overflow\n        return forge.util.nextTick(function() {\n          _reseed(generate);\n        });\n      }\n\n      // generate the random bytes\n      var bytes = cipher(ctx.key, ctx.seed);\n      ctx.generated += bytes.length;\n      b.putBytes(bytes);\n\n      // generate bytes for a new key and seed\n      ctx.key = formatKey(cipher(ctx.key, increment(ctx.seed)));\n      ctx.seed = formatSeed(cipher(ctx.key, ctx.seed));\n\n      forge.util.setImmediate(generate);\n    }\n  };\n\n  /**\n   * Generates random bytes synchronously.\n   *\n   * @param count the number of random bytes to generate.\n   *\n   * @return count random bytes as a string.\n   */\n  ctx.generateSync = function(count) {\n    // simple generator using counter-based CBC\n    var cipher = ctx.plugin.cipher;\n    var increment = ctx.plugin.increment;\n    var formatKey = ctx.plugin.formatKey;\n    var formatSeed = ctx.plugin.formatSeed;\n\n    // paranoid deviation from Fortuna:\n    // reset key for every request to protect previously\n    // generated random bytes should the key be discovered;\n    // there is no 100ms based reseeding because of this\n    // forced reseed for every `generateSync` call\n    ctx.key = null;\n\n    var b = forge.util.createBuffer();\n    while(b.length() < count) {\n      // if amount of data generated is greater than 1 MiB, trigger reseed\n      if(ctx.generated > 0xfffff) {\n        ctx.key = null;\n      }\n\n      if(ctx.key === null) {\n        _reseedSync();\n      }\n\n      // generate the random bytes\n      var bytes = cipher(ctx.key, ctx.seed);\n      ctx.generated += bytes.length;\n      b.putBytes(bytes);\n\n      // generate bytes for a new key and seed\n      ctx.key = formatKey(cipher(ctx.key, increment(ctx.seed)));\n      ctx.seed = formatSeed(cipher(ctx.key, ctx.seed));\n    }\n\n    return b.getBytes(count);\n  };\n\n  /**\n   * Private function that asynchronously reseeds a generator.\n   *\n   * @param callback(err) called once the operation completes.\n   */\n  function _reseed(callback) {\n    if(ctx.pools[0].messageLength >= 32) {\n      _seed();\n      return callback();\n    }\n    // not enough seed data...\n    var needed = (32 - ctx.pools[0].messageLength) << 5;\n    ctx.seedFile(needed, function(err, bytes) {\n      if(err) {\n        return callback(err);\n      }\n      ctx.collect(bytes);\n      _seed();\n      callback();\n    });\n  }\n\n  /**\n   * Private function that synchronously reseeds a generator.\n   */\n  function _reseedSync() {\n    if(ctx.pools[0].messageLength >= 32) {\n      return _seed();\n    }\n    // not enough seed data...\n    var needed = (32 - ctx.pools[0].messageLength) << 5;\n    ctx.collect(ctx.seedFileSync(needed));\n    _seed();\n  }\n\n  /**\n   * Private function that seeds a generator once enough bytes are available.\n   */\n  function _seed() {\n    // update reseed count\n    ctx.reseeds = (ctx.reseeds === 0xffffffff) ? 0 : ctx.reseeds + 1;\n\n    // goal is to update `key` via:\n    // key = hash(key + s)\n    //   where 's' is all collected entropy from selected pools, then...\n\n    // create a plugin-based message digest\n    var md = ctx.plugin.md.create();\n\n    // consume current key bytes\n    md.update(ctx.keyBytes);\n\n    // digest the entropy of pools whose index k meet the\n    // condition 'n mod 2^k == 0' where n is the number of reseeds\n    var _2powK = 1;\n    for(var k = 0; k < 32; ++k) {\n      if(ctx.reseeds % _2powK === 0) {\n        md.update(ctx.pools[k].digest().getBytes());\n        ctx.pools[k].start();\n      }\n      _2powK = _2powK << 1;\n    }\n\n    // get digest for key bytes\n    ctx.keyBytes = md.digest().getBytes();\n\n    // paranoid deviation from Fortuna:\n    // update `seed` via `seed = hash(key)`\n    // instead of initializing to zero once and only\n    // ever incrementing it\n    md.start();\n    md.update(ctx.keyBytes);\n    var seedBytes = md.digest().getBytes();\n\n    // update state\n    ctx.key = ctx.plugin.formatKey(ctx.keyBytes);\n    ctx.seed = ctx.plugin.formatSeed(seedBytes);\n    ctx.generated = 0;\n  }\n\n  /**\n   * The built-in default seedFile. This seedFile is used when entropy\n   * is needed immediately.\n   *\n   * @param needed the number of bytes that are needed.\n   *\n   * @return the random bytes.\n   */\n  function defaultSeedFile(needed) {\n    // use window.crypto.getRandomValues strong source of entropy if available\n    var getRandomValues = null;\n    var globalScope = forge.util.globalScope;\n    var _crypto = globalScope.crypto || globalScope.msCrypto;\n    if(_crypto && _crypto.getRandomValues) {\n      getRandomValues = function(arr) {\n        return _crypto.getRandomValues(arr);\n      };\n    }\n\n    var b = forge.util.createBuffer();\n    if(getRandomValues) {\n      while(b.length() < needed) {\n        // max byte length is 65536 before QuotaExceededError is thrown\n        // http://www.w3.org/TR/WebCryptoAPI/#RandomSource-method-getRandomValues\n        var count = Math.max(1, Math.min(needed - b.length(), 65536) / 4);\n        var entropy = new Uint32Array(Math.floor(count));\n        try {\n          getRandomValues(entropy);\n          for(var i = 0; i < entropy.length; ++i) {\n            b.putInt32(entropy[i]);\n          }\n        } catch(e) {\n          /* only ignore QuotaExceededError */\n          if(!(typeof QuotaExceededError !== 'undefined' &&\n            e instanceof QuotaExceededError)) {\n            throw e;\n          }\n        }\n      }\n    }\n\n    // be sad and add some weak random data\n    if(b.length() < needed) {\n      /* Draws from Park-Miller \"minimal standard\" 31 bit PRNG,\n      implemented with David G. Carta's optimization: with 32 bit math\n      and without division (Public Domain). */\n      var hi, lo, next;\n      var seed = Math.floor(Math.random() * 0x010000);\n      while(b.length() < needed) {\n        lo = 16807 * (seed & 0xFFFF);\n        hi = 16807 * (seed >> 16);\n        lo += (hi & 0x7FFF) << 16;\n        lo += hi >> 15;\n        lo = (lo & 0x7FFFFFFF) + (lo >> 31);\n        seed = lo & 0xFFFFFFFF;\n\n        // consume lower 3 bytes of seed\n        for(var i = 0; i < 3; ++i) {\n          // throw in more pseudo random\n          next = seed >>> (i << 3);\n          next ^= Math.floor(Math.random() * 0x0100);\n          b.putByte(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 * 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 <stesie@brokenpipe.de>\n *\n * Information on the RC2 cipher is available from RFC #2268,\n * http://www.ietf.org/rfc/rfc2268.txt\n */\nvar forge = require('./forge');\nrequire('./util');\n\nvar piTable = [\n  0xd9, 0x78, 0xf9, 0xc4, 0x19, 0xdd, 0xb5, 0xed, 0x28, 0xe9, 0xfd, 0x79, 0x4a, 0xa0, 0xd8, 0x9d,\n  0xc6, 0x7e, 0x37, 0x83, 0x2b, 0x76, 0x53, 0x8e, 0x62, 0x4c, 0x64, 0x88, 0x44, 0x8b, 0xfb, 0xa2,\n  0x17, 0x9a, 0x59, 0xf5, 0x87, 0xb3, 0x4f, 0x13, 0x61, 0x45, 0x6d, 0x8d, 0x09, 0x81, 0x7d, 0x32,\n  0xbd, 0x8f, 0x40, 0xeb, 0x86, 0xb7, 0x7b, 0x0b, 0xf0, 0x95, 0x21, 0x22, 0x5c, 0x6b, 0x4e, 0x82,\n  0x54, 0xd6, 0x65, 0x93, 0xce, 0x60, 0xb2, 0x1c, 0x73, 0x56, 0xc0, 0x14, 0xa7, 0x8c, 0xf1, 0xdc,\n  0x12, 0x75, 0xca, 0x1f, 0x3b, 0xbe, 0xe4, 0xd1, 0x42, 0x3d, 0xd4, 0x30, 0xa3, 0x3c, 0xb6, 0x26,\n  0x6f, 0xbf, 0x0e, 0xda, 0x46, 0x69, 0x07, 0x57, 0x27, 0xf2, 0x1d, 0x9b, 0xbc, 0x94, 0x43, 0x03,\n  0xf8, 0x11, 0xc7, 0xf6, 0x90, 0xef, 0x3e, 0xe7, 0x06, 0xc3, 0xd5, 0x2f, 0xc8, 0x66, 0x1e, 0xd7,\n  0x08, 0xe8, 0xea, 0xde, 0x80, 0x52, 0xee, 0xf7, 0x84, 0xaa, 0x72, 0xac, 0x35, 0x4d, 0x6a, 0x2a,\n  0x96, 0x1a, 0xd2, 0x71, 0x5a, 0x15, 0x49, 0x74, 0x4b, 0x9f, 0xd0, 0x5e, 0x04, 0x18, 0xa4, 0xec,\n  0xc2, 0xe0, 0x41, 0x6e, 0x0f, 0x51, 0xcb, 0xcc, 0x24, 0x91, 0xaf, 0x50, 0xa1, 0xf4, 0x70, 0x39,\n  0x99, 0x7c, 0x3a, 0x85, 0x23, 0xb8, 0xb4, 0x7a, 0xfc, 0x02, 0x36, 0x5b, 0x25, 0x55, 0x97, 0x31,\n  0x2d, 0x5d, 0xfa, 0x98, 0xe3, 0x8a, 0x92, 0xae, 0x05, 0xdf, 0x29, 0x10, 0x67, 0x6c, 0xba, 0xc9,\n  0xd3, 0x00, 0xe6, 0xcf, 0xe1, 0x9e, 0xa8, 0x2c, 0x63, 0x16, 0x01, 0x3f, 0x58, 0xe2, 0x89, 0xa9,\n  0x0d, 0x38, 0x34, 0x1b, 0xab, 0x33, 0xff, 0xb0, 0xbb, 0x48, 0x0c, 0x5f, 0xb9, 0xb1, 0xcd, 0x2e,\n  0xc5, 0xf3, 0xdb, 0x47, 0xe5, 0xa5, 0x9c, 0x77, 0x0a, 0xa6, 0x20, 0x68, 0xfe, 0x7f, 0xc1, 0xad\n];\n\nvar s = [1, 2, 3, 5];\n\n/**\n * Rotate a word left by given number of bits.\n *\n * Bits that are shifted out on the left are put back in on the right\n * hand side.\n *\n * @param word The word to shift left.\n * @param bits The number of bits to shift by.\n * @return The rotated word.\n */\nvar rol = function(word, bits) {\n  return ((word << bits) & 0xffff) | ((word & 0xffff) >> (16 - bits));\n};\n\n/**\n * Rotate a word right by given number of bits.\n *\n * Bits that are shifted out on the right are put back in on the left\n * hand side.\n *\n * @param word The word to shift right.\n * @param bits The number of bits to shift by.\n * @return The rotated word.\n */\nvar ror = function(word, bits) {\n  return ((word & 0xffff) >> bits) | ((word << (16 - bits)) & 0xffff);\n};\n\n/* RC2 API */\nmodule.exports = forge.rc2 = forge.rc2 || {};\n\n/**\n * Perform RC2 key expansion as per RFC #2268, section 2.\n *\n * @param key variable-length user key (between 1 and 128 bytes)\n * @param effKeyBits number of effective key bits (default: 128)\n * @return the expanded RC2 key (ByteBuffer of 128 bytes)\n */\nforge.rc2.expandKey = function(key, effKeyBits) {\n  if(typeof key === 'string') {\n    key = forge.util.createBuffer(key);\n  }\n  effKeyBits = effKeyBits || 128;\n\n  /* introduce variables that match the names used in RFC #2268 */\n  var L = key;\n  var T = key.length();\n  var T1 = effKeyBits;\n  var T8 = Math.ceil(T1 / 8);\n  var TM = 0xff >> (T1 & 0x07);\n  var i;\n\n  for(i = T; i < 128; i++) {\n    L.putByte(piTable[(L.at(i - 1) + L.at(i - T)) & 0xff]);\n  }\n\n  L.setAt(128 - T8, piTable[L.at(128 - T8) & TM]);\n\n  for(i = 127 - T8; i >= 0; i--) {\n    L.setAt(i, piTable[L.at(i + 1) ^ L.at(i + T8)]);\n  }\n\n  return L;\n};\n\n/**\n * Creates a RC2 cipher object.\n *\n * @param key the symmetric key to use (as base for key generation).\n * @param bits the number of effective key bits.\n * @param encrypt false for decryption, true for encryption.\n *\n * @return the cipher.\n */\nvar createCipher = function(key, bits, encrypt) {\n  var _finish = false, _input = null, _output = null, _iv = null;\n  var mixRound, mashRound;\n  var i, j, K = [];\n\n  /* Expand key and fill into K[] Array */\n  key = forge.rc2.expandKey(key, bits);\n  for(i = 0; i < 64; i++) {\n    K.push(key.getInt16Le());\n  }\n\n  if(encrypt) {\n    /**\n     * Perform one mixing round \"in place\".\n     *\n     * @param R Array of four words to perform mixing on.\n     */\n    mixRound = function(R) {\n      for(i = 0; i < 4; i++) {\n        R[i] += K[j] + (R[(i + 3) % 4] & R[(i + 2) % 4]) +\n          ((~R[(i + 3) % 4]) & R[(i + 1) % 4]);\n        R[i] = rol(R[i], s[i]);\n        j++;\n      }\n    };\n\n    /**\n     * Perform one mashing round \"in place\".\n     *\n     * @param R Array of four words to perform mashing on.\n     */\n    mashRound = function(R) {\n      for(i = 0; i < 4; i++) {\n        R[i] += K[R[(i + 3) % 4] & 63];\n      }\n    };\n  } else {\n    /**\n     * Perform one r-mixing round \"in place\".\n     *\n     * @param R Array of four words to perform mixing on.\n     */\n    mixRound = function(R) {\n      for(i = 3; i >= 0; i--) {\n        R[i] = ror(R[i], s[i]);\n        R[i] -= K[j] + (R[(i + 3) % 4] & R[(i + 2) % 4]) +\n          ((~R[(i + 3) % 4]) & R[(i + 1) % 4]);\n        j--;\n      }\n    };\n\n    /**\n     * Perform one r-mashing round \"in place\".\n     *\n     * @param R Array of four words to perform mashing on.\n     */\n    mashRound = function(R) {\n      for(i = 3; i >= 0; i--) {\n        R[i] -= K[R[(i + 3) % 4] & 63];\n      }\n    };\n  }\n\n  /**\n   * Run the specified cipher execution plan.\n   *\n   * This function takes four words from the input buffer, applies the IV on\n   * it (if requested) and runs the provided execution plan.\n   *\n   * The plan must be put together in form of a array of arrays.  Where the\n   * outer one is simply a list of steps to perform and the inner one needs\n   * to have two elements: the first one telling how many rounds to perform,\n   * the second one telling what to do (i.e. the function to call).\n   *\n   * @param {Array} plan The plan to execute.\n   */\n  var runPlan = function(plan) {\n    var R = [];\n\n    /* Get data from input buffer and fill the four words into R */\n    for(i = 0; i < 4; i++) {\n      var val = _input.getInt16Le();\n\n      if(_iv !== null) {\n        if(encrypt) {\n          /* We're encrypting, apply the IV first. */\n          val ^= _iv.getInt16Le();\n        } else {\n          /* We're decryption, keep cipher text for next block. */\n          _iv.putInt16Le(val);\n        }\n      }\n\n      R.push(val & 0xffff);\n    }\n\n    /* Reset global \"j\" variable as per spec. */\n    j = encrypt ? 0 : 63;\n\n    /* Run execution plan. */\n    for(var ptr = 0; ptr < plan.length; ptr++) {\n      for(var ctr = 0; ctr < plan[ptr][0]; ctr++) {\n        plan[ptr][1](R);\n      }\n    }\n\n    /* Write back result to output buffer. */\n    for(i = 0; i < 4; i++) {\n      if(_iv !== null) {\n        if(encrypt) {\n          /* We're encrypting in CBC-mode, feed back encrypted bytes into\n             IV buffer to carry it forward to next block. */\n          _iv.putInt16Le(R[i]);\n        } else {\n          R[i] ^= _iv.getInt16Le();\n        }\n      }\n\n      _output.putInt16Le(R[i]);\n    }\n  };\n\n  /* Create cipher object */\n  var cipher = null;\n  cipher = {\n    /**\n     * Starts or restarts the encryption or decryption process, whichever\n     * was previously configured.\n     *\n     * To use the cipher in CBC mode, iv may be given either as a string\n     * of bytes, or as a byte buffer.  For ECB mode, give null as iv.\n     *\n     * @param iv the initialization vector to use, null for ECB mode.\n     * @param output the output the buffer to write to, null to create one.\n     */\n    start: function(iv, output) {\n      if(iv) {\n        /* CBC mode */\n        if(typeof iv === 'string') {\n          iv = forge.util.createBuffer(iv);\n        }\n      }\n\n      _finish = false;\n      _input = forge.util.createBuffer();\n      _output = output || new forge.util.createBuffer();\n      _iv = iv;\n\n      cipher.output = _output;\n    },\n\n    /**\n     * Updates the next block.\n     *\n     * @param input the buffer to read from.\n     */\n    update: function(input) {\n      if(!_finish) {\n        // not finishing, so fill the input buffer with more input\n        _input.putBuffer(input);\n      }\n\n      while(_input.length() >= 8) {\n        runPlan([\n            [ 5, mixRound ],\n            [ 1, mashRound ],\n            [ 6, mixRound ],\n            [ 1, mashRound ],\n            [ 5, mixRound ]\n          ]);\n      }\n    },\n\n    /**\n     * Finishes encrypting or decrypting.\n     *\n     * @param pad a padding function to use, null for PKCS#7 padding,\n     *           signature(blockSize, buffer, decrypt).\n     *\n     * @return true if successful, false on error.\n     */\n    finish: function(pad) {\n      var rval = true;\n\n      if(encrypt) {\n        if(pad) {\n          rval = pad(8, _input, !encrypt);\n        } else {\n          // add PKCS#7 padding to block (each pad byte is the\n          // value of the number of pad bytes)\n          var padding = (_input.length() === 8) ? 8 : (8 - _input.length());\n          _input.fillWithByte(padding, padding);\n        }\n      }\n\n      if(rval) {\n        // do final update\n        _finish = true;\n        cipher.update();\n      }\n\n      if(!encrypt) {\n        // check for error: input data not a multiple of block size\n        rval = (_input.length() === 0);\n        if(rval) {\n          if(pad) {\n            rval = pad(8, _output, !encrypt);\n          } else {\n            // ensure padding byte count is valid\n            var len = _output.length();\n            var count = _output.at(len - 1);\n\n            if(count > len) {\n              rval = false;\n            } else {\n              // trim off padding bytes\n              _output.truncate(count);\n            }\n          }\n        }\n      }\n\n      return rval;\n    }\n  };\n\n  return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to encrypt data in ECB or CBC mode using the\n * given symmetric key. The output will be stored in the 'output' member\n * of the returned cipher.\n *\n * The key and iv may be given as a string of bytes or a byte buffer.\n * The cipher is initialized to use 128 effective key bits.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n *\n * @return the cipher.\n */\nforge.rc2.startEncrypting = function(key, iv, output) {\n  var cipher = forge.rc2.createEncryptionCipher(key, 128);\n  cipher.start(iv, output);\n  return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to encrypt data in ECB or CBC mode using the\n * given symmetric key.\n *\n * The key may be given as a string of bytes or a byte buffer.\n *\n * To start encrypting call start() on the cipher with an iv and optional\n * output buffer.\n *\n * @param key the symmetric key to use.\n *\n * @return the cipher.\n */\nforge.rc2.createEncryptionCipher = function(key, bits) {\n  return createCipher(key, bits, true);\n};\n\n/**\n * Creates an RC2 cipher object to decrypt data in ECB or CBC mode using the\n * given symmetric key. The output will be stored in the 'output' member\n * of the returned cipher.\n *\n * The key and iv may be given as a string of bytes or a byte buffer.\n * The cipher is initialized to use 128 effective key bits.\n *\n * @param key the symmetric key to use.\n * @param iv the initialization vector to use.\n * @param output the buffer to write to, null to create one.\n *\n * @return the cipher.\n */\nforge.rc2.startDecrypting = function(key, iv, output) {\n  var cipher = forge.rc2.createDecryptionCipher(key, 128);\n  cipher.start(iv, output);\n  return cipher;\n};\n\n/**\n * Creates an RC2 cipher object to decrypt data in ECB or CBC mode using the\n * given symmetric key.\n *\n * The key may be given as a string of bytes or a byte buffer.\n *\n * To start decrypting call start() on the cipher with an iv and optional\n * output buffer.\n *\n * @param key the symmetric key to use.\n *\n * @return the cipher.\n */\nforge.rc2.createDecryptionCipher = function(key, bits) {\n  return createCipher(key, bits, false);\n};\n","// Copyright (c) 2005  Tom Wu\n// All Rights Reserved.\n// See \"LICENSE\" for details.\n\n// Basic JavaScript BN library - subset useful for RSA encryption.\n\n/*\nLicensing (LICENSE)\n-------------------\n\nThis software is covered under the following copyright:\n*/\n/*\n * Copyright (c) 2003-2005  Tom Wu\n * All Rights Reserved.\n *\n * Permission is hereby granted, free of charge, to any person obtaining\n * a copy of this software and associated documentation files (the\n * \"Software\"), to deal in the Software without restriction, including\n * without limitation the rights to use, copy, modify, merge, publish,\n * distribute, sublicense, and/or sell copies of the Software, and to\n * permit persons to whom the Software is furnished to do so, subject to\n * the following conditions:\n *\n * The above copyright notice and this permission notice shall be\n * included in all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS-IS\" AND WITHOUT WARRANTY OF ANY KIND,\n * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY\n * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.\n *\n * IN NO EVENT SHALL TOM WU BE LIABLE FOR ANY SPECIAL, INCIDENTAL,\n * INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, OR ANY DAMAGES WHATSOEVER\n * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER OR NOT ADVISED OF\n * THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF LIABILITY, ARISING OUT\n * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n *\n * In addition, the following condition applies:\n *\n * All redistributions must retain an intact copy of this copyright notice\n * and disclaimer.\n */\n/*\nAddress all questions regarding this license to:\n\n  Tom Wu\n  tjw@cs.Stanford.EDU\n*/\nvar forge = require('./forge');\n\nmodule.exports = forge.jsbn = forge.jsbn || {};\n\n// Bits per digit\nvar dbits;\n\n// JavaScript engine analysis\nvar canary = 0xdeadbeefcafe;\nvar j_lm = ((canary&0xffffff)==0xefcafe);\n\n// (public) Constructor\nfunction BigInteger(a,b,c) {\n  this.data = [];\n  if(a != null)\n    if(\"number\" == typeof a) this.fromNumber(a,b,c);\n    else if(b == null && \"string\" != typeof a) this.fromString(a,256);\n    else this.fromString(a,b);\n}\nforge.jsbn.BigInteger = BigInteger;\n\n// return new, unset BigInteger\nfunction nbi() { return new BigInteger(null); }\n\n// am: Compute w_j += (x*this_i), propagate carries,\n// c is initial carry, returns final carry.\n// c < 3*dvalue, x < 2*dvalue, this_i < dvalue\n// We need to select the fastest one that works in this environment.\n\n// am1: use a single mult and divide to get the high bits,\n// max digit bits should be 26 because\n// max internal value = 2*dvalue^2-2*dvalue (< 2^53)\nfunction am1(i,x,w,j,c,n) {\n  while(--n >= 0) {\n    var v = x*this.data[i++]+w.data[j]+c;\n    c = Math.floor(v/0x4000000);\n    w.data[j++] = v&0x3ffffff;\n  }\n  return c;\n}\n// am2 avoids a big mult-and-extract completely.\n// Max digit bits should be <= 30 because we do bitwise ops\n// on values up to 2*hdvalue^2-hdvalue-1 (< 2^31)\nfunction am2(i,x,w,j,c,n) {\n  var xl = x&0x7fff, xh = x>>15;\n  while(--n >= 0) {\n    var l = this.data[i]&0x7fff;\n    var h = this.data[i++]>>15;\n    var m = xh*l+h*xl;\n    l = xl*l+((m&0x7fff)<<15)+w.data[j]+(c&0x3fffffff);\n    c = (l>>>30)+(m>>>15)+xh*h+(c>>>30);\n    w.data[j++] = l&0x3fffffff;\n  }\n  return c;\n}\n// Alternately, set max digit bits to 28 since some\n// browsers slow down when dealing with 32-bit numbers.\nfunction am3(i,x,w,j,c,n) {\n  var xl = x&0x3fff, xh = x>>14;\n  while(--n >= 0) {\n    var l = this.data[i]&0x3fff;\n    var h = this.data[i++]>>14;\n    var m = xh*l+h*xl;\n    l = xl*l+((m&0x3fff)<<14)+w.data[j]+c;\n    c = (l>>28)+(m>>14)+xh*h;\n    w.data[j++] = l&0xfffffff;\n  }\n  return c;\n}\n\n// node.js (no browser)\nif(typeof(navigator) === 'undefined')\n{\n   BigInteger.prototype.am = am3;\n   dbits = 28;\n} else if(j_lm && (navigator.appName == \"Microsoft Internet Explorer\")) {\n  BigInteger.prototype.am = am2;\n  dbits = 30;\n} else if(j_lm && (navigator.appName != \"Netscape\")) {\n  BigInteger.prototype.am = am1;\n  dbits = 26;\n} else { // Mozilla/Netscape seems to prefer am3\n  BigInteger.prototype.am = am3;\n  dbits = 28;\n}\n\nBigInteger.prototype.DB = dbits;\nBigInteger.prototype.DM = ((1<<dbits)-1);\nBigInteger.prototype.DV = (1<<dbits);\n\nvar BI_FP = 52;\nBigInteger.prototype.FV = Math.pow(2,BI_FP);\nBigInteger.prototype.F1 = BI_FP-dbits;\nBigInteger.prototype.F2 = 2*dbits-BI_FP;\n\n// Digit conversions\nvar BI_RM = \"0123456789abcdefghijklmnopqrstuvwxyz\";\nvar BI_RC = new Array();\nvar rr,vv;\nrr = \"0\".charCodeAt(0);\nfor(vv = 0; vv <= 9; ++vv) BI_RC[rr++] = vv;\nrr = \"a\".charCodeAt(0);\nfor(vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv;\nrr = \"A\".charCodeAt(0);\nfor(vv = 10; vv < 36; ++vv) BI_RC[rr++] = vv;\n\nfunction int2char(n) { return BI_RM.charAt(n); }\nfunction intAt(s,i) {\n  var c = BI_RC[s.charCodeAt(i)];\n  return (c==null)?-1:c;\n}\n\n// (protected) copy this to r\nfunction bnpCopyTo(r) {\n  for(var i = this.t-1; i >= 0; --i) r.data[i] = this.data[i];\n  r.t = this.t;\n  r.s = this.s;\n}\n\n// (protected) set from integer value x, -DV <= x < DV\nfunction bnpFromInt(x) {\n  this.t = 1;\n  this.s = (x<0)?-1:0;\n  if(x > 0) this.data[0] = x;\n  else if(x < -1) this.data[0] = x+this.DV;\n  else this.t = 0;\n}\n\n// return bigint initialized to value\nfunction nbv(i) { var r = nbi(); r.fromInt(i); return r; }\n\n// (protected) set from string and radix\nfunction bnpFromString(s,b) {\n  var k;\n  if(b == 16) k = 4;\n  else if(b == 8) k = 3;\n  else if(b == 256) k = 8; // byte array\n  else if(b == 2) k = 1;\n  else if(b == 32) k = 5;\n  else if(b == 4) k = 2;\n  else { this.fromRadix(s,b); return; }\n  this.t = 0;\n  this.s = 0;\n  var i = s.length, mi = false, sh = 0;\n  while(--i >= 0) {\n    var x = (k==8)?s[i]&0xff:intAt(s,i);\n    if(x < 0) {\n      if(s.charAt(i) == \"-\") mi = true;\n      continue;\n    }\n    mi = false;\n    if(sh == 0)\n      this.data[this.t++] = x;\n    else if(sh+k > this.DB) {\n      this.data[this.t-1] |= (x&((1<<(this.DB-sh))-1))<<sh;\n      this.data[this.t++] = (x>>(this.DB-sh));\n    } else\n      this.data[this.t-1] |= x<<sh;\n    sh += k;\n    if(sh >= this.DB) sh -= this.DB;\n  }\n  if(k == 8 && (s[0]&0x80) != 0) {\n    this.s = -1;\n    if(sh > 0) this.data[this.t-1] |= ((1<<(this.DB-sh))-1)<<sh;\n  }\n  this.clamp();\n  if(mi) BigInteger.ZERO.subTo(this,this);\n}\n\n// (protected) clamp off excess high words\nfunction bnpClamp() {\n  var c = this.s&this.DM;\n  while(this.t > 0 && this.data[this.t-1] == c) --this.t;\n}\n\n// (public) return string representation in given radix\nfunction bnToString(b) {\n  if(this.s < 0) return \"-\"+this.negate().toString(b);\n  var k;\n  if(b == 16) k = 4;\n  else if(b == 8) k = 3;\n  else if(b == 2) k = 1;\n  else if(b == 32) k = 5;\n  else if(b == 4) k = 2;\n  else return this.toRadix(b);\n  var km = (1<<k)-1, d, m = false, r = \"\", i = this.t;\n  var p = this.DB-(i*this.DB)%k;\n  if(i-- > 0) {\n    if(p < this.DB && (d = this.data[i]>>p) > 0) { m = true; r = int2char(d); }\n    while(i >= 0) {\n      if(p < k) {\n        d = (this.data[i]&((1<<p)-1))<<(k-p);\n        d |= this.data[--i]>>(p+=this.DB-k);\n      } else {\n        d = (this.data[i]>>(p-=k))&km;\n        if(p <= 0) { p += this.DB; --i; }\n      }\n      if(d > 0) m = true;\n      if(m) r += int2char(d);\n    }\n  }\n  return m?r:\"0\";\n}\n\n// (public) -this\nfunction bnNegate() { var r = nbi(); BigInteger.ZERO.subTo(this,r); return r; }\n\n// (public) |this|\nfunction bnAbs() { return (this.s<0)?this.negate():this; }\n\n// (public) return + if this > a, - if this < a, 0 if equal\nfunction bnCompareTo(a) {\n  var r = this.s-a.s;\n  if(r != 0) return r;\n  var i = this.t;\n  r = i-a.t;\n  if(r != 0) return (this.s<0)?-r:r;\n  while(--i >= 0) if((r=this.data[i]-a.data[i]) != 0) return r;\n  return 0;\n}\n\n// returns bit length of the integer x\nfunction nbits(x) {\n  var r = 1, t;\n  if((t=x>>>16) != 0) { x = t; r += 16; }\n  if((t=x>>8) != 0) { x = t; r += 8; }\n  if((t=x>>4) != 0) { x = t; r += 4; }\n  if((t=x>>2) != 0) { x = t; r += 2; }\n  if((t=x>>1) != 0) { x = t; r += 1; }\n  return r;\n}\n\n// (public) return the number of bits in \"this\"\nfunction bnBitLength() {\n  if(this.t <= 0) return 0;\n  return this.DB*(this.t-1)+nbits(this.data[this.t-1]^(this.s&this.DM));\n}\n\n// (protected) r = this << n*DB\nfunction bnpDLShiftTo(n,r) {\n  var i;\n  for(i = this.t-1; i >= 0; --i) r.data[i+n] = this.data[i];\n  for(i = n-1; i >= 0; --i) r.data[i] = 0;\n  r.t = this.t+n;\n  r.s = this.s;\n}\n\n// (protected) r = this >> n*DB\nfunction bnpDRShiftTo(n,r) {\n  for(var i = n; i < this.t; ++i) r.data[i-n] = this.data[i];\n  r.t = Math.max(this.t-n,0);\n  r.s = this.s;\n}\n\n// (protected) r = this << n\nfunction bnpLShiftTo(n,r) {\n  var bs = n%this.DB;\n  var cbs = this.DB-bs;\n  var bm = (1<<cbs)-1;\n  var ds = Math.floor(n/this.DB), c = (this.s<<bs)&this.DM, i;\n  for(i = this.t-1; i >= 0; --i) {\n    r.data[i+ds+1] = (this.data[i]>>cbs)|c;\n    c = (this.data[i]&bm)<<bs;\n  }\n  for(i = ds-1; i >= 0; --i) r.data[i] = 0;\n  r.data[ds] = c;\n  r.t = this.t+ds+1;\n  r.s = this.s;\n  r.clamp();\n}\n\n// (protected) r = this >> n\nfunction bnpRShiftTo(n,r) {\n  r.s = this.s;\n  var ds = Math.floor(n/this.DB);\n  if(ds >= this.t) { r.t = 0; return; }\n  var bs = n%this.DB;\n  var cbs = this.DB-bs;\n  var bm = (1<<bs)-1;\n  r.data[0] = this.data[ds]>>bs;\n  for(var i = ds+1; i < this.t; ++i) {\n    r.data[i-ds-1] |= (this.data[i]&bm)<<cbs;\n    r.data[i-ds] = this.data[i]>>bs;\n  }\n  if(bs > 0) r.data[this.t-ds-1] |= (this.s&bm)<<cbs;\n  r.t = this.t-ds;\n  r.clamp();\n}\n\n// (protected) r = this - a\nfunction bnpSubTo(a,r) {\n  var i = 0, c = 0, m = Math.min(a.t,this.t);\n  while(i < m) {\n    c += this.data[i]-a.data[i];\n    r.data[i++] = c&this.DM;\n    c >>= this.DB;\n  }\n  if(a.t < this.t) {\n    c -= a.s;\n    while(i < this.t) {\n      c += this.data[i];\n      r.data[i++] = c&this.DM;\n      c >>= this.DB;\n    }\n    c += this.s;\n  } else {\n    c += this.s;\n    while(i < a.t) {\n      c -= a.data[i];\n      r.data[i++] = c&this.DM;\n      c >>= this.DB;\n    }\n    c -= a.s;\n  }\n  r.s = (c<0)?-1:0;\n  if(c < -1) r.data[i++] = this.DV+c;\n  else if(c > 0) r.data[i++] = c;\n  r.t = i;\n  r.clamp();\n}\n\n// (protected) r = this * a, r != this,a (HAC 14.12)\n// \"this\" should be the larger one if appropriate.\nfunction bnpMultiplyTo(a,r) {\n  var x = this.abs(), y = a.abs();\n  var i = x.t;\n  r.t = i+y.t;\n  while(--i >= 0) r.data[i] = 0;\n  for(i = 0; i < y.t; ++i) r.data[i+x.t] = x.am(0,y.data[i],r,i,0,x.t);\n  r.s = 0;\n  r.clamp();\n  if(this.s != a.s) BigInteger.ZERO.subTo(r,r);\n}\n\n// (protected) r = this^2, r != this (HAC 14.16)\nfunction bnpSquareTo(r) {\n  var x = this.abs();\n  var i = r.t = 2*x.t;\n  while(--i >= 0) r.data[i] = 0;\n  for(i = 0; i < x.t-1; ++i) {\n    var c = x.am(i,x.data[i],r,2*i,0,1);\n    if((r.data[i+x.t]+=x.am(i+1,2*x.data[i],r,2*i+1,c,x.t-i-1)) >= x.DV) {\n      r.data[i+x.t] -= x.DV;\n      r.data[i+x.t+1] = 1;\n    }\n  }\n  if(r.t > 0) r.data[r.t-1] += x.am(i,x.data[i],r,2*i,0,1);\n  r.s = 0;\n  r.clamp();\n}\n\n// (protected) divide this by m, quotient and remainder to q, r (HAC 14.20)\n// r != q, this != m.  q or r may be null.\nfunction bnpDivRemTo(m,q,r) {\n  var pm = m.abs();\n  if(pm.t <= 0) return;\n  var pt = this.abs();\n  if(pt.t < pm.t) {\n    if(q != null) q.fromInt(0);\n    if(r != null) this.copyTo(r);\n    return;\n  }\n  if(r == null) r = nbi();\n  var y = nbi(), ts = this.s, ms = m.s;\n  var nsh = this.DB-nbits(pm.data[pm.t-1]);\t// normalize modulus\n  if(nsh > 0) { pm.lShiftTo(nsh,y); pt.lShiftTo(nsh,r); } else { pm.copyTo(y); pt.copyTo(r); }\n  var ys = y.t;\n  var y0 = y.data[ys-1];\n  if(y0 == 0) return;\n  var yt = y0*(1<<this.F1)+((ys>1)?y.data[ys-2]>>this.F2:0);\n  var d1 = this.FV/yt, d2 = (1<<this.F1)/yt, e = 1<<this.F2;\n  var i = r.t, j = i-ys, t = (q==null)?nbi():q;\n  y.dlShiftTo(j,t);\n  if(r.compareTo(t) >= 0) {\n    r.data[r.t++] = 1;\n    r.subTo(t,r);\n  }\n  BigInteger.ONE.dlShiftTo(ys,t);\n  t.subTo(y,y);\t// \"negative\" y so we can replace sub with am later\n  while(y.t < ys) y.data[y.t++] = 0;\n  while(--j >= 0) {\n    // Estimate quotient digit\n    var qd = (r.data[--i]==y0)?this.DM:Math.floor(r.data[i]*d1+(r.data[i-1]+e)*d2);\n    if((r.data[i]+=y.am(0,qd,r,j,0,ys)) < qd) {\t// Try it out\n      y.dlShiftTo(j,t);\n      r.subTo(t,r);\n      while(r.data[i] < --qd) r.subTo(t,r);\n    }\n  }\n  if(q != null) {\n    r.drShiftTo(ys,q);\n    if(ts != ms) BigInteger.ZERO.subTo(q,q);\n  }\n  r.t = ys;\n  r.clamp();\n  if(nsh > 0) r.rShiftTo(nsh,r);\t// Denormalize remainder\n  if(ts < 0) BigInteger.ZERO.subTo(r,r);\n}\n\n// (public) this mod a\nfunction bnMod(a) {\n  var r = nbi();\n  this.abs().divRemTo(a,null,r);\n  if(this.s < 0 && r.compareTo(BigInteger.ZERO) > 0) a.subTo(r,r);\n  return r;\n}\n\n// Modular reduction using \"classic\" algorithm\nfunction Classic(m) { this.m = m; }\nfunction cConvert(x) {\n  if(x.s < 0 || x.compareTo(this.m) >= 0) return x.mod(this.m);\n  else return x;\n}\nfunction cRevert(x) { return x; }\nfunction cReduce(x) { x.divRemTo(this.m,null,x); }\nfunction cMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\nfunction cSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\nClassic.prototype.convert = cConvert;\nClassic.prototype.revert = cRevert;\nClassic.prototype.reduce = cReduce;\nClassic.prototype.mulTo = cMulTo;\nClassic.prototype.sqrTo = cSqrTo;\n\n// (protected) return \"-1/this % 2^DB\"; useful for Mont. reduction\n// justification:\n//         xy == 1 (mod m)\n//         xy =  1+km\n//   xy(2-xy) = (1+km)(1-km)\n// x[y(2-xy)] = 1-k^2m^2\n// x[y(2-xy)] == 1 (mod m^2)\n// if y is 1/x mod m, then y(2-xy) is 1/x mod m^2\n// should reduce x and y(2-xy) by m^2 at each step to keep size bounded.\n// JS multiply \"overflows\" differently from C/C++, so care is needed here.\nfunction bnpInvDigit() {\n  if(this.t < 1) return 0;\n  var x = this.data[0];\n  if((x&1) == 0) return 0;\n  var y = x&3;\t\t// y == 1/x mod 2^2\n  y = (y*(2-(x&0xf)*y))&0xf;\t// y == 1/x mod 2^4\n  y = (y*(2-(x&0xff)*y))&0xff;\t// y == 1/x mod 2^8\n  y = (y*(2-(((x&0xffff)*y)&0xffff)))&0xffff;\t// y == 1/x mod 2^16\n  // last step - calculate inverse mod DV directly;\n  // assumes 16 < DB <= 32 and assumes ability to handle 48-bit ints\n  y = (y*(2-x*y%this.DV))%this.DV;\t\t// y == 1/x mod 2^dbits\n  // we really want the negative inverse, and -DV < y < DV\n  return (y>0)?this.DV-y:-y;\n}\n\n// Montgomery reduction\nfunction Montgomery(m) {\n  this.m = m;\n  this.mp = m.invDigit();\n  this.mpl = this.mp&0x7fff;\n  this.mph = this.mp>>15;\n  this.um = (1<<(m.DB-15))-1;\n  this.mt2 = 2*m.t;\n}\n\n// xR mod m\nfunction montConvert(x) {\n  var r = nbi();\n  x.abs().dlShiftTo(this.m.t,r);\n  r.divRemTo(this.m,null,r);\n  if(x.s < 0 && r.compareTo(BigInteger.ZERO) > 0) this.m.subTo(r,r);\n  return r;\n}\n\n// x/R mod m\nfunction montRevert(x) {\n  var r = nbi();\n  x.copyTo(r);\n  this.reduce(r);\n  return r;\n}\n\n// x = x/R mod m (HAC 14.32)\nfunction montReduce(x) {\n  while(x.t <= this.mt2)\t// pad x so am has enough room later\n    x.data[x.t++] = 0;\n  for(var i = 0; i < this.m.t; ++i) {\n    // faster way of calculating u0 = x.data[i]*mp mod DV\n    var j = x.data[i]&0x7fff;\n    var u0 = (j*this.mpl+(((j*this.mph+(x.data[i]>>15)*this.mpl)&this.um)<<15))&x.DM;\n    // use am to combine the multiply-shift-add into one call\n    j = i+this.m.t;\n    x.data[j] += this.m.am(0,u0,x,i,0,this.m.t);\n    // propagate carry\n    while(x.data[j] >= x.DV) { x.data[j] -= x.DV; x.data[++j]++; }\n  }\n  x.clamp();\n  x.drShiftTo(this.m.t,x);\n  if(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n}\n\n// r = \"x^2/R mod m\"; x != r\nfunction montSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n// r = \"xy/R mod m\"; x,y != r\nfunction montMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\nMontgomery.prototype.convert = montConvert;\nMontgomery.prototype.revert = montRevert;\nMontgomery.prototype.reduce = montReduce;\nMontgomery.prototype.mulTo = montMulTo;\nMontgomery.prototype.sqrTo = montSqrTo;\n\n// (protected) true iff this is even\nfunction bnpIsEven() { return ((this.t>0)?(this.data[0]&1):this.s) == 0; }\n\n// (protected) this^e, e < 2^32, doing sqr and mul with \"r\" (HAC 14.79)\nfunction bnpExp(e,z) {\n  if(e > 0xffffffff || e < 1) return BigInteger.ONE;\n  var r = nbi(), r2 = nbi(), g = z.convert(this), i = nbits(e)-1;\n  g.copyTo(r);\n  while(--i >= 0) {\n    z.sqrTo(r,r2);\n    if((e&(1<<i)) > 0) z.mulTo(r2,g,r);\n    else { var t = r; r = r2; r2 = t; }\n  }\n  return z.revert(r);\n}\n\n// (public) this^e % m, 0 <= e < 2^32\nfunction bnModPowInt(e,m) {\n  var z;\n  if(e < 256 || m.isEven()) z = new Classic(m); else z = new Montgomery(m);\n  return this.exp(e,z);\n}\n\n// protected\nBigInteger.prototype.copyTo = bnpCopyTo;\nBigInteger.prototype.fromInt = bnpFromInt;\nBigInteger.prototype.fromString = bnpFromString;\nBigInteger.prototype.clamp = bnpClamp;\nBigInteger.prototype.dlShiftTo = bnpDLShiftTo;\nBigInteger.prototype.drShiftTo = bnpDRShiftTo;\nBigInteger.prototype.lShiftTo = bnpLShiftTo;\nBigInteger.prototype.rShiftTo = bnpRShiftTo;\nBigInteger.prototype.subTo = bnpSubTo;\nBigInteger.prototype.multiplyTo = bnpMultiplyTo;\nBigInteger.prototype.squareTo = bnpSquareTo;\nBigInteger.prototype.divRemTo = bnpDivRemTo;\nBigInteger.prototype.invDigit = bnpInvDigit;\nBigInteger.prototype.isEven = bnpIsEven;\nBigInteger.prototype.exp = bnpExp;\n\n// public\nBigInteger.prototype.toString = bnToString;\nBigInteger.prototype.negate = bnNegate;\nBigInteger.prototype.abs = bnAbs;\nBigInteger.prototype.compareTo = bnCompareTo;\nBigInteger.prototype.bitLength = bnBitLength;\nBigInteger.prototype.mod = bnMod;\nBigInteger.prototype.modPowInt = bnModPowInt;\n\n// \"constants\"\nBigInteger.ZERO = nbv(0);\nBigInteger.ONE = nbv(1);\n\n// jsbn2 lib\n\n//Copyright (c) 2005-2009  Tom Wu\n//All Rights Reserved.\n//See \"LICENSE\" for details (See jsbn.js for LICENSE).\n\n//Extended JavaScript BN functions, required for RSA private ops.\n\n//Version 1.1: new BigInteger(\"0\", 10) returns \"proper\" zero\n\n//(public)\nfunction bnClone() { var r = nbi(); this.copyTo(r); return r; }\n\n//(public) return value as integer\nfunction bnIntValue() {\nif(this.s < 0) {\n if(this.t == 1) return this.data[0]-this.DV;\n else if(this.t == 0) return -1;\n} else if(this.t == 1) return this.data[0];\nelse if(this.t == 0) return 0;\n// assumes 16 < DB < 32\nreturn ((this.data[1]&((1<<(32-this.DB))-1))<<this.DB)|this.data[0];\n}\n\n//(public) return value as byte\nfunction bnByteValue() { return (this.t==0)?this.s:(this.data[0]<<24)>>24; }\n\n//(public) return value as short (assumes DB>=16)\nfunction bnShortValue() { return (this.t==0)?this.s:(this.data[0]<<16)>>16; }\n\n//(protected) return x s.t. r^x < DV\nfunction bnpChunkSize(r) { return Math.floor(Math.LN2*this.DB/Math.log(r)); }\n\n//(public) 0 if this == 0, 1 if this > 0\nfunction bnSigNum() {\nif(this.s < 0) return -1;\nelse if(this.t <= 0 || (this.t == 1 && this.data[0] <= 0)) return 0;\nelse return 1;\n}\n\n//(protected) convert to radix string\nfunction bnpToRadix(b) {\nif(b == null) b = 10;\nif(this.signum() == 0 || b < 2 || b > 36) return \"0\";\nvar cs = this.chunkSize(b);\nvar a = Math.pow(b,cs);\nvar d = nbv(a), y = nbi(), z = nbi(), r = \"\";\nthis.divRemTo(d,y,z);\nwhile(y.signum() > 0) {\n r = (a+z.intValue()).toString(b).substr(1) + r;\n y.divRemTo(d,y,z);\n}\nreturn z.intValue().toString(b) + r;\n}\n\n//(protected) convert from radix string\nfunction bnpFromRadix(s,b) {\nthis.fromInt(0);\nif(b == null) b = 10;\nvar cs = this.chunkSize(b);\nvar d = Math.pow(b,cs), mi = false, j = 0, w = 0;\nfor(var i = 0; i < s.length; ++i) {\n var x = intAt(s,i);\n if(x < 0) {\n   if(s.charAt(i) == \"-\" && this.signum() == 0) mi = true;\n   continue;\n }\n w = b*w+x;\n if(++j >= cs) {\n   this.dMultiply(d);\n   this.dAddOffset(w,0);\n   j = 0;\n   w = 0;\n }\n}\nif(j > 0) {\n this.dMultiply(Math.pow(b,j));\n this.dAddOffset(w,0);\n}\nif(mi) BigInteger.ZERO.subTo(this,this);\n}\n\n//(protected) alternate constructor\nfunction bnpFromNumber(a,b,c) {\nif(\"number\" == typeof b) {\n // new BigInteger(int,int,RNG)\n if(a < 2) this.fromInt(1);\n else {\n   this.fromNumber(a,c);\n   if(!this.testBit(a-1))  // force MSB set\n     this.bitwiseTo(BigInteger.ONE.shiftLeft(a-1),op_or,this);\n   if(this.isEven()) this.dAddOffset(1,0); // force odd\n   while(!this.isProbablePrime(b)) {\n     this.dAddOffset(2,0);\n     if(this.bitLength() > a) this.subTo(BigInteger.ONE.shiftLeft(a-1),this);\n   }\n }\n} else {\n // new BigInteger(int,RNG)\n var x = new Array(), t = a&7;\n x.length = (a>>3)+1;\n b.nextBytes(x);\n if(t > 0) x[0] &= ((1<<t)-1); else x[0] = 0;\n this.fromString(x,256);\n}\n}\n\n//(public) convert to bigendian byte array\nfunction bnToByteArray() {\nvar i = this.t, r = new Array();\nr[0] = this.s;\nvar p = this.DB-(i*this.DB)%8, d, k = 0;\nif(i-- > 0) {\n if(p < this.DB && (d = this.data[i]>>p) != (this.s&this.DM)>>p)\n   r[k++] = d|(this.s<<(this.DB-p));\n while(i >= 0) {\n   if(p < 8) {\n     d = (this.data[i]&((1<<p)-1))<<(8-p);\n     d |= this.data[--i]>>(p+=this.DB-8);\n   } else {\n     d = (this.data[i]>>(p-=8))&0xff;\n     if(p <= 0) { p += this.DB; --i; }\n   }\n   if((d&0x80) != 0) d |= -256;\n   if(k == 0 && (this.s&0x80) != (d&0x80)) ++k;\n   if(k > 0 || d != this.s) r[k++] = d;\n }\n}\nreturn r;\n}\n\nfunction bnEquals(a) { return(this.compareTo(a)==0); }\nfunction bnMin(a) { return(this.compareTo(a)<0)?this:a; }\nfunction bnMax(a) { return(this.compareTo(a)>0)?this:a; }\n\n//(protected) r = this op a (bitwise)\nfunction bnpBitwiseTo(a,op,r) {\nvar i, f, m = Math.min(a.t,this.t);\nfor(i = 0; i < m; ++i) r.data[i] = op(this.data[i],a.data[i]);\nif(a.t < this.t) {\n f = a.s&this.DM;\n for(i = m; i < this.t; ++i) r.data[i] = op(this.data[i],f);\n r.t = this.t;\n} else {\n f = this.s&this.DM;\n for(i = m; i < a.t; ++i) r.data[i] = op(f,a.data[i]);\n r.t = a.t;\n}\nr.s = op(this.s,a.s);\nr.clamp();\n}\n\n//(public) this & a\nfunction op_and(x,y) { return x&y; }\nfunction bnAnd(a) { var r = nbi(); this.bitwiseTo(a,op_and,r); return r; }\n\n//(public) this | a\nfunction op_or(x,y) { return x|y; }\nfunction bnOr(a) { var r = nbi(); this.bitwiseTo(a,op_or,r); return r; }\n\n//(public) this ^ a\nfunction op_xor(x,y) { return x^y; }\nfunction bnXor(a) { var r = nbi(); this.bitwiseTo(a,op_xor,r); return r; }\n\n//(public) this & ~a\nfunction op_andnot(x,y) { return x&~y; }\nfunction bnAndNot(a) { var r = nbi(); this.bitwiseTo(a,op_andnot,r); return r; }\n\n//(public) ~this\nfunction bnNot() {\nvar r = nbi();\nfor(var i = 0; i < this.t; ++i) r.data[i] = this.DM&~this.data[i];\nr.t = this.t;\nr.s = ~this.s;\nreturn r;\n}\n\n//(public) this << n\nfunction bnShiftLeft(n) {\nvar r = nbi();\nif(n < 0) this.rShiftTo(-n,r); else this.lShiftTo(n,r);\nreturn r;\n}\n\n//(public) this >> n\nfunction bnShiftRight(n) {\nvar r = nbi();\nif(n < 0) this.lShiftTo(-n,r); else this.rShiftTo(n,r);\nreturn r;\n}\n\n//return index of lowest 1-bit in x, x < 2^31\nfunction lbit(x) {\nif(x == 0) return -1;\nvar r = 0;\nif((x&0xffff) == 0) { x >>= 16; r += 16; }\nif((x&0xff) == 0) { x >>= 8; r += 8; }\nif((x&0xf) == 0) { x >>= 4; r += 4; }\nif((x&3) == 0) { x >>= 2; r += 2; }\nif((x&1) == 0) ++r;\nreturn r;\n}\n\n//(public) returns index of lowest 1-bit (or -1 if none)\nfunction bnGetLowestSetBit() {\nfor(var i = 0; i < this.t; ++i)\n if(this.data[i] != 0) return i*this.DB+lbit(this.data[i]);\nif(this.s < 0) return this.t*this.DB;\nreturn -1;\n}\n\n//return number of 1 bits in x\nfunction cbit(x) {\nvar r = 0;\nwhile(x != 0) { x &= x-1; ++r; }\nreturn r;\n}\n\n//(public) return number of set bits\nfunction bnBitCount() {\nvar r = 0, x = this.s&this.DM;\nfor(var i = 0; i < this.t; ++i) r += cbit(this.data[i]^x);\nreturn r;\n}\n\n//(public) true iff nth bit is set\nfunction bnTestBit(n) {\nvar j = Math.floor(n/this.DB);\nif(j >= this.t) return(this.s!=0);\nreturn((this.data[j]&(1<<(n%this.DB)))!=0);\n}\n\n//(protected) this op (1<<n)\nfunction bnpChangeBit(n,op) {\nvar r = BigInteger.ONE.shiftLeft(n);\nthis.bitwiseTo(r,op,r);\nreturn r;\n}\n\n//(public) this | (1<<n)\nfunction bnSetBit(n) { return this.changeBit(n,op_or); }\n\n//(public) this & ~(1<<n)\nfunction bnClearBit(n) { return this.changeBit(n,op_andnot); }\n\n//(public) this ^ (1<<n)\nfunction bnFlipBit(n) { return this.changeBit(n,op_xor); }\n\n//(protected) r = this + a\nfunction bnpAddTo(a,r) {\nvar i = 0, c = 0, m = Math.min(a.t,this.t);\nwhile(i < m) {\n c += this.data[i]+a.data[i];\n r.data[i++] = c&this.DM;\n c >>= this.DB;\n}\nif(a.t < this.t) {\n c += a.s;\n while(i < this.t) {\n   c += this.data[i];\n   r.data[i++] = c&this.DM;\n   c >>= this.DB;\n }\n c += this.s;\n} else {\n c += this.s;\n while(i < a.t) {\n   c += a.data[i];\n   r.data[i++] = c&this.DM;\n   c >>= this.DB;\n }\n c += a.s;\n}\nr.s = (c<0)?-1:0;\nif(c > 0) r.data[i++] = c;\nelse if(c < -1) r.data[i++] = this.DV+c;\nr.t = i;\nr.clamp();\n}\n\n//(public) this + a\nfunction bnAdd(a) { var r = nbi(); this.addTo(a,r); return r; }\n\n//(public) this - a\nfunction bnSubtract(a) { var r = nbi(); this.subTo(a,r); return r; }\n\n//(public) this * a\nfunction bnMultiply(a) { var r = nbi(); this.multiplyTo(a,r); return r; }\n\n//(public) this / a\nfunction bnDivide(a) { var r = nbi(); this.divRemTo(a,r,null); return r; }\n\n//(public) this % a\nfunction bnRemainder(a) { var r = nbi(); this.divRemTo(a,null,r); return r; }\n\n//(public) [this/a,this%a]\nfunction bnDivideAndRemainder(a) {\nvar q = nbi(), r = nbi();\nthis.divRemTo(a,q,r);\nreturn new Array(q,r);\n}\n\n//(protected) this *= n, this >= 0, 1 < n < DV\nfunction bnpDMultiply(n) {\nthis.data[this.t] = this.am(0,n-1,this,0,0,this.t);\n++this.t;\nthis.clamp();\n}\n\n//(protected) this += n << w words, this >= 0\nfunction bnpDAddOffset(n,w) {\nif(n == 0) return;\nwhile(this.t <= w) this.data[this.t++] = 0;\nthis.data[w] += n;\nwhile(this.data[w] >= this.DV) {\n this.data[w] -= this.DV;\n if(++w >= this.t) this.data[this.t++] = 0;\n ++this.data[w];\n}\n}\n\n//A \"null\" reducer\nfunction NullExp() {}\nfunction nNop(x) { return x; }\nfunction nMulTo(x,y,r) { x.multiplyTo(y,r); }\nfunction nSqrTo(x,r) { x.squareTo(r); }\n\nNullExp.prototype.convert = nNop;\nNullExp.prototype.revert = nNop;\nNullExp.prototype.mulTo = nMulTo;\nNullExp.prototype.sqrTo = nSqrTo;\n\n//(public) this^e\nfunction bnPow(e) { return this.exp(e,new NullExp()); }\n\n//(protected) r = lower n words of \"this * a\", a.t <= n\n//\"this\" should be the larger one if appropriate.\nfunction bnpMultiplyLowerTo(a,n,r) {\nvar i = Math.min(this.t+a.t,n);\nr.s = 0; // assumes a,this >= 0\nr.t = i;\nwhile(i > 0) r.data[--i] = 0;\nvar j;\nfor(j = r.t-this.t; i < j; ++i) r.data[i+this.t] = this.am(0,a.data[i],r,i,0,this.t);\nfor(j = Math.min(a.t,n); i < j; ++i) this.am(0,a.data[i],r,i,0,n-i);\nr.clamp();\n}\n\n//(protected) r = \"this * a\" without lower n words, n > 0\n//\"this\" should be the larger one if appropriate.\nfunction bnpMultiplyUpperTo(a,n,r) {\n--n;\nvar i = r.t = this.t+a.t-n;\nr.s = 0; // assumes a,this >= 0\nwhile(--i >= 0) r.data[i] = 0;\nfor(i = Math.max(n-this.t,0); i < a.t; ++i)\n r.data[this.t+i-n] = this.am(n-i,a.data[i],r,0,0,this.t+i-n);\nr.clamp();\nr.drShiftTo(1,r);\n}\n\n//Barrett modular reduction\nfunction Barrett(m) {\n// setup Barrett\nthis.r2 = nbi();\nthis.q3 = nbi();\nBigInteger.ONE.dlShiftTo(2*m.t,this.r2);\nthis.mu = this.r2.divide(m);\nthis.m = m;\n}\n\nfunction barrettConvert(x) {\nif(x.s < 0 || x.t > 2*this.m.t) return x.mod(this.m);\nelse if(x.compareTo(this.m) < 0) return x;\nelse { var r = nbi(); x.copyTo(r); this.reduce(r); return r; }\n}\n\nfunction barrettRevert(x) { return x; }\n\n//x = x mod m (HAC 14.42)\nfunction barrettReduce(x) {\nx.drShiftTo(this.m.t-1,this.r2);\nif(x.t > this.m.t+1) { x.t = this.m.t+1; x.clamp(); }\nthis.mu.multiplyUpperTo(this.r2,this.m.t+1,this.q3);\nthis.m.multiplyLowerTo(this.q3,this.m.t+1,this.r2);\nwhile(x.compareTo(this.r2) < 0) x.dAddOffset(1,this.m.t+1);\nx.subTo(this.r2,x);\nwhile(x.compareTo(this.m) >= 0) x.subTo(this.m,x);\n}\n\n//r = x^2 mod m; x != r\nfunction barrettSqrTo(x,r) { x.squareTo(r); this.reduce(r); }\n\n//r = x*y mod m; x,y != r\nfunction barrettMulTo(x,y,r) { x.multiplyTo(y,r); this.reduce(r); }\n\nBarrett.prototype.convert = barrettConvert;\nBarrett.prototype.revert = barrettRevert;\nBarrett.prototype.reduce = barrettReduce;\nBarrett.prototype.mulTo = barrettMulTo;\nBarrett.prototype.sqrTo = barrettSqrTo;\n\n//(public) this^e % m (HAC 14.85)\nfunction bnModPow(e,m) {\nvar i = e.bitLength(), k, r = nbv(1), z;\nif(i <= 0) return r;\nelse if(i < 18) k = 1;\nelse if(i < 48) k = 3;\nelse if(i < 144) k = 4;\nelse if(i < 768) k = 5;\nelse k = 6;\nif(i < 8)\n z = new Classic(m);\nelse if(m.isEven())\n z = new Barrett(m);\nelse\n z = new Montgomery(m);\n\n// precomputation\nvar g = new Array(), n = 3, k1 = k-1, km = (1<<k)-1;\ng[1] = z.convert(this);\nif(k > 1) {\n var g2 = nbi();\n z.sqrTo(g[1],g2);\n while(n <= km) {\n   g[n] = nbi();\n   z.mulTo(g2,g[n-2],g[n]);\n   n += 2;\n }\n}\n\nvar j = e.t-1, w, is1 = true, r2 = nbi(), t;\ni = nbits(e.data[j])-1;\nwhile(j >= 0) {\n if(i >= k1) w = (e.data[j]>>(i-k1))&km;\n else {\n   w = (e.data[j]&((1<<(i+1))-1))<<(k1-i);\n   if(j > 0) w |= e.data[j-1]>>(this.DB+i-k1);\n }\n\n n = k;\n while((w&1) == 0) { w >>= 1; --n; }\n if((i -= n) < 0) { i += this.DB; --j; }\n if(is1) {  // ret == 1, don't bother squaring or multiplying it\n   g[w].copyTo(r);\n   is1 = false;\n } else {\n   while(n > 1) { z.sqrTo(r,r2); z.sqrTo(r2,r); n -= 2; }\n   if(n > 0) z.sqrTo(r,r2); else { t = r; r = r2; r2 = t; }\n   z.mulTo(r2,g[w],r);\n }\n\n while(j >= 0 && (e.data[j]&(1<<i)) == 0) {\n   z.sqrTo(r,r2); t = r; r = r2; r2 = t;\n   if(--i < 0) { i = this.DB-1; --j; }\n }\n}\nreturn z.revert(r);\n}\n\n//(public) gcd(this,a) (HAC 14.54)\nfunction bnGCD(a) {\nvar x = (this.s<0)?this.negate():this.clone();\nvar y = (a.s<0)?a.negate():a.clone();\nif(x.compareTo(y) < 0) { var t = x; x = y; y = t; }\nvar i = x.getLowestSetBit(), g = y.getLowestSetBit();\nif(g < 0) return x;\nif(i < g) g = i;\nif(g > 0) {\n x.rShiftTo(g,x);\n y.rShiftTo(g,y);\n}\nwhile(x.signum() > 0) {\n if((i = x.getLowestSetBit()) > 0) x.rShiftTo(i,x);\n if((i = y.getLowestSetBit()) > 0) y.rShiftTo(i,y);\n if(x.compareTo(y) >= 0) {\n   x.subTo(y,x);\n   x.rShiftTo(1,x);\n } else {\n   y.subTo(x,y);\n   y.rShiftTo(1,y);\n }\n}\nif(g > 0) y.lShiftTo(g,y);\nreturn y;\n}\n\n//(protected) this % n, n < 2^26\nfunction bnpModInt(n) {\nif(n <= 0) return 0;\nvar d = this.DV%n, r = (this.s<0)?n-1:0;\nif(this.t > 0)\n if(d == 0) r = this.data[0]%n;\n else for(var i = this.t-1; i >= 0; --i) r = (d*r+this.data[i])%n;\nreturn r;\n}\n\n//(public) 1/this % m (HAC 14.61)\nfunction bnModInverse(m) {\nvar ac = m.isEven();\nif((this.isEven() && ac) || m.signum() == 0) return BigInteger.ZERO;\nvar u = m.clone(), v = this.clone();\nvar a = nbv(1), b = nbv(0), c = nbv(0), d = nbv(1);\nwhile(u.signum() != 0) {\n while(u.isEven()) {\n   u.rShiftTo(1,u);\n   if(ac) {\n     if(!a.isEven() || !b.isEven()) { a.addTo(this,a); b.subTo(m,b); }\n     a.rShiftTo(1,a);\n   } else if(!b.isEven()) b.subTo(m,b);\n   b.rShiftTo(1,b);\n }\n while(v.isEven()) {\n   v.rShiftTo(1,v);\n   if(ac) {\n     if(!c.isEven() || !d.isEven()) { c.addTo(this,c); d.subTo(m,d); }\n     c.rShiftTo(1,c);\n   } else if(!d.isEven()) d.subTo(m,d);\n   d.rShiftTo(1,d);\n }\n if(u.compareTo(v) >= 0) {\n   u.subTo(v,u);\n   if(ac) a.subTo(c,a);\n   b.subTo(d,b);\n } else {\n   v.subTo(u,v);\n   if(ac) c.subTo(a,c);\n   d.subTo(b,d);\n }\n}\nif(v.compareTo(BigInteger.ONE) != 0) return BigInteger.ZERO;\nif(d.compareTo(m) >= 0) return d.subtract(m);\nif(d.signum() < 0) d.addTo(m,d); else return d;\nif(d.signum() < 0) return d.add(m); else return d;\n}\n\nvar lowprimes = [2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,53,59,61,67,71,73,79,83,89,97,101,103,107,109,113,127,131,137,139,149,151,157,163,167,173,179,181,191,193,197,199,211,223,227,229,233,239,241,251,257,263,269,271,277,281,283,293,307,311,313,317,331,337,347,349,353,359,367,373,379,383,389,397,401,409,419,421,431,433,439,443,449,457,461,463,467,479,487,491,499,503,509];\nvar lplim = (1<<26)/lowprimes[lowprimes.length-1];\n\n//(public) test primality with certainty >= 1-.5^t\nfunction bnIsProbablePrime(t) {\nvar i, x = this.abs();\nif(x.t == 1 && x.data[0] <= lowprimes[lowprimes.length-1]) {\n for(i = 0; i < lowprimes.length; ++i)\n   if(x.data[0] == lowprimes[i]) return true;\n return false;\n}\nif(x.isEven()) return false;\ni = 1;\nwhile(i < lowprimes.length) {\n var m = lowprimes[i], j = i+1;\n while(j < lowprimes.length && m < lplim) m *= lowprimes[j++];\n m = x.modInt(m);\n while(i < j) if(m%lowprimes[i++] == 0) return false;\n}\nreturn x.millerRabin(t);\n}\n\n//(protected) true if probably prime (HAC 4.24, Miller-Rabin)\nfunction bnpMillerRabin(t) {\nvar n1 = this.subtract(BigInteger.ONE);\nvar k = n1.getLowestSetBit();\nif(k <= 0) return false;\nvar r = n1.shiftRight(k);\nvar prng = bnGetPrng();\nvar a;\nfor(var i = 0; i < t; ++i) {\n // select witness 'a' at random from between 1 and n1\n do {\n   a = new BigInteger(this.bitLength(), prng);\n }\n while(a.compareTo(BigInteger.ONE) <= 0 || a.compareTo(n1) >= 0);\n var y = a.modPow(r,this);\n if(y.compareTo(BigInteger.ONE) != 0 && y.compareTo(n1) != 0) {\n   var j = 1;\n   while(j++ < k && y.compareTo(n1) != 0) {\n     y = y.modPowInt(2,this);\n     if(y.compareTo(BigInteger.ONE) == 0) return false;\n   }\n   if(y.compareTo(n1) != 0) return false;\n }\n}\nreturn true;\n}\n\n// get pseudo random number generator\nfunction bnGetPrng() {\n  // create prng with api that matches BigInteger secure random\n  return {\n    // x is an array to fill with bytes\n    nextBytes: function(x) {\n      for(var i = 0; i < x.length; ++i) {\n        x[i] = Math.floor(Math.random() * 0x0100);\n      }\n    }\n  };\n}\n\n//protected\nBigInteger.prototype.chunkSize = bnpChunkSize;\nBigInteger.prototype.toRadix = bnpToRadix;\nBigInteger.prototype.fromRadix = bnpFromRadix;\nBigInteger.prototype.fromNumber = bnpFromNumber;\nBigInteger.prototype.bitwiseTo = bnpBitwiseTo;\nBigInteger.prototype.changeBit = bnpChangeBit;\nBigInteger.prototype.addTo = bnpAddTo;\nBigInteger.prototype.dMultiply = bnpDMultiply;\nBigInteger.prototype.dAddOffset = bnpDAddOffset;\nBigInteger.prototype.multiplyLowerTo = bnpMultiplyLowerTo;\nBigInteger.prototype.multiplyUpperTo = bnpMultiplyUpperTo;\nBigInteger.prototype.modInt = bnpModInt;\nBigInteger.prototype.millerRabin = bnpMillerRabin;\n\n//public\nBigInteger.prototype.clone = bnClone;\nBigInteger.prototype.intValue = bnIntValue;\nBigInteger.prototype.byteValue = bnByteValue;\nBigInteger.prototype.shortValue = bnShortValue;\nBigInteger.prototype.signum = bnSigNum;\nBigInteger.prototype.toByteArray = bnToByteArray;\nBigInteger.prototype.equals = bnEquals;\nBigInteger.prototype.min = bnMin;\nBigInteger.prototype.max = bnMax;\nBigInteger.prototype.and = bnAnd;\nBigInteger.prototype.or = bnOr;\nBigInteger.prototype.xor = bnXor;\nBigInteger.prototype.andNot = bnAndNot;\nBigInteger.prototype.not = bnNot;\nBigInteger.prototype.shiftLeft = bnShiftLeft;\nBigInteger.prototype.shiftRight = bnShiftRight;\nBigInteger.prototype.getLowestSetBit = bnGetLowestSetBit;\nBigInteger.prototype.bitCount = bnBitCount;\nBigInteger.prototype.testBit = bnTestBit;\nBigInteger.prototype.setBit = bnSetBit;\nBigInteger.prototype.clearBit = bnClearBit;\nBigInteger.prototype.flipBit = bnFlipBit;\nBigInteger.prototype.add = bnAdd;\nBigInteger.prototype.subtract = bnSubtract;\nBigInteger.prototype.multiply = bnMultiply;\nBigInteger.prototype.divide = bnDivide;\nBigInteger.prototype.remainder = bnRemainder;\nBigInteger.prototype.divideAndRemainder = bnDivideAndRemainder;\nBigInteger.prototype.modPow = bnModPow;\nBigInteger.prototype.modInverse = bnModInverse;\nBigInteger.prototype.pow = bnPow;\nBigInteger.prototype.gcd = bnGCD;\nBigInteger.prototype.isProbablePrime = bnIsProbablePrime;\n\n//BigInteger interfaces not implemented in jsbn:\n\n//BigInteger(int signum, byte[] magnitude)\n//double doubleValue()\n//float floatValue()\n//int hashCode()\n//long longValue()\n//static BigInteger valueOf(long val)\n","/**\n * 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 * Partial implementation of PKCS#1 v2.2: RSA-OEAP\n *\n * Modified but based on the following MIT and BSD licensed code:\n *\n * https://github.com/kjur/jsjws/blob/master/rsa.js:\n *\n * The 'jsjws'(JSON Web Signature JavaScript Library) License\n *\n * Copyright (c) 2012 Kenji Urushima\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n *\n * http://webrsa.cvs.sourceforge.net/viewvc/webrsa/Client/RSAES-OAEP.js?content-type=text%2Fplain:\n *\n * RSAES-OAEP.js\n * $Id: RSAES-OAEP.js,v 1.1.1.1 2003/03/19 15:37:20 ellispritchard Exp $\n * JavaScript Implementation of PKCS #1 v2.1 RSA CRYPTOGRAPHY STANDARD (RSA Laboratories, June 14, 2002)\n * Copyright (C) Ellis Pritchard, Guardian Unlimited 2003.\n * Contact: ellis@nukinetics.com\n * Distributed under the BSD License.\n *\n * Official documentation: http://www.rsa.com/rsalabs/node.asp?id=2125\n *\n * @author Evan Jones (http://evanjones.ca/)\n * @author Dave Longley\n *\n * Copyright (c) 2013-2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./random');\nrequire('./sha1');\n\n// shortcut for PKCS#1 API\nvar pkcs1 = module.exports = forge.pkcs1 = forge.pkcs1 || {};\n\n/**\n * Encode the given RSAES-OAEP message (M) using key, with optional label (L)\n * and seed.\n *\n * This method does not perform RSA encryption, it only encodes the message\n * using RSAES-OAEP.\n *\n * @param key the RSA key to use.\n * @param message the message to encode.\n * @param options the options to use:\n *          label an optional label to use.\n *          seed the seed to use.\n *          md the message digest object to use, undefined for SHA-1.\n *          mgf1 optional mgf1 parameters:\n *            md the message digest object to use for MGF1.\n *\n * @return the encoded message bytes.\n */\npkcs1.encode_rsa_oaep = function(key, message, options) {\n  // parse arguments\n  var label;\n  var seed;\n  var md;\n  var mgf1Md;\n  // legacy args (label, seed, md)\n  if(typeof options === 'string') {\n    label = options;\n    seed = arguments[3] || undefined;\n    md = arguments[4] || undefined;\n  } else if(options) {\n    label = options.label || undefined;\n    seed = options.seed || undefined;\n    md = options.md || undefined;\n    if(options.mgf1 && options.mgf1.md) {\n      mgf1Md = options.mgf1.md;\n    }\n  }\n\n  // default OAEP to SHA-1 message digest\n  if(!md) {\n    md = forge.md.sha1.create();\n  } else {\n    md.start();\n  }\n\n  // default MGF-1 to same as OAEP\n  if(!mgf1Md) {\n    mgf1Md = md;\n  }\n\n  // compute length in bytes and check output\n  var keyLength = Math.ceil(key.n.bitLength() / 8);\n  var maxLength = keyLength - 2 * md.digestLength - 2;\n  if(message.length > maxLength) {\n    var error = new Error('RSAES-OAEP input message length is too long.');\n    error.length = message.length;\n    error.maxLength = maxLength;\n    throw error;\n  }\n\n  if(!label) {\n    label = '';\n  }\n  md.update(label, 'raw');\n  var lHash = md.digest();\n\n  var PS = '';\n  var PS_length = maxLength - message.length;\n  for(var i = 0; i < PS_length; i++) {\n    PS += '\\x00';\n  }\n\n  var DB = lHash.getBytes() + PS + '\\x01' + message;\n\n  if(!seed) {\n    seed = forge.random.getBytes(md.digestLength);\n  } else if(seed.length !== md.digestLength) {\n    var error = new Error('Invalid RSAES-OAEP seed. The seed length must ' +\n      'match the digest length.');\n    error.seedLength = seed.length;\n    error.digestLength = md.digestLength;\n    throw error;\n  }\n\n  var dbMask = rsa_mgf1(seed, keyLength - md.digestLength - 1, mgf1Md);\n  var maskedDB = forge.util.xorBytes(DB, dbMask, DB.length);\n\n  var seedMask = rsa_mgf1(maskedDB, md.digestLength, mgf1Md);\n  var maskedSeed = forge.util.xorBytes(seed, seedMask, seed.length);\n\n  // return encoded message\n  return '\\x00' + maskedSeed + maskedDB;\n};\n\n/**\n * Decode the given RSAES-OAEP encoded message (EM) using key, with optional\n * label (L).\n *\n * This method does not perform RSA decryption, it only decodes the message\n * using RSAES-OAEP.\n *\n * @param key the RSA key to use.\n * @param em the encoded message to decode.\n * @param options the options to use:\n *          label an optional label to use.\n *          md the message digest object to use for OAEP, undefined for SHA-1.\n *          mgf1 optional mgf1 parameters:\n *            md the message digest object to use for MGF1.\n *\n * @return the decoded message bytes.\n */\npkcs1.decode_rsa_oaep = function(key, em, options) {\n  // parse args\n  var label;\n  var md;\n  var mgf1Md;\n  // legacy args\n  if(typeof options === 'string') {\n    label = options;\n    md = arguments[3] || undefined;\n  } else if(options) {\n    label = options.label || undefined;\n    md = options.md || undefined;\n    if(options.mgf1 && options.mgf1.md) {\n      mgf1Md = options.mgf1.md;\n    }\n  }\n\n  // compute length in bytes\n  var keyLength = Math.ceil(key.n.bitLength() / 8);\n\n  if(em.length !== keyLength) {\n    var error = new Error('RSAES-OAEP encoded message length is invalid.');\n    error.length = em.length;\n    error.expectedLength = keyLength;\n    throw error;\n  }\n\n  // default OAEP to SHA-1 message digest\n  if(md === undefined) {\n    md = forge.md.sha1.create();\n  } else {\n    md.start();\n  }\n\n  // default MGF-1 to same as OAEP\n  if(!mgf1Md) {\n    mgf1Md = md;\n  }\n\n  if(keyLength < 2 * md.digestLength + 2) {\n    throw new Error('RSAES-OAEP key is too short for the hash function.');\n  }\n\n  if(!label) {\n    label = '';\n  }\n  md.update(label, 'raw');\n  var lHash = md.digest().getBytes();\n\n  // split the message into its parts\n  var y = em.charAt(0);\n  var maskedSeed = em.substring(1, md.digestLength + 1);\n  var maskedDB = em.substring(1 + md.digestLength);\n\n  var seedMask = rsa_mgf1(maskedDB, md.digestLength, mgf1Md);\n  var seed = forge.util.xorBytes(maskedSeed, seedMask, maskedSeed.length);\n\n  var dbMask = rsa_mgf1(seed, keyLength - md.digestLength - 1, mgf1Md);\n  var db = forge.util.xorBytes(maskedDB, dbMask, maskedDB.length);\n\n  var lHashPrime = db.substring(0, md.digestLength);\n\n  // constant time check that all values match what is expected\n  var error = (y !== '\\x00');\n\n  // constant time check lHash vs lHashPrime\n  for(var i = 0; i < md.digestLength; ++i) {\n    error |= (lHash.charAt(i) !== lHashPrime.charAt(i));\n  }\n\n  // \"constant time\" find the 0x1 byte separating the padding (zeros) from the\n  // message\n  // TODO: It must be possible to do this in a better/smarter way?\n  var in_ps = 1;\n  var index = md.digestLength;\n  for(var j = md.digestLength; j < db.length; j++) {\n    var code = db.charCodeAt(j);\n\n    var is_0 = (code & 0x1) ^ 0x1;\n\n    // non-zero if not 0 or 1 in the ps section\n    var error_mask = in_ps ? 0xfffe : 0x0000;\n    error |= (code & error_mask);\n\n    // latch in_ps to zero after we find 0x1\n    in_ps = in_ps & is_0;\n    index += in_ps;\n  }\n\n  if(error || db.charCodeAt(index) !== 0x1) {\n    throw new Error('Invalid RSAES-OAEP padding.');\n  }\n\n  return db.substring(index + 1);\n};\n\nfunction rsa_mgf1(seed, maskLength, hash) {\n  // default to SHA-1 message digest\n  if(!hash) {\n    hash = forge.md.sha1.create();\n  }\n  var t = '';\n  var count = Math.ceil(maskLength / hash.digestLength);\n  for(var i = 0; i < count; ++i) {\n    var c = String.fromCharCode(\n      (i >> 24) & 0xFF, (i >> 16) & 0xFF, (i >> 8) & 0xFF, i & 0xFF);\n    hash.start();\n    hash.update(seed + c);\n    t += hash.digest().getBytes();\n  }\n  return t.substring(0, maskLength);\n}\n","/**\n * Prime number generation API.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./jsbn');\nrequire('./random');\n\n(function() {\n\n// forge.prime already defined\nif(forge.prime) {\n  module.exports = forge.prime;\n  return;\n}\n\n/* PRIME API */\nvar prime = module.exports = forge.prime = forge.prime || {};\n\nvar BigInteger = forge.jsbn.BigInteger;\n\n// primes are 30k+i for i = 1, 7, 11, 13, 17, 19, 23, 29\nvar GCD_30_DELTA = [6, 4, 2, 4, 2, 4, 6, 2];\nvar THIRTY = new BigInteger(null);\nTHIRTY.fromInt(30);\nvar op_or = function(x, y) {return x|y;};\n\n/**\n * Generates a random probable prime with the given number of bits.\n *\n * Alternative algorithms can be specified by name as a string or as an\n * object with custom options like so:\n *\n * {\n *   name: 'PRIMEINC',\n *   options: {\n *     maxBlockTime: <the maximum amount of time to block the main\n *       thread before allowing I/O other JS to run>,\n *     millerRabinTests: <the number of miller-rabin tests to run>,\n *     workerScript: <the worker script URL>,\n *     workers: <the number of web workers (if supported) to use,\n *       -1 to use estimated cores minus one>.\n *     workLoad: the size of the work load, ie: number of possible prime\n *       numbers for each web worker to check per work assignment,\n *       (default: 100).\n *   }\n * }\n *\n * @param bits the number of bits for the prime number.\n * @param options the options to use.\n *          [algorithm] the algorithm to use (default: 'PRIMEINC').\n *          [prng] a custom crypto-secure pseudo-random number generator to use,\n *            that must define \"getBytesSync\".\n *\n * @return callback(err, num) called once the operation completes.\n */\nprime.generateProbablePrime = function(bits, options, callback) {\n  if(typeof options === 'function') {\n    callback = options;\n    options = {};\n  }\n  options = options || {};\n\n  // default to PRIMEINC algorithm\n  var algorithm = options.algorithm || 'PRIMEINC';\n  if(typeof algorithm === 'string') {\n    algorithm = {name: algorithm};\n  }\n  algorithm.options = algorithm.options || {};\n\n  // create prng with api that matches BigInteger secure random\n  var prng = options.prng || forge.random;\n  var rng = {\n    // x is an array to fill with bytes\n    nextBytes: function(x) {\n      var b = prng.getBytesSync(x.length);\n      for(var i = 0; i < x.length; ++i) {\n        x[i] = b.charCodeAt(i);\n      }\n    }\n  };\n\n  if(algorithm.name === 'PRIMEINC') {\n    return primeincFindPrime(bits, rng, algorithm.options, callback);\n  }\n\n  throw new Error('Invalid prime generation algorithm: ' + algorithm.name);\n};\n\nfunction primeincFindPrime(bits, rng, options, callback) {\n  if('workers' in options) {\n    return primeincFindPrimeWithWorkers(bits, rng, options, callback);\n  }\n  return primeincFindPrimeWithoutWorkers(bits, rng, options, callback);\n}\n\nfunction primeincFindPrimeWithoutWorkers(bits, rng, options, callback) {\n  // initialize random number\n  var num = generateRandom(bits, rng);\n\n  /* Note: All primes are of the form 30k+i for i < 30 and gcd(30, i)=1. The\n  number we are given is always aligned at 30k + 1. Each time the number is\n  determined not to be prime we add to get to the next 'i', eg: if the number\n  was at 30k + 1 we add 6. */\n  var deltaIdx = 0;\n\n  // get required number of MR tests\n  var mrTests = getMillerRabinTests(num.bitLength());\n  if('millerRabinTests' in options) {\n    mrTests = options.millerRabinTests;\n  }\n\n  // find prime nearest to 'num' for maxBlockTime ms\n  // 10 ms gives 5ms of leeway for other calculations before dropping\n  // below 60fps (1000/60 == 16.67), but in reality, the number will\n  // likely be higher due to an 'atomic' big int modPow\n  var maxBlockTime = 10;\n  if('maxBlockTime' in options) {\n    maxBlockTime = options.maxBlockTime;\n  }\n\n  _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback);\n}\n\nfunction _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback) {\n  var start = +new Date();\n  do {\n    // overflow, regenerate random number\n    if(num.bitLength() > bits) {\n      num = generateRandom(bits, rng);\n    }\n    // do primality test\n    if(num.isProbablePrime(mrTests)) {\n      return callback(null, num);\n    }\n    // get next potential prime\n    num.dAddOffset(GCD_30_DELTA[deltaIdx++ % 8], 0);\n  } while(maxBlockTime < 0 || (+new Date() - start < maxBlockTime));\n\n  // keep trying later\n  forge.util.setImmediate(function() {\n    _primeinc(num, bits, rng, deltaIdx, mrTests, maxBlockTime, callback);\n  });\n}\n\n// NOTE: This algorithm is indeterminate in nature because workers\n// run in parallel looking at different segments of numbers. Even if this\n// algorithm is run twice with the same input from a predictable RNG, it\n// may produce different outputs.\nfunction primeincFindPrimeWithWorkers(bits, rng, options, callback) {\n  // web workers unavailable\n  if(typeof Worker === 'undefined') {\n    return primeincFindPrimeWithoutWorkers(bits, rng, options, callback);\n  }\n\n  // initialize random number\n  var num = generateRandom(bits, rng);\n\n  // use web workers to generate keys\n  var numWorkers = options.workers;\n  var workLoad = options.workLoad || 100;\n  var range = workLoad * 30 / 8;\n  var workerScript = options.workerScript || 'forge/prime.worker.js';\n  if(numWorkers === -1) {\n    return forge.util.estimateCores(function(err, cores) {\n      if(err) {\n        // default to 2\n        cores = 2;\n      }\n      numWorkers = cores - 1;\n      generate();\n    });\n  }\n  generate();\n\n  function generate() {\n    // require at least 1 worker\n    numWorkers = Math.max(1, numWorkers);\n\n    // TODO: consider optimizing by starting workers outside getPrime() ...\n    // note that in order to clean up they will have to be made internally\n    // asynchronous which may actually be slower\n\n    // start workers immediately\n    var workers = [];\n    for(var i = 0; i < numWorkers; ++i) {\n      // FIXME: fix path or use blob URLs\n      workers[i] = new Worker(workerScript);\n    }\n    var running = numWorkers;\n\n    // listen for requests from workers and assign ranges to find prime\n    for(var i = 0; i < numWorkers; ++i) {\n      workers[i].addEventListener('message', workerMessage);\n    }\n\n    /* Note: The distribution of random numbers is unknown. Therefore, each\n    web worker is continuously allocated a range of numbers to check for a\n    random number until one is found.\n\n    Every 30 numbers will be checked just 8 times, because prime numbers\n    have the form:\n\n    30k+i, for i < 30 and gcd(30, i)=1 (there are 8 values of i for this)\n\n    Therefore, if we want a web worker to run N checks before asking for\n    a new range of numbers, each range must contain N*30/8 numbers.\n\n    For 100 checks (workLoad), this is a range of 375. */\n\n    var found = false;\n    function workerMessage(e) {\n      // ignore message, prime already found\n      if(found) {\n        return;\n      }\n\n      --running;\n      var data = e.data;\n      if(data.found) {\n        // terminate all workers\n        for(var i = 0; i < workers.length; ++i) {\n          workers[i].terminate();\n        }\n        found = true;\n        return callback(null, new BigInteger(data.prime, 16));\n      }\n\n      // overflow, regenerate random number\n      if(num.bitLength() > bits) {\n        num = generateRandom(bits, rng);\n      }\n\n      // assign new range to check\n      var hex = num.toString(16);\n\n      // start prime search\n      e.target.postMessage({\n        hex: hex,\n        workLoad: workLoad\n      });\n\n      num.dAddOffset(range, 0);\n    }\n  }\n}\n\n/**\n * Generates a random number using the given number of bits and RNG.\n *\n * @param bits the number of bits for the number.\n * @param rng the random number generator to use.\n *\n * @return the random number.\n */\nfunction generateRandom(bits, rng) {\n  var num = new BigInteger(bits, rng);\n  // force MSB set\n  var bits1 = bits - 1;\n  if(!num.testBit(bits1)) {\n    num.bitwiseTo(BigInteger.ONE.shiftLeft(bits1), op_or, num);\n  }\n  // align number on 30k+1 boundary\n  num.dAddOffset(31 - num.mod(THIRTY).byteValue(), 0);\n  return num;\n}\n\n/**\n * Returns the required number of Miller-Rabin tests to generate a\n * prime with an error probability of (1/2)^80.\n *\n * See Handbook of Applied Cryptography Chapter 4, Table 4.4.\n *\n * @param bits the bit size.\n *\n * @return the required number of iterations.\n */\nfunction getMillerRabinTests(bits) {\n  if(bits <= 100) return 27;\n  if(bits <= 150) return 18;\n  if(bits <= 200) return 15;\n  if(bits <= 250) return 12;\n  if(bits <= 300) return 9;\n  if(bits <= 350) return 8;\n  if(bits <= 400) return 7;\n  if(bits <= 500) return 6;\n  if(bits <= 600) return 5;\n  if(bits <= 800) return 4;\n  if(bits <= 1250) return 3;\n  return 2;\n}\n\n})();\n","/**\n * Javascript implementation of 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 * Password-based encryption functions.\n *\n * @author Dave Longley\n * @author Stefan Siegl <stesie@brokenpipe.de>\n *\n * Copyright (c) 2010-2013 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * An EncryptedPrivateKeyInfo:\n *\n * EncryptedPrivateKeyInfo ::= SEQUENCE {\n *   encryptionAlgorithm  EncryptionAlgorithmIdentifier,\n *   encryptedData        EncryptedData }\n *\n * EncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * EncryptedData ::= OCTET STRING\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./md');\nrequire('./oids');\nrequire('./pbkdf2');\nrequire('./pem');\nrequire('./random');\nrequire('./rc2');\nrequire('./rsa');\nrequire('./util');\n\nif(typeof BigInteger === 'undefined') {\n  var BigInteger = forge.jsbn.BigInteger;\n}\n\n// shortcut for asn.1 API\nvar asn1 = forge.asn1;\n\n/* Password-based encryption implementation. */\nvar pki = forge.pki = forge.pki || {};\nmodule.exports = pki.pbe = forge.pbe = forge.pbe || {};\nvar oids = pki.oids;\n\n// validator for an EncryptedPrivateKeyInfo structure\n// Note: Currently only works w/algorithm params\nvar encryptedPrivateKeyValidator = {\n  name: 'EncryptedPrivateKeyInfo',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'EncryptedPrivateKeyInfo.encryptionAlgorithm',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'AlgorithmIdentifier.algorithm',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OID,\n      constructed: false,\n      capture: 'encryptionOid'\n    }, {\n      name: 'AlgorithmIdentifier.parameters',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.SEQUENCE,\n      constructed: true,\n      captureAsn1: 'encryptionParams'\n    }]\n  }, {\n    // encryptedData\n    name: 'EncryptedPrivateKeyInfo.encryptedData',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OCTETSTRING,\n    constructed: false,\n    capture: 'encryptedData'\n  }]\n};\n\n// validator for a PBES2Algorithms structure\n// Note: Currently only works w/PBKDF2 + AES encryption schemes\nvar PBES2AlgorithmsValidator = {\n  name: 'PBES2Algorithms',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'PBES2Algorithms.keyDerivationFunc',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'PBES2Algorithms.keyDerivationFunc.oid',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OID,\n      constructed: false,\n      capture: 'kdfOid'\n    }, {\n      name: 'PBES2Algorithms.params',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.SEQUENCE,\n      constructed: true,\n      value: [{\n        name: 'PBES2Algorithms.params.salt',\n        tagClass: asn1.Class.UNIVERSAL,\n        type: asn1.Type.OCTETSTRING,\n        constructed: false,\n        capture: 'kdfSalt'\n      }, {\n        name: 'PBES2Algorithms.params.iterationCount',\n        tagClass: asn1.Class.UNIVERSAL,\n        type: asn1.Type.INTEGER,\n        constructed: false,\n        capture: 'kdfIterationCount'\n      }, {\n        name: 'PBES2Algorithms.params.keyLength',\n        tagClass: asn1.Class.UNIVERSAL,\n        type: asn1.Type.INTEGER,\n        constructed: false,\n        optional: true,\n        capture: 'keyLength'\n      }, {\n        // prf\n        name: 'PBES2Algorithms.params.prf',\n        tagClass: asn1.Class.UNIVERSAL,\n        type: asn1.Type.SEQUENCE,\n        constructed: true,\n        optional: true,\n        value: [{\n          name: 'PBES2Algorithms.params.prf.algorithm',\n          tagClass: asn1.Class.UNIVERSAL,\n          type: asn1.Type.OID,\n          constructed: false,\n          capture: 'prfOid'\n        }]\n      }]\n    }]\n  }, {\n    name: 'PBES2Algorithms.encryptionScheme',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'PBES2Algorithms.encryptionScheme.oid',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OID,\n      constructed: false,\n      capture: 'encOid'\n    }, {\n      name: 'PBES2Algorithms.encryptionScheme.iv',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OCTETSTRING,\n      constructed: false,\n      capture: 'encIv'\n    }]\n  }]\n};\n\nvar pkcs12PbeParamsValidator = {\n  name: 'pkcs-12PbeParams',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'pkcs-12PbeParams.salt',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OCTETSTRING,\n    constructed: false,\n    capture: 'salt'\n  }, {\n    name: 'pkcs-12PbeParams.iterations',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.INTEGER,\n    constructed: false,\n    capture: 'iterations'\n  }]\n};\n\n/**\n * Encrypts a ASN.1 PrivateKeyInfo object, producing an EncryptedPrivateKeyInfo.\n *\n * PBES2Algorithms ALGORITHM-IDENTIFIER ::=\n *   { {PBES2-params IDENTIFIED BY id-PBES2}, ...}\n *\n * id-PBES2 OBJECT IDENTIFIER ::= {pkcs-5 13}\n *\n * PBES2-params ::= SEQUENCE {\n *   keyDerivationFunc AlgorithmIdentifier {{PBES2-KDFs}},\n *   encryptionScheme AlgorithmIdentifier {{PBES2-Encs}}\n * }\n *\n * PBES2-KDFs ALGORITHM-IDENTIFIER ::=\n *   { {PBKDF2-params IDENTIFIED BY id-PBKDF2}, ... }\n *\n * PBES2-Encs ALGORITHM-IDENTIFIER ::= { ... }\n *\n * PBKDF2-params ::= SEQUENCE {\n *   salt CHOICE {\n *     specified OCTET STRING,\n *     otherSource AlgorithmIdentifier {{PBKDF2-SaltSources}}\n *   },\n *   iterationCount INTEGER (1..MAX),\n *   keyLength INTEGER (1..MAX) OPTIONAL,\n *   prf AlgorithmIdentifier {{PBKDF2-PRFs}} DEFAULT algid-hmacWithSHA1\n * }\n *\n * @param obj the ASN.1 PrivateKeyInfo object.\n * @param password the password to encrypt with.\n * @param options:\n *          algorithm the encryption algorithm to use\n *            ('aes128', 'aes192', 'aes256', '3des'), defaults to 'aes128'.\n *          count the iteration count to use.\n *          saltSize the salt size to use.\n *          prfAlgorithm the PRF message digest algorithm to use\n *            ('sha1', 'sha224', 'sha256', 'sha384', 'sha512')\n *\n * @return the ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptPrivateKeyInfo = function(obj, password, options) {\n  // set default options\n  options = options || {};\n  options.saltSize = options.saltSize || 8;\n  options.count = options.count || 2048;\n  options.algorithm = options.algorithm || 'aes128';\n  options.prfAlgorithm = options.prfAlgorithm || 'sha1';\n\n  // generate PBE params\n  var salt = forge.random.getBytesSync(options.saltSize);\n  var count = options.count;\n  var countBytes = asn1.integerToDer(count);\n  var dkLen;\n  var encryptionAlgorithm;\n  var encryptedData;\n  if(options.algorithm.indexOf('aes') === 0 || options.algorithm === 'des') {\n    // do PBES2\n    var ivLen, encOid, cipherFn;\n    switch(options.algorithm) {\n    case 'aes128':\n      dkLen = 16;\n      ivLen = 16;\n      encOid = oids['aes128-CBC'];\n      cipherFn = forge.aes.createEncryptionCipher;\n      break;\n    case 'aes192':\n      dkLen = 24;\n      ivLen = 16;\n      encOid = oids['aes192-CBC'];\n      cipherFn = forge.aes.createEncryptionCipher;\n      break;\n    case 'aes256':\n      dkLen = 32;\n      ivLen = 16;\n      encOid = oids['aes256-CBC'];\n      cipherFn = forge.aes.createEncryptionCipher;\n      break;\n    case 'des':\n      dkLen = 8;\n      ivLen = 8;\n      encOid = oids['desCBC'];\n      cipherFn = forge.des.createEncryptionCipher;\n      break;\n    default:\n      var error = new Error('Cannot encrypt private key. Unknown encryption algorithm.');\n      error.algorithm = options.algorithm;\n      throw error;\n    }\n\n    // get PRF message digest\n    var prfAlgorithm = 'hmacWith' + options.prfAlgorithm.toUpperCase();\n    var md = prfAlgorithmToMessageDigest(prfAlgorithm);\n\n    // encrypt private key using pbe SHA-1 and AES/DES\n    var dk = forge.pkcs5.pbkdf2(password, salt, count, dkLen, md);\n    var iv = forge.random.getBytesSync(ivLen);\n    var cipher = cipherFn(dk);\n    cipher.start(iv);\n    cipher.update(asn1.toDer(obj));\n    cipher.finish();\n    encryptedData = cipher.output.getBytes();\n\n    // get PBKDF2-params\n    var params = createPbkdf2Params(salt, countBytes, dkLen, prfAlgorithm);\n\n    encryptionAlgorithm = asn1.create(\n      asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n        asn1.oidToDer(oids['pkcs5PBES2']).getBytes()),\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // keyDerivationFunc\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n            asn1.oidToDer(oids['pkcs5PBKDF2']).getBytes()),\n          // PBKDF2-params\n          params\n        ]),\n        // encryptionScheme\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n            asn1.oidToDer(encOid).getBytes()),\n          // iv\n          asn1.create(\n            asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, iv)\n        ])\n      ])\n    ]);\n  } else if(options.algorithm === '3des') {\n    // Do PKCS12 PBE\n    dkLen = 24;\n\n    var saltBytes = new forge.util.ByteBuffer(salt);\n    var dk = pki.pbe.generatePkcs12Key(password, saltBytes, 1, count, dkLen);\n    var iv = pki.pbe.generatePkcs12Key(password, saltBytes, 2, count, dkLen);\n    var cipher = forge.des.createEncryptionCipher(dk);\n    cipher.start(iv);\n    cipher.update(asn1.toDer(obj));\n    cipher.finish();\n    encryptedData = cipher.output.getBytes();\n\n    encryptionAlgorithm = asn1.create(\n      asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n        asn1.oidToDer(oids['pbeWithSHAAnd3-KeyTripleDES-CBC']).getBytes()),\n      // pkcs-12PbeParams\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // salt\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, salt),\n        // iteration count\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n          countBytes.getBytes())\n      ])\n    ]);\n  } else {\n    var error = new Error('Cannot encrypt private key. Unknown encryption algorithm.');\n    error.algorithm = options.algorithm;\n    throw error;\n  }\n\n  // EncryptedPrivateKeyInfo\n  var rval = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n    // encryptionAlgorithm\n    encryptionAlgorithm,\n    // encryptedData\n    asn1.create(\n      asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, encryptedData)\n  ]);\n  return rval;\n};\n\n/**\n * Decrypts a ASN.1 PrivateKeyInfo object.\n *\n * @param obj the ASN.1 EncryptedPrivateKeyInfo object.\n * @param password the password to decrypt with.\n *\n * @return the ASN.1 PrivateKeyInfo on success, null on failure.\n */\npki.decryptPrivateKeyInfo = function(obj, password) {\n  var rval = null;\n\n  // get PBE params\n  var capture = {};\n  var errors = [];\n  if(!asn1.validate(obj, encryptedPrivateKeyValidator, capture, errors)) {\n    var error = new Error('Cannot read encrypted private key. ' +\n      'ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n    error.errors = errors;\n    throw error;\n  }\n\n  // get cipher\n  var oid = asn1.derToOid(capture.encryptionOid);\n  var cipher = pki.pbe.getCipher(oid, capture.encryptionParams, password);\n\n  // get encrypted data\n  var encrypted = forge.util.createBuffer(capture.encryptedData);\n\n  cipher.update(encrypted);\n  if(cipher.finish()) {\n    rval = asn1.fromDer(cipher.output);\n  }\n\n  return rval;\n};\n\n/**\n * Converts a EncryptedPrivateKeyInfo to PEM format.\n *\n * @param epki the EncryptedPrivateKeyInfo.\n * @param maxline the maximum characters per line, defaults to 64.\n *\n * @return the PEM-formatted encrypted private key.\n */\npki.encryptedPrivateKeyToPem = function(epki, maxline) {\n  // convert to DER, then PEM-encode\n  var msg = {\n    type: 'ENCRYPTED PRIVATE KEY',\n    body: asn1.toDer(epki).getBytes()\n  };\n  return forge.pem.encode(msg, {maxline: maxline});\n};\n\n/**\n * Converts a PEM-encoded EncryptedPrivateKeyInfo to ASN.1 format. Decryption\n * is not performed.\n *\n * @param pem the EncryptedPrivateKeyInfo in PEM-format.\n *\n * @return the ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptedPrivateKeyFromPem = function(pem) {\n  var msg = forge.pem.decode(pem)[0];\n\n  if(msg.type !== 'ENCRYPTED PRIVATE KEY') {\n    var error = new Error('Could not convert encrypted private key from PEM; ' +\n      'PEM header type is \"ENCRYPTED PRIVATE KEY\".');\n    error.headerType = msg.type;\n    throw error;\n  }\n  if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n    throw new Error('Could not convert encrypted private key from PEM; ' +\n      'PEM is encrypted.');\n  }\n\n  // convert DER to ASN.1 object\n  return asn1.fromDer(msg.body);\n};\n\n/**\n * Encrypts an RSA private key. By default, the key will be wrapped in\n * a PrivateKeyInfo and encrypted to produce a PKCS#8 EncryptedPrivateKeyInfo.\n * This is the standard, preferred way to encrypt a private key.\n *\n * To produce a non-standard PEM-encrypted private key that uses encapsulated\n * headers to indicate the encryption algorithm (old-style non-PKCS#8 OpenSSL\n * private key encryption), set the 'legacy' option to true. Note: Using this\n * option will cause the iteration count to be forced to 1.\n *\n * Note: The 'des' algorithm is supported, but it is not considered to be\n * secure because it only uses a single 56-bit key. If possible, it is highly\n * recommended that a different algorithm be used.\n *\n * @param rsaKey the RSA key to encrypt.\n * @param password the password to use.\n * @param options:\n *          algorithm: the encryption algorithm to use\n *            ('aes128', 'aes192', 'aes256', '3des', 'des').\n *          count: the iteration count to use.\n *          saltSize: the salt size to use.\n *          legacy: output an old non-PKCS#8 PEM-encrypted+encapsulated\n *            headers (DEK-Info) private key.\n *\n * @return the PEM-encoded ASN.1 EncryptedPrivateKeyInfo.\n */\npki.encryptRsaPrivateKey = function(rsaKey, password, options) {\n  // standard PKCS#8\n  options = options || {};\n  if(!options.legacy) {\n    // encrypt PrivateKeyInfo\n    var rval = pki.wrapRsaPrivateKey(pki.privateKeyToAsn1(rsaKey));\n    rval = pki.encryptPrivateKeyInfo(rval, password, options);\n    return pki.encryptedPrivateKeyToPem(rval);\n  }\n\n  // legacy non-PKCS#8\n  var algorithm;\n  var iv;\n  var dkLen;\n  var cipherFn;\n  switch(options.algorithm) {\n  case 'aes128':\n    algorithm = 'AES-128-CBC';\n    dkLen = 16;\n    iv = forge.random.getBytesSync(16);\n    cipherFn = forge.aes.createEncryptionCipher;\n    break;\n  case 'aes192':\n    algorithm = 'AES-192-CBC';\n    dkLen = 24;\n    iv = forge.random.getBytesSync(16);\n    cipherFn = forge.aes.createEncryptionCipher;\n    break;\n  case 'aes256':\n    algorithm = 'AES-256-CBC';\n    dkLen = 32;\n    iv = forge.random.getBytesSync(16);\n    cipherFn = forge.aes.createEncryptionCipher;\n    break;\n  case '3des':\n    algorithm = 'DES-EDE3-CBC';\n    dkLen = 24;\n    iv = forge.random.getBytesSync(8);\n    cipherFn = forge.des.createEncryptionCipher;\n    break;\n  case 'des':\n    algorithm = 'DES-CBC';\n    dkLen = 8;\n    iv = forge.random.getBytesSync(8);\n    cipherFn = forge.des.createEncryptionCipher;\n    break;\n  default:\n    var error = new Error('Could not encrypt RSA private key; unsupported ' +\n      'encryption algorithm \"' + options.algorithm + '\".');\n    error.algorithm = options.algorithm;\n    throw error;\n  }\n\n  // encrypt private key using OpenSSL legacy key derivation\n  var dk = forge.pbe.opensslDeriveBytes(password, iv.substr(0, 8), dkLen);\n  var cipher = cipherFn(dk);\n  cipher.start(iv);\n  cipher.update(asn1.toDer(pki.privateKeyToAsn1(rsaKey)));\n  cipher.finish();\n\n  var msg = {\n    type: 'RSA PRIVATE KEY',\n    procType: {\n      version: '4',\n      type: 'ENCRYPTED'\n    },\n    dekInfo: {\n      algorithm: algorithm,\n      parameters: forge.util.bytesToHex(iv).toUpperCase()\n    },\n    body: cipher.output.getBytes()\n  };\n  return forge.pem.encode(msg);\n};\n\n/**\n * Decrypts an RSA private key.\n *\n * @param pem the PEM-formatted EncryptedPrivateKeyInfo to decrypt.\n * @param password the password to use.\n *\n * @return the RSA key on success, null on failure.\n */\npki.decryptRsaPrivateKey = function(pem, password) {\n  var rval = null;\n\n  var msg = forge.pem.decode(pem)[0];\n\n  if(msg.type !== 'ENCRYPTED PRIVATE KEY' &&\n    msg.type !== 'PRIVATE KEY' &&\n    msg.type !== 'RSA PRIVATE KEY') {\n    var error = new Error('Could not convert private key from PEM; PEM header type ' +\n      'is not \"ENCRYPTED PRIVATE KEY\", \"PRIVATE KEY\", or \"RSA PRIVATE KEY\".');\n    error.headerType = error;\n    throw error;\n  }\n\n  if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n    var dkLen;\n    var cipherFn;\n    switch(msg.dekInfo.algorithm) {\n    case 'DES-CBC':\n      dkLen = 8;\n      cipherFn = forge.des.createDecryptionCipher;\n      break;\n    case 'DES-EDE3-CBC':\n      dkLen = 24;\n      cipherFn = forge.des.createDecryptionCipher;\n      break;\n    case 'AES-128-CBC':\n      dkLen = 16;\n      cipherFn = forge.aes.createDecryptionCipher;\n      break;\n    case 'AES-192-CBC':\n      dkLen = 24;\n      cipherFn = forge.aes.createDecryptionCipher;\n      break;\n    case 'AES-256-CBC':\n      dkLen = 32;\n      cipherFn = forge.aes.createDecryptionCipher;\n      break;\n    case 'RC2-40-CBC':\n      dkLen = 5;\n      cipherFn = function(key) {\n        return forge.rc2.createDecryptionCipher(key, 40);\n      };\n      break;\n    case 'RC2-64-CBC':\n      dkLen = 8;\n      cipherFn = function(key) {\n        return forge.rc2.createDecryptionCipher(key, 64);\n      };\n      break;\n    case 'RC2-128-CBC':\n      dkLen = 16;\n      cipherFn = function(key) {\n        return forge.rc2.createDecryptionCipher(key, 128);\n      };\n      break;\n    default:\n      var error = new Error('Could not decrypt private key; unsupported ' +\n        'encryption algorithm \"' + msg.dekInfo.algorithm + '\".');\n      error.algorithm = msg.dekInfo.algorithm;\n      throw error;\n    }\n\n    // use OpenSSL legacy key derivation\n    var iv = forge.util.hexToBytes(msg.dekInfo.parameters);\n    var dk = forge.pbe.opensslDeriveBytes(password, iv.substr(0, 8), dkLen);\n    var cipher = cipherFn(dk);\n    cipher.start(iv);\n    cipher.update(forge.util.createBuffer(msg.body));\n    if(cipher.finish()) {\n      rval = cipher.output.getBytes();\n    } else {\n      return rval;\n    }\n  } else {\n    rval = msg.body;\n  }\n\n  if(msg.type === 'ENCRYPTED PRIVATE KEY') {\n    rval = pki.decryptPrivateKeyInfo(asn1.fromDer(rval), password);\n  } else {\n    // decryption already performed above\n    rval = asn1.fromDer(rval);\n  }\n\n  if(rval !== null) {\n    rval = pki.privateKeyFromAsn1(rval);\n  }\n\n  return rval;\n};\n\n/**\n * Derives a PKCS#12 key.\n *\n * @param password the password to derive the key material from, null or\n *          undefined for none.\n * @param salt the salt, as a ByteBuffer, to use.\n * @param id the PKCS#12 ID byte (1 = key material, 2 = IV, 3 = MAC).\n * @param iter the iteration count.\n * @param n the number of bytes to derive from the password.\n * @param md the message digest to use, defaults to SHA-1.\n *\n * @return a ByteBuffer with the bytes derived from the password.\n */\npki.pbe.generatePkcs12Key = function(password, salt, id, iter, n, md) {\n  var j, l;\n\n  if(typeof md === 'undefined' || md === null) {\n    if(!('sha1' in forge.md)) {\n      throw new Error('\"sha1\" hash algorithm unavailable.');\n    }\n    md = forge.md.sha1.create();\n  }\n\n  var u = md.digestLength;\n  var v = md.blockLength;\n  var result = new forge.util.ByteBuffer();\n\n  /* Convert password to Unicode byte buffer + trailing 0-byte. */\n  var passBuf = new forge.util.ByteBuffer();\n  if(password !== null && password !== undefined) {\n    for(l = 0; l < password.length; l++) {\n      passBuf.putInt16(password.charCodeAt(l));\n    }\n    passBuf.putInt16(0);\n  }\n\n  /* Length of salt and password in BYTES. */\n  var p = passBuf.length();\n  var s = salt.length();\n\n  /* 1. Construct a string, D (the \"diversifier\"), by concatenating\n        v copies of ID. */\n  var D = new forge.util.ByteBuffer();\n  D.fillWithByte(id, v);\n\n  /* 2. Concatenate copies of the salt together to create a string S of length\n        v * ceil(s / v) bytes (the final copy of the salt may be trunacted\n        to create S).\n        Note that if the salt is the empty string, then so is S. */\n  var Slen = v * Math.ceil(s / v);\n  var S = new forge.util.ByteBuffer();\n  for(l = 0; l < Slen; l++) {\n    S.putByte(salt.at(l % s));\n  }\n\n  /* 3. Concatenate copies of the password together to create a string P of\n        length v * ceil(p / v) bytes (the final copy of the password may be\n        truncated to create P).\n        Note that if the password is the empty string, then so is P. */\n  var Plen = v * Math.ceil(p / v);\n  var P = new forge.util.ByteBuffer();\n  for(l = 0; l < Plen; l++) {\n    P.putByte(passBuf.at(l % p));\n  }\n\n  /* 4. Set I=S||P to be the concatenation of S and P. */\n  var I = S;\n  I.putBuffer(P);\n\n  /* 5. Set c=ceil(n / u). */\n  var c = Math.ceil(n / u);\n\n  /* 6. For i=1, 2, ..., c, do the following: */\n  for(var i = 1; i <= c; i++) {\n    /* a) Set Ai=H^r(D||I). (l.e. the rth hash of D||I, H(H(H(...H(D||I)))) */\n    var buf = new forge.util.ByteBuffer();\n    buf.putBytes(D.bytes());\n    buf.putBytes(I.bytes());\n    for(var round = 0; round < iter; round++) {\n      md.start();\n      md.update(buf.getBytes());\n      buf = md.digest();\n    }\n\n    /* b) Concatenate copies of Ai to create a string B of length v bytes (the\n          final copy of Ai may be truncated to create B). */\n    var B = new forge.util.ByteBuffer();\n    for(l = 0; l < v; l++) {\n      B.putByte(buf.at(l % u));\n    }\n\n    /* c) Treating I as a concatenation I0, I1, ..., Ik-1 of v-byte blocks,\n          where k=ceil(s / v) + ceil(p / v), modify I by setting\n          Ij=(Ij+B+1) mod 2v for each j.  */\n    var k = Math.ceil(s / v) + Math.ceil(p / v);\n    var Inew = new forge.util.ByteBuffer();\n    for(j = 0; j < k; j++) {\n      var chunk = new forge.util.ByteBuffer(I.getBytes(v));\n      var x = 0x1ff;\n      for(l = B.length() - 1; l >= 0; l--) {\n        x = x >> 8;\n        x += B.at(l) + chunk.at(l);\n        chunk.setAt(l, x & 0xff);\n      }\n      Inew.putBuffer(chunk);\n    }\n    I = Inew;\n\n    /* Add Ai to A. */\n    result.putBuffer(buf);\n  }\n\n  result.truncate(result.length() - n);\n  return result;\n};\n\n/**\n * Get new Forge cipher object instance.\n *\n * @param oid the OID (in string notation).\n * @param params the ASN.1 params object.\n * @param password the password to decrypt with.\n *\n * @return new cipher object instance.\n */\npki.pbe.getCipher = function(oid, params, password) {\n  switch(oid) {\n  case pki.oids['pkcs5PBES2']:\n    return pki.pbe.getCipherForPBES2(oid, params, password);\n\n  case pki.oids['pbeWithSHAAnd3-KeyTripleDES-CBC']:\n  case pki.oids['pbewithSHAAnd40BitRC2-CBC']:\n    return pki.pbe.getCipherForPKCS12PBE(oid, params, password);\n\n  default:\n    var error = new Error('Cannot read encrypted PBE data block. Unsupported OID.');\n    error.oid = oid;\n    error.supportedOids = [\n      'pkcs5PBES2',\n      'pbeWithSHAAnd3-KeyTripleDES-CBC',\n      'pbewithSHAAnd40BitRC2-CBC'\n    ];\n    throw error;\n  }\n};\n\n/**\n * Get new Forge cipher object instance according to PBES2 params block.\n *\n * The returned cipher instance is already started using the IV\n * from PBES2 parameter block.\n *\n * @param oid the PKCS#5 PBKDF2 OID (in string notation).\n * @param params the ASN.1 PBES2-params object.\n * @param password the password to decrypt with.\n *\n * @return new cipher object instance.\n */\npki.pbe.getCipherForPBES2 = function(oid, params, password) {\n  // get PBE params\n  var capture = {};\n  var errors = [];\n  if(!asn1.validate(params, PBES2AlgorithmsValidator, capture, errors)) {\n    var error = new Error('Cannot read password-based-encryption algorithm ' +\n      'parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n    error.errors = errors;\n    throw error;\n  }\n\n  // check oids\n  oid = asn1.derToOid(capture.kdfOid);\n  if(oid !== pki.oids['pkcs5PBKDF2']) {\n    var error = new Error('Cannot read encrypted private key. ' +\n      'Unsupported key derivation function OID.');\n    error.oid = oid;\n    error.supportedOids = ['pkcs5PBKDF2'];\n    throw error;\n  }\n  oid = asn1.derToOid(capture.encOid);\n  if(oid !== pki.oids['aes128-CBC'] &&\n    oid !== pki.oids['aes192-CBC'] &&\n    oid !== pki.oids['aes256-CBC'] &&\n    oid !== pki.oids['des-EDE3-CBC'] &&\n    oid !== pki.oids['desCBC']) {\n    var error = new Error('Cannot read encrypted private key. ' +\n      'Unsupported encryption scheme OID.');\n    error.oid = oid;\n    error.supportedOids = [\n      'aes128-CBC', 'aes192-CBC', 'aes256-CBC', 'des-EDE3-CBC', 'desCBC'];\n    throw error;\n  }\n\n  // set PBE params\n  var salt = capture.kdfSalt;\n  var count = forge.util.createBuffer(capture.kdfIterationCount);\n  count = count.getInt(count.length() << 3);\n  var dkLen;\n  var cipherFn;\n  switch(pki.oids[oid]) {\n  case 'aes128-CBC':\n    dkLen = 16;\n    cipherFn = forge.aes.createDecryptionCipher;\n    break;\n  case 'aes192-CBC':\n    dkLen = 24;\n    cipherFn = forge.aes.createDecryptionCipher;\n    break;\n  case 'aes256-CBC':\n    dkLen = 32;\n    cipherFn = forge.aes.createDecryptionCipher;\n    break;\n  case 'des-EDE3-CBC':\n    dkLen = 24;\n    cipherFn = forge.des.createDecryptionCipher;\n    break;\n  case 'desCBC':\n    dkLen = 8;\n    cipherFn = forge.des.createDecryptionCipher;\n    break;\n  }\n\n  // get PRF message digest\n  var md = prfOidToMessageDigest(capture.prfOid);\n\n  // decrypt private key using pbe with chosen PRF and AES/DES\n  var dk = forge.pkcs5.pbkdf2(password, salt, count, dkLen, md);\n  var iv = capture.encIv;\n  var cipher = cipherFn(dk);\n  cipher.start(iv);\n\n  return cipher;\n};\n\n/**\n * Get new Forge cipher object instance for PKCS#12 PBE.\n *\n * The returned cipher instance is already started using the key & IV\n * derived from the provided password and PKCS#12 PBE salt.\n *\n * @param oid The PKCS#12 PBE OID (in string notation).\n * @param params The ASN.1 PKCS#12 PBE-params object.\n * @param password The password to decrypt with.\n *\n * @return the new cipher object instance.\n */\npki.pbe.getCipherForPKCS12PBE = function(oid, params, password) {\n  // get PBE params\n  var capture = {};\n  var errors = [];\n  if(!asn1.validate(params, pkcs12PbeParamsValidator, capture, errors)) {\n    var error = new Error('Cannot read password-based-encryption algorithm ' +\n      'parameters. ASN.1 object is not a supported EncryptedPrivateKeyInfo.');\n    error.errors = errors;\n    throw error;\n  }\n\n  var salt = forge.util.createBuffer(capture.salt);\n  var count = forge.util.createBuffer(capture.iterations);\n  count = count.getInt(count.length() << 3);\n\n  var dkLen, dIvLen, cipherFn;\n  switch(oid) {\n    case pki.oids['pbeWithSHAAnd3-KeyTripleDES-CBC']:\n      dkLen = 24;\n      dIvLen = 8;\n      cipherFn = forge.des.startDecrypting;\n      break;\n\n    case pki.oids['pbewithSHAAnd40BitRC2-CBC']:\n      dkLen = 5;\n      dIvLen = 8;\n      cipherFn = function(key, iv) {\n        var cipher = forge.rc2.createDecryptionCipher(key, 40);\n        cipher.start(iv, null);\n        return cipher;\n      };\n      break;\n\n    default:\n      var error = new Error('Cannot read PKCS #12 PBE data block. Unsupported OID.');\n      error.oid = oid;\n      throw error;\n  }\n\n  // get PRF message digest\n  var md = prfOidToMessageDigest(capture.prfOid);\n  var key = pki.pbe.generatePkcs12Key(password, salt, 1, count, dkLen, md);\n  md.start();\n  var iv = pki.pbe.generatePkcs12Key(password, salt, 2, count, dIvLen, md);\n\n  return cipherFn(key, iv);\n};\n\n/**\n * OpenSSL's legacy key derivation function.\n *\n * See: http://www.openssl.org/docs/crypto/EVP_BytesToKey.html\n *\n * @param password the password to derive the key from.\n * @param salt the salt to use, null for none.\n * @param dkLen the number of bytes needed for the derived key.\n * @param [options] the options to use:\n *          [md] an optional message digest object to use.\n */\npki.pbe.opensslDeriveBytes = function(password, salt, dkLen, md) {\n  if(typeof md === 'undefined' || md === null) {\n    if(!('md5' in forge.md)) {\n      throw new Error('\"md5\" hash algorithm unavailable.');\n    }\n    md = forge.md.md5.create();\n  }\n  if(salt === null) {\n    salt = '';\n  }\n  var digests = [hash(md, password + salt)];\n  for(var length = 16, i = 1; length < dkLen; ++i, length += 16) {\n    digests.push(hash(md, digests[i - 1] + password + salt));\n  }\n  return digests.join('').substr(0, dkLen);\n};\n\nfunction hash(md, bytes) {\n  return md.start().update(bytes).digest().getBytes();\n}\n\nfunction prfOidToMessageDigest(prfOid) {\n  // get PRF algorithm, default to SHA-1\n  var prfAlgorithm;\n  if(!prfOid) {\n    prfAlgorithm = 'hmacWithSHA1';\n  } else {\n    prfAlgorithm = pki.oids[asn1.derToOid(prfOid)];\n    if(!prfAlgorithm) {\n      var error = new Error('Unsupported PRF OID.');\n      error.oid = prfOid;\n      error.supported = [\n        'hmacWithSHA1', 'hmacWithSHA224', 'hmacWithSHA256', 'hmacWithSHA384',\n        'hmacWithSHA512'];\n      throw error;\n    }\n  }\n  return prfAlgorithmToMessageDigest(prfAlgorithm);\n}\n\nfunction prfAlgorithmToMessageDigest(prfAlgorithm) {\n  var factory = forge.md;\n  switch(prfAlgorithm) {\n  case 'hmacWithSHA224':\n    factory = forge.md.sha512;\n  case 'hmacWithSHA1':\n  case 'hmacWithSHA256':\n  case 'hmacWithSHA384':\n  case 'hmacWithSHA512':\n    prfAlgorithm = prfAlgorithm.substr(8).toLowerCase();\n    break;\n  default:\n    var error = new Error('Unsupported PRF algorithm.');\n    error.algorithm = prfAlgorithm;\n    error.supported = [\n      'hmacWithSHA1', 'hmacWithSHA224', 'hmacWithSHA256', 'hmacWithSHA384',\n      'hmacWithSHA512'];\n    throw error;\n  }\n  if(!factory || !(prfAlgorithm in factory)) {\n    throw new Error('Unknown hash algorithm: ' + prfAlgorithm);\n  }\n  return factory[prfAlgorithm].create();\n}\n\nfunction createPbkdf2Params(salt, countBytes, dkLen, prfAlgorithm) {\n  var params = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n    // salt\n    asn1.create(\n      asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, salt),\n    // iteration count\n    asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n      countBytes.getBytes())\n  ]);\n  // when PRF algorithm is not SHA-1 default, add key length and PRF algorithm\n  if(prfAlgorithm !== 'hmacWithSHA1') {\n    params.value.push(\n      // key length\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n        forge.util.hexToBytes(dkLen.toString(16))),\n      // AlgorithmIdentifier\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // algorithm\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n          asn1.oidToDer(pki.oids[prfAlgorithm]).getBytes()),\n        // parameters (null)\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n      ]));\n  }\n  return params;\n}\n","/**\n * Javascript implementation of ASN.1 validators for PKCS#7 v1.5.\n *\n * @author Dave Longley\n * @author Stefan Siegl\n *\n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * The ASN.1 representation of PKCS#7 is as follows\n * (see RFC #2315 for details, http://www.ietf.org/rfc/rfc2315.txt):\n *\n * A PKCS#7 message consists of a ContentInfo on root level, which may\n * contain any number of further ContentInfo nested into it.\n *\n * ContentInfo ::= SEQUENCE {\n *   contentType                ContentType,\n *   content               [0]  EXPLICIT ANY DEFINED BY contentType OPTIONAL\n * }\n *\n * ContentType ::= OBJECT IDENTIFIER\n *\n * EnvelopedData ::= SEQUENCE {\n *   version                    Version,\n *   recipientInfos             RecipientInfos,\n *   encryptedContentInfo       EncryptedContentInfo\n * }\n *\n * EncryptedData ::= SEQUENCE {\n *   version                    Version,\n *   encryptedContentInfo       EncryptedContentInfo\n * }\n *\n * id-signedData OBJECT IDENTIFIER ::= { iso(1) member-body(2)\n *   us(840) rsadsi(113549) pkcs(1) pkcs7(7) 2 }\n *\n * SignedData ::= SEQUENCE {\n *   version           INTEGER,\n *   digestAlgorithms  DigestAlgorithmIdentifiers,\n *   contentInfo       ContentInfo,\n *   certificates      [0] IMPLICIT Certificates OPTIONAL,\n *   crls              [1] IMPLICIT CertificateRevocationLists OPTIONAL,\n *   signerInfos       SignerInfos\n * }\n *\n * SignerInfos ::= SET OF SignerInfo\n *\n * SignerInfo ::= SEQUENCE {\n *   version                    Version,\n *   issuerAndSerialNumber      IssuerAndSerialNumber,\n *   digestAlgorithm            DigestAlgorithmIdentifier,\n *   authenticatedAttributes    [0] IMPLICIT Attributes OPTIONAL,\n *   digestEncryptionAlgorithm  DigestEncryptionAlgorithmIdentifier,\n *   encryptedDigest            EncryptedDigest,\n *   unauthenticatedAttributes  [1] IMPLICIT Attributes OPTIONAL\n * }\n *\n * EncryptedDigest ::= OCTET STRING\n *\n * Attributes ::= SET OF Attribute\n *\n * Attribute ::= SEQUENCE {\n *   attrType    OBJECT IDENTIFIER,\n *   attrValues  SET OF AttributeValue\n * }\n *\n * AttributeValue ::= ANY\n *\n * Version ::= INTEGER\n *\n * RecipientInfos ::= SET OF RecipientInfo\n *\n * EncryptedContentInfo ::= SEQUENCE {\n *   contentType                 ContentType,\n *   contentEncryptionAlgorithm  ContentEncryptionAlgorithmIdentifier,\n *   encryptedContent       [0]  IMPLICIT EncryptedContent OPTIONAL\n * }\n *\n * ContentEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of AES and DES3, there is only one,\n * the IV.\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n *    algorithm OBJECT IDENTIFIER,\n *    parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * EncryptedContent ::= OCTET STRING\n *\n * RecipientInfo ::= SEQUENCE {\n *   version                     Version,\n *   issuerAndSerialNumber       IssuerAndSerialNumber,\n *   keyEncryptionAlgorithm      KeyEncryptionAlgorithmIdentifier,\n *   encryptedKey                EncryptedKey\n * }\n *\n * IssuerAndSerialNumber ::= SEQUENCE {\n *   issuer                      Name,\n *   serialNumber                CertificateSerialNumber\n * }\n *\n * CertificateSerialNumber ::= INTEGER\n *\n * KeyEncryptionAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * EncryptedKey ::= OCTET STRING\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./util');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7v = module.exports = forge.pkcs7asn1 = forge.pkcs7asn1 || {};\nforge.pkcs7 = forge.pkcs7 || {};\nforge.pkcs7.asn1 = p7v;\n\nvar contentInfoValidator = {\n  name: 'ContentInfo',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'ContentInfo.ContentType',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OID,\n    constructed: false,\n    capture: 'contentType'\n  }, {\n    name: 'ContentInfo.content',\n    tagClass: asn1.Class.CONTEXT_SPECIFIC,\n    type: 0,\n    constructed: true,\n    optional: true,\n    captureAsn1: 'content'\n  }]\n};\np7v.contentInfoValidator = contentInfoValidator;\n\nvar encryptedContentInfoValidator = {\n  name: 'EncryptedContentInfo',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'EncryptedContentInfo.contentType',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OID,\n    constructed: false,\n    capture: 'contentType'\n  }, {\n    name: 'EncryptedContentInfo.contentEncryptionAlgorithm',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'EncryptedContentInfo.contentEncryptionAlgorithm.algorithm',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OID,\n      constructed: false,\n      capture: 'encAlgorithm'\n    }, {\n      name: 'EncryptedContentInfo.contentEncryptionAlgorithm.parameter',\n      tagClass: asn1.Class.UNIVERSAL,\n      captureAsn1: 'encParameter'\n    }]\n  }, {\n    name: 'EncryptedContentInfo.encryptedContent',\n    tagClass: asn1.Class.CONTEXT_SPECIFIC,\n    type: 0,\n    /* The PKCS#7 structure output by OpenSSL somewhat differs from what\n     * other implementations do generate.\n     *\n     * OpenSSL generates a structure like this:\n     * SEQUENCE {\n     *    ...\n     *    [0]\n     *       26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n     *       C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n     *       ...\n     * }\n     *\n     * Whereas other implementations (and this PKCS#7 module) generate:\n     * SEQUENCE {\n     *    ...\n     *    [0] {\n     *       OCTET STRING\n     *          26 DA 67 D2 17 9C 45 3C B1 2A A8 59 2F 29 33 38\n     *          C3 C3 DF 86 71 74 7A 19 9F 40 D0 29 BE 85 90 45\n     *          ...\n     *    }\n     * }\n     *\n     * In order to support both, we just capture the context specific\n     * field here.  The OCTET STRING bit is removed below.\n     */\n    capture: 'encryptedContent',\n    captureAsn1: 'encryptedContentAsn1'\n  }]\n};\n\np7v.envelopedDataValidator = {\n  name: 'EnvelopedData',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'EnvelopedData.Version',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.INTEGER,\n    constructed: false,\n    capture: 'version'\n  }, {\n    name: 'EnvelopedData.RecipientInfos',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SET,\n    constructed: true,\n    captureAsn1: 'recipientInfos'\n  }].concat(encryptedContentInfoValidator)\n};\n\np7v.encryptedDataValidator = {\n  name: 'EncryptedData',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'EncryptedData.Version',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.INTEGER,\n    constructed: false,\n    capture: 'version'\n  }].concat(encryptedContentInfoValidator)\n};\n\nvar signerValidator = {\n  name: 'SignerInfo',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'SignerInfo.version',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.INTEGER,\n    constructed: false\n  }, {\n    name: 'SignerInfo.issuerAndSerialNumber',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'SignerInfo.issuerAndSerialNumber.issuer',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.SEQUENCE,\n      constructed: true,\n      captureAsn1: 'issuer'\n    }, {\n      name: 'SignerInfo.issuerAndSerialNumber.serialNumber',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.INTEGER,\n      constructed: false,\n      capture: 'serial'\n    }]\n  }, {\n    name: 'SignerInfo.digestAlgorithm',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'SignerInfo.digestAlgorithm.algorithm',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OID,\n      constructed: false,\n      capture: 'digestAlgorithm'\n    }, {\n      name: 'SignerInfo.digestAlgorithm.parameter',\n      tagClass: asn1.Class.UNIVERSAL,\n      constructed: false,\n      captureAsn1: 'digestParameter',\n      optional: true\n    }]\n  }, {\n    name: 'SignerInfo.authenticatedAttributes',\n    tagClass: asn1.Class.CONTEXT_SPECIFIC,\n    type: 0,\n    constructed: true,\n    optional: true,\n    capture: 'authenticatedAttributes'\n  }, {\n    name: 'SignerInfo.digestEncryptionAlgorithm',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    capture: 'signatureAlgorithm'\n  }, {\n    name: 'SignerInfo.encryptedDigest',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OCTETSTRING,\n    constructed: false,\n    capture: 'signature'\n  }, {\n    name: 'SignerInfo.unauthenticatedAttributes',\n    tagClass: asn1.Class.CONTEXT_SPECIFIC,\n    type: 1,\n    constructed: true,\n    optional: true,\n    capture: 'unauthenticatedAttributes'\n  }]\n};\n\np7v.signedDataValidator = {\n  name: 'SignedData',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'SignedData.Version',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.INTEGER,\n    constructed: false,\n    capture: 'version'\n  }, {\n    name: 'SignedData.DigestAlgorithms',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SET,\n    constructed: true,\n    captureAsn1: 'digestAlgorithms'\n  },\n  contentInfoValidator,\n  {\n    name: 'SignedData.Certificates',\n    tagClass: asn1.Class.CONTEXT_SPECIFIC,\n    type: 0,\n    optional: true,\n    captureAsn1: 'certificates'\n  }, {\n    name: 'SignedData.CertificateRevocationLists',\n    tagClass: asn1.Class.CONTEXT_SPECIFIC,\n    type: 1,\n    optional: true,\n    captureAsn1: 'crls'\n  }, {\n    name: 'SignedData.SignerInfos',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SET,\n    capture: 'signerInfos',\n    optional: true,\n    value: [signerValidator]\n  }]\n};\n\np7v.recipientInfoValidator = {\n  name: 'RecipientInfo',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'RecipientInfo.version',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.INTEGER,\n    constructed: false,\n    capture: 'version'\n  }, {\n    name: 'RecipientInfo.issuerAndSerial',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'RecipientInfo.issuerAndSerial.issuer',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.SEQUENCE,\n      constructed: true,\n      captureAsn1: 'issuer'\n    }, {\n      name: 'RecipientInfo.issuerAndSerial.serialNumber',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.INTEGER,\n      constructed: false,\n      capture: 'serial'\n    }]\n  }, {\n    name: 'RecipientInfo.keyEncryptionAlgorithm',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'RecipientInfo.keyEncryptionAlgorithm.algorithm',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OID,\n      constructed: false,\n      capture: 'encAlgorithm'\n    }, {\n      name: 'RecipientInfo.keyEncryptionAlgorithm.parameter',\n      tagClass: asn1.Class.UNIVERSAL,\n      constructed: false,\n      captureAsn1: 'encParameter',\n      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 mask generation function MGF1.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\nforge.mgf = forge.mgf || {};\nvar mgf1 = module.exports = forge.mgf.mgf1 = forge.mgf1 = forge.mgf1 || {};\n\n/**\n * Creates a MGF1 mask generation function object.\n *\n * @param md the message digest API to use (eg: forge.md.sha1.create()).\n *\n * @return a mask generation function object.\n */\nmgf1.create = function(md) {\n  var mgf = {\n    /**\n     * Generate mask of specified length.\n     *\n     * @param {String} seed The seed for mask generation.\n     * @param maskLen Number of bytes to generate.\n     * @return {String} The generated mask.\n     */\n    generate: function(seed, maskLen) {\n      /* 2. Let T be the empty octet string. */\n      var t = new forge.util.ByteBuffer();\n\n      /* 3. For counter from 0 to ceil(maskLen / hLen), do the following: */\n      var len = Math.ceil(maskLen / md.digestLength);\n      for(var i = 0; i < len; i++) {\n        /* a. Convert counter to an octet string C of length 4 octets */\n        var c = new forge.util.ByteBuffer();\n        c.putInt32(i);\n\n        /* b. Concatenate the hash of the seed mgfSeed and C to the octet\n         * string T: */\n        md.start();\n        md.update(seed + c.getBytes());\n        t.putBuffer(md.digest());\n      }\n\n      /* Output the leading maskLen octets of T as the octet string mask. */\n      t.truncate(t.length() - maskLen);\n      return t.getBytes();\n    }\n  };\n\n  return mgf;\n};\n","/**\n * Javascript implementation of PKCS#1 PSS signature padding.\n *\n * @author Stefan Siegl\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n */\nvar forge = require('./forge');\nrequire('./random');\nrequire('./util');\n\n// shortcut for PSS API\nvar pss = module.exports = forge.pss = forge.pss || {};\n\n/**\n * Creates a PSS signature scheme object.\n *\n * There are several ways to provide a salt for encoding:\n *\n * 1. Specify the saltLength only and the built-in PRNG will generate it.\n * 2. Specify the saltLength and a custom PRNG with 'getBytesSync' defined that\n *   will be used.\n * 3. Specify the salt itself as a forge.util.ByteBuffer.\n *\n * @param options the options to use:\n *          md the message digest object to use, a forge md instance.\n *          mgf the mask generation function to use, a forge mgf instance.\n *          [saltLength] the length of the salt in octets.\n *          [prng] the pseudo-random number generator to use to produce a salt.\n *          [salt] the salt to use when encoding.\n *\n * @return a signature scheme object.\n */\npss.create = function(options) {\n  // backwards compatibility w/legacy args: hash, mgf, sLen\n  if(arguments.length === 3) {\n    options = {\n      md: arguments[0],\n      mgf: arguments[1],\n      saltLength: arguments[2]\n    };\n  }\n\n  var hash = options.md;\n  var mgf = options.mgf;\n  var hLen = hash.digestLength;\n\n  var salt_ = options.salt || null;\n  if(typeof salt_ === 'string') {\n    // assume binary-encoded string\n    salt_ = forge.util.createBuffer(salt_);\n  }\n\n  var sLen;\n  if('saltLength' in options) {\n    sLen = options.saltLength;\n  } else if(salt_ !== null) {\n    sLen = salt_.length();\n  } else {\n    throw new Error('Salt length not specified or specific salt not given.');\n  }\n\n  if(salt_ !== null && salt_.length() !== sLen) {\n    throw new Error('Given salt length does not match length of given salt.');\n  }\n\n  var prng = options.prng || forge.random;\n\n  var pssobj = {};\n\n  /**\n   * Encodes a PSS signature.\n   *\n   * This function implements EMSA-PSS-ENCODE as per RFC 3447, section 9.1.1.\n   *\n   * @param md the message digest object with the hash to sign.\n   * @param modsBits the length of the RSA modulus in bits.\n   *\n   * @return the encoded message as a binary-encoded string of length\n   *           ceil((modBits - 1) / 8).\n   */\n  pssobj.encode = function(md, modBits) {\n    var i;\n    var emBits = modBits - 1;\n    var emLen = Math.ceil(emBits / 8);\n\n    /* 2. Let mHash = Hash(M), an octet string of length hLen. */\n    var mHash = md.digest().getBytes();\n\n    /* 3. If emLen < hLen + sLen + 2, output \"encoding error\" and stop. */\n    if(emLen < hLen + sLen + 2) {\n      throw new Error('Message is too long to encrypt.');\n    }\n\n    /* 4. Generate a random octet string salt of length sLen; if sLen = 0,\n     *    then salt is the empty string. */\n    var salt;\n    if(salt_ === null) {\n      salt = prng.getBytesSync(sLen);\n    } else {\n      salt = salt_.bytes();\n    }\n\n    /* 5. Let M' = (0x)00 00 00 00 00 00 00 00 || mHash || salt; */\n    var m_ = new forge.util.ByteBuffer();\n    m_.fillWithByte(0, 8);\n    m_.putBytes(mHash);\n    m_.putBytes(salt);\n\n    /* 6. Let H = Hash(M'), an octet string of length hLen. */\n    hash.start();\n    hash.update(m_.getBytes());\n    var h = hash.digest().getBytes();\n\n    /* 7. Generate an octet string PS consisting of emLen - sLen - hLen - 2\n     *    zero octets.  The length of PS may be 0. */\n    var ps = new forge.util.ByteBuffer();\n    ps.fillWithByte(0, emLen - sLen - hLen - 2);\n\n    /* 8. Let DB = PS || 0x01 || salt; DB is an octet string of length\n     *    emLen - hLen - 1. */\n    ps.putByte(0x01);\n    ps.putBytes(salt);\n    var db = ps.getBytes();\n\n    /* 9. Let dbMask = MGF(H, emLen - hLen - 1). */\n    var maskLen = emLen - hLen - 1;\n    var dbMask = mgf.generate(h, maskLen);\n\n    /* 10. Let maskedDB = DB \\xor dbMask. */\n    var maskedDB = '';\n    for(i = 0; i < maskLen; i++) {\n      maskedDB += String.fromCharCode(db.charCodeAt(i) ^ dbMask.charCodeAt(i));\n    }\n\n    /* 11. Set the leftmost 8emLen - emBits bits of the leftmost octet in\n     *     maskedDB to zero. */\n    var mask = (0xFF00 >> (8 * emLen - emBits)) & 0xFF;\n    maskedDB = String.fromCharCode(maskedDB.charCodeAt(0) & ~mask) +\n      maskedDB.substr(1);\n\n    /* 12. Let EM = maskedDB || H || 0xbc.\n     * 13. Output EM. */\n    return maskedDB + h + String.fromCharCode(0xbc);\n  };\n\n  /**\n   * Verifies a PSS signature.\n   *\n   * This function implements EMSA-PSS-VERIFY as per RFC 3447, section 9.1.2.\n   *\n   * @param mHash the message digest hash, as a binary-encoded string, to\n   *         compare against the signature.\n   * @param em the encoded message, as a binary-encoded string\n   *          (RSA decryption result).\n   * @param modsBits the length of the RSA modulus in bits.\n   *\n   * @return true if the signature was verified, false if not.\n   */\n  pssobj.verify = function(mHash, em, modBits) {\n    var i;\n    var emBits = modBits - 1;\n    var emLen = Math.ceil(emBits / 8);\n\n    /* c. Convert the message representative m to an encoded message EM\n     *    of length emLen = ceil((modBits - 1) / 8) octets, where modBits\n     *    is the length in bits of the RSA modulus n */\n    em = em.substr(-emLen);\n\n    /* 3. If emLen < hLen + sLen + 2, output \"inconsistent\" and stop. */\n    if(emLen < hLen + sLen + 2) {\n      throw new Error('Inconsistent parameters to PSS signature verification.');\n    }\n\n    /* 4. If the rightmost octet of EM does not have hexadecimal value\n     *    0xbc, output \"inconsistent\" and stop. */\n    if(em.charCodeAt(emLen - 1) !== 0xbc) {\n      throw new Error('Encoded message does not end in 0xBC.');\n    }\n\n    /* 5. Let maskedDB be the leftmost emLen - hLen - 1 octets of EM, and\n     *    let H be the next hLen octets. */\n    var maskLen = emLen - hLen - 1;\n    var maskedDB = em.substr(0, maskLen);\n    var h = em.substr(maskLen, hLen);\n\n    /* 6. If the leftmost 8emLen - emBits bits of the leftmost octet in\n     *    maskedDB are not all equal to zero, output \"inconsistent\" and stop. */\n    var mask = (0xFF00 >> (8 * emLen - emBits)) & 0xFF;\n    if((maskedDB.charCodeAt(0) & mask) !== 0) {\n      throw new Error('Bits beyond keysize not zero as expected.');\n    }\n\n    /* 7. Let dbMask = MGF(H, emLen - hLen - 1). */\n    var dbMask = mgf.generate(h, maskLen);\n\n    /* 8. Let DB = maskedDB \\xor dbMask. */\n    var db = '';\n    for(i = 0; i < maskLen; i++) {\n      db += String.fromCharCode(maskedDB.charCodeAt(i) ^ dbMask.charCodeAt(i));\n    }\n\n    /* 9. Set the leftmost 8emLen - emBits bits of the leftmost octet\n     * in DB to zero. */\n    db = String.fromCharCode(db.charCodeAt(0) & ~mask) + db.substr(1);\n\n    /* 10. If the emLen - hLen - sLen - 2 leftmost octets of DB are not zero\n     * or if the octet at position emLen - hLen - sLen - 1 (the leftmost\n     * position is \"position 1\") does not have hexadecimal value 0x01,\n     * output \"inconsistent\" and stop. */\n    var checkLen = emLen - hLen - sLen - 2;\n    for(i = 0; i < checkLen; i++) {\n      if(db.charCodeAt(i) !== 0x00) {\n        throw new Error('Leftmost octets not zero as expected');\n      }\n    }\n\n    if(db.charCodeAt(checkLen) !== 0x01) {\n      throw new Error('Inconsistent PSS signature, 0x01 marker not found');\n    }\n\n    /* 11. Let salt be the last sLen octets of DB. */\n    var salt = db.substr(-sLen);\n\n    /* 12.  Let M' = (0x)00 00 00 00 00 00 00 00 || mHash || salt */\n    var m_ = new forge.util.ByteBuffer();\n    m_.fillWithByte(0, 8);\n    m_.putBytes(mHash);\n    m_.putBytes(salt);\n\n    /* 13. Let H' = Hash(M'), an octet string of length hLen. */\n    hash.start();\n    hash.update(m_.getBytes());\n    var h_ = hash.digest().getBytes();\n\n    /* 14. If H = H', output \"consistent.\" Otherwise, output \"inconsistent.\" */\n    return h === h_;\n  };\n\n  return pssobj;\n};\n","/**\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 <the-csr-pem-file> -verify -noout -text\n   *\n   * @return true if verified, false if not.\n   */\n  csr.verify = function() {\n    var rval = false;\n\n    var md = csr.md;\n    if(md === null) {\n      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 * Node.js module for Forge mask generation functions.\n *\n * @author Stefan Siegl\n *\n * Copyright 2012 Stefan Siegl <stesie@brokenpipe.de>\n */\nvar forge = require('./forge');\nrequire('./mgf1');\n\nmodule.exports = forge.mgf = forge.mgf || {};\nforge.mgf.mgf1 = forge.mgf1;\n","/**\n * Javascript implementation of PKCS#12.\n *\n * @author Dave Longley\n * @author Stefan Siegl <stesie@brokenpipe.de>\n *\n * Copyright (c) 2010-2014 Digital Bazaar, Inc.\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n *\n * The ASN.1 representation of PKCS#12 is as follows\n * (see ftp://ftp.rsasecurity.com/pub/pkcs/pkcs-12/pkcs-12-tc1.pdf for details)\n *\n * PFX ::= SEQUENCE {\n *   version  INTEGER {v3(3)}(v3,...),\n *   authSafe ContentInfo,\n *   macData  MacData OPTIONAL\n * }\n *\n * MacData ::= SEQUENCE {\n *   mac DigestInfo,\n *   macSalt OCTET STRING,\n *   iterations INTEGER DEFAULT 1\n * }\n * Note: The iterations default is for historical reasons and its use is\n * deprecated. A higher value, like 1024, is recommended.\n *\n * DigestInfo is defined in PKCS#7 as follows:\n *\n * DigestInfo ::= SEQUENCE {\n *   digestAlgorithm DigestAlgorithmIdentifier,\n *   digest Digest\n * }\n *\n * DigestAlgorithmIdentifier ::= AlgorithmIdentifier\n *\n * The AlgorithmIdentifier contains an Object Identifier (OID) and parameters\n * for the algorithm, if any. In the case of SHA1 there is none.\n *\n * AlgorithmIdentifer ::= SEQUENCE {\n *    algorithm OBJECT IDENTIFIER,\n *    parameters ANY DEFINED BY algorithm OPTIONAL\n * }\n *\n * Digest ::= OCTET STRING\n *\n *\n * ContentInfo ::= SEQUENCE {\n *   contentType ContentType,\n *   content     [0] EXPLICIT ANY DEFINED BY contentType OPTIONAL\n * }\n *\n * ContentType ::= OBJECT IDENTIFIER\n *\n * AuthenticatedSafe ::= SEQUENCE OF ContentInfo\n * -- Data if unencrypted\n * -- EncryptedData if password-encrypted\n * -- EnvelopedData if public key-encrypted\n *\n *\n * SafeContents ::= SEQUENCE OF SafeBag\n *\n * SafeBag ::= SEQUENCE {\n *   bagId     BAG-TYPE.&id ({PKCS12BagSet})\n *   bagValue  [0] EXPLICIT BAG-TYPE.&Type({PKCS12BagSet}{@bagId}),\n *   bagAttributes SET OF PKCS12Attribute OPTIONAL\n * }\n *\n * PKCS12Attribute ::= SEQUENCE {\n *   attrId ATTRIBUTE.&id ({PKCS12AttrSet}),\n *   attrValues SET OF ATTRIBUTE.&Type ({PKCS12AttrSet}{@attrId})\n * } -- This type is compatible with the X.500 type 'Attribute'\n *\n * PKCS12AttrSet ATTRIBUTE ::= {\n *   friendlyName | -- from PKCS #9\n *   localKeyId, -- from PKCS #9\n *   ... -- Other attributes are allowed\n * }\n *\n * CertBag ::= SEQUENCE {\n *   certId    BAG-TYPE.&id   ({CertTypes}),\n *   certValue [0] EXPLICIT BAG-TYPE.&Type ({CertTypes}{@certId})\n * }\n *\n * x509Certificate BAG-TYPE ::= {OCTET STRING IDENTIFIED BY {certTypes 1}}\n *   -- DER-encoded X.509 certificate stored in OCTET STRING\n *\n * sdsiCertificate BAG-TYPE ::= {IA5String IDENTIFIED BY {certTypes 2}}\n * -- Base64-encoded SDSI certificate stored in IA5String\n *\n * CertTypes BAG-TYPE ::= {\n *   x509Certificate |\n *   sdsiCertificate,\n *   ... -- For future extensions\n * }\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./hmac');\nrequire('./oids');\nrequire('./pkcs7asn1');\nrequire('./pbe');\nrequire('./random');\nrequire('./rsa');\nrequire('./sha1');\nrequire('./util');\nrequire('./x509');\n\n// shortcut for asn.1 & PKI API\nvar asn1 = forge.asn1;\nvar pki = forge.pki;\n\n// shortcut for PKCS#12 API\nvar p12 = module.exports = forge.pkcs12 = forge.pkcs12 || {};\n\nvar contentInfoValidator = {\n  name: 'ContentInfo',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,  // a ContentInfo\n  constructed: true,\n  value: [{\n    name: 'ContentInfo.contentType',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OID,\n    constructed: false,\n    capture: 'contentType'\n  }, {\n    name: 'ContentInfo.content',\n    tagClass: asn1.Class.CONTEXT_SPECIFIC,\n    constructed: true,\n    captureAsn1: 'content'\n  }]\n};\n\nvar pfxValidator = {\n  name: 'PFX',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'PFX.version',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.INTEGER,\n    constructed: false,\n    capture: 'version'\n  },\n  contentInfoValidator, {\n    name: 'PFX.macData',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    optional: true,\n    captureAsn1: 'mac',\n    value: [{\n      name: 'PFX.macData.mac',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.SEQUENCE,  // DigestInfo\n      constructed: true,\n      value: [{\n        name: 'PFX.macData.mac.digestAlgorithm',\n        tagClass: asn1.Class.UNIVERSAL,\n        type: asn1.Type.SEQUENCE,  // DigestAlgorithmIdentifier\n        constructed: true,\n        value: [{\n          name: 'PFX.macData.mac.digestAlgorithm.algorithm',\n          tagClass: asn1.Class.UNIVERSAL,\n          type: asn1.Type.OID,\n          constructed: false,\n          capture: 'macAlgorithm'\n        }, {\n          name: 'PFX.macData.mac.digestAlgorithm.parameters',\n          tagClass: asn1.Class.UNIVERSAL,\n          captureAsn1: 'macAlgorithmParameters'\n        }]\n      }, {\n        name: 'PFX.macData.mac.digest',\n        tagClass: asn1.Class.UNIVERSAL,\n        type: asn1.Type.OCTETSTRING,\n        constructed: false,\n        capture: 'macDigest'\n      }]\n    }, {\n      name: 'PFX.macData.macSalt',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OCTETSTRING,\n      constructed: false,\n      capture: 'macSalt'\n    }, {\n      name: 'PFX.macData.iterations',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.INTEGER,\n      constructed: false,\n      optional: true,\n      capture: 'macIterations'\n    }]\n  }]\n};\n\nvar safeBagValidator = {\n  name: 'SafeBag',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'SafeBag.bagId',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OID,\n    constructed: false,\n    capture: 'bagId'\n  }, {\n    name: 'SafeBag.bagValue',\n    tagClass: asn1.Class.CONTEXT_SPECIFIC,\n    constructed: true,\n    captureAsn1: 'bagValue'\n  }, {\n    name: 'SafeBag.bagAttributes',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SET,\n    constructed: true,\n    optional: true,\n    capture: 'bagAttributes'\n  }]\n};\n\nvar attributeValidator = {\n  name: 'Attribute',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'Attribute.attrId',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OID,\n    constructed: false,\n    capture: 'oid'\n  }, {\n    name: 'Attribute.attrValues',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SET,\n    constructed: true,\n    capture: 'values'\n  }]\n};\n\nvar certBagValidator = {\n  name: 'CertBag',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    name: 'CertBag.certId',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OID,\n    constructed: false,\n    capture: 'certId'\n  }, {\n    name: 'CertBag.certValue',\n    tagClass: asn1.Class.CONTEXT_SPECIFIC,\n    constructed: true,\n    /* So far we only support X.509 certificates (which are wrapped in\n       an OCTET STRING, hence hard code that here). */\n    value: [{\n      name: 'CertBag.certValue[0]',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Class.OCTETSTRING,\n      constructed: false,\n      capture: 'cert'\n    }]\n  }]\n};\n\n/**\n * Search SafeContents structure for bags with matching attributes.\n *\n * The search can optionally be narrowed by a certain bag type.\n *\n * @param safeContents the SafeContents structure to search in.\n * @param attrName the name of the attribute to compare against.\n * @param attrValue the attribute value to search for.\n * @param [bagType] bag type to narrow search by.\n *\n * @return an array of matching bags.\n */\nfunction _getBagsByAttribute(safeContents, attrName, attrValue, bagType) {\n  var result = [];\n\n  for(var i = 0; i < safeContents.length; i++) {\n    for(var j = 0; j < safeContents[i].safeBags.length; j++) {\n      var bag = safeContents[i].safeBags[j];\n      if(bagType !== undefined && bag.type !== bagType) {\n        continue;\n      }\n      // only filter by bag type, no attribute specified\n      if(attrName === null) {\n        result.push(bag);\n        continue;\n      }\n      if(bag.attributes[attrName] !== undefined &&\n        bag.attributes[attrName].indexOf(attrValue) >= 0) {\n        result.push(bag);\n      }\n    }\n  }\n\n  return result;\n}\n\n/**\n * Converts a PKCS#12 PFX in ASN.1 notation into a PFX object.\n *\n * @param obj The PKCS#12 PFX in ASN.1 notation.\n * @param strict true to use strict DER decoding, false not to (default: true).\n * @param {String} password Password to decrypt with (optional).\n *\n * @return PKCS#12 PFX object.\n */\np12.pkcs12FromAsn1 = function(obj, strict, password) {\n  // handle args\n  if(typeof strict === 'string') {\n    password = strict;\n    strict = true;\n  } else if(strict === undefined) {\n    strict = true;\n  }\n\n  // validate PFX and capture data\n  var capture = {};\n  var errors = [];\n  if(!asn1.validate(obj, pfxValidator, capture, errors)) {\n    var error = new Error('Cannot read PKCS#12 PFX. ' +\n      'ASN.1 object is not an PKCS#12 PFX.');\n    error.errors = error;\n    throw error;\n  }\n\n  var pfx = {\n    version: capture.version.charCodeAt(0),\n    safeContents: [],\n\n    /**\n     * Gets bags with matching attributes.\n     *\n     * @param filter the attributes to filter by:\n     *          [localKeyId] the localKeyId to search for.\n     *          [localKeyIdHex] the localKeyId in hex to search for.\n     *          [friendlyName] the friendly name to search for.\n     *          [bagType] bag type to narrow each attribute search by.\n     *\n     * @return a map of attribute type to an array of matching bags or, if no\n     *           attribute was given but a bag type, the map key will be the\n     *           bag type.\n     */\n    getBags: function(filter) {\n      var rval = {};\n\n      var localKeyId;\n      if('localKeyId' in filter) {\n        localKeyId = filter.localKeyId;\n      } else if('localKeyIdHex' in filter) {\n        localKeyId = forge.util.hexToBytes(filter.localKeyIdHex);\n      }\n\n      // filter on bagType only\n      if(localKeyId === undefined && !('friendlyName' in filter) &&\n        'bagType' in filter) {\n        rval[filter.bagType] = _getBagsByAttribute(\n          pfx.safeContents, null, null, filter.bagType);\n      }\n\n      if(localKeyId !== undefined) {\n        rval.localKeyId = _getBagsByAttribute(\n          pfx.safeContents, 'localKeyId',\n          localKeyId, filter.bagType);\n      }\n      if('friendlyName' in filter) {\n        rval.friendlyName = _getBagsByAttribute(\n          pfx.safeContents, 'friendlyName',\n          filter.friendlyName, filter.bagType);\n      }\n\n      return rval;\n    },\n\n    /**\n     * DEPRECATED: use getBags() instead.\n     *\n     * Get bags with matching friendlyName attribute.\n     *\n     * @param friendlyName the friendly name to search for.\n     * @param [bagType] bag type to narrow search by.\n     *\n     * @return an array of bags with matching friendlyName attribute.\n     */\n    getBagsByFriendlyName: function(friendlyName, bagType) {\n      return _getBagsByAttribute(\n        pfx.safeContents, 'friendlyName', friendlyName, bagType);\n    },\n\n    /**\n     * DEPRECATED: use getBags() instead.\n     *\n     * Get bags with matching localKeyId attribute.\n     *\n     * @param localKeyId the localKeyId to search for.\n     * @param [bagType] bag type to narrow search by.\n     *\n     * @return an array of bags with matching localKeyId attribute.\n     */\n    getBagsByLocalKeyId: function(localKeyId, bagType) {\n      return _getBagsByAttribute(\n        pfx.safeContents, 'localKeyId', localKeyId, bagType);\n    }\n  };\n\n  if(capture.version.charCodeAt(0) !== 3) {\n    var error = new Error('PKCS#12 PFX of version other than 3 not supported.');\n    error.version = capture.version.charCodeAt(0);\n    throw error;\n  }\n\n  if(asn1.derToOid(capture.contentType) !== pki.oids.data) {\n    var error = new Error('Only PKCS#12 PFX in password integrity mode supported.');\n    error.oid = asn1.derToOid(capture.contentType);\n    throw error;\n  }\n\n  var data = capture.content.value[0];\n  if(data.tagClass !== asn1.Class.UNIVERSAL ||\n     data.type !== asn1.Type.OCTETSTRING) {\n    throw new Error('PKCS#12 authSafe content data is not an OCTET STRING.');\n  }\n  data = _decodePkcs7Data(data);\n\n  // check for MAC\n  if(capture.mac) {\n    var md = null;\n    var macKeyBytes = 0;\n    var macAlgorithm = asn1.derToOid(capture.macAlgorithm);\n    switch(macAlgorithm) {\n    case pki.oids.sha1:\n      md = forge.md.sha1.create();\n      macKeyBytes = 20;\n      break;\n    case pki.oids.sha256:\n      md = forge.md.sha256.create();\n      macKeyBytes = 32;\n      break;\n    case pki.oids.sha384:\n      md = forge.md.sha384.create();\n      macKeyBytes = 48;\n      break;\n    case pki.oids.sha512:\n      md = forge.md.sha512.create();\n      macKeyBytes = 64;\n      break;\n    case pki.oids.md5:\n      md = forge.md.md5.create();\n      macKeyBytes = 16;\n      break;\n    }\n    if(md === null) {\n      throw new Error('PKCS#12 uses unsupported MAC algorithm: ' + macAlgorithm);\n    }\n\n    // verify MAC (iterations default to 1)\n    var macSalt = new forge.util.ByteBuffer(capture.macSalt);\n    var macIterations = (('macIterations' in capture) ?\n      parseInt(forge.util.bytesToHex(capture.macIterations), 16) : 1);\n    var macKey = p12.generateKey(\n      password, macSalt, 3, macIterations, macKeyBytes, md);\n    var mac = forge.hmac.create();\n    mac.start(md, macKey);\n    mac.update(data.value);\n    var macValue = mac.getMac();\n    if(macValue.getBytes() !== capture.macDigest) {\n      throw new Error('PKCS#12 MAC could not be verified. Invalid password?');\n    }\n  }\n\n  _decodeAuthenticatedSafe(pfx, data.value, strict, password);\n  return pfx;\n};\n\n/**\n * Decodes PKCS#7 Data. PKCS#7 (RFC 2315) defines \"Data\" as an OCTET STRING,\n * but it is sometimes an OCTET STRING that is composed/constructed of chunks,\n * each its own OCTET STRING. This is BER-encoding vs. DER-encoding. This\n * function transforms this corner-case into the usual simple,\n * non-composed/constructed OCTET STRING.\n *\n * This function may be moved to ASN.1 at some point to better deal with\n * more BER-encoding issues, should they arise.\n *\n * @param data the ASN.1 Data object to transform.\n */\nfunction _decodePkcs7Data(data) {\n  // handle special case of \"chunked\" data content: an octet string composed\n  // of other octet strings\n  if(data.composed || data.constructed) {\n    var value = forge.util.createBuffer();\n    for(var i = 0; i < data.value.length; ++i) {\n      value.putBytes(data.value[i].value);\n    }\n    data.composed = data.constructed = false;\n    data.value = value.getBytes();\n  }\n  return data;\n}\n\n/**\n * Decode PKCS#12 AuthenticatedSafe (BER encoded) into PFX object.\n *\n * The AuthenticatedSafe is a BER-encoded SEQUENCE OF ContentInfo.\n *\n * @param pfx The PKCS#12 PFX object to fill.\n * @param {String} authSafe BER-encoded AuthenticatedSafe.\n * @param strict true to use strict DER decoding, false not to.\n * @param {String} password Password to decrypt with (optional).\n */\nfunction _decodeAuthenticatedSafe(pfx, authSafe, strict, password) {\n  authSafe = asn1.fromDer(authSafe, strict);  /* actually it's BER encoded */\n\n  if(authSafe.tagClass !== asn1.Class.UNIVERSAL ||\n     authSafe.type !== asn1.Type.SEQUENCE ||\n     authSafe.constructed !== true) {\n    throw new Error('PKCS#12 AuthenticatedSafe expected to be a ' +\n      'SEQUENCE OF ContentInfo');\n  }\n\n  for(var i = 0; i < authSafe.value.length; i++) {\n    var contentInfo = authSafe.value[i];\n\n    // validate contentInfo and capture data\n    var capture = {};\n    var errors = [];\n    if(!asn1.validate(contentInfo, contentInfoValidator, capture, errors)) {\n      var error = new Error('Cannot read ContentInfo.');\n      error.errors = errors;\n      throw error;\n    }\n\n    var obj = {\n      encrypted: false\n    };\n    var safeContents = null;\n    var data = capture.content.value[0];\n    switch(asn1.derToOid(capture.contentType)) {\n    case pki.oids.data:\n      if(data.tagClass !== asn1.Class.UNIVERSAL ||\n         data.type !== asn1.Type.OCTETSTRING) {\n        throw new Error('PKCS#12 SafeContents Data is not an OCTET STRING.');\n      }\n      safeContents = _decodePkcs7Data(data).value;\n      break;\n    case pki.oids.encryptedData:\n      safeContents = _decryptSafeContents(data, password);\n      obj.encrypted = true;\n      break;\n    default:\n      var error = new Error('Unsupported PKCS#12 contentType.');\n      error.contentType = asn1.derToOid(capture.contentType);\n      throw error;\n    }\n\n    obj.safeBags = _decodeSafeContents(safeContents, strict, password);\n    pfx.safeContents.push(obj);\n  }\n}\n\n/**\n * Decrypt PKCS#7 EncryptedData structure.\n *\n * @param data ASN.1 encoded EncryptedContentInfo object.\n * @param password The user-provided password.\n *\n * @return The decrypted SafeContents (ASN.1 object).\n */\nfunction _decryptSafeContents(data, password) {\n  var capture = {};\n  var errors = [];\n  if(!asn1.validate(\n    data, forge.pkcs7.asn1.encryptedDataValidator, capture, errors)) {\n    var error = new Error('Cannot read EncryptedContentInfo.');\n    error.errors = errors;\n    throw error;\n  }\n\n  var oid = asn1.derToOid(capture.contentType);\n  if(oid !== pki.oids.data) {\n    var error = new Error(\n      'PKCS#12 EncryptedContentInfo ContentType is not Data.');\n    error.oid = oid;\n    throw error;\n  }\n\n  // get cipher\n  oid = asn1.derToOid(capture.encAlgorithm);\n  var cipher = pki.pbe.getCipher(oid, capture.encParameter, password);\n\n  // get encrypted data\n  var encryptedContentAsn1 = _decodePkcs7Data(capture.encryptedContentAsn1);\n  var encrypted = forge.util.createBuffer(encryptedContentAsn1.value);\n\n  cipher.update(encrypted);\n  if(!cipher.finish()) {\n    throw new Error('Failed to decrypt PKCS#12 SafeContents.');\n  }\n\n  return cipher.output.getBytes();\n}\n\n/**\n * Decode PKCS#12 SafeContents (BER-encoded) into array of Bag objects.\n *\n * The safeContents is a BER-encoded SEQUENCE OF SafeBag.\n *\n * @param {String} safeContents BER-encoded safeContents.\n * @param strict true to use strict DER decoding, false not to.\n * @param {String} password Password to decrypt with (optional).\n *\n * @return {Array} Array of Bag objects.\n */\nfunction _decodeSafeContents(safeContents, strict, password) {\n  // if strict and no safe contents, return empty safes\n  if(!strict && safeContents.length === 0) {\n    return [];\n  }\n\n  // actually it's BER-encoded\n  safeContents = asn1.fromDer(safeContents, strict);\n\n  if(safeContents.tagClass !== asn1.Class.UNIVERSAL ||\n    safeContents.type !== asn1.Type.SEQUENCE ||\n    safeContents.constructed !== true) {\n    throw new Error(\n      'PKCS#12 SafeContents expected to be a SEQUENCE OF SafeBag.');\n  }\n\n  var res = [];\n  for(var i = 0; i < safeContents.value.length; i++) {\n    var safeBag = safeContents.value[i];\n\n    // validate SafeBag and capture data\n    var capture = {};\n    var errors = [];\n    if(!asn1.validate(safeBag, safeBagValidator, capture, errors)) {\n      var error = new Error('Cannot read SafeBag.');\n      error.errors = errors;\n      throw error;\n    }\n\n    /* Create bag object and push to result array. */\n    var bag = {\n      type: asn1.derToOid(capture.bagId),\n      attributes: _decodeBagAttributes(capture.bagAttributes)\n    };\n    res.push(bag);\n\n    var validator, decoder;\n    var bagAsn1 = capture.bagValue.value[0];\n    switch(bag.type) {\n      case pki.oids.pkcs8ShroudedKeyBag:\n        /* bagAsn1 has a EncryptedPrivateKeyInfo, which we need to decrypt.\n           Afterwards we can handle it like a keyBag,\n           which is a PrivateKeyInfo. */\n        bagAsn1 = pki.decryptPrivateKeyInfo(bagAsn1, password);\n        if(bagAsn1 === null) {\n          throw new Error(\n            'Unable to decrypt PKCS#8 ShroudedKeyBag, wrong password?');\n        }\n\n        /* fall through */\n      case pki.oids.keyBag:\n        /* A PKCS#12 keyBag is a simple PrivateKeyInfo as understood by our\n           PKI module, hence we don't have to do validation/capturing here,\n           just pass what we already got. */\n        try {\n          bag.key = pki.privateKeyFromAsn1(bagAsn1);\n        } catch(e) {\n          // ignore unknown key type, pass asn1 value\n          bag.key = null;\n          bag.asn1 = bagAsn1;\n        }\n        continue;  /* Nothing more to do. */\n\n      case pki.oids.certBag:\n        /* A PKCS#12 certBag can wrap both X.509 and sdsi certificates.\n           Therefore put the SafeBag content through another validator to\n           capture the fields.  Afterwards check & store the results. */\n        validator = certBagValidator;\n        decoder = function() {\n          if(asn1.derToOid(capture.certId) !== pki.oids.x509Certificate) {\n            var error = new Error(\n              'Unsupported certificate type, only X.509 supported.');\n            error.oid = asn1.derToOid(capture.certId);\n            throw error;\n          }\n\n          // true=produce cert hash\n          var certAsn1 = asn1.fromDer(capture.cert, strict);\n          try {\n            bag.cert = pki.certificateFromAsn1(certAsn1, true);\n          } catch(e) {\n            // ignore unknown cert type, pass asn1 value\n            bag.cert = null;\n            bag.asn1 = certAsn1;\n          }\n        };\n        break;\n\n      default:\n        var error = new Error('Unsupported PKCS#12 SafeBag type.');\n        error.oid = bag.type;\n        throw error;\n    }\n\n    /* Validate SafeBag value (i.e. CertBag, etc.) and capture data if needed. */\n    if(validator !== undefined &&\n       !asn1.validate(bagAsn1, validator, capture, errors)) {\n      var error = new Error('Cannot read PKCS#12 ' + validator.name);\n      error.errors = errors;\n      throw error;\n    }\n\n    /* Call decoder function from above to store the results. */\n    decoder();\n  }\n\n  return res;\n}\n\n/**\n * Decode PKCS#12 SET OF PKCS12Attribute into JavaScript object.\n *\n * @param attributes SET OF PKCS12Attribute (ASN.1 object).\n *\n * @return the decoded attributes.\n */\nfunction _decodeBagAttributes(attributes) {\n  var decodedAttrs = {};\n\n  if(attributes !== undefined) {\n    for(var i = 0; i < attributes.length; ++i) {\n      var capture = {};\n      var errors = [];\n      if(!asn1.validate(attributes[i], attributeValidator, capture, errors)) {\n        var error = new Error('Cannot read PKCS#12 BagAttribute.');\n        error.errors = errors;\n        throw error;\n      }\n\n      var oid = asn1.derToOid(capture.oid);\n      if(pki.oids[oid] === undefined) {\n        // unsupported attribute type, ignore.\n        continue;\n      }\n\n      decodedAttrs[pki.oids[oid]] = [];\n      for(var j = 0; j < capture.values.length; ++j) {\n        decodedAttrs[pki.oids[oid]].push(capture.values[j].value);\n      }\n    }\n  }\n\n  return decodedAttrs;\n}\n\n/**\n * Wraps a private key and certificate in a PKCS#12 PFX wrapper. If a\n * password is provided then the private key will be encrypted.\n *\n * An entire certificate chain may also be included. To do this, pass\n * an array for the \"cert\" parameter where the first certificate is\n * the one that is paired with the private key and each subsequent one\n * verifies the previous one. The certificates may be in PEM format or\n * have been already parsed by Forge.\n *\n * @todo implement password-based-encryption for the whole package\n *\n * @param key the private key.\n * @param cert the certificate (may be an array of certificates in order\n *          to specify a certificate chain).\n * @param password the password to use, null for none.\n * @param options:\n *          algorithm the encryption algorithm to use\n *            ('aes128', 'aes192', 'aes256', '3des'), defaults to 'aes128'.\n *          count the iteration count to use.\n *          saltSize the salt size to use.\n *          useMac true to include a MAC, false not to, defaults to true.\n *          localKeyId the local key ID to use, in hex.\n *          friendlyName the friendly name to use.\n *          generateLocalKeyId true to generate a random local key ID,\n *            false not to, defaults to true.\n *\n * @return the PKCS#12 PFX ASN.1 object.\n */\np12.toPkcs12Asn1 = function(key, cert, password, options) {\n  // set default options\n  options = options || {};\n  options.saltSize = options.saltSize || 8;\n  options.count = options.count || 2048;\n  options.algorithm = options.algorithm || options.encAlgorithm || 'aes128';\n  if(!('useMac' in options)) {\n    options.useMac = true;\n  }\n  if(!('localKeyId' in options)) {\n    options.localKeyId = null;\n  }\n  if(!('generateLocalKeyId' in options)) {\n    options.generateLocalKeyId = true;\n  }\n\n  var localKeyId = options.localKeyId;\n  var bagAttrs;\n  if(localKeyId !== null) {\n    localKeyId = forge.util.hexToBytes(localKeyId);\n  } else if(options.generateLocalKeyId) {\n    // use SHA-1 of paired cert, if available\n    if(cert) {\n      var pairedCert = forge.util.isArray(cert) ? cert[0] : cert;\n      if(typeof pairedCert === 'string') {\n        pairedCert = pki.certificateFromPem(pairedCert);\n      }\n      var sha1 = forge.md.sha1.create();\n      sha1.update(asn1.toDer(pki.certificateToAsn1(pairedCert)).getBytes());\n      localKeyId = sha1.digest().getBytes();\n    } else {\n      // FIXME: consider using SHA-1 of public key (which can be generated\n      // from private key components), see: cert.generateSubjectKeyIdentifier\n      // generate random bytes\n      localKeyId = forge.random.getBytes(20);\n    }\n  }\n\n  var attrs = [];\n  if(localKeyId !== null) {\n    attrs.push(\n      // localKeyID\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // attrId\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n          asn1.oidToDer(pki.oids.localKeyId).getBytes()),\n        // attrValues\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n            localKeyId)\n        ])\n      ]));\n  }\n  if('friendlyName' in options) {\n    attrs.push(\n      // friendlyName\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // attrId\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n          asn1.oidToDer(pki.oids.friendlyName).getBytes()),\n        // attrValues\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, [\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.BMPSTRING, false,\n            options.friendlyName)\n        ])\n      ]));\n  }\n\n  if(attrs.length > 0) {\n    bagAttrs = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true, attrs);\n  }\n\n  // collect contents for AuthenticatedSafe\n  var contents = [];\n\n  // create safe bag(s) for certificate chain\n  var chain = [];\n  if(cert !== null) {\n    if(forge.util.isArray(cert)) {\n      chain = cert;\n    } else {\n      chain = [cert];\n    }\n  }\n\n  var certSafeBags = [];\n  for(var i = 0; i < chain.length; ++i) {\n    // convert cert from PEM as necessary\n    cert = chain[i];\n    if(typeof cert === 'string') {\n      cert = pki.certificateFromPem(cert);\n    }\n\n    // SafeBag\n    var certBagAttrs = (i === 0) ? bagAttrs : undefined;\n    var certAsn1 = pki.certificateToAsn1(cert);\n    var certSafeBag =\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // bagId\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n          asn1.oidToDer(pki.oids.certBag).getBytes()),\n        // bagValue\n        asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n          // CertBag\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n            // certId\n            asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n              asn1.oidToDer(pki.oids.x509Certificate).getBytes()),\n            // certValue (x509Certificate)\n            asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n              asn1.create(\n                asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n                asn1.toDer(certAsn1).getBytes())\n            ])])]),\n        // bagAttributes (OPTIONAL)\n        certBagAttrs\n      ]);\n    certSafeBags.push(certSafeBag);\n  }\n\n  if(certSafeBags.length > 0) {\n    // SafeContents\n    var certSafeContents = asn1.create(\n      asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, certSafeBags);\n\n    // ContentInfo\n    var certCI =\n      // PKCS#7 ContentInfo\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // contentType\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n          // OID for the content type is 'data'\n          asn1.oidToDer(pki.oids.data).getBytes()),\n        // content\n        asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n          asn1.create(\n            asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n            asn1.toDer(certSafeContents).getBytes())\n        ])\n      ]);\n    contents.push(certCI);\n  }\n\n  // create safe contents for private key\n  var keyBag = null;\n  if(key !== null) {\n    // SafeBag\n    var pkAsn1 = pki.wrapRsaPrivateKey(pki.privateKeyToAsn1(key));\n    if(password === null) {\n      // no encryption\n      keyBag = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // bagId\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n          asn1.oidToDer(pki.oids.keyBag).getBytes()),\n        // bagValue\n        asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n          // PrivateKeyInfo\n          pkAsn1\n        ]),\n        // bagAttributes (OPTIONAL)\n        bagAttrs\n      ]);\n    } else {\n      // encrypted PrivateKeyInfo\n      keyBag = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // bagId\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n          asn1.oidToDer(pki.oids.pkcs8ShroudedKeyBag).getBytes()),\n        // bagValue\n        asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n          // EncryptedPrivateKeyInfo\n          pki.encryptPrivateKeyInfo(pkAsn1, password, options)\n        ]),\n        // bagAttributes (OPTIONAL)\n        bagAttrs\n      ]);\n    }\n\n    // SafeContents\n    var keySafeContents =\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [keyBag]);\n\n    // ContentInfo\n    var keyCI =\n      // PKCS#7 ContentInfo\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // contentType\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n          // OID for the content type is 'data'\n          asn1.oidToDer(pki.oids.data).getBytes()),\n        // content\n        asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n          asn1.create(\n            asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n            asn1.toDer(keySafeContents).getBytes())\n        ])\n      ]);\n    contents.push(keyCI);\n  }\n\n  // create AuthenticatedSafe by stringing together the contents\n  var safe = asn1.create(\n    asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, contents);\n\n  var macData;\n  if(options.useMac) {\n    // MacData\n    var sha1 = forge.md.sha1.create();\n    var macSalt = new forge.util.ByteBuffer(\n      forge.random.getBytes(options.saltSize));\n    var count = options.count;\n    // 160-bit key\n    var key = p12.generateKey(password, macSalt, 3, count, 20);\n    var mac = forge.hmac.create();\n    mac.start(sha1, key);\n    mac.update(asn1.toDer(safe).getBytes());\n    var macValue = mac.getMac();\n    macData = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n      // mac DigestInfo\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // digestAlgorithm\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n          // algorithm = SHA-1\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n            asn1.oidToDer(pki.oids.sha1).getBytes()),\n          // parameters = Null\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n        ]),\n        // digest\n        asn1.create(\n          asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING,\n          false, macValue.getBytes())\n      ]),\n      // macSalt OCTET STRING\n      asn1.create(\n        asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, macSalt.getBytes()),\n      // iterations INTEGER (XXX: Only support count < 65536)\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n        asn1.integerToDer(count).getBytes()\n      )\n    ]);\n  }\n\n  // PFX\n  return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n    // version (3)\n    asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n      asn1.integerToDer(3).getBytes()),\n    // PKCS#7 ContentInfo\n    asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n      // contentType\n      asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n        // OID for the content type is 'data'\n        asn1.oidToDer(pki.oids.data).getBytes()),\n      // content\n      asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n        asn1.create(\n          asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n          asn1.toDer(safe).getBytes())\n      ])\n    ]),\n    macData\n  ]);\n};\n\n/**\n * Derives a PKCS#12 key.\n *\n * @param password the password to derive the key material from, null or\n *          undefined for none.\n * @param salt the salt, as a ByteBuffer, to use.\n * @param id the PKCS#12 ID byte (1 = key material, 2 = IV, 3 = MAC).\n * @param iter the iteration count.\n * @param n the number of bytes to derive from the password.\n * @param md the message digest to use, defaults to SHA-1.\n *\n * @return a ByteBuffer with the bytes derived from the password.\n */\np12.generateKey = forge.pbe.generatePkcs12Key;\n","/**\n * Javascript implementation of 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 * A Javascript implementation of Transport Layer Security (TLS).\n *\n * @author Dave Longley\n *\n * Copyright (c) 2009-2014 Digital Bazaar, Inc.\n *\n * The TLS Handshake Protocol involves the following steps:\n *\n * - Exchange hello messages to agree on algorithms, exchange random values,\n * and check for session resumption.\n *\n * - Exchange the necessary cryptographic parameters to allow the client and\n * server to agree on a premaster secret.\n *\n * - Exchange certificates and cryptographic information to allow the client\n * and server to authenticate themselves.\n *\n * - Generate a master secret from the premaster secret and exchanged random\n * values.\n *\n * - Provide security parameters to the record layer.\n *\n * - Allow the client and server to verify that their peer has calculated the\n * same security parameters and that the handshake occurred without tampering\n * by an attacker.\n *\n * Up to 4 different messages may be sent during a key exchange. The server\n * certificate, the server key exchange, the client certificate, and the\n * client key exchange.\n *\n * A typical handshake (from the client's perspective).\n *\n * 1. Client sends ClientHello.\n * 2. Client receives ServerHello.\n * 3. Client receives optional Certificate.\n * 4. Client receives optional ServerKeyExchange.\n * 5. Client receives ServerHelloDone.\n * 6. Client sends optional Certificate.\n * 7. Client sends ClientKeyExchange.\n * 8. Client sends optional CertificateVerify.\n * 9. Client sends ChangeCipherSpec.\n * 10. Client sends Finished.\n * 11. Client receives ChangeCipherSpec.\n * 12. Client receives Finished.\n * 13. Client sends/receives application data.\n *\n * To reuse an existing session:\n *\n * 1. Client sends ClientHello with session ID for reuse.\n * 2. Client receives ServerHello with same session ID if reusing.\n * 3. Client receives ChangeCipherSpec message if reusing.\n * 4. Client receives Finished.\n * 5. Client sends ChangeCipherSpec.\n * 6. Client sends Finished.\n *\n * Note: Client ignores HelloRequest if in the middle of a handshake.\n *\n * Record Layer:\n *\n * The record layer fragments information blocks into TLSPlaintext records\n * carrying data in chunks of 2^14 bytes or less. Client message boundaries are\n * not preserved in the record layer (i.e., multiple client messages of the\n * same ContentType MAY be coalesced into a single TLSPlaintext record, or a\n * single message MAY be fragmented across several records).\n *\n * struct {\n *   uint8 major;\n *   uint8 minor;\n * } ProtocolVersion;\n *\n * struct {\n *   ContentType type;\n *   ProtocolVersion version;\n *   uint16 length;\n *   opaque fragment[TLSPlaintext.length];\n * } TLSPlaintext;\n *\n * type:\n *   The higher-level protocol used to process the enclosed fragment.\n *\n * version:\n *   The version of the protocol being employed. TLS Version 1.2 uses version\n *   {3, 3}. TLS Version 1.0 uses version {3, 1}. Note that a client that\n *   supports multiple versions of TLS may not know what version will be\n *   employed before it receives the ServerHello.\n *\n * length:\n *   The length (in bytes) of the following TLSPlaintext.fragment. The length\n *   MUST NOT exceed 2^14 = 16384 bytes.\n *\n * fragment:\n *   The application data. This data is transparent and treated as an\n *   independent block to be dealt with by the higher-level protocol specified\n *   by the type field.\n *\n * Implementations MUST NOT send zero-length fragments of Handshake, Alert, or\n * ChangeCipherSpec content types. Zero-length fragments of Application data\n * MAY be sent as they are potentially useful as a traffic analysis\n * countermeasure.\n *\n * Note: Data of different TLS record layer content types MAY be interleaved.\n * Application data is generally of lower precedence for transmission than\n * other content types. However, records MUST be delivered to the network in\n * the same order as they are protected by the record layer. Recipients MUST\n * receive and process interleaved application layer traffic during handshakes\n * subsequent to the first one on a connection.\n *\n * struct {\n *   ContentType type;       // same as TLSPlaintext.type\n *   ProtocolVersion version;// same as TLSPlaintext.version\n *   uint16 length;\n *   opaque fragment[TLSCompressed.length];\n * } TLSCompressed;\n *\n * length:\n *   The length (in bytes) of the following TLSCompressed.fragment.\n *   The length MUST NOT exceed 2^14 + 1024.\n *\n * fragment:\n *   The compressed form of TLSPlaintext.fragment.\n *\n * Note: A CompressionMethod.null operation is an identity operation; no fields\n * are altered. In this implementation, since no compression is supported,\n * uncompressed records are always the same as compressed records.\n *\n * Encryption Information:\n *\n * The encryption and MAC functions translate a TLSCompressed structure into a\n * TLSCiphertext. The decryption functions reverse the process. The MAC of the\n * record also includes a sequence number so that missing, extra, or repeated\n * messages are detectable.\n *\n * struct {\n *   ContentType type;\n *   ProtocolVersion version;\n *   uint16 length;\n *   select (SecurityParameters.cipher_type) {\n *     case stream: GenericStreamCipher;\n *     case block:  GenericBlockCipher;\n *     case aead:   GenericAEADCipher;\n *   } fragment;\n * } TLSCiphertext;\n *\n * type:\n *   The type field is identical to TLSCompressed.type.\n *\n * version:\n *   The version field is identical to TLSCompressed.version.\n *\n * length:\n *   The length (in bytes) of the following TLSCiphertext.fragment.\n *   The length MUST NOT exceed 2^14 + 2048.\n *\n * fragment:\n *   The encrypted form of TLSCompressed.fragment, with the MAC.\n *\n * Note: Only CBC Block Ciphers are supported by this implementation.\n *\n * The TLSCompressed.fragment structures are converted to/from block\n * TLSCiphertext.fragment structures.\n *\n * struct {\n *   opaque IV[SecurityParameters.record_iv_length];\n *   block-ciphered struct {\n *     opaque content[TLSCompressed.length];\n *     opaque MAC[SecurityParameters.mac_length];\n *     uint8 padding[GenericBlockCipher.padding_length];\n *     uint8 padding_length;\n *   };\n * } GenericBlockCipher;\n *\n * The MAC is generated as described in Section 6.2.3.1.\n *\n * IV:\n *   The Initialization Vector (IV) SHOULD be chosen at random, and MUST be\n *   unpredictable. Note that in versions of TLS prior to 1.1, there was no\n *   IV field, and the last ciphertext block of the previous record (the \"CBC\n *   residue\") was used as the IV. This was changed to prevent the attacks\n *   described in [CBCATT]. For block ciphers, the IV length is of length\n *   SecurityParameters.record_iv_length, which is equal to the\n *   SecurityParameters.block_size.\n *\n * padding:\n *   Padding that is added to force the length of the plaintext to be an\n *   integral multiple of the block cipher's block length. The padding MAY be\n *   any length up to 255 bytes, as long as it results in the\n *   TLSCiphertext.length being an integral multiple of the block length.\n *   Lengths longer than necessary might be desirable to frustrate attacks on\n *   a protocol that are based on analysis of the lengths of exchanged\n *   messages. Each uint8 in the padding data vector MUST be filled with the\n *   padding length value. The receiver MUST check this padding and MUST use\n *   the bad_record_mac alert to indicate padding errors.\n *\n * padding_length:\n *   The padding length MUST be such that the total size of the\n *   GenericBlockCipher structure is a multiple of the cipher's block length.\n *   Legal values range from zero to 255, inclusive. This length specifies the\n *   length of the padding field exclusive of the padding_length field itself.\n *\n * The encrypted data length (TLSCiphertext.length) is one more than the sum of\n * SecurityParameters.block_length, TLSCompressed.length,\n * SecurityParameters.mac_length, and padding_length.\n *\n * Example: If the block length is 8 bytes, the content length\n * (TLSCompressed.length) is 61 bytes, and the MAC length is 20 bytes, then the\n * length before padding is 82 bytes (this does not include the IV. Thus, the\n * padding length modulo 8 must be equal to 6 in order to make the total length\n * an even multiple of 8 bytes (the block length). The padding length can be\n * 6, 14, 22, and so on, through 254. If the padding length were the minimum\n * necessary, 6, the padding would be 6 bytes, each containing the value 6.\n * Thus, the last 8 octets of the GenericBlockCipher before block encryption\n * would be xx 06 06 06 06 06 06 06, where xx is the last octet of the MAC.\n *\n * Note: With block ciphers in CBC mode (Cipher Block Chaining), it is critical\n * that the entire plaintext of the record be known before any ciphertext is\n * transmitted. Otherwise, it is possible for the attacker to mount the attack\n * described in [CBCATT].\n *\n * Implementation note: Canvel et al. [CBCTIME] have demonstrated a timing\n * attack on CBC padding based on the time required to compute the MAC. In\n * order to defend against this attack, implementations MUST ensure that\n * record processing time is essentially the same whether or not the padding\n * is correct. In general, the best way to do this is to compute the MAC even\n * if the padding is incorrect, and only then reject the packet. For instance,\n * if the pad appears to be incorrect, the implementation might assume a\n * zero-length pad and then compute the MAC. This leaves a small timing\n * channel, since MAC performance depends, to some extent, on the size of the\n * data fragment, but it is not believed to be large enough to be exploitable,\n * due to the large block size of existing MACs and the small size of the\n * timing signal.\n */\nvar forge = require('./forge');\nrequire('./asn1');\nrequire('./hmac');\nrequire('./md5');\nrequire('./pem');\nrequire('./pki');\nrequire('./random');\nrequire('./sha1');\nrequire('./util');\n\n/**\n * Generates pseudo random bytes by mixing the result of two hash functions,\n * MD5 and SHA-1.\n *\n * prf_TLS1(secret, label, seed) =\n *   P_MD5(S1, label + seed) XOR P_SHA-1(S2, label + seed);\n *\n * Each P_hash function functions as follows:\n *\n * P_hash(secret, seed) = HMAC_hash(secret, A(1) + seed) +\n *                        HMAC_hash(secret, A(2) + seed) +\n *                        HMAC_hash(secret, A(3) + seed) + ...\n * A() is defined as:\n *   A(0) = seed\n *   A(i) = HMAC_hash(secret, A(i-1))\n *\n * The '+' operator denotes concatenation.\n *\n * As many iterations A(N) as are needed are performed to generate enough\n * pseudo random byte output. If an iteration creates more data than is\n * necessary, then it is truncated.\n *\n * Therefore:\n * A(1) = HMAC_hash(secret, A(0))\n *      = HMAC_hash(secret, seed)\n * A(2) = HMAC_hash(secret, A(1))\n *      = HMAC_hash(secret, HMAC_hash(secret, seed))\n *\n * Therefore:\n * P_hash(secret, seed) =\n *   HMAC_hash(secret, HMAC_hash(secret, A(0)) + seed) +\n *   HMAC_hash(secret, HMAC_hash(secret, A(1)) + seed) +\n *   ...\n *\n * Therefore:\n * P_hash(secret, seed) =\n *   HMAC_hash(secret, HMAC_hash(secret, seed) + seed) +\n *   HMAC_hash(secret, HMAC_hash(secret, HMAC_hash(secret, seed)) + seed) +\n *   ...\n *\n * @param secret the secret to use.\n * @param label the label to use.\n * @param seed the seed value to use.\n * @param length the number of bytes to generate.\n *\n * @return the pseudo random bytes in a byte buffer.\n */\nvar prf_TLS1 = function(secret, label, seed, length) {\n  var rval = forge.util.createBuffer();\n\n  /* For TLS 1.0, the secret is split in half, into two secrets of equal\n    length. If the secret has an odd length then the last byte of the first\n    half will be the same as the first byte of the second. The length of the\n    two secrets is half of the secret rounded up. */\n  var idx = (secret.length >> 1);\n  var slen = idx + (secret.length & 1);\n  var s1 = secret.substr(0, slen);\n  var s2 = secret.substr(idx, slen);\n  var ai = forge.util.createBuffer();\n  var hmac = forge.hmac.create();\n  seed = label + seed;\n\n  // determine the number of iterations that must be performed to generate\n  // enough output bytes, md5 creates 16 byte hashes, sha1 creates 20\n  var md5itr = Math.ceil(length / 16);\n  var sha1itr = Math.ceil(length / 20);\n\n  // do md5 iterations\n  hmac.start('MD5', s1);\n  var md5bytes = forge.util.createBuffer();\n  ai.putBytes(seed);\n  for(var i = 0; i < md5itr; ++i) {\n    // HMAC_hash(secret, A(i-1))\n    hmac.start(null, null);\n    hmac.update(ai.getBytes());\n    ai.putBuffer(hmac.digest());\n\n    // HMAC_hash(secret, A(i) + seed)\n    hmac.start(null, null);\n    hmac.update(ai.bytes() + seed);\n    md5bytes.putBuffer(hmac.digest());\n  }\n\n  // do sha1 iterations\n  hmac.start('SHA1', s2);\n  var sha1bytes = forge.util.createBuffer();\n  ai.clear();\n  ai.putBytes(seed);\n  for(var i = 0; i < sha1itr; ++i) {\n    // HMAC_hash(secret, A(i-1))\n    hmac.start(null, null);\n    hmac.update(ai.getBytes());\n    ai.putBuffer(hmac.digest());\n\n    // HMAC_hash(secret, A(i) + seed)\n    hmac.start(null, null);\n    hmac.update(ai.bytes() + seed);\n    sha1bytes.putBuffer(hmac.digest());\n  }\n\n  // XOR the md5 bytes with the sha1 bytes\n  rval.putBytes(forge.util.xorBytes(\n    md5bytes.getBytes(), sha1bytes.getBytes(), length));\n\n  return rval;\n};\n\n/**\n * Generates pseudo random bytes using a SHA256 algorithm. For TLS 1.2.\n *\n * @param secret the secret to use.\n * @param label the label to use.\n * @param seed the seed value to use.\n * @param length the number of bytes to generate.\n *\n * @return the pseudo random bytes in a byte buffer.\n */\nvar prf_sha256 = function(secret, label, seed, length) {\n   // FIXME: implement me for TLS 1.2\n};\n\n/**\n * Gets a MAC for a record using the SHA-1 hash algorithm.\n *\n * @param key the mac key.\n * @param state the sequence number (array of two 32-bit integers).\n * @param record the record.\n *\n * @return the sha-1 hash (20 bytes) for the given record.\n */\nvar hmac_sha1 = function(key, seqNum, record) {\n  /* MAC is computed like so:\n  HMAC_hash(\n    key, seqNum +\n      TLSCompressed.type +\n      TLSCompressed.version +\n      TLSCompressed.length +\n      TLSCompressed.fragment)\n  */\n  var hmac = forge.hmac.create();\n  hmac.start('SHA1', key);\n  var b = forge.util.createBuffer();\n  b.putInt32(seqNum[0]);\n  b.putInt32(seqNum[1]);\n  b.putByte(record.type);\n  b.putByte(record.version.major);\n  b.putByte(record.version.minor);\n  b.putInt16(record.length);\n  b.putBytes(record.fragment.bytes());\n  hmac.update(b.getBytes());\n  return hmac.digest().getBytes();\n};\n\n/**\n * Compresses the TLSPlaintext record into a TLSCompressed record using the\n * deflate algorithm.\n *\n * @param c the TLS connection.\n * @param record the TLSPlaintext record to compress.\n * @param s the ConnectionState to use.\n *\n * @return true on success, false on failure.\n */\nvar deflate = function(c, record, s) {\n  var rval = false;\n\n  try {\n    var bytes = c.deflate(record.fragment.getBytes());\n    record.fragment = forge.util.createBuffer(bytes);\n    record.length = bytes.length;\n    rval = true;\n  } catch(ex) {\n    // deflate error, fail out\n  }\n\n  return rval;\n};\n\n/**\n * Decompresses the TLSCompressed record into a TLSPlaintext record using the\n * deflate algorithm.\n *\n * @param c the TLS connection.\n * @param record the TLSCompressed record to decompress.\n * @param s the ConnectionState to use.\n *\n * @return true on success, false on failure.\n */\nvar inflate = function(c, record, s) {\n  var rval = false;\n\n  try {\n    var bytes = c.inflate(record.fragment.getBytes());\n    record.fragment = forge.util.createBuffer(bytes);\n    record.length = bytes.length;\n    rval = true;\n  } catch(ex) {\n    // inflate error, fail out\n  }\n\n  return rval;\n};\n\n/**\n * Reads a TLS variable-length vector from a byte buffer.\n *\n * Variable-length vectors are defined by specifying a subrange of legal\n * lengths, inclusively, using the notation <floor..ceiling>. When these are\n * encoded, the actual length precedes the vector's contents in the byte\n * stream. The length will be in the form of a number consuming as many bytes\n * as required to hold the vector's specified maximum (ceiling) length. A\n * variable-length vector with an actual length field of zero is referred to\n * as an empty vector.\n *\n * @param b the byte buffer.\n * @param lenBytes the number of bytes required to store the length.\n *\n * @return the resulting byte buffer.\n */\nvar readVector = function(b, lenBytes) {\n  var len = 0;\n  switch(lenBytes) {\n  case 1:\n    len = b.getByte();\n    break;\n  case 2:\n    len = b.getInt16();\n    break;\n  case 3:\n    len = b.getInt24();\n    break;\n  case 4:\n    len = b.getInt32();\n    break;\n  }\n\n  // read vector bytes into a new buffer\n  return forge.util.createBuffer(b.getBytes(len));\n};\n\n/**\n * Writes a TLS variable-length vector to a byte buffer.\n *\n * @param b the byte buffer.\n * @param lenBytes the number of bytes required to store the length.\n * @param v the byte buffer vector.\n */\nvar writeVector = function(b, lenBytes, v) {\n  // encode length at the start of the vector, where the number of bytes for\n  // the length is the maximum number of bytes it would take to encode the\n  // vector's ceiling\n  b.putInt(v.length(), lenBytes << 3);\n  b.putBuffer(v);\n};\n\n/**\n * The tls implementation.\n */\nvar tls = {};\n\n/**\n * Version: TLS 1.2 = 3.3, TLS 1.1 = 3.2, TLS 1.0 = 3.1. Both TLS 1.1 and\n * TLS 1.2 were still too new (ie: openSSL didn't implement them) at the time\n * of this implementation so TLS 1.0 was implemented instead.\n */\ntls.Versions = {\n  TLS_1_0: {major: 3, minor: 1},\n  TLS_1_1: {major: 3, minor: 2},\n  TLS_1_2: {major: 3, minor: 3}\n};\ntls.SupportedVersions = [\n  tls.Versions.TLS_1_1,\n  tls.Versions.TLS_1_0\n];\ntls.Version = tls.SupportedVersions[0];\n\n/**\n * Maximum fragment size. True maximum is 16384, but we fragment before that\n * to allow for unusual small increases during compression.\n */\ntls.MaxFragment = 16384 - 1024;\n\n/**\n * Whether this entity is considered the \"client\" or \"server\".\n * enum { server, client } ConnectionEnd;\n */\ntls.ConnectionEnd = {\n  server: 0,\n  client: 1\n};\n\n/**\n * Pseudo-random function algorithm used to generate keys from the master\n * secret.\n * enum { tls_prf_sha256 } PRFAlgorithm;\n */\ntls.PRFAlgorithm = {\n  tls_prf_sha256: 0\n};\n\n/**\n * Bulk encryption algorithms.\n * enum { null, rc4, des3, aes } BulkCipherAlgorithm;\n */\ntls.BulkCipherAlgorithm = {\n  none: null,\n  rc4: 0,\n  des3: 1,\n  aes: 2\n};\n\n/**\n * Cipher types.\n * enum { stream, block, aead } CipherType;\n */\ntls.CipherType = {\n  stream: 0,\n  block: 1,\n  aead: 2\n};\n\n/**\n * MAC (Message Authentication Code) algorithms.\n * enum { null, hmac_md5, hmac_sha1, hmac_sha256,\n *   hmac_sha384, hmac_sha512} MACAlgorithm;\n */\ntls.MACAlgorithm = {\n  none: null,\n  hmac_md5: 0,\n  hmac_sha1: 1,\n  hmac_sha256: 2,\n  hmac_sha384: 3,\n  hmac_sha512: 4\n};\n\n/**\n * Compression algorithms.\n * enum { null(0), deflate(1), (255) } CompressionMethod;\n */\ntls.CompressionMethod = {\n  none: 0,\n  deflate: 1\n};\n\n/**\n * TLS record content types.\n * enum {\n *   change_cipher_spec(20), alert(21), handshake(22),\n *   application_data(23), (255)\n * } ContentType;\n */\ntls.ContentType = {\n  change_cipher_spec: 20,\n  alert: 21,\n  handshake: 22,\n  application_data: 23,\n  heartbeat: 24\n};\n\n/**\n * TLS handshake types.\n * enum {\n *   hello_request(0), client_hello(1), server_hello(2),\n *   certificate(11), server_key_exchange (12),\n *   certificate_request(13), server_hello_done(14),\n *   certificate_verify(15), client_key_exchange(16),\n *   finished(20), (255)\n * } HandshakeType;\n */\ntls.HandshakeType = {\n  hello_request: 0,\n  client_hello: 1,\n  server_hello: 2,\n  certificate: 11,\n  server_key_exchange: 12,\n  certificate_request: 13,\n  server_hello_done: 14,\n  certificate_verify: 15,\n  client_key_exchange: 16,\n  finished: 20\n};\n\n/**\n * TLS Alert Protocol.\n *\n * enum { warning(1), fatal(2), (255) } AlertLevel;\n *\n * enum {\n *   close_notify(0),\n *   unexpected_message(10),\n *   bad_record_mac(20),\n *   decryption_failed(21),\n *   record_overflow(22),\n *   decompression_failure(30),\n *   handshake_failure(40),\n *   bad_certificate(42),\n *   unsupported_certificate(43),\n *   certificate_revoked(44),\n *   certificate_expired(45),\n *   certificate_unknown(46),\n *   illegal_parameter(47),\n *   unknown_ca(48),\n *   access_denied(49),\n *   decode_error(50),\n *   decrypt_error(51),\n *   export_restriction(60),\n *   protocol_version(70),\n *   insufficient_security(71),\n *   internal_error(80),\n *   user_canceled(90),\n *   no_renegotiation(100),\n *   (255)\n * } AlertDescription;\n *\n * struct {\n *   AlertLevel level;\n *   AlertDescription description;\n * } Alert;\n */\ntls.Alert = {};\ntls.Alert.Level = {\n  warning: 1,\n  fatal: 2\n};\ntls.Alert.Description = {\n  close_notify: 0,\n  unexpected_message: 10,\n  bad_record_mac: 20,\n  decryption_failed: 21,\n  record_overflow: 22,\n  decompression_failure: 30,\n  handshake_failure: 40,\n  bad_certificate: 42,\n  unsupported_certificate: 43,\n  certificate_revoked: 44,\n  certificate_expired: 45,\n  certificate_unknown: 46,\n  illegal_parameter: 47,\n  unknown_ca: 48,\n  access_denied: 49,\n  decode_error: 50,\n  decrypt_error: 51,\n  export_restriction: 60,\n  protocol_version: 70,\n  insufficient_security: 71,\n  internal_error: 80,\n  user_canceled: 90,\n  no_renegotiation: 100\n};\n\n/**\n * TLS Heartbeat Message types.\n * enum {\n *   heartbeat_request(1),\n *   heartbeat_response(2),\n *   (255)\n * } HeartbeatMessageType;\n */\ntls.HeartbeatMessageType = {\n  heartbeat_request: 1,\n  heartbeat_response: 2\n};\n\n/**\n * Supported cipher suites.\n */\ntls.CipherSuites = {};\n\n/**\n * Gets a supported cipher suite from its 2 byte ID.\n *\n * @param twoBytes two bytes in a string.\n *\n * @return the matching supported cipher suite or null.\n */\ntls.getCipherSuite = function(twoBytes) {\n  var rval = null;\n  for(var key in tls.CipherSuites) {\n    var cs = tls.CipherSuites[key];\n    if(cs.id[0] === twoBytes.charCodeAt(0) &&\n      cs.id[1] === twoBytes.charCodeAt(1)) {\n      rval = cs;\n      break;\n    }\n  }\n  return rval;\n};\n\n/**\n * Called when an unexpected record is encountered.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleUnexpected = function(c, record) {\n  // if connection is client and closed, ignore unexpected messages\n  var ignore = (!c.open && c.entity === tls.ConnectionEnd.client);\n  if(!ignore) {\n    c.error(c, {\n      message: 'Unexpected message. Received TLS record out of order.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.unexpected_message\n      }\n    });\n  }\n};\n\n/**\n * Called when a client receives a HelloRequest record.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleHelloRequest = function(c, record, length) {\n  // ignore renegotiation requests from the server during a handshake, but\n  // if handshaking, send a warning alert that renegotation is denied\n  if(!c.handshaking && c.handshakes > 0) {\n    // send alert warning\n    tls.queue(c, tls.createAlert(c, {\n       level: tls.Alert.Level.warning,\n       description: tls.Alert.Description.no_renegotiation\n    }));\n    tls.flush(c);\n  }\n\n  // continue\n  c.process();\n};\n\n/**\n * Parses a hello message from a ClientHello or ServerHello record.\n *\n * @param record the record to parse.\n *\n * @return the parsed message.\n */\ntls.parseHelloMessage = function(c, record, length) {\n  var msg = null;\n\n  var client = (c.entity === tls.ConnectionEnd.client);\n\n  // minimum of 38 bytes in message\n  if(length < 38) {\n    c.error(c, {\n      message: client ?\n        'Invalid ServerHello message. Message too short.' :\n        'Invalid ClientHello message. Message too short.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.illegal_parameter\n      }\n    });\n  } else {\n    // use 'remaining' to calculate # of remaining bytes in the message\n    var b = record.fragment;\n    var remaining = b.length();\n    msg = {\n      version: {\n        major: b.getByte(),\n        minor: b.getByte()\n      },\n      random: forge.util.createBuffer(b.getBytes(32)),\n      session_id: readVector(b, 1),\n      extensions: []\n    };\n    if(client) {\n      msg.cipher_suite = b.getBytes(2);\n      msg.compression_method = b.getByte();\n    } else {\n      msg.cipher_suites = readVector(b, 2);\n      msg.compression_methods = readVector(b, 1);\n    }\n\n    // read extensions if there are any bytes left in the message\n    remaining = length - (remaining - b.length());\n    if(remaining > 0) {\n      // parse extensions\n      var exts = readVector(b, 2);\n      while(exts.length() > 0) {\n        msg.extensions.push({\n          type: [exts.getByte(), exts.getByte()],\n          data: readVector(exts, 2)\n        });\n      }\n\n      // TODO: make extension support modular\n      if(!client) {\n        for(var i = 0; i < msg.extensions.length; ++i) {\n          var ext = msg.extensions[i];\n\n          // support SNI extension\n          if(ext.type[0] === 0x00 && ext.type[1] === 0x00) {\n            // get server name list\n            var snl = readVector(ext.data, 2);\n            while(snl.length() > 0) {\n              // read server name type\n              var snType = snl.getByte();\n\n              // only HostName type (0x00) is known, break out if\n              // another type is detected\n              if(snType !== 0x00) {\n                break;\n              }\n\n              // add host name to server name list\n              c.session.extensions.server_name.serverNameList.push(\n                readVector(snl, 2).getBytes());\n            }\n          }\n        }\n      }\n    }\n\n    // version already set, do not allow version change\n    if(c.session.version) {\n      if(msg.version.major !== c.session.version.major ||\n        msg.version.minor !== c.session.version.minor) {\n        return c.error(c, {\n          message: 'TLS version change is disallowed during renegotiation.',\n          send: true,\n          alert: {\n            level: tls.Alert.Level.fatal,\n            description: tls.Alert.Description.protocol_version\n          }\n        });\n      }\n    }\n\n    // get the chosen (ServerHello) cipher suite\n    if(client) {\n      // FIXME: should be checking configured acceptable cipher suites\n      c.session.cipherSuite = tls.getCipherSuite(msg.cipher_suite);\n    } else {\n      // get a supported preferred (ClientHello) cipher suite\n      // choose the first supported cipher suite\n      var tmp = forge.util.createBuffer(msg.cipher_suites.bytes());\n      while(tmp.length() > 0) {\n        // FIXME: should be checking configured acceptable suites\n        // cipher suites take up 2 bytes\n        c.session.cipherSuite = tls.getCipherSuite(tmp.getBytes(2));\n        if(c.session.cipherSuite !== null) {\n          break;\n        }\n      }\n    }\n\n    // cipher suite not supported\n    if(c.session.cipherSuite === null) {\n      return c.error(c, {\n        message: 'No cipher suites in common.',\n        send: true,\n        alert: {\n          level: tls.Alert.Level.fatal,\n          description: tls.Alert.Description.handshake_failure\n        },\n        cipherSuite: forge.util.bytesToHex(msg.cipher_suite)\n      });\n    }\n\n    // TODO: handle compression methods\n    if(client) {\n      c.session.compressionMethod = msg.compression_method;\n    } else {\n      // no compression\n      c.session.compressionMethod = tls.CompressionMethod.none;\n    }\n  }\n\n  return msg;\n};\n\n/**\n * Creates security parameters for the given connection based on the given\n * hello message.\n *\n * @param c the TLS connection.\n * @param msg the hello message.\n */\ntls.createSecurityParameters = function(c, msg) {\n  /* Note: security params are from TLS 1.2, some values like prf_algorithm\n  are ignored for TLS 1.0/1.1 and the builtin as specified in the spec is\n  used. */\n\n  // TODO: handle other options from server when more supported\n\n  // get client and server randoms\n  var client = (c.entity === tls.ConnectionEnd.client);\n  var msgRandom = msg.random.bytes();\n  var cRandom = client ? c.session.sp.client_random : msgRandom;\n  var sRandom = client ? msgRandom : tls.createRandom().getBytes();\n\n  // create new security parameters\n  c.session.sp = {\n    entity: c.entity,\n    prf_algorithm: tls.PRFAlgorithm.tls_prf_sha256,\n    bulk_cipher_algorithm: null,\n    cipher_type: null,\n    enc_key_length: null,\n    block_length: null,\n    fixed_iv_length: null,\n    record_iv_length: null,\n    mac_algorithm: null,\n    mac_length: null,\n    mac_key_length: null,\n    compression_algorithm: c.session.compressionMethod,\n    pre_master_secret: null,\n    master_secret: null,\n    client_random: cRandom,\n    server_random: sRandom\n  };\n};\n\n/**\n * Called when a client receives a ServerHello record.\n *\n * When a ServerHello message will be sent:\n *   The server will send this message in response to a client hello message\n *   when it was able to find an acceptable set of algorithms. If it cannot\n *   find such a match, it will respond with a handshake failure alert.\n *\n * uint24 length;\n * struct {\n *   ProtocolVersion server_version;\n *   Random random;\n *   SessionID session_id;\n *   CipherSuite cipher_suite;\n *   CompressionMethod compression_method;\n *   select(extensions_present) {\n *     case false:\n *       struct {};\n *     case true:\n *       Extension extensions<0..2^16-1>;\n *   };\n * } ServerHello;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleServerHello = function(c, record, length) {\n  var msg = tls.parseHelloMessage(c, record, length);\n  if(c.fail) {\n    return;\n  }\n\n  // ensure server version is compatible\n  if(msg.version.minor <= c.version.minor) {\n    c.version.minor = msg.version.minor;\n  } else {\n    return c.error(c, {\n      message: 'Incompatible TLS version.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.protocol_version\n      }\n    });\n  }\n\n  // indicate session version has been set\n  c.session.version = c.version;\n\n  // get the session ID from the message\n  var sessionId = msg.session_id.bytes();\n\n  // if the session ID is not blank and matches the cached one, resume\n  // the session\n  if(sessionId.length > 0 && sessionId === c.session.id) {\n    // resuming session, expect a ChangeCipherSpec next\n    c.expect = SCC;\n    c.session.resuming = true;\n\n    // get new server random\n    c.session.sp.server_random = msg.random.bytes();\n  } else {\n    // not resuming, expect a server Certificate message next\n    c.expect = SCE;\n    c.session.resuming = false;\n\n    // create new security parameters\n    tls.createSecurityParameters(c, msg);\n  }\n\n  // set new session ID\n  c.session.id = sessionId;\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a server receives a ClientHello record.\n *\n * When a ClientHello message will be sent:\n *   When a client first connects to a server it is required to send the\n *   client hello as its first message. The client can also send a client\n *   hello in response to a hello request or on its own initiative in order\n *   to renegotiate the security parameters in an existing connection.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleClientHello = function(c, record, length) {\n  var msg = tls.parseHelloMessage(c, record, length);\n  if(c.fail) {\n    return;\n  }\n\n  // get the session ID from the message\n  var sessionId = msg.session_id.bytes();\n\n  // see if the given session ID is in the cache\n  var session = null;\n  if(c.sessionCache) {\n    session = c.sessionCache.getSession(sessionId);\n    if(session === null) {\n      // session ID not found\n      sessionId = '';\n    } else if(session.version.major !== msg.version.major ||\n      session.version.minor > msg.version.minor) {\n      // if session version is incompatible with client version, do not resume\n      session = null;\n      sessionId = '';\n    }\n  }\n\n  // no session found to resume, generate a new session ID\n  if(sessionId.length === 0) {\n    sessionId = forge.random.getBytes(32);\n  }\n\n  // update session\n  c.session.id = sessionId;\n  c.session.clientHelloVersion = msg.version;\n  c.session.sp = {};\n  if(session) {\n    // use version and security parameters from resumed session\n    c.version = c.session.version = session.version;\n    c.session.sp = session.sp;\n  } else {\n    // use highest compatible minor version\n    var version;\n    for(var i = 1; i < tls.SupportedVersions.length; ++i) {\n      version = tls.SupportedVersions[i];\n      if(version.minor <= msg.version.minor) {\n        break;\n      }\n    }\n    c.version = {major: version.major, minor: version.minor};\n    c.session.version = c.version;\n  }\n\n  // if a session is set, resume it\n  if(session !== null) {\n    // resuming session, expect a ChangeCipherSpec next\n    c.expect = CCC;\n    c.session.resuming = true;\n\n    // get new client random\n    c.session.sp.client_random = msg.random.bytes();\n  } else {\n    // not resuming, expect a Certificate or ClientKeyExchange\n    c.expect = (c.verifyClient !== false) ? CCE : CKE;\n    c.session.resuming = false;\n\n    // create new security parameters\n    tls.createSecurityParameters(c, msg);\n  }\n\n  // connection now open\n  c.open = true;\n\n  // queue server hello\n  tls.queue(c, tls.createRecord(c, {\n    type: tls.ContentType.handshake,\n    data: tls.createServerHello(c)\n  }));\n\n  if(c.session.resuming) {\n    // queue change cipher spec message\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.change_cipher_spec,\n      data: tls.createChangeCipherSpec()\n    }));\n\n    // create pending state\n    c.state.pending = tls.createConnectionState(c);\n\n    // change current write state to pending write state\n    c.state.current.write = c.state.pending.write;\n\n    // queue finished\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.handshake,\n      data: tls.createFinished(c)\n    }));\n  } else {\n    // queue server certificate\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.handshake,\n      data: tls.createCertificate(c)\n    }));\n\n    if(!c.fail) {\n      // queue server key exchange\n      tls.queue(c, tls.createRecord(c, {\n        type: tls.ContentType.handshake,\n        data: tls.createServerKeyExchange(c)\n      }));\n\n      // request client certificate if set\n      if(c.verifyClient !== false) {\n        // queue certificate request\n        tls.queue(c, tls.createRecord(c, {\n          type: tls.ContentType.handshake,\n          data: tls.createCertificateRequest(c)\n        }));\n      }\n\n      // queue server hello done\n      tls.queue(c, tls.createRecord(c, {\n        type: tls.ContentType.handshake,\n        data: tls.createServerHelloDone(c)\n      }));\n    }\n  }\n\n  // send records\n  tls.flush(c);\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a client receives a Certificate record.\n *\n * When this message will be sent:\n *   The server must send a certificate whenever the agreed-upon key exchange\n *   method is not an anonymous one. This message will always immediately\n *   follow the server hello message.\n *\n * Meaning of this message:\n *   The certificate type must be appropriate for the selected cipher suite's\n *   key exchange algorithm, and is generally an X.509v3 certificate. It must\n *   contain a key which matches the key exchange method, as follows. Unless\n *   otherwise specified, the signing algorithm for the certificate must be\n *   the same as the algorithm for the certificate key. Unless otherwise\n *   specified, the public key may be of any length.\n *\n * opaque ASN.1Cert<1..2^24-1>;\n * struct {\n *   ASN.1Cert certificate_list<1..2^24-1>;\n * } Certificate;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleCertificate = function(c, record, length) {\n  // minimum of 3 bytes in message\n  if(length < 3) {\n    return c.error(c, {\n      message: 'Invalid Certificate message. Message too short.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.illegal_parameter\n      }\n    });\n  }\n\n  var b = record.fragment;\n  var msg = {\n    certificate_list: readVector(b, 3)\n  };\n\n  /* The sender's certificate will be first in the list (chain), each\n    subsequent one that follows will certify the previous one, but root\n    certificates (self-signed) that specify the certificate authority may\n    be omitted under the assumption that clients must already possess it. */\n  var cert, asn1;\n  var certs = [];\n  try {\n    while(msg.certificate_list.length() > 0) {\n      // each entry in msg.certificate_list is a vector with 3 len bytes\n      cert = readVector(msg.certificate_list, 3);\n      asn1 = forge.asn1.fromDer(cert);\n      cert = forge.pki.certificateFromAsn1(asn1, true);\n      certs.push(cert);\n    }\n  } catch(ex) {\n    return c.error(c, {\n      message: 'Could not parse certificate list.',\n      cause: ex,\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.bad_certificate\n      }\n    });\n  }\n\n  // ensure at least 1 certificate was provided if in client-mode\n  // or if verifyClient was set to true to require a certificate\n  // (as opposed to 'optional')\n  var client = (c.entity === tls.ConnectionEnd.client);\n  if((client || c.verifyClient === true) && certs.length === 0) {\n    // error, no certificate\n    c.error(c, {\n      message: client ?\n        'No server certificate provided.' :\n        'No client certificate provided.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.illegal_parameter\n      }\n    });\n  } else if(certs.length === 0) {\n    // no certs to verify\n    // expect a ServerKeyExchange or ClientKeyExchange message next\n    c.expect = client ? SKE : CKE;\n  } else {\n    // save certificate in session\n    if(client) {\n      c.session.serverCertificate = certs[0];\n    } else {\n      c.session.clientCertificate = certs[0];\n    }\n\n    if(tls.verifyCertificateChain(c, certs)) {\n      // expect a ServerKeyExchange or ClientKeyExchange message next\n      c.expect = client ? SKE : CKE;\n    }\n  }\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a client receives a ServerKeyExchange record.\n *\n * When this message will be sent:\n *   This message will be sent immediately after the server certificate\n *   message (or the server hello message, if this is an anonymous\n *   negotiation).\n *\n *   The server key exchange message is sent by the server only when the\n *   server certificate message (if sent) does not contain enough data to\n *   allow the client to exchange a premaster secret.\n *\n * Meaning of this message:\n *   This message conveys cryptographic information to allow the client to\n *   communicate the premaster secret: either an RSA public key to encrypt\n *   the premaster secret with, or a Diffie-Hellman public key with which the\n *   client can complete a key exchange (with the result being the premaster\n *   secret.)\n *\n * enum {\n *   dhe_dss, dhe_rsa, dh_anon, rsa, dh_dss, dh_rsa\n * } KeyExchangeAlgorithm;\n *\n * struct {\n *   opaque dh_p<1..2^16-1>;\n *   opaque dh_g<1..2^16-1>;\n *   opaque dh_Ys<1..2^16-1>;\n * } ServerDHParams;\n *\n * struct {\n *   select(KeyExchangeAlgorithm) {\n *     case dh_anon:\n *       ServerDHParams params;\n *     case dhe_dss:\n *     case dhe_rsa:\n *       ServerDHParams params;\n *       digitally-signed struct {\n *         opaque client_random[32];\n *         opaque server_random[32];\n *         ServerDHParams params;\n *       } signed_params;\n *     case rsa:\n *     case dh_dss:\n *     case dh_rsa:\n *       struct {};\n *   };\n * } ServerKeyExchange;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleServerKeyExchange = function(c, record, length) {\n  // this implementation only supports RSA, no Diffie-Hellman support\n  // so any length > 0 is invalid\n  if(length > 0) {\n    return c.error(c, {\n      message: 'Invalid key parameters. Only RSA is supported.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.unsupported_certificate\n      }\n    });\n  }\n\n  // expect an optional CertificateRequest message next\n  c.expect = SCR;\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a client receives a ClientKeyExchange record.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleClientKeyExchange = function(c, record, length) {\n  // this implementation only supports RSA, no Diffie-Hellman support\n  // so any length < 48 is invalid\n  if(length < 48) {\n    return c.error(c, {\n      message: 'Invalid key parameters. Only RSA is supported.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.unsupported_certificate\n      }\n    });\n  }\n\n  var b = record.fragment;\n  var msg = {\n    enc_pre_master_secret: readVector(b, 2).getBytes()\n  };\n\n  // do rsa decryption\n  var privateKey = null;\n  if(c.getPrivateKey) {\n    try {\n      privateKey = c.getPrivateKey(c, c.session.serverCertificate);\n      privateKey = forge.pki.privateKeyFromPem(privateKey);\n    } catch(ex) {\n      c.error(c, {\n        message: 'Could not get private key.',\n        cause: ex,\n        send: true,\n        alert: {\n          level: tls.Alert.Level.fatal,\n          description: tls.Alert.Description.internal_error\n        }\n      });\n    }\n  }\n\n  if(privateKey === null) {\n    return c.error(c, {\n      message: 'No private key set.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.internal_error\n      }\n    });\n  }\n\n  try {\n    // decrypt 48-byte pre-master secret\n    var sp = c.session.sp;\n    sp.pre_master_secret = privateKey.decrypt(msg.enc_pre_master_secret);\n\n    // ensure client hello version matches first 2 bytes\n    var version = c.session.clientHelloVersion;\n    if(version.major !== sp.pre_master_secret.charCodeAt(0) ||\n      version.minor !== sp.pre_master_secret.charCodeAt(1)) {\n      // error, do not send alert (see BLEI attack below)\n      throw new Error('TLS version rollback attack detected.');\n    }\n  } catch(ex) {\n    /* Note: Daniel Bleichenbacher [BLEI] can be used to attack a\n      TLS server which is using PKCS#1 encoded RSA, so instead of\n      failing here, we generate 48 random bytes and use that as\n      the pre-master secret. */\n    sp.pre_master_secret = forge.random.getBytes(48);\n  }\n\n  // expect a CertificateVerify message if a Certificate was received that\n  // does not have fixed Diffie-Hellman params, otherwise expect\n  // ChangeCipherSpec\n  c.expect = CCC;\n  if(c.session.clientCertificate !== null) {\n    // only RSA support, so expect CertificateVerify\n    // TODO: support Diffie-Hellman\n    c.expect = CCV;\n  }\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a client receives a CertificateRequest record.\n *\n * When this message will be sent:\n *   A non-anonymous server can optionally request a certificate from the\n *   client, if appropriate for the selected cipher suite. This message, if\n *   sent, will immediately follow the Server Key Exchange message (if it is\n *   sent; otherwise, the Server Certificate message).\n *\n * enum {\n *   rsa_sign(1), dss_sign(2), rsa_fixed_dh(3), dss_fixed_dh(4),\n *   rsa_ephemeral_dh_RESERVED(5), dss_ephemeral_dh_RESERVED(6),\n *   fortezza_dms_RESERVED(20), (255)\n * } ClientCertificateType;\n *\n * opaque DistinguishedName<1..2^16-1>;\n *\n * struct {\n *   ClientCertificateType certificate_types<1..2^8-1>;\n *   SignatureAndHashAlgorithm supported_signature_algorithms<2^16-1>;\n *   DistinguishedName certificate_authorities<0..2^16-1>;\n * } CertificateRequest;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleCertificateRequest = function(c, record, length) {\n  // minimum of 3 bytes in message\n  if(length < 3) {\n    return c.error(c, {\n      message: 'Invalid CertificateRequest. Message too short.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.illegal_parameter\n      }\n    });\n  }\n\n  // TODO: TLS 1.2+ has different format including\n  // SignatureAndHashAlgorithm after cert types\n  var b = record.fragment;\n  var msg = {\n    certificate_types: readVector(b, 1),\n    certificate_authorities: readVector(b, 2)\n  };\n\n  // save certificate request in session\n  c.session.certificateRequest = msg;\n\n  // expect a ServerHelloDone message next\n  c.expect = SHD;\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a server receives a CertificateVerify record.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleCertificateVerify = function(c, record, length) {\n  if(length < 2) {\n    return c.error(c, {\n      message: 'Invalid CertificateVerify. Message too short.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.illegal_parameter\n      }\n    });\n  }\n\n  // rewind to get full bytes for message so it can be manually\n  // digested below (special case for CertificateVerify messages because\n  // they must be digested *after* handling as opposed to all others)\n  var b = record.fragment;\n  b.read -= 4;\n  var msgBytes = b.bytes();\n  b.read += 4;\n\n  var msg = {\n    signature: readVector(b, 2).getBytes()\n  };\n\n  // TODO: add support for DSA\n\n  // generate data to verify\n  var verify = forge.util.createBuffer();\n  verify.putBuffer(c.session.md5.digest());\n  verify.putBuffer(c.session.sha1.digest());\n  verify = verify.getBytes();\n\n  try {\n    var cert = c.session.clientCertificate;\n    /*b = forge.pki.rsa.decrypt(\n      msg.signature, cert.publicKey, true, verify.length);\n    if(b !== verify) {*/\n    if(!cert.publicKey.verify(verify, msg.signature, 'NONE')) {\n      throw new Error('CertificateVerify signature does not match.');\n    }\n\n    // digest message now that it has been handled\n    c.session.md5.update(msgBytes);\n    c.session.sha1.update(msgBytes);\n  } catch(ex) {\n    return c.error(c, {\n      message: 'Bad signature in CertificateVerify.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.handshake_failure\n      }\n    });\n  }\n\n  // expect ChangeCipherSpec\n  c.expect = CCC;\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a client receives a ServerHelloDone record.\n *\n * When this message will be sent:\n *   The server hello done message is sent by the server to indicate the end\n *   of the server hello and associated messages. After sending this message\n *   the server will wait for a client response.\n *\n * Meaning of this message:\n *   This message means that the server is done sending messages to support\n *   the key exchange, and the client can proceed with its phase of the key\n *   exchange.\n *\n *   Upon receipt of the server hello done message the client should verify\n *   that the server provided a valid certificate if required and check that\n *   the server hello parameters are acceptable.\n *\n * struct {} ServerHelloDone;\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleServerHelloDone = function(c, record, length) {\n  // len must be 0 bytes\n  if(length > 0) {\n    return c.error(c, {\n      message: 'Invalid ServerHelloDone message. Invalid length.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.record_overflow\n      }\n    });\n  }\n\n  if(c.serverCertificate === null) {\n    // no server certificate was provided\n    var error = {\n      message: 'No server certificate provided. Not enough security.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.insufficient_security\n      }\n    };\n\n    // call application callback\n    var depth = 0;\n    var ret = c.verify(c, error.alert.description, depth, []);\n    if(ret !== true) {\n      // check for custom alert info\n      if(ret || ret === 0) {\n        // set custom message and alert description\n        if(typeof ret === 'object' && !forge.util.isArray(ret)) {\n          if(ret.message) {\n            error.message = ret.message;\n          }\n          if(ret.alert) {\n            error.alert.description = ret.alert;\n          }\n        } else if(typeof ret === 'number') {\n          // set custom alert description\n          error.alert.description = ret;\n        }\n      }\n\n      // send error\n      return c.error(c, error);\n    }\n  }\n\n  // create client certificate message if requested\n  if(c.session.certificateRequest !== null) {\n    record = tls.createRecord(c, {\n      type: tls.ContentType.handshake,\n      data: tls.createCertificate(c)\n    });\n    tls.queue(c, record);\n  }\n\n  // create client key exchange message\n  record = tls.createRecord(c, {\n     type: tls.ContentType.handshake,\n     data: tls.createClientKeyExchange(c)\n  });\n  tls.queue(c, record);\n\n  // expect no messages until the following callback has been called\n  c.expect = SER;\n\n  // create callback to handle client signature (for client-certs)\n  var callback = function(c, signature) {\n    if(c.session.certificateRequest !== null &&\n      c.session.clientCertificate !== null) {\n      // create certificate verify message\n      tls.queue(c, tls.createRecord(c, {\n        type: tls.ContentType.handshake,\n        data: tls.createCertificateVerify(c, signature)\n      }));\n    }\n\n    // create change cipher spec message\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.change_cipher_spec,\n      data: tls.createChangeCipherSpec()\n    }));\n\n    // create pending state\n    c.state.pending = tls.createConnectionState(c);\n\n    // change current write state to pending write state\n    c.state.current.write = c.state.pending.write;\n\n    // create finished message\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.handshake,\n      data: tls.createFinished(c)\n    }));\n\n    // expect a server ChangeCipherSpec message next\n    c.expect = SCC;\n\n    // send records\n    tls.flush(c);\n\n    // continue\n    c.process();\n  };\n\n  // if there is no certificate request or no client certificate, do\n  // callback immediately\n  if(c.session.certificateRequest === null ||\n    c.session.clientCertificate === null) {\n    return callback(c, null);\n  }\n\n  // otherwise get the client signature\n  tls.getClientSignature(c, callback);\n};\n\n/**\n * Called when a ChangeCipherSpec record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleChangeCipherSpec = function(c, record) {\n  if(record.fragment.getByte() !== 0x01) {\n    return c.error(c, {\n      message: 'Invalid ChangeCipherSpec message received.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.illegal_parameter\n      }\n    });\n  }\n\n  // create pending state if:\n  // 1. Resuming session in client mode OR\n  // 2. NOT resuming session in server mode\n  var client = (c.entity === tls.ConnectionEnd.client);\n  if((c.session.resuming && client) || (!c.session.resuming && !client)) {\n    c.state.pending = tls.createConnectionState(c);\n  }\n\n  // change current read state to pending read state\n  c.state.current.read = c.state.pending.read;\n\n  // clear pending state if:\n  // 1. NOT resuming session in client mode OR\n  // 2. resuming a session in server mode\n  if((!c.session.resuming && client) || (c.session.resuming && !client)) {\n    c.state.pending = null;\n  }\n\n  // expect a Finished record next\n  c.expect = client ? SFI : CFI;\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a Finished record is received.\n *\n * When this message will be sent:\n *   A finished message is always sent immediately after a change\n *   cipher spec message to verify that the key exchange and\n *   authentication processes were successful. It is essential that a\n *   change cipher spec message be received between the other\n *   handshake messages and the Finished message.\n *\n * Meaning of this message:\n *   The finished message is the first protected with the just-\n *   negotiated algorithms, keys, and secrets. Recipients of finished\n *   messages must verify that the contents are correct.  Once a side\n *   has sent its Finished message and received and validated the\n *   Finished message from its peer, it may begin to send and receive\n *   application data over the connection.\n *\n * struct {\n *   opaque verify_data[verify_data_length];\n * } Finished;\n *\n * verify_data\n *   PRF(master_secret, finished_label, Hash(handshake_messages))\n *     [0..verify_data_length-1];\n *\n * finished_label\n *   For Finished messages sent by the client, the string\n *   \"client finished\". For Finished messages sent by the server, the\n *   string \"server finished\".\n *\n * verify_data_length depends on the cipher suite. If it is not specified\n * by the cipher suite, then it is 12. Versions of TLS < 1.2 always used\n * 12 bytes.\n *\n * @param c the connection.\n * @param record the record.\n * @param length the length of the handshake message.\n */\ntls.handleFinished = function(c, record, length) {\n  // rewind to get full bytes for message so it can be manually\n  // digested below (special case for Finished messages because they\n  // must be digested *after* handling as opposed to all others)\n  var b = record.fragment;\n  b.read -= 4;\n  var msgBytes = b.bytes();\n  b.read += 4;\n\n  // message contains only verify_data\n  var vd = record.fragment.getBytes();\n\n  // ensure verify data is correct\n  b = forge.util.createBuffer();\n  b.putBuffer(c.session.md5.digest());\n  b.putBuffer(c.session.sha1.digest());\n\n  // set label based on entity type\n  var client = (c.entity === tls.ConnectionEnd.client);\n  var label = client ? 'server finished' : 'client finished';\n\n  // TODO: determine prf function and verify length for TLS 1.2\n  var sp = c.session.sp;\n  var vdl = 12;\n  var prf = prf_TLS1;\n  b = prf(sp.master_secret, label, b.getBytes(), vdl);\n  if(b.getBytes() !== vd) {\n    return c.error(c, {\n      message: 'Invalid verify_data in Finished message.',\n      send: true,\n      alert: {\n        level: tls.Alert.Level.fatal,\n        description: tls.Alert.Description.decrypt_error\n      }\n    });\n  }\n\n  // digest finished message now that it has been handled\n  c.session.md5.update(msgBytes);\n  c.session.sha1.update(msgBytes);\n\n  // resuming session as client or NOT resuming session as server\n  if((c.session.resuming && client) || (!c.session.resuming && !client)) {\n    // create change cipher spec message\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.change_cipher_spec,\n      data: tls.createChangeCipherSpec()\n    }));\n\n    // change current write state to pending write state, clear pending\n    c.state.current.write = c.state.pending.write;\n    c.state.pending = null;\n\n    // create finished message\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.handshake,\n      data: tls.createFinished(c)\n    }));\n  }\n\n  // expect application data next\n  c.expect = client ? SAD : CAD;\n\n  // handshake complete\n  c.handshaking = false;\n  ++c.handshakes;\n\n  // save access to peer certificate\n  c.peerCertificate = client ?\n    c.session.serverCertificate : c.session.clientCertificate;\n\n  // send records\n  tls.flush(c);\n\n  // now connected\n  c.isConnected = true;\n  c.connected(c);\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when an Alert record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleAlert = function(c, record) {\n  // read alert\n  var b = record.fragment;\n  var alert = {\n    level: b.getByte(),\n    description: b.getByte()\n  };\n\n  // TODO: consider using a table?\n  // get appropriate message\n  var msg;\n  switch(alert.description) {\n  case tls.Alert.Description.close_notify:\n    msg = 'Connection closed.';\n    break;\n  case tls.Alert.Description.unexpected_message:\n    msg = 'Unexpected message.';\n    break;\n  case tls.Alert.Description.bad_record_mac:\n    msg = 'Bad record MAC.';\n    break;\n  case tls.Alert.Description.decryption_failed:\n    msg = 'Decryption failed.';\n    break;\n  case tls.Alert.Description.record_overflow:\n    msg = 'Record overflow.';\n    break;\n  case tls.Alert.Description.decompression_failure:\n    msg = 'Decompression failed.';\n    break;\n  case tls.Alert.Description.handshake_failure:\n    msg = 'Handshake failure.';\n    break;\n  case tls.Alert.Description.bad_certificate:\n    msg = 'Bad certificate.';\n    break;\n  case tls.Alert.Description.unsupported_certificate:\n    msg = 'Unsupported certificate.';\n    break;\n  case tls.Alert.Description.certificate_revoked:\n    msg = 'Certificate revoked.';\n    break;\n  case tls.Alert.Description.certificate_expired:\n    msg = 'Certificate expired.';\n    break;\n  case tls.Alert.Description.certificate_unknown:\n    msg = 'Certificate unknown.';\n    break;\n  case tls.Alert.Description.illegal_parameter:\n    msg = 'Illegal parameter.';\n    break;\n  case tls.Alert.Description.unknown_ca:\n    msg = 'Unknown certificate authority.';\n    break;\n  case tls.Alert.Description.access_denied:\n    msg = 'Access denied.';\n    break;\n  case tls.Alert.Description.decode_error:\n    msg = 'Decode error.';\n    break;\n  case tls.Alert.Description.decrypt_error:\n    msg = 'Decrypt error.';\n    break;\n  case tls.Alert.Description.export_restriction:\n    msg = 'Export restriction.';\n    break;\n  case tls.Alert.Description.protocol_version:\n    msg = 'Unsupported protocol version.';\n    break;\n  case tls.Alert.Description.insufficient_security:\n    msg = 'Insufficient security.';\n    break;\n  case tls.Alert.Description.internal_error:\n    msg = 'Internal error.';\n    break;\n  case tls.Alert.Description.user_canceled:\n    msg = 'User canceled.';\n    break;\n  case tls.Alert.Description.no_renegotiation:\n    msg = 'Renegotiation not supported.';\n    break;\n  default:\n    msg = 'Unknown error.';\n    break;\n  }\n\n  // close connection on close_notify, not an error\n  if(alert.description === tls.Alert.Description.close_notify) {\n    return c.close();\n  }\n\n  // call error handler\n  c.error(c, {\n    message: msg,\n    send: false,\n    // origin is the opposite end\n    origin: (c.entity === tls.ConnectionEnd.client) ? 'server' : 'client',\n    alert: alert\n  });\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a Handshake record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleHandshake = function(c, record) {\n  // get the handshake type and message length\n  var b = record.fragment;\n  var type = b.getByte();\n  var length = b.getInt24();\n\n  // see if the record fragment doesn't yet contain the full message\n  if(length > b.length()) {\n    // cache the record, clear its fragment, and reset the buffer read\n    // pointer before the type and length were read\n    c.fragmented = record;\n    record.fragment = forge.util.createBuffer();\n    b.read -= 4;\n\n    // continue\n    return c.process();\n  }\n\n  // full message now available, clear cache, reset read pointer to\n  // before type and length\n  c.fragmented = null;\n  b.read -= 4;\n\n  // save the handshake bytes for digestion after handler is found\n  // (include type and length of handshake msg)\n  var bytes = b.bytes(length + 4);\n\n  // restore read pointer\n  b.read += 4;\n\n  // handle expected message\n  if(type in hsTable[c.entity][c.expect]) {\n    // initialize server session\n    if(c.entity === tls.ConnectionEnd.server && !c.open && !c.fail) {\n      c.handshaking = true;\n      c.session = {\n        version: null,\n        extensions: {\n          server_name: {\n            serverNameList: []\n          }\n        },\n        cipherSuite: null,\n        compressionMethod: null,\n        serverCertificate: null,\n        clientCertificate: null,\n        md5: forge.md.md5.create(),\n        sha1: forge.md.sha1.create()\n      };\n    }\n\n    /* Update handshake messages digest. Finished and CertificateVerify\n      messages are not digested here. They can't be digested as part of\n      the verify_data that they contain. These messages are manually\n      digested in their handlers. HelloRequest messages are simply never\n      included in the handshake message digest according to spec. */\n    if(type !== tls.HandshakeType.hello_request &&\n      type !== tls.HandshakeType.certificate_verify &&\n      type !== tls.HandshakeType.finished) {\n      c.session.md5.update(bytes);\n      c.session.sha1.update(bytes);\n    }\n\n    // handle specific handshake type record\n    hsTable[c.entity][c.expect][type](c, record, length);\n  } else {\n    // unexpected record\n    tls.handleUnexpected(c, record);\n  }\n};\n\n/**\n * Called when an ApplicationData record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleApplicationData = function(c, record) {\n  // buffer data, notify that its ready\n  c.data.putBuffer(record.fragment);\n  c.dataReady(c);\n\n  // continue\n  c.process();\n};\n\n/**\n * Called when a Heartbeat record is received.\n *\n * @param c the connection.\n * @param record the record.\n */\ntls.handleHeartbeat = function(c, record) {\n  // get the heartbeat type and payload\n  var b = record.fragment;\n  var type = b.getByte();\n  var length = b.getInt16();\n  var payload = b.getBytes(length);\n\n  if(type === tls.HeartbeatMessageType.heartbeat_request) {\n    // discard request during handshake or if length is too large\n    if(c.handshaking || length > payload.length) {\n      // continue\n      return c.process();\n    }\n    // retransmit payload\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.heartbeat,\n      data: tls.createHeartbeat(\n        tls.HeartbeatMessageType.heartbeat_response, payload)\n    }));\n    tls.flush(c);\n  } else if(type === tls.HeartbeatMessageType.heartbeat_response) {\n    // check payload against expected payload, discard heartbeat if no match\n    if(payload !== c.expectedHeartbeatPayload) {\n      // continue\n      return c.process();\n    }\n\n    // notify that a valid heartbeat was received\n    if(c.heartbeatReceived) {\n      c.heartbeatReceived(c, forge.util.createBuffer(payload));\n    }\n  }\n\n  // continue\n  c.process();\n};\n\n/**\n * The transistional state tables for receiving TLS records. It maps the\n * current TLS engine state and a received record to a function to handle the\n * record and update the state.\n *\n * For instance, if the current state is SHE, then the TLS engine is expecting\n * a ServerHello record. Once a record is received, the handler function is\n * looked up using the state SHE and the record's content type.\n *\n * The resulting function will either be an error handler or a record handler.\n * The function will take whatever action is appropriate and update the state\n * for the next record.\n *\n * The states are all based on possible server record types. Note that the\n * client will never specifically expect to receive a HelloRequest or an alert\n * from the server so there is no state that reflects this. These messages may\n * occur at any time.\n *\n * There are two tables for mapping states because there is a second tier of\n * types for handshake messages. Once a record with a content type of handshake\n * is received, the handshake record handler will look up the handshake type in\n * the secondary map to get its appropriate handler.\n *\n * Valid message orders are as follows:\n *\n * =======================FULL HANDSHAKE======================\n * Client                                               Server\n *\n * ClientHello                  -------->\n *                                                 ServerHello\n *                                                Certificate*\n *                                          ServerKeyExchange*\n *                                         CertificateRequest*\n *                              <--------      ServerHelloDone\n * Certificate*\n * ClientKeyExchange\n * CertificateVerify*\n * [ChangeCipherSpec]\n * Finished                     -------->\n *                                          [ChangeCipherSpec]\n *                              <--------             Finished\n * Application Data             <------->     Application Data\n *\n * =====================SESSION RESUMPTION=====================\n * Client                                                Server\n *\n * ClientHello                   -------->\n *                                                  ServerHello\n *                                           [ChangeCipherSpec]\n *                               <--------             Finished\n * [ChangeCipherSpec]\n * Finished                      -------->\n * Application Data              <------->     Application Data\n */\n// client expect states (indicate which records are expected to be received)\nvar SHE = 0; // rcv server hello\nvar SCE = 1; // rcv server certificate\nvar SKE = 2; // rcv server key exchange\nvar SCR = 3; // rcv certificate request\nvar SHD = 4; // rcv server hello done\nvar SCC = 5; // rcv change cipher spec\nvar SFI = 6; // rcv finished\nvar SAD = 7; // rcv application data\nvar SER = 8; // not expecting any messages at this point\n\n// server expect states\nvar CHE = 0; // rcv client hello\nvar CCE = 1; // rcv client certificate\nvar CKE = 2; // rcv client key exchange\nvar CCV = 3; // rcv certificate verify\nvar CCC = 4; // rcv change cipher spec\nvar CFI = 5; // rcv finished\nvar CAD = 6; // rcv application data\nvar CER = 7; // not expecting any messages at this point\n\n// map client current expect state and content type to function\nvar __ = tls.handleUnexpected;\nvar R0 = tls.handleChangeCipherSpec;\nvar R1 = tls.handleAlert;\nvar R2 = tls.handleHandshake;\nvar R3 = tls.handleApplicationData;\nvar R4 = tls.handleHeartbeat;\nvar ctTable = [];\nctTable[tls.ConnectionEnd.client] = [\n//      CC,AL,HS,AD,HB\n/*SHE*/[__,R1,R2,__,R4],\n/*SCE*/[__,R1,R2,__,R4],\n/*SKE*/[__,R1,R2,__,R4],\n/*SCR*/[__,R1,R2,__,R4],\n/*SHD*/[__,R1,R2,__,R4],\n/*SCC*/[R0,R1,__,__,R4],\n/*SFI*/[__,R1,R2,__,R4],\n/*SAD*/[__,R1,R2,R3,R4],\n/*SER*/[__,R1,R2,__,R4]\n];\n\n// map server current expect state and content type to function\nctTable[tls.ConnectionEnd.server] = [\n//      CC,AL,HS,AD\n/*CHE*/[__,R1,R2,__,R4],\n/*CCE*/[__,R1,R2,__,R4],\n/*CKE*/[__,R1,R2,__,R4],\n/*CCV*/[__,R1,R2,__,R4],\n/*CCC*/[R0,R1,__,__,R4],\n/*CFI*/[__,R1,R2,__,R4],\n/*CAD*/[__,R1,R2,R3,R4],\n/*CER*/[__,R1,R2,__,R4]\n];\n\n// map client current expect state and handshake type to function\nvar H0 = tls.handleHelloRequest;\nvar H1 = tls.handleServerHello;\nvar H2 = tls.handleCertificate;\nvar H3 = tls.handleServerKeyExchange;\nvar H4 = tls.handleCertificateRequest;\nvar H5 = tls.handleServerHelloDone;\nvar H6 = tls.handleFinished;\nvar hsTable = [];\nhsTable[tls.ConnectionEnd.client] = [\n//      HR,01,SH,03,04,05,06,07,08,09,10,SC,SK,CR,HD,15,CK,17,18,19,FI\n/*SHE*/[__,__,H1,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*SCE*/[H0,__,__,__,__,__,__,__,__,__,__,H2,H3,H4,H5,__,__,__,__,__,__],\n/*SKE*/[H0,__,__,__,__,__,__,__,__,__,__,__,H3,H4,H5,__,__,__,__,__,__],\n/*SCR*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,H4,H5,__,__,__,__,__,__],\n/*SHD*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,H5,__,__,__,__,__,__],\n/*SCC*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*SFI*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,H6],\n/*SAD*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*SER*/[H0,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__]\n];\n\n// map server current expect state and handshake type to function\n// Note: CAD[CH] does not map to FB because renegotation is prohibited\nvar H7 = tls.handleClientHello;\nvar H8 = tls.handleClientKeyExchange;\nvar H9 = tls.handleCertificateVerify;\nhsTable[tls.ConnectionEnd.server] = [\n//      01,CH,02,03,04,05,06,07,08,09,10,CC,12,13,14,CV,CK,17,18,19,FI\n/*CHE*/[__,H7,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*CCE*/[__,__,__,__,__,__,__,__,__,__,__,H2,__,__,__,__,__,__,__,__,__],\n/*CKE*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,H8,__,__,__,__],\n/*CCV*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,H9,__,__,__,__,__],\n/*CCC*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*CFI*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,H6],\n/*CAD*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__],\n/*CER*/[__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__,__]\n];\n\n/**\n * Generates the master_secret and keys using the given security parameters.\n *\n * The security parameters for a TLS connection state are defined as such:\n *\n * struct {\n *   ConnectionEnd          entity;\n *   PRFAlgorithm           prf_algorithm;\n *   BulkCipherAlgorithm    bulk_cipher_algorithm;\n *   CipherType             cipher_type;\n *   uint8                  enc_key_length;\n *   uint8                  block_length;\n *   uint8                  fixed_iv_length;\n *   uint8                  record_iv_length;\n *   MACAlgorithm           mac_algorithm;\n *   uint8                  mac_length;\n *   uint8                  mac_key_length;\n *   CompressionMethod      compression_algorithm;\n *   opaque                 master_secret[48];\n *   opaque                 client_random[32];\n *   opaque                 server_random[32];\n * } SecurityParameters;\n *\n * Note that this definition is from TLS 1.2. In TLS 1.0 some of these\n * parameters are ignored because, for instance, the PRFAlgorithm is a\n * builtin-fixed algorithm combining iterations of MD5 and SHA-1 in TLS 1.0.\n *\n * The Record Protocol requires an algorithm to generate keys required by the\n * current connection state.\n *\n * The master secret is expanded into a sequence of secure bytes, which is then\n * split to a client write MAC key, a server write MAC key, a client write\n * encryption key, and a server write encryption key. In TLS 1.0 a client write\n * IV and server write IV are also generated. Each of these is generated from\n * the byte sequence in that order. Unused values are empty. In TLS 1.2, some\n * AEAD ciphers may additionally require a client write IV and a server write\n * IV (see Section 6.2.3.3).\n *\n * When keys, MAC keys, and IVs are generated, the master secret is used as an\n * entropy source.\n *\n * To generate the key material, compute:\n *\n * master_secret = PRF(pre_master_secret, \"master secret\",\n *                     ClientHello.random + ServerHello.random)\n *\n * key_block = PRF(SecurityParameters.master_secret,\n *                 \"key expansion\",\n *                 SecurityParameters.server_random +\n *                 SecurityParameters.client_random);\n *\n * until enough output has been generated. Then, the key_block is\n * partitioned as follows:\n *\n * client_write_MAC_key[SecurityParameters.mac_key_length]\n * server_write_MAC_key[SecurityParameters.mac_key_length]\n * client_write_key[SecurityParameters.enc_key_length]\n * server_write_key[SecurityParameters.enc_key_length]\n * client_write_IV[SecurityParameters.fixed_iv_length]\n * server_write_IV[SecurityParameters.fixed_iv_length]\n *\n * In TLS 1.2, the client_write_IV and server_write_IV are only generated for\n * implicit nonce techniques as described in Section 3.2.1 of [AEAD]. This\n * implementation uses TLS 1.0 so IVs are generated.\n *\n * Implementation note: The currently defined cipher suite which requires the\n * most material is AES_256_CBC_SHA256. It requires 2 x 32 byte keys and 2 x 32\n * byte MAC keys, for a total 128 bytes of key material. In TLS 1.0 it also\n * requires 2 x 16 byte IVs, so it actually takes 160 bytes of key material.\n *\n * @param c the connection.\n * @param sp the security parameters to use.\n *\n * @return the security keys.\n */\ntls.generateKeys = function(c, sp) {\n  // TLS_RSA_WITH_AES_128_CBC_SHA (required to be compliant with TLS 1.2) &\n  // TLS_RSA_WITH_AES_256_CBC_SHA are the only cipher suites implemented\n  // at present\n\n  // TLS_DHE_DSS_WITH_3DES_EDE_CBC_SHA is required to be compliant with\n  // TLS 1.0 but we don't care right now because AES is better and we have\n  // an implementation for it\n\n  // TODO: TLS 1.2 implementation\n  /*\n  // determine the PRF\n  var prf;\n  switch(sp.prf_algorithm) {\n  case tls.PRFAlgorithm.tls_prf_sha256:\n    prf = prf_sha256;\n    break;\n  default:\n    // should never happen\n    throw new Error('Invalid PRF');\n  }\n  */\n\n  // TLS 1.0/1.1 implementation\n  var prf = prf_TLS1;\n\n  // concatenate server and client random\n  var random = sp.client_random + sp.server_random;\n\n  // only create master secret if session is new\n  if(!c.session.resuming) {\n    // create master secret, clean up pre-master secret\n    sp.master_secret = prf(\n      sp.pre_master_secret, 'master secret', random, 48).bytes();\n    sp.pre_master_secret = null;\n  }\n\n  // generate the amount of key material needed\n  random = sp.server_random + sp.client_random;\n  var length = 2 * sp.mac_key_length + 2 * sp.enc_key_length;\n\n  // include IV for TLS/1.0\n  var tls10 = (c.version.major === tls.Versions.TLS_1_0.major &&\n    c.version.minor === tls.Versions.TLS_1_0.minor);\n  if(tls10) {\n    length += 2 * sp.fixed_iv_length;\n  }\n  var km = prf(sp.master_secret, 'key expansion', random, length);\n\n  // split the key material into the MAC and encryption keys\n  var rval = {\n    client_write_MAC_key: km.getBytes(sp.mac_key_length),\n    server_write_MAC_key: km.getBytes(sp.mac_key_length),\n    client_write_key: km.getBytes(sp.enc_key_length),\n    server_write_key: km.getBytes(sp.enc_key_length)\n  };\n\n  // include TLS 1.0 IVs\n  if(tls10) {\n    rval.client_write_IV = km.getBytes(sp.fixed_iv_length);\n    rval.server_write_IV = km.getBytes(sp.fixed_iv_length);\n  }\n\n  return rval;\n};\n\n/**\n * Creates a new initialized TLS connection state. A connection state has\n * a read mode and a write mode.\n *\n * compression state:\n *   The current state of the compression algorithm.\n *\n * cipher state:\n *   The current state of the encryption algorithm. This will consist of the\n *   scheduled key for that connection. For stream ciphers, this will also\n *   contain whatever state information is necessary to allow the stream to\n *   continue to encrypt or decrypt data.\n *\n * MAC key:\n *   The MAC key for the connection.\n *\n * sequence number:\n *   Each connection state contains a sequence number, which is maintained\n *   separately for read and write states. The sequence number MUST be set to\n *   zero whenever a connection state is made the active state. Sequence\n *   numbers are of type uint64 and may not exceed 2^64-1. Sequence numbers do\n *   not wrap. If a TLS implementation would need to wrap a sequence number,\n *   it must renegotiate instead. A sequence number is incremented after each\n *   record: specifically, the first record transmitted under a particular\n *   connection state MUST use sequence number 0.\n *\n * @param c the connection.\n *\n * @return the new initialized TLS connection state.\n */\ntls.createConnectionState = function(c) {\n  var client = (c.entity === tls.ConnectionEnd.client);\n\n  var createMode = function() {\n    var mode = {\n      // two 32-bit numbers, first is most significant\n      sequenceNumber: [0, 0],\n      macKey: null,\n      macLength: 0,\n      macFunction: null,\n      cipherState: null,\n      cipherFunction: function(record) {return true;},\n      compressionState: null,\n      compressFunction: function(record) {return true;},\n      updateSequenceNumber: function() {\n        if(mode.sequenceNumber[1] === 0xFFFFFFFF) {\n          mode.sequenceNumber[1] = 0;\n          ++mode.sequenceNumber[0];\n        } else {\n          ++mode.sequenceNumber[1];\n        }\n      }\n    };\n    return mode;\n  };\n  var state = {\n    read: createMode(),\n    write: createMode()\n  };\n\n  // update function in read mode will decrypt then decompress a record\n  state.read.update = function(c, record) {\n    if(!state.read.cipherFunction(record, state.read)) {\n      c.error(c, {\n        message: 'Could not decrypt record or bad MAC.',\n        send: true,\n        alert: {\n          level: tls.Alert.Level.fatal,\n          // doesn't matter if decryption failed or MAC was\n          // invalid, return the same error so as not to reveal\n          // which one occurred\n          description: tls.Alert.Description.bad_record_mac\n        }\n      });\n    } else if(!state.read.compressFunction(c, record, state.read)) {\n      c.error(c, {\n        message: 'Could not decompress record.',\n        send: true,\n        alert: {\n          level: tls.Alert.Level.fatal,\n          description: tls.Alert.Description.decompression_failure\n        }\n      });\n    }\n    return !c.fail;\n  };\n\n  // update function in write mode will compress then encrypt a record\n  state.write.update = function(c, record) {\n    if(!state.write.compressFunction(c, record, state.write)) {\n      // error, but do not send alert since it would require\n      // compression as well\n      c.error(c, {\n        message: 'Could not compress record.',\n        send: false,\n        alert: {\n          level: tls.Alert.Level.fatal,\n          description: tls.Alert.Description.internal_error\n        }\n      });\n    } else if(!state.write.cipherFunction(record, state.write)) {\n      // error, but do not send alert since it would require\n      // encryption as well\n      c.error(c, {\n        message: 'Could not encrypt record.',\n        send: false,\n        alert: {\n          level: tls.Alert.Level.fatal,\n          description: tls.Alert.Description.internal_error\n        }\n      });\n    }\n    return !c.fail;\n  };\n\n  // handle security parameters\n  if(c.session) {\n    var sp = c.session.sp;\n    c.session.cipherSuite.initSecurityParameters(sp);\n\n    // generate keys\n    sp.keys = tls.generateKeys(c, sp);\n    state.read.macKey = client ?\n      sp.keys.server_write_MAC_key : sp.keys.client_write_MAC_key;\n    state.write.macKey = client ?\n      sp.keys.client_write_MAC_key : sp.keys.server_write_MAC_key;\n\n    // cipher suite setup\n    c.session.cipherSuite.initConnectionState(state, c, sp);\n\n    // compression setup\n    switch(sp.compression_algorithm) {\n    case tls.CompressionMethod.none:\n      break;\n    case tls.CompressionMethod.deflate:\n      state.read.compressFunction = inflate;\n      state.write.compressFunction = deflate;\n      break;\n    default:\n      throw new Error('Unsupported compression algorithm.');\n    }\n  }\n\n  return state;\n};\n\n/**\n * Creates a Random structure.\n *\n * struct {\n *   uint32 gmt_unix_time;\n *   opaque random_bytes[28];\n * } Random;\n *\n * gmt_unix_time:\n *   The current time and date in standard UNIX 32-bit format (seconds since\n *   the midnight starting Jan 1, 1970, UTC, ignoring leap seconds) according\n *   to the sender's internal clock. Clocks are not required to be set\n *   correctly by the basic TLS protocol; higher-level or application\n *   protocols may define additional requirements. Note that, for historical\n *   reasons, the data element is named using GMT, the predecessor of the\n *   current worldwide time base, UTC.\n * random_bytes:\n *   28 bytes generated by a secure random number generator.\n *\n * @return the Random structure as a byte array.\n */\ntls.createRandom = function() {\n  // get UTC milliseconds\n  var d = new Date();\n  var utc = +d + d.getTimezoneOffset() * 60000;\n  var rval = forge.util.createBuffer();\n  rval.putInt32(utc);\n  rval.putBytes(forge.random.getBytes(28));\n  return rval;\n};\n\n/**\n * Creates a TLS record with the given type and data.\n *\n * @param c the connection.\n * @param options:\n *   type: the record type.\n *   data: the plain text data in a byte buffer.\n *\n * @return the created record.\n */\ntls.createRecord = function(c, options) {\n  if(!options.data) {\n    return null;\n  }\n  var record = {\n    type: options.type,\n    version: {\n      major: c.version.major,\n      minor: c.version.minor\n    },\n    length: options.data.length(),\n    fragment: options.data\n  };\n  return record;\n};\n\n/**\n * Creates a TLS alert record.\n *\n * @param c the connection.\n * @param alert:\n *   level: the TLS alert level.\n *   description: the TLS alert description.\n *\n * @return the created alert record.\n */\ntls.createAlert = function(c, alert) {\n  var b = forge.util.createBuffer();\n  b.putByte(alert.level);\n  b.putByte(alert.description);\n  return tls.createRecord(c, {\n    type: tls.ContentType.alert,\n    data: b\n  });\n};\n\n/* The structure of a TLS handshake message.\n *\n * struct {\n *    HandshakeType msg_type;    // handshake type\n *    uint24 length;             // bytes in message\n *    select(HandshakeType) {\n *       case hello_request:       HelloRequest;\n *       case client_hello:        ClientHello;\n *       case server_hello:        ServerHello;\n *       case certificate:         Certificate;\n *       case server_key_exchange: ServerKeyExchange;\n *       case certificate_request: CertificateRequest;\n *       case server_hello_done:   ServerHelloDone;\n *       case certificate_verify:  CertificateVerify;\n *       case client_key_exchange: ClientKeyExchange;\n *       case finished:            Finished;\n *    } body;\n * } Handshake;\n */\n\n/**\n * Creates a ClientHello message.\n *\n * opaque SessionID<0..32>;\n * enum { null(0), deflate(1), (255) } CompressionMethod;\n * uint8 CipherSuite[2];\n *\n * struct {\n *   ProtocolVersion client_version;\n *   Random random;\n *   SessionID session_id;\n *   CipherSuite cipher_suites<2..2^16-2>;\n *   CompressionMethod compression_methods<1..2^8-1>;\n *   select(extensions_present) {\n *     case false:\n *       struct {};\n *     case true:\n *       Extension extensions<0..2^16-1>;\n *   };\n * } ClientHello;\n *\n * The extension format for extended client hellos and server hellos is:\n *\n * struct {\n *   ExtensionType extension_type;\n *   opaque extension_data<0..2^16-1>;\n * } Extension;\n *\n * Here:\n *\n * - \"extension_type\" identifies the particular extension type.\n * - \"extension_data\" contains information specific to the particular\n * extension type.\n *\n * The extension types defined in this document are:\n *\n * enum {\n *   server_name(0), max_fragment_length(1),\n *   client_certificate_url(2), trusted_ca_keys(3),\n *   truncated_hmac(4), status_request(5), (65535)\n * } ExtensionType;\n *\n * @param c the connection.\n *\n * @return the ClientHello byte buffer.\n */\ntls.createClientHello = function(c) {\n  // save hello version\n  c.session.clientHelloVersion = {\n    major: c.version.major,\n    minor: c.version.minor\n  };\n\n  // create supported cipher suites\n  var cipherSuites = forge.util.createBuffer();\n  for(var i = 0; i < c.cipherSuites.length; ++i) {\n    var cs = c.cipherSuites[i];\n    cipherSuites.putByte(cs.id[0]);\n    cipherSuites.putByte(cs.id[1]);\n  }\n  var cSuites = cipherSuites.length();\n\n  // create supported compression methods, null always supported, but\n  // also support deflate if connection has inflate and deflate methods\n  var compressionMethods = forge.util.createBuffer();\n  compressionMethods.putByte(tls.CompressionMethod.none);\n  // FIXME: deflate support disabled until issues with raw deflate data\n  // without zlib headers are resolved\n  /*\n  if(c.inflate !== null && c.deflate !== null) {\n    compressionMethods.putByte(tls.CompressionMethod.deflate);\n  }\n  */\n  var cMethods = compressionMethods.length();\n\n  // create TLS SNI (server name indication) extension if virtual host\n  // has been specified, see RFC 3546\n  var extensions = forge.util.createBuffer();\n  if(c.virtualHost) {\n    // create extension struct\n    var ext = forge.util.createBuffer();\n    ext.putByte(0x00); // type server_name (ExtensionType is 2 bytes)\n    ext.putByte(0x00);\n\n    /* In order to provide the server name, clients MAY include an\n     * extension of type \"server_name\" in the (extended) client hello.\n     * The \"extension_data\" field of this extension SHALL contain\n     * \"ServerNameList\" where:\n     *\n     * struct {\n     *   NameType name_type;\n     *   select(name_type) {\n     *     case host_name: HostName;\n     *   } name;\n     * } ServerName;\n     *\n     * enum {\n     *   host_name(0), (255)\n     * } NameType;\n     *\n     * opaque HostName<1..2^16-1>;\n     *\n     * struct {\n     *   ServerName server_name_list<1..2^16-1>\n     * } ServerNameList;\n     */\n    var serverName = forge.util.createBuffer();\n    serverName.putByte(0x00); // type host_name\n    writeVector(serverName, 2, forge.util.createBuffer(c.virtualHost));\n\n    // ServerNameList is in extension_data\n    var snList = forge.util.createBuffer();\n    writeVector(snList, 2, serverName);\n    writeVector(ext, 2, snList);\n    extensions.putBuffer(ext);\n  }\n  var extLength = extensions.length();\n  if(extLength > 0) {\n    // add extension vector length\n    extLength += 2;\n  }\n\n  // determine length of the handshake message\n  // cipher suites and compression methods size will need to be\n  // updated if more get added to the list\n  var sessionId = c.session.id;\n  var length =\n    sessionId.length + 1 + // session ID vector\n    2 +                    // version (major + minor)\n    4 + 28 +               // random time and random bytes\n    2 + cSuites +          // cipher suites vector\n    1 + cMethods +         // compression methods vector\n    extLength;             // extensions vector\n\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  rval.putByte(tls.HandshakeType.client_hello);\n  rval.putInt24(length);                     // handshake length\n  rval.putByte(c.version.major);             // major version\n  rval.putByte(c.version.minor);             // minor version\n  rval.putBytes(c.session.sp.client_random); // random time + bytes\n  writeVector(rval, 1, forge.util.createBuffer(sessionId));\n  writeVector(rval, 2, cipherSuites);\n  writeVector(rval, 1, compressionMethods);\n  if(extLength > 0) {\n    writeVector(rval, 2, extensions);\n  }\n  return rval;\n};\n\n/**\n * Creates a ServerHello message.\n *\n * @param c the connection.\n *\n * @return the ServerHello byte buffer.\n */\ntls.createServerHello = function(c) {\n  // determine length of the handshake message\n  var sessionId = c.session.id;\n  var length =\n    sessionId.length + 1 + // session ID vector\n    2 +                    // version (major + minor)\n    4 + 28 +               // random time and random bytes\n    2 +                    // chosen cipher suite\n    1;                     // chosen compression method\n\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  rval.putByte(tls.HandshakeType.server_hello);\n  rval.putInt24(length);                     // handshake length\n  rval.putByte(c.version.major);             // major version\n  rval.putByte(c.version.minor);             // minor version\n  rval.putBytes(c.session.sp.server_random); // random time + bytes\n  writeVector(rval, 1, forge.util.createBuffer(sessionId));\n  rval.putByte(c.session.cipherSuite.id[0]);\n  rval.putByte(c.session.cipherSuite.id[1]);\n  rval.putByte(c.session.compressionMethod);\n  return rval;\n};\n\n/**\n * Creates a Certificate message.\n *\n * When this message will be sent:\n *   This is the first message the client can send after receiving a server\n *   hello done message and the first message the server can send after\n *   sending a ServerHello. This client message is only sent if the server\n *   requests a certificate. If no suitable certificate is available, the\n *   client should send a certificate message containing no certificates. If\n *   client authentication is required by the server for the handshake to\n *   continue, it may respond with a fatal handshake failure alert.\n *\n * opaque ASN.1Cert<1..2^24-1>;\n *\n * struct {\n *   ASN.1Cert certificate_list<0..2^24-1>;\n * } Certificate;\n *\n * @param c the connection.\n *\n * @return the Certificate byte buffer.\n */\ntls.createCertificate = function(c) {\n  // TODO: check certificate request to ensure types are supported\n\n  // get a certificate (a certificate as a PEM string)\n  var client = (c.entity === tls.ConnectionEnd.client);\n  var cert = null;\n  if(c.getCertificate) {\n    var hint;\n    if(client) {\n      hint = c.session.certificateRequest;\n    } else {\n      hint = c.session.extensions.server_name.serverNameList;\n    }\n    cert = c.getCertificate(c, hint);\n  }\n\n  // buffer to hold certificate list\n  var certList = forge.util.createBuffer();\n  if(cert !== null) {\n    try {\n      // normalize cert to a chain of certificates\n      if(!forge.util.isArray(cert)) {\n        cert = [cert];\n      }\n      var asn1 = null;\n      for(var i = 0; i < cert.length; ++i) {\n        var msg = forge.pem.decode(cert[i])[0];\n        if(msg.type !== 'CERTIFICATE' &&\n          msg.type !== 'X509 CERTIFICATE' &&\n          msg.type !== 'TRUSTED CERTIFICATE') {\n          var error = new Error('Could not convert certificate from PEM; PEM ' +\n            'header type is not \"CERTIFICATE\", \"X509 CERTIFICATE\", or ' +\n            '\"TRUSTED CERTIFICATE\".');\n          error.headerType = msg.type;\n          throw error;\n        }\n        if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n          throw new Error('Could not convert certificate from PEM; PEM is encrypted.');\n        }\n\n        var der = forge.util.createBuffer(msg.body);\n        if(asn1 === null) {\n          asn1 = forge.asn1.fromDer(der.bytes(), false);\n        }\n\n        // certificate entry is itself a vector with 3 length bytes\n        var certBuffer = forge.util.createBuffer();\n        writeVector(certBuffer, 3, der);\n\n        // add cert vector to cert list vector\n        certList.putBuffer(certBuffer);\n      }\n\n      // save certificate\n      cert = forge.pki.certificateFromAsn1(asn1);\n      if(client) {\n        c.session.clientCertificate = cert;\n      } else {\n        c.session.serverCertificate = cert;\n      }\n    } catch(ex) {\n      return c.error(c, {\n        message: 'Could not send certificate list.',\n        cause: ex,\n        send: true,\n        alert: {\n          level: tls.Alert.Level.fatal,\n          description: tls.Alert.Description.bad_certificate\n        }\n      });\n    }\n  }\n\n  // determine length of the handshake message\n  var length = 3 + certList.length(); // cert list vector\n\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  rval.putByte(tls.HandshakeType.certificate);\n  rval.putInt24(length);\n  writeVector(rval, 3, certList);\n  return rval;\n};\n\n/**\n * Creates a ClientKeyExchange message.\n *\n * When this message will be sent:\n *   This message is always sent by the client. It will immediately follow the\n *   client certificate message, if it is sent. Otherwise it will be the first\n *   message sent by the client after it receives the server hello done\n *   message.\n *\n * Meaning of this message:\n *   With this message, the premaster secret is set, either though direct\n *   transmission of the RSA-encrypted secret, or by the transmission of\n *   Diffie-Hellman parameters which will allow each side to agree upon the\n *   same premaster secret. When the key exchange method is DH_RSA or DH_DSS,\n *   client certification has been requested, and the client was able to\n *   respond with a certificate which contained a Diffie-Hellman public key\n *   whose parameters (group and generator) matched those specified by the\n *   server in its certificate, this message will not contain any data.\n *\n * Meaning of this message:\n *   If RSA is being used for key agreement and authentication, the client\n *   generates a 48-byte premaster secret, encrypts it using the public key\n *   from the server's certificate or the temporary RSA key provided in a\n *   server key exchange message, and sends the result in an encrypted\n *   premaster secret message. This structure is a variant of the client\n *   key exchange message, not a message in itself.\n *\n * struct {\n *   select(KeyExchangeAlgorithm) {\n *     case rsa: EncryptedPreMasterSecret;\n *     case diffie_hellman: ClientDiffieHellmanPublic;\n *   } exchange_keys;\n * } ClientKeyExchange;\n *\n * struct {\n *   ProtocolVersion client_version;\n *   opaque random[46];\n * } PreMasterSecret;\n *\n * struct {\n *   public-key-encrypted PreMasterSecret pre_master_secret;\n * } EncryptedPreMasterSecret;\n *\n * A public-key-encrypted element is encoded as a vector <0..2^16-1>.\n *\n * @param c the connection.\n *\n * @return the ClientKeyExchange byte buffer.\n */\ntls.createClientKeyExchange = function(c) {\n  // create buffer to encrypt\n  var b = forge.util.createBuffer();\n\n  // add highest client-supported protocol to help server avoid version\n  // rollback attacks\n  b.putByte(c.session.clientHelloVersion.major);\n  b.putByte(c.session.clientHelloVersion.minor);\n\n  // generate and add 46 random bytes\n  b.putBytes(forge.random.getBytes(46));\n\n  // save pre-master secret\n  var sp = c.session.sp;\n  sp.pre_master_secret = b.getBytes();\n\n  // RSA-encrypt the pre-master secret\n  var key = c.session.serverCertificate.publicKey;\n  b = key.encrypt(sp.pre_master_secret);\n\n  /* Note: The encrypted pre-master secret will be stored in a\n    public-key-encrypted opaque vector that has the length prefixed using\n    2 bytes, so include those 2 bytes in the handshake message length. This\n    is done as a minor optimization instead of calling writeVector(). */\n\n  // determine length of the handshake message\n  var length = b.length + 2;\n\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  rval.putByte(tls.HandshakeType.client_key_exchange);\n  rval.putInt24(length);\n  // add vector length bytes\n  rval.putInt16(b.length);\n  rval.putBytes(b);\n  return rval;\n};\n\n/**\n * Creates a ServerKeyExchange message.\n *\n * @param c the connection.\n *\n * @return the ServerKeyExchange byte buffer.\n */\ntls.createServerKeyExchange = function(c) {\n  // this implementation only supports RSA, no Diffie-Hellman support,\n  // so this record is empty\n\n  // determine length of the handshake message\n  var length = 0;\n\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  if(length > 0) {\n    rval.putByte(tls.HandshakeType.server_key_exchange);\n    rval.putInt24(length);\n  }\n  return rval;\n};\n\n/**\n * Gets the signed data used to verify a client-side certificate. See\n * tls.createCertificateVerify() for details.\n *\n * @param c the connection.\n * @param callback the callback to call once the signed data is ready.\n */\ntls.getClientSignature = function(c, callback) {\n  // generate data to RSA encrypt\n  var b = forge.util.createBuffer();\n  b.putBuffer(c.session.md5.digest());\n  b.putBuffer(c.session.sha1.digest());\n  b = b.getBytes();\n\n  // create default signing function as necessary\n  c.getSignature = c.getSignature || function(c, b, callback) {\n    // do rsa encryption, call callback\n    var privateKey = null;\n    if(c.getPrivateKey) {\n      try {\n        privateKey = c.getPrivateKey(c, c.session.clientCertificate);\n        privateKey = forge.pki.privateKeyFromPem(privateKey);\n      } catch(ex) {\n        c.error(c, {\n          message: 'Could not get private key.',\n          cause: ex,\n          send: true,\n          alert: {\n            level: tls.Alert.Level.fatal,\n            description: tls.Alert.Description.internal_error\n          }\n        });\n      }\n    }\n    if(privateKey === null) {\n      c.error(c, {\n        message: 'No private key set.',\n        send: true,\n        alert: {\n          level: tls.Alert.Level.fatal,\n          description: tls.Alert.Description.internal_error\n        }\n      });\n    } else {\n      b = privateKey.sign(b, null);\n    }\n    callback(c, b);\n  };\n\n  // get client signature\n  c.getSignature(c, b, callback);\n};\n\n/**\n * Creates a CertificateVerify message.\n *\n * Meaning of this message:\n *   This structure conveys the client's Diffie-Hellman public value\n *   (Yc) if it was not already included in the client's certificate.\n *   The encoding used for Yc is determined by the enumerated\n *   PublicValueEncoding. This structure is a variant of the client\n *   key exchange message, not a message in itself.\n *\n * When this message will be sent:\n *   This message is used to provide explicit verification of a client\n *   certificate. This message is only sent following a client\n *   certificate that has signing capability (i.e. all certificates\n *   except those containing fixed Diffie-Hellman parameters). When\n *   sent, it will immediately follow the client key exchange message.\n *\n * struct {\n *   Signature signature;\n * } CertificateVerify;\n *\n * CertificateVerify.signature.md5_hash\n *   MD5(handshake_messages);\n *\n * Certificate.signature.sha_hash\n *   SHA(handshake_messages);\n *\n * Here handshake_messages refers to all handshake messages sent or\n * received starting at client hello up to but not including this\n * message, including the type and length fields of the handshake\n * messages.\n *\n * select(SignatureAlgorithm) {\n *   case anonymous: struct { };\n *   case rsa:\n *     digitally-signed struct {\n *       opaque md5_hash[16];\n *       opaque sha_hash[20];\n *     };\n *   case dsa:\n *     digitally-signed struct {\n *       opaque sha_hash[20];\n *     };\n * } Signature;\n *\n * In digital signing, one-way hash functions are used as input for a\n * signing algorithm. A digitally-signed element is encoded as an opaque\n * vector <0..2^16-1>, where the length is specified by the signing\n * algorithm and key.\n *\n * In RSA signing, a 36-byte structure of two hashes (one SHA and one\n * MD5) is signed (encrypted with the private key). It is encoded with\n * PKCS #1 block type 0 or type 1 as described in [PKCS1].\n *\n * In DSS, the 20 bytes of the SHA hash are run directly through the\n * Digital Signing Algorithm with no additional hashing.\n *\n * @param c the connection.\n * @param signature the signature to include in the message.\n *\n * @return the CertificateVerify byte buffer.\n */\ntls.createCertificateVerify = function(c, signature) {\n  /* Note: The signature will be stored in a \"digitally-signed\" opaque\n    vector that has the length prefixed using 2 bytes, so include those\n    2 bytes in the handshake message length. This is done as a minor\n    optimization instead of calling writeVector(). */\n\n  // determine length of the handshake message\n  var length = signature.length + 2;\n\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  rval.putByte(tls.HandshakeType.certificate_verify);\n  rval.putInt24(length);\n  // add vector length bytes\n  rval.putInt16(signature.length);\n  rval.putBytes(signature);\n  return rval;\n};\n\n/**\n * Creates a CertificateRequest message.\n *\n * @param c the connection.\n *\n * @return the CertificateRequest byte buffer.\n */\ntls.createCertificateRequest = function(c) {\n  // TODO: support other certificate types\n  var certTypes = forge.util.createBuffer();\n\n  // common RSA certificate type\n  certTypes.putByte(0x01);\n\n  // add distinguished names from CA store\n  var cAs = forge.util.createBuffer();\n  for(var key in c.caStore.certs) {\n    var cert = c.caStore.certs[key];\n    var dn = forge.pki.distinguishedNameToAsn1(cert.subject);\n    var byteBuffer = forge.asn1.toDer(dn);\n    cAs.putInt16(byteBuffer.length());\n    cAs.putBuffer(byteBuffer);\n  }\n\n  // TODO: TLS 1.2+ has a different format\n\n  // determine length of the handshake message\n  var length =\n    1 + certTypes.length() +\n    2 + cAs.length();\n\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  rval.putByte(tls.HandshakeType.certificate_request);\n  rval.putInt24(length);\n  writeVector(rval, 1, certTypes);\n  writeVector(rval, 2, cAs);\n  return rval;\n};\n\n/**\n * Creates a ServerHelloDone message.\n *\n * @param c the connection.\n *\n * @return the ServerHelloDone byte buffer.\n */\ntls.createServerHelloDone = function(c) {\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  rval.putByte(tls.HandshakeType.server_hello_done);\n  rval.putInt24(0);\n  return rval;\n};\n\n/**\n * Creates a ChangeCipherSpec message.\n *\n * The change cipher spec protocol exists to signal transitions in\n * ciphering strategies. The protocol consists of a single message,\n * which is encrypted and compressed under the current (not the pending)\n * connection state. The message consists of a single byte of value 1.\n *\n * struct {\n *   enum { change_cipher_spec(1), (255) } type;\n * } ChangeCipherSpec;\n *\n * @return the ChangeCipherSpec byte buffer.\n */\ntls.createChangeCipherSpec = function() {\n  var rval = forge.util.createBuffer();\n  rval.putByte(0x01);\n  return rval;\n};\n\n/**\n * Creates a Finished message.\n *\n * struct {\n *   opaque verify_data[12];\n * } Finished;\n *\n * verify_data\n *   PRF(master_secret, finished_label, MD5(handshake_messages) +\n *   SHA-1(handshake_messages)) [0..11];\n *\n * finished_label\n *   For Finished messages sent by the client, the string \"client\n *   finished\". For Finished messages sent by the server, the\n *   string \"server finished\".\n *\n * handshake_messages\n *   All of the data from all handshake messages up to but not\n *   including this message. This is only data visible at the\n *   handshake layer and does not include record layer headers.\n *   This is the concatenation of all the Handshake structures as\n *   defined in 7.4 exchanged thus far.\n *\n * @param c the connection.\n *\n * @return the Finished byte buffer.\n */\ntls.createFinished = function(c) {\n  // generate verify_data\n  var b = forge.util.createBuffer();\n  b.putBuffer(c.session.md5.digest());\n  b.putBuffer(c.session.sha1.digest());\n\n  // TODO: determine prf function and verify length for TLS 1.2\n  var client = (c.entity === tls.ConnectionEnd.client);\n  var sp = c.session.sp;\n  var vdl = 12;\n  var prf = prf_TLS1;\n  var label = client ? 'client finished' : 'server finished';\n  b = prf(sp.master_secret, label, b.getBytes(), vdl);\n\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  rval.putByte(tls.HandshakeType.finished);\n  rval.putInt24(b.length());\n  rval.putBuffer(b);\n  return rval;\n};\n\n/**\n * Creates a HeartbeatMessage (See RFC 6520).\n *\n * struct {\n *   HeartbeatMessageType type;\n *   uint16 payload_length;\n *   opaque payload[HeartbeatMessage.payload_length];\n *   opaque padding[padding_length];\n * } HeartbeatMessage;\n *\n * The total length of a HeartbeatMessage MUST NOT exceed 2^14 or\n * max_fragment_length when negotiated as defined in [RFC6066].\n *\n * type: The message type, either heartbeat_request or heartbeat_response.\n *\n * payload_length: The length of the payload.\n *\n * payload: The payload consists of arbitrary content.\n *\n * padding: The padding is random content that MUST be ignored by the\n *   receiver. The length of a HeartbeatMessage is TLSPlaintext.length\n *   for TLS and DTLSPlaintext.length for DTLS. Furthermore, the\n *   length of the type field is 1 byte, and the length of the\n *   payload_length is 2. Therefore, the padding_length is\n *   TLSPlaintext.length - payload_length - 3 for TLS and\n *   DTLSPlaintext.length - payload_length - 3 for DTLS. The\n *   padding_length MUST be at least 16.\n *\n * The sender of a HeartbeatMessage MUST use a random padding of at\n * least 16 bytes. The padding of a received HeartbeatMessage message\n * MUST be ignored.\n *\n * If the payload_length of a received HeartbeatMessage is too large,\n * the received HeartbeatMessage MUST be discarded silently.\n *\n * @param c the connection.\n * @param type the tls.HeartbeatMessageType.\n * @param payload the heartbeat data to send as the payload.\n * @param [payloadLength] the payload length to use, defaults to the\n *          actual payload length.\n *\n * @return the HeartbeatRequest byte buffer.\n */\ntls.createHeartbeat = function(type, payload, payloadLength) {\n  if(typeof payloadLength === 'undefined') {\n    payloadLength = payload.length;\n  }\n  // build record fragment\n  var rval = forge.util.createBuffer();\n  rval.putByte(type);               // heartbeat message type\n  rval.putInt16(payloadLength);     // payload length\n  rval.putBytes(payload);           // payload\n  // padding\n  var plaintextLength = rval.length();\n  var paddingLength = Math.max(16, plaintextLength - payloadLength - 3);\n  rval.putBytes(forge.random.getBytes(paddingLength));\n  return rval;\n};\n\n/**\n * Fragments, compresses, encrypts, and queues a record for delivery.\n *\n * @param c the connection.\n * @param record the record to queue.\n */\ntls.queue = function(c, record) {\n  // error during record creation\n  if(!record) {\n    return;\n  }\n\n  if(record.fragment.length() === 0) {\n    if(record.type === tls.ContentType.handshake ||\n      record.type === tls.ContentType.alert ||\n      record.type === tls.ContentType.change_cipher_spec) {\n      // Empty handshake, alert of change cipher spec messages are not allowed per the TLS specification and should not be sent.\n      return;\n    }\n  }\n\n  // if the record is a handshake record, update handshake hashes\n  if(record.type === tls.ContentType.handshake) {\n    var bytes = record.fragment.bytes();\n    c.session.md5.update(bytes);\n    c.session.sha1.update(bytes);\n    bytes = null;\n  }\n\n  // handle record fragmentation\n  var records;\n  if(record.fragment.length() <= tls.MaxFragment) {\n    records = [record];\n  } else {\n    // fragment data as long as it is too long\n    records = [];\n    var data = record.fragment.bytes();\n    while(data.length > tls.MaxFragment) {\n      records.push(tls.createRecord(c, {\n        type: record.type,\n        data: forge.util.createBuffer(data.slice(0, tls.MaxFragment))\n      }));\n      data = data.slice(tls.MaxFragment);\n    }\n    // add last record\n    if(data.length > 0) {\n      records.push(tls.createRecord(c, {\n        type: record.type,\n        data: forge.util.createBuffer(data)\n      }));\n    }\n  }\n\n  // compress and encrypt all fragmented records\n  for(var i = 0; i < records.length && !c.fail; ++i) {\n    // update the record using current write state\n    var rec = records[i];\n    var s = c.state.current.write;\n    if(s.update(c, rec)) {\n      // store record\n      c.records.push(rec);\n    }\n  }\n};\n\n/**\n * Flushes all queued records to the output buffer and calls the\n * tlsDataReady() handler on the given connection.\n *\n * @param c the connection.\n *\n * @return true on success, false on failure.\n */\ntls.flush = function(c) {\n  for(var i = 0; i < c.records.length; ++i) {\n    var record = c.records[i];\n\n    // add record header and fragment\n    c.tlsData.putByte(record.type);\n    c.tlsData.putByte(record.version.major);\n    c.tlsData.putByte(record.version.minor);\n    c.tlsData.putInt16(record.fragment.length());\n    c.tlsData.putBuffer(c.records[i].fragment);\n  }\n  c.records = [];\n  return c.tlsDataReady(c);\n};\n\n/**\n * Maps a pki.certificateError to a tls.Alert.Description.\n *\n * @param error the error to map.\n *\n * @return the alert description.\n */\nvar _certErrorToAlertDesc = function(error) {\n  switch(error) {\n  case true:\n    return true;\n  case forge.pki.certificateError.bad_certificate:\n    return tls.Alert.Description.bad_certificate;\n  case forge.pki.certificateError.unsupported_certificate:\n    return tls.Alert.Description.unsupported_certificate;\n  case forge.pki.certificateError.certificate_revoked:\n    return tls.Alert.Description.certificate_revoked;\n  case forge.pki.certificateError.certificate_expired:\n    return tls.Alert.Description.certificate_expired;\n  case forge.pki.certificateError.certificate_unknown:\n    return tls.Alert.Description.certificate_unknown;\n  case forge.pki.certificateError.unknown_ca:\n    return tls.Alert.Description.unknown_ca;\n  default:\n    return tls.Alert.Description.bad_certificate;\n  }\n};\n\n/**\n * Maps a tls.Alert.Description to a pki.certificateError.\n *\n * @param desc the alert description.\n *\n * @return the certificate error.\n */\nvar _alertDescToCertError = function(desc) {\n  switch(desc) {\n  case true:\n    return true;\n  case tls.Alert.Description.bad_certificate:\n    return forge.pki.certificateError.bad_certificate;\n  case tls.Alert.Description.unsupported_certificate:\n    return forge.pki.certificateError.unsupported_certificate;\n  case tls.Alert.Description.certificate_revoked:\n    return forge.pki.certificateError.certificate_revoked;\n  case tls.Alert.Description.certificate_expired:\n    return forge.pki.certificateError.certificate_expired;\n  case tls.Alert.Description.certificate_unknown:\n    return forge.pki.certificateError.certificate_unknown;\n  case tls.Alert.Description.unknown_ca:\n    return forge.pki.certificateError.unknown_ca;\n  default:\n    return forge.pki.certificateError.bad_certificate;\n  }\n};\n\n/**\n * Verifies a certificate chain against the given connection's\n * Certificate Authority store.\n *\n * @param c the TLS connection.\n * @param chain the certificate chain to verify, with the root or highest\n *          authority at the end.\n *\n * @return true if successful, false if not.\n */\ntls.verifyCertificateChain = function(c, chain) {\n  try {\n    // Make a copy of c.verifyOptions so that we can modify options.verify\n    // without modifying c.verifyOptions.\n    var options = {};\n    for (var key in c.verifyOptions) {\n      options[key] = c.verifyOptions[key];\n    }\n\n    options.verify = function(vfd, depth, chain) {\n      // convert pki.certificateError to tls alert description\n      var desc = _certErrorToAlertDesc(vfd);\n\n      // call application callback\n      var ret = c.verify(c, vfd, depth, chain);\n      if(ret !== true) {\n        if(typeof ret === 'object' && !forge.util.isArray(ret)) {\n          // throw custom error\n          var error = new Error('The application rejected the certificate.');\n          error.send = true;\n          error.alert = {\n            level: tls.Alert.Level.fatal,\n            description: tls.Alert.Description.bad_certificate\n          };\n          if(ret.message) {\n            error.message = ret.message;\n          }\n          if(ret.alert) {\n            error.alert.description = ret.alert;\n          }\n          throw error;\n        }\n\n        // convert tls alert description to pki.certificateError\n        if(ret !== vfd) {\n          ret = _alertDescToCertError(ret);\n        }\n      }\n\n      return ret;\n    };\n\n    // verify chain\n    forge.pki.verifyCertificateChain(c.caStore, chain, options);\n  } catch(ex) {\n    // build tls error if not already customized\n    var err = ex;\n    if(typeof err !== 'object' || forge.util.isArray(err)) {\n      err = {\n        send: true,\n        alert: {\n          level: tls.Alert.Level.fatal,\n          description: _certErrorToAlertDesc(ex)\n        }\n      };\n    }\n    if(!('send' in err)) {\n      err.send = true;\n    }\n    if(!('alert' in err)) {\n      err.alert = {\n        level: tls.Alert.Level.fatal,\n        description: _certErrorToAlertDesc(err.error)\n      };\n    }\n\n    // send error\n    c.error(c, err);\n  }\n\n  return !c.fail;\n};\n\n/**\n * Creates a new TLS session cache.\n *\n * @param cache optional map of session ID to cached session.\n * @param capacity the maximum size for the cache (default: 100).\n *\n * @return the new TLS session cache.\n */\ntls.createSessionCache = function(cache, capacity) {\n  var rval = null;\n\n  // assume input is already a session cache object\n  if(cache && cache.getSession && cache.setSession && cache.order) {\n    rval = cache;\n  } else {\n    // create cache\n    rval = {};\n    rval.cache = cache || {};\n    rval.capacity = Math.max(capacity || 100, 1);\n    rval.order = [];\n\n    // store order for sessions, delete session overflow\n    for(var key in cache) {\n      if(rval.order.length <= capacity) {\n        rval.order.push(key);\n      } else {\n        delete cache[key];\n      }\n    }\n\n    // get a session from a session ID (or get any session)\n    rval.getSession = function(sessionId) {\n      var session = null;\n      var key = null;\n\n      // if session ID provided, use it\n      if(sessionId) {\n        key = forge.util.bytesToHex(sessionId);\n      } else if(rval.order.length > 0) {\n        // get first session from cache\n        key = rval.order[0];\n      }\n\n      if(key !== null && key in rval.cache) {\n        // get cached session and remove from cache\n        session = rval.cache[key];\n        delete rval.cache[key];\n        for(var i in rval.order) {\n          if(rval.order[i] === key) {\n            rval.order.splice(i, 1);\n            break;\n          }\n        }\n      }\n\n      return session;\n    };\n\n    // set a session in the cache\n    rval.setSession = function(sessionId, session) {\n      // remove session from cache if at capacity\n      if(rval.order.length === rval.capacity) {\n        var key = rval.order.shift();\n        delete rval.cache[key];\n      }\n      // add session to cache\n      var key = forge.util.bytesToHex(sessionId);\n      rval.order.push(key);\n      rval.cache[key] = session;\n    };\n  }\n\n  return rval;\n};\n\n/**\n * Creates a new TLS connection.\n *\n * See public createConnection() docs for more details.\n *\n * @param options the options for this connection.\n *\n * @return the new TLS connection.\n */\ntls.createConnection = function(options) {\n  var caStore = null;\n  if(options.caStore) {\n    // if CA store is an array, convert it to a CA store object\n    if(forge.util.isArray(options.caStore)) {\n      caStore = forge.pki.createCaStore(options.caStore);\n    } else {\n      caStore = options.caStore;\n    }\n  } else {\n    // create empty CA store\n    caStore = forge.pki.createCaStore();\n  }\n\n  // setup default cipher suites\n  var cipherSuites = options.cipherSuites || null;\n  if(cipherSuites === null) {\n    cipherSuites = [];\n    for(var key in tls.CipherSuites) {\n      cipherSuites.push(tls.CipherSuites[key]);\n    }\n  }\n\n  // set default entity\n  var entity = (options.server || false) ?\n    tls.ConnectionEnd.server : tls.ConnectionEnd.client;\n\n  // create session cache if requested\n  var sessionCache = options.sessionCache ?\n    tls.createSessionCache(options.sessionCache) : null;\n\n  // create TLS connection\n  var c = {\n    version: {major: tls.Version.major, minor: tls.Version.minor},\n    entity: entity,\n    sessionId: options.sessionId,\n    caStore: caStore,\n    sessionCache: sessionCache,\n    cipherSuites: cipherSuites,\n    connected: options.connected,\n    virtualHost: options.virtualHost || null,\n    verifyClient: options.verifyClient || false,\n    verify: options.verify || function(cn, vfd, dpth, cts) {return vfd;},\n    verifyOptions: options.verifyOptions || {},\n    getCertificate: options.getCertificate || null,\n    getPrivateKey: options.getPrivateKey || null,\n    getSignature: options.getSignature || null,\n    input: forge.util.createBuffer(),\n    tlsData: forge.util.createBuffer(),\n    data: forge.util.createBuffer(),\n    tlsDataReady: options.tlsDataReady,\n    dataReady: options.dataReady,\n    heartbeatReceived: options.heartbeatReceived,\n    closed: options.closed,\n    error: function(c, ex) {\n      // set origin if not set\n      ex.origin = ex.origin ||\n        ((c.entity === tls.ConnectionEnd.client) ? 'client' : 'server');\n\n      // send TLS alert\n      if(ex.send) {\n        tls.queue(c, tls.createAlert(c, ex.alert));\n        tls.flush(c);\n      }\n\n      // error is fatal by default\n      var fatal = (ex.fatal !== false);\n      if(fatal) {\n        // set fail flag\n        c.fail = true;\n      }\n\n      // call error handler first\n      options.error(c, ex);\n\n      if(fatal) {\n        // fatal error, close connection, do not clear fail\n        c.close(false);\n      }\n    },\n    deflate: options.deflate || null,\n    inflate: options.inflate || null\n  };\n\n  /**\n   * Resets a closed TLS connection for reuse. Called in c.close().\n   *\n   * @param clearFail true to clear the fail flag (default: true).\n   */\n  c.reset = function(clearFail) {\n    c.version = {major: tls.Version.major, minor: tls.Version.minor};\n    c.record = null;\n    c.session = null;\n    c.peerCertificate = null;\n    c.state = {\n      pending: null,\n      current: null\n    };\n    c.expect = (c.entity === tls.ConnectionEnd.client) ? SHE : CHE;\n    c.fragmented = null;\n    c.records = [];\n    c.open = false;\n    c.handshakes = 0;\n    c.handshaking = false;\n    c.isConnected = false;\n    c.fail = !(clearFail || typeof(clearFail) === 'undefined');\n    c.input.clear();\n    c.tlsData.clear();\n    c.data.clear();\n    c.state.current = tls.createConnectionState(c);\n  };\n\n  // do initial reset of connection\n  c.reset();\n\n  /**\n   * Updates the current TLS engine state based on the given record.\n   *\n   * @param c the TLS connection.\n   * @param record the TLS record to act on.\n   */\n  var _update = function(c, record) {\n    // get record handler (align type in table by subtracting lowest)\n    var aligned = record.type - tls.ContentType.change_cipher_spec;\n    var handlers = ctTable[c.entity][c.expect];\n    if(aligned in handlers) {\n      handlers[aligned](c, record);\n    } else {\n      // unexpected record\n      tls.handleUnexpected(c, record);\n    }\n  };\n\n  /**\n   * Reads the record header and initializes the next record on the given\n   * connection.\n   *\n   * @param c the TLS connection with the next record.\n   *\n   * @return 0 if the input data could be processed, otherwise the\n   *         number of bytes required for data to be processed.\n   */\n  var _readRecordHeader = function(c) {\n    var rval = 0;\n\n    // get input buffer and its length\n    var b = c.input;\n    var len = b.length();\n\n    // need at least 5 bytes to initialize a record\n    if(len < 5) {\n      rval = 5 - len;\n    } else {\n      // enough bytes for header\n      // initialize record\n      c.record = {\n        type: b.getByte(),\n        version: {\n          major: b.getByte(),\n          minor: b.getByte()\n        },\n        length: b.getInt16(),\n        fragment: forge.util.createBuffer(),\n        ready: false\n      };\n\n      // check record version\n      var compatibleVersion = (c.record.version.major === c.version.major);\n      if(compatibleVersion && c.session && c.session.version) {\n        // session version already set, require same minor version\n        compatibleVersion = (c.record.version.minor === c.version.minor);\n      }\n      if(!compatibleVersion) {\n        c.error(c, {\n          message: 'Incompatible TLS version.',\n          send: true,\n          alert: {\n            level: tls.Alert.Level.fatal,\n            description: tls.Alert.Description.protocol_version\n          }\n        });\n      }\n    }\n\n    return rval;\n  };\n\n  /**\n   * Reads the next record's contents and appends its message to any\n   * previously fragmented message.\n   *\n   * @param c the TLS connection with the next record.\n   *\n   * @return 0 if the input data could be processed, otherwise the\n   *         number of bytes required for data to be processed.\n   */\n  var _readRecord = function(c) {\n    var rval = 0;\n\n    // ensure there is enough input data to get the entire record\n    var b = c.input;\n    var len = b.length();\n    if(len < c.record.length) {\n      // not enough data yet, return how much is required\n      rval = c.record.length - len;\n    } else {\n      // there is enough data to parse the pending record\n      // fill record fragment and compact input buffer\n      c.record.fragment.putBytes(b.getBytes(c.record.length));\n      b.compact();\n\n      // update record using current read state\n      var s = c.state.current.read;\n      if(s.update(c, c.record)) {\n        // see if there is a previously fragmented message that the\n        // new record's message fragment should be appended to\n        if(c.fragmented !== null) {\n          // if the record type matches a previously fragmented\n          // record, append the record fragment to it\n          if(c.fragmented.type === c.record.type) {\n            // concatenate record fragments\n            c.fragmented.fragment.putBuffer(c.record.fragment);\n            c.record = c.fragmented;\n          } else {\n            // error, invalid fragmented record\n            c.error(c, {\n              message: 'Invalid fragmented record.',\n              send: true,\n              alert: {\n                level: tls.Alert.Level.fatal,\n                description:\n                  tls.Alert.Description.unexpected_message\n              }\n            });\n          }\n        }\n\n        // record is now ready\n        c.record.ready = true;\n      }\n    }\n\n    return rval;\n  };\n\n  /**\n   * Performs a handshake using the TLS Handshake Protocol, as a client.\n   *\n   * This method should only be called if the connection is in client mode.\n   *\n   * @param sessionId the session ID to use, null to start a new one.\n   */\n  c.handshake = function(sessionId) {\n    // error to call this in non-client mode\n    if(c.entity !== tls.ConnectionEnd.client) {\n      // not fatal error\n      c.error(c, {\n        message: 'Cannot initiate handshake as a server.',\n        fatal: false\n      });\n    } else if(c.handshaking) {\n      // handshake is already in progress, fail but not fatal error\n      c.error(c, {\n        message: 'Handshake already in progress.',\n        fatal: false\n      });\n    } else {\n      // clear fail flag on reuse\n      if(c.fail && !c.open && c.handshakes === 0) {\n        c.fail = false;\n      }\n\n      // now handshaking\n      c.handshaking = true;\n\n      // default to blank (new session)\n      sessionId = sessionId || '';\n\n      // if a session ID was specified, try to find it in the cache\n      var session = null;\n      if(sessionId.length > 0) {\n        if(c.sessionCache) {\n          session = c.sessionCache.getSession(sessionId);\n        }\n\n        // matching session not found in cache, clear session ID\n        if(session === null) {\n          sessionId = '';\n        }\n      }\n\n      // no session given, grab a session from the cache, if available\n      if(sessionId.length === 0 && c.sessionCache) {\n        session = c.sessionCache.getSession();\n        if(session !== null) {\n          sessionId = session.id;\n        }\n      }\n\n      // set up session\n      c.session = {\n        id: sessionId,\n        version: null,\n        cipherSuite: null,\n        compressionMethod: null,\n        serverCertificate: null,\n        certificateRequest: null,\n        clientCertificate: null,\n        sp: {},\n        md5: forge.md.md5.create(),\n        sha1: forge.md.sha1.create()\n      };\n\n      // use existing session information\n      if(session) {\n        // only update version on connection, session version not yet set\n        c.version = session.version;\n        c.session.sp = session.sp;\n      }\n\n      // generate new client random\n      c.session.sp.client_random = tls.createRandom().getBytes();\n\n      // connection now open\n      c.open = true;\n\n      // send hello\n      tls.queue(c, tls.createRecord(c, {\n        type: tls.ContentType.handshake,\n        data: tls.createClientHello(c)\n      }));\n      tls.flush(c);\n    }\n  };\n\n  /**\n   * Called when TLS protocol data has been received from somewhere and should\n   * be processed by the TLS engine.\n   *\n   * @param data the TLS protocol data, as a string, to process.\n   *\n   * @return 0 if the data could be processed, otherwise the number of bytes\n   *         required for data to be processed.\n   */\n  c.process = function(data) {\n    var rval = 0;\n\n    // buffer input data\n    if(data) {\n      c.input.putBytes(data);\n    }\n\n    // process next record if no failure, process will be called after\n    // each record is handled (since handling can be asynchronous)\n    if(!c.fail) {\n      // reset record if ready and now empty\n      if(c.record !== null &&\n        c.record.ready && c.record.fragment.isEmpty()) {\n        c.record = null;\n      }\n\n      // if there is no pending record, try to read record header\n      if(c.record === null) {\n        rval = _readRecordHeader(c);\n      }\n\n      // read the next record (if record not yet ready)\n      if(!c.fail && c.record !== null && !c.record.ready) {\n        rval = _readRecord(c);\n      }\n\n      // record ready to be handled, update engine state\n      if(!c.fail && c.record !== null && c.record.ready) {\n        _update(c, c.record);\n      }\n    }\n\n    return rval;\n  };\n\n  /**\n   * Requests that application data be packaged into a TLS record. The\n   * tlsDataReady handler will be called when the TLS record(s) have been\n   * prepared.\n   *\n   * @param data the application data, as a raw 'binary' encoded string, to\n   *          be sent; to send utf-16/utf-8 string data, use the return value\n   *          of util.encodeUtf8(str).\n   *\n   * @return true on success, false on failure.\n   */\n  c.prepare = function(data) {\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.application_data,\n      data: forge.util.createBuffer(data)\n    }));\n    return tls.flush(c);\n  };\n\n  /**\n   * Requests that a heartbeat request be packaged into a TLS record for\n   * transmission. The tlsDataReady handler will be called when TLS record(s)\n   * have been prepared.\n   *\n   * When a heartbeat response has been received, the heartbeatReceived\n   * handler will be called with the matching payload. This handler can\n   * be used to clear a retransmission timer, etc.\n   *\n   * @param payload the heartbeat data to send as the payload in the message.\n   * @param [payloadLength] the payload length to use, defaults to the\n   *          actual payload length.\n   *\n   * @return true on success, false on failure.\n   */\n  c.prepareHeartbeatRequest = function(payload, payloadLength) {\n    if(payload instanceof forge.util.ByteBuffer) {\n      payload = payload.bytes();\n    }\n    if(typeof payloadLength === 'undefined') {\n      payloadLength = payload.length;\n    }\n    c.expectedHeartbeatPayload = payload;\n    tls.queue(c, tls.createRecord(c, {\n      type: tls.ContentType.heartbeat,\n      data: tls.createHeartbeat(\n        tls.HeartbeatMessageType.heartbeat_request, payload, payloadLength)\n    }));\n    return tls.flush(c);\n  };\n\n  /**\n   * Closes the connection (sends a close_notify alert).\n   *\n   * @param clearFail true to clear the fail flag (default: true).\n   */\n  c.close = function(clearFail) {\n    // save session if connection didn't fail\n    if(!c.fail && c.sessionCache && c.session) {\n      // only need to preserve session ID, version, and security params\n      var session = {\n        id: c.session.id,\n        version: c.session.version,\n        sp: c.session.sp\n      };\n      session.sp.keys = null;\n      c.sessionCache.setSession(session.id, session);\n    }\n\n    if(c.open) {\n      // connection no longer open, clear input\n      c.open = false;\n      c.input.clear();\n\n      // if connected or handshaking, send an alert\n      if(c.isConnected || c.handshaking) {\n        c.isConnected = c.handshaking = false;\n\n        // send close_notify alert\n        tls.queue(c, tls.createAlert(c, {\n          level: tls.Alert.Level.warning,\n          description: tls.Alert.Description.close_notify\n        }));\n        tls.flush(c);\n      }\n\n      // call handler\n      c.closed(c);\n    }\n\n    // reset TLS connection, do not clear fail flag\n    c.reset(clearFail);\n  };\n\n  return c;\n};\n\n/* TLS API */\nmodule.exports = forge.tls = forge.tls || {};\n\n// expose non-functions\nfor(var key in tls) {\n  if(typeof tls[key] !== 'function') {\n    forge.tls[key] = tls[key];\n  }\n}\n\n// expose prf_tls1 for testing\nforge.tls.prf_tls1 = prf_TLS1;\n\n// expose sha1 hmac method\nforge.tls.hmac_sha1 = hmac_sha1;\n\n// expose session cache creation\nforge.tls.createSessionCache = tls.createSessionCache;\n\n/**\n * Creates a new TLS connection. This does not make any assumptions about the\n * transport layer that TLS is working on top of, ie: it does not assume there\n * is a TCP/IP connection or establish one. A TLS connection is totally\n * abstracted away from the layer is runs on top of, it merely establishes a\n * secure channel between a client\" and a \"server\".\n *\n * A TLS connection contains 4 connection states: pending read and write, and\n * current read and write.\n *\n * At initialization, the current read and write states will be null. Only once\n * the security parameters have been set and the keys have been generated can\n * the pending states be converted into current states. Current states will be\n * updated for each record processed.\n *\n * A custom certificate verify callback may be provided to check information\n * like the common name on the server's certificate. It will be called for\n * every certificate in the chain. It has the following signature:\n *\n * variable func(c, certs, index, preVerify)\n * Where:\n * c         The TLS connection\n * verified  Set to true if certificate was verified, otherwise the alert\n *           tls.Alert.Description for why the certificate failed.\n * depth     The current index in the chain, where 0 is the server's cert.\n * certs     The certificate chain, *NOTE* if the server was anonymous then\n *           the chain will be empty.\n *\n * The function returns true on success and on failure either the appropriate\n * tls.Alert.Description or an object with 'alert' set to the appropriate\n * tls.Alert.Description and 'message' set to a custom error message. If true\n * is not returned then the connection will abort using, in order of\n * availability, first the returned alert description, second the preVerify\n * alert description, and lastly the default 'bad_certificate'.\n *\n * There are three callbacks that can be used to make use of client-side\n * certificates where each takes the TLS connection as the first parameter:\n *\n * getCertificate(conn, hint)\n *   The second parameter is a hint as to which certificate should be\n *   returned. If the connection entity is a client, then the hint will be\n *   the CertificateRequest message from the server that is part of the\n *   TLS protocol. If the connection entity is a server, then it will be\n *   the servername list provided via an SNI extension the ClientHello, if\n *   one was provided (empty array if not). The hint can be examined to\n *   determine which certificate to use (advanced). Most implementations\n *   will just return a certificate. The return value must be a\n *   PEM-formatted certificate or an array of PEM-formatted certificates\n *   that constitute a certificate chain, with the first in the array/chain\n *   being the client's certificate.\n * getPrivateKey(conn, certificate)\n *   The second parameter is an forge.pki X.509 certificate object that\n *   is associated with the requested private key. The return value must\n *   be a PEM-formatted private key.\n * getSignature(conn, bytes, callback)\n *   This callback can be used instead of getPrivateKey if the private key\n *   is not directly accessible in javascript or should not be. For\n *   instance, a secure external web service could provide the signature\n *   in exchange for appropriate credentials. The second parameter is a\n *   string of bytes to be signed that are part of the TLS protocol. These\n *   bytes are used to verify that the private key for the previously\n *   provided client-side certificate is accessible to the client. The\n *   callback is a function that takes 2 parameters, the TLS connection\n *   and the RSA encrypted (signed) bytes as a string. This callback must\n *   be called once the signature is ready.\n *\n * @param options the options for this connection:\n *   server: true if the connection is server-side, false for client.\n *   sessionId: a session ID to reuse, null for a new connection.\n *   caStore: an array of certificates to trust.\n *   sessionCache: a session cache to use.\n *   cipherSuites: an optional array of cipher suites to use,\n *     see tls.CipherSuites.\n *   connected: function(conn) called when the first handshake completes.\n *   virtualHost: the virtual server name to use in a TLS SNI extension.\n *   verifyClient: true to require a client certificate in server mode,\n *     'optional' to request one, false not to (default: false).\n *   verify: a handler used to custom verify certificates in the chain.\n *   verifyOptions: an object with options for the certificate chain validation.\n *     See documentation of pki.verifyCertificateChain for possible options.\n *     verifyOptions.verify is ignored. If you wish to specify a verify handler\n *     use the verify key.\n *   getCertificate: an optional callback used to get a certificate or\n *     a chain of certificates (as an array).\n *   getPrivateKey: an optional callback used to get a private key.\n *   getSignature: an optional callback used to get a signature.\n *   tlsDataReady: function(conn) called when TLS protocol data has been\n *     prepared and is ready to be used (typically sent over a socket\n *     connection to its destination), read from conn.tlsData buffer.\n *   dataReady: function(conn) called when application data has\n *     been parsed from a TLS record and should be consumed by the\n *     application, read from conn.data buffer.\n *   closed: function(conn) called when the connection has been closed.\n *   error: function(conn, error) called when there was an error.\n *   deflate: function(inBytes) if provided, will deflate TLS records using\n *     the deflate algorithm if the server supports it.\n *   inflate: function(inBytes) if provided, will inflate TLS records using\n *     the deflate algorithm if the server supports it.\n *\n * @return the new TLS connection.\n */\nforge.tls.createConnection = tls.createConnection;\n","/**\n * A Javascript implementation of AES Cipher Suites for TLS.\n *\n * @author Dave Longley\n *\n * Copyright (c) 2009-2015 Digital Bazaar, Inc.\n *\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./tls');\n\nvar tls = module.exports = forge.tls;\n\n/**\n * Supported cipher suites.\n */\ntls.CipherSuites['TLS_RSA_WITH_AES_128_CBC_SHA'] = {\n  id: [0x00, 0x2f],\n  name: 'TLS_RSA_WITH_AES_128_CBC_SHA',\n  initSecurityParameters: function(sp) {\n    sp.bulk_cipher_algorithm = tls.BulkCipherAlgorithm.aes;\n    sp.cipher_type = tls.CipherType.block;\n    sp.enc_key_length = 16;\n    sp.block_length = 16;\n    sp.fixed_iv_length = 16;\n    sp.record_iv_length = 16;\n    sp.mac_algorithm = tls.MACAlgorithm.hmac_sha1;\n    sp.mac_length = 20;\n    sp.mac_key_length = 20;\n  },\n  initConnectionState: initConnectionState\n};\ntls.CipherSuites['TLS_RSA_WITH_AES_256_CBC_SHA'] = {\n  id: [0x00, 0x35],\n  name: 'TLS_RSA_WITH_AES_256_CBC_SHA',\n  initSecurityParameters: function(sp) {\n    sp.bulk_cipher_algorithm = tls.BulkCipherAlgorithm.aes;\n    sp.cipher_type = tls.CipherType.block;\n    sp.enc_key_length = 32;\n    sp.block_length = 16;\n    sp.fixed_iv_length = 16;\n    sp.record_iv_length = 16;\n    sp.mac_algorithm = tls.MACAlgorithm.hmac_sha1;\n    sp.mac_length = 20;\n    sp.mac_key_length = 20;\n  },\n  initConnectionState: initConnectionState\n};\n\nfunction initConnectionState(state, c, sp) {\n  var client = (c.entity === forge.tls.ConnectionEnd.client);\n\n  // cipher setup\n  state.read.cipherState = {\n    init: false,\n    cipher: forge.cipher.createDecipher('AES-CBC', client ?\n      sp.keys.server_write_key : sp.keys.client_write_key),\n    iv: client ? sp.keys.server_write_IV : sp.keys.client_write_IV\n  };\n  state.write.cipherState = {\n    init: false,\n    cipher: forge.cipher.createCipher('AES-CBC', client ?\n      sp.keys.client_write_key : sp.keys.server_write_key),\n    iv: client ? sp.keys.client_write_IV : sp.keys.server_write_IV\n  };\n  state.read.cipherFunction = decrypt_aes_cbc_sha1;\n  state.write.cipherFunction = encrypt_aes_cbc_sha1;\n\n  // MAC setup\n  state.read.macLength = state.write.macLength = sp.mac_length;\n  state.read.macFunction = state.write.macFunction = tls.hmac_sha1;\n}\n\n/**\n * Encrypts the TLSCompressed record into a TLSCipherText record using AES\n * in CBC mode.\n *\n * @param record the TLSCompressed record to encrypt.\n * @param s the ConnectionState to use.\n *\n * @return true on success, false on failure.\n */\nfunction encrypt_aes_cbc_sha1(record, s) {\n  var rval = false;\n\n  // append MAC to fragment, update sequence number\n  var mac = s.macFunction(s.macKey, s.sequenceNumber, record);\n  record.fragment.putBytes(mac);\n  s.updateSequenceNumber();\n\n  // TLS 1.1+ use an explicit IV every time to protect against CBC attacks\n  var iv;\n  if(record.version.minor === tls.Versions.TLS_1_0.minor) {\n    // use the pre-generated IV when initializing for TLS 1.0, otherwise use\n    // the residue from the previous encryption\n    iv = s.cipherState.init ? null : s.cipherState.iv;\n  } else {\n    iv = forge.random.getBytesSync(16);\n  }\n\n  s.cipherState.init = true;\n\n  // start cipher\n  var cipher = s.cipherState.cipher;\n  cipher.start({iv: iv});\n\n  // TLS 1.1+ write IV into output\n  if(record.version.minor >= tls.Versions.TLS_1_1.minor) {\n    cipher.output.putBytes(iv);\n  }\n\n  // do encryption (default padding is appropriate)\n  cipher.update(record.fragment);\n  if(cipher.finish(encrypt_aes_cbc_sha1_padding)) {\n    // set record fragment to encrypted output\n    record.fragment = cipher.output;\n    record.length = record.fragment.length();\n    rval = true;\n  }\n\n  return rval;\n}\n\n/**\n * Handles padding for aes_cbc_sha1 in encrypt mode.\n *\n * @param blockSize the block size.\n * @param input the input buffer.\n * @param decrypt true in decrypt mode, false in encrypt mode.\n *\n * @return true on success, false on failure.\n */\nfunction encrypt_aes_cbc_sha1_padding(blockSize, input, decrypt) {\n  /* The encrypted data length (TLSCiphertext.length) is one more than the sum\n   of SecurityParameters.block_length, TLSCompressed.length,\n   SecurityParameters.mac_length, and padding_length.\n\n   The padding may be any length up to 255 bytes long, as long as it results in\n   the TLSCiphertext.length being an integral multiple of the block length.\n   Lengths longer than necessary might be desirable to frustrate attacks on a\n   protocol based on analysis of the lengths of exchanged messages. Each uint8\n   in the padding data vector must be filled with the padding length value.\n\n   The padding length should be such that the total size of the\n   GenericBlockCipher structure is a multiple of the cipher's block length.\n   Legal values range from zero to 255, inclusive. This length specifies the\n   length of the padding field exclusive of the padding_length field itself.\n\n   This is slightly different from PKCS#7 because the padding value is 1\n   less than the actual number of padding bytes if you include the\n   padding_length uint8 itself as a padding byte. */\n  if(!decrypt) {\n    // get the number of padding bytes required to reach the blockSize and\n    // subtract 1 for the padding value (to make room for the padding_length\n    // uint8)\n    var padding = blockSize - (input.length() % blockSize);\n    input.fillWithByte(padding - 1, padding);\n  }\n  return true;\n}\n\n/**\n * Handles padding for aes_cbc_sha1 in decrypt mode.\n *\n * @param blockSize the block size.\n * @param output the output buffer.\n * @param decrypt true in decrypt mode, false in encrypt mode.\n *\n * @return true on success, false on failure.\n */\nfunction decrypt_aes_cbc_sha1_padding(blockSize, output, decrypt) {\n  var rval = true;\n  if(decrypt) {\n    /* The last byte in the output specifies the number of padding bytes not\n      including itself. Each of the padding bytes has the same value as that\n      last byte (known as the padding_length). Here we check all padding\n      bytes to ensure they have the value of padding_length even if one of\n      them is bad in order to ward-off timing attacks. */\n    var len = output.length();\n    var paddingLength = output.last();\n    for(var i = len - 1 - paddingLength; i < len - 1; ++i) {\n      rval = rval && (output.at(i) == paddingLength);\n    }\n    if(rval) {\n      // trim off padding bytes and last padding length byte\n      output.truncate(paddingLength + 1);\n    }\n  }\n  return rval;\n}\n\n/**\n * Decrypts a TLSCipherText record into a TLSCompressed record using\n * AES in CBC mode.\n *\n * @param record the TLSCipherText record to decrypt.\n * @param s the ConnectionState to use.\n *\n * @return true on success, false on failure.\n */\nfunction decrypt_aes_cbc_sha1(record, s) {\n  var rval = false;\n\n  var iv;\n  if(record.version.minor === tls.Versions.TLS_1_0.minor) {\n    // use pre-generated IV when initializing for TLS 1.0, otherwise use the\n    // residue from the previous decryption\n    iv = s.cipherState.init ? null : s.cipherState.iv;\n  } else {\n    // TLS 1.1+ use an explicit IV every time to protect against CBC attacks\n    // that is appended to the record fragment\n    iv = record.fragment.getBytes(16);\n  }\n\n  s.cipherState.init = true;\n\n  // start cipher\n  var cipher = s.cipherState.cipher;\n  cipher.start({iv: iv});\n\n  // do decryption\n  cipher.update(record.fragment);\n  rval = cipher.finish(decrypt_aes_cbc_sha1_padding);\n\n  // even if decryption fails, keep going to minimize timing attacks\n\n  // decrypted data:\n  // first (len - 20) bytes = application data\n  // last 20 bytes          = MAC\n  var macLen = s.macLength;\n\n  // create a random MAC to check against should the mac length check fail\n  // Note: do this regardless of the failure to keep timing consistent\n  var mac = forge.random.getBytesSync(macLen);\n\n  // get fragment and mac\n  var len = cipher.output.length();\n  if(len >= macLen) {\n    record.fragment = cipher.output.getBytes(len - macLen);\n    mac = cipher.output.getBytes(macLen);\n  } else {\n    // bad data, but get bytes anyway to try to keep timing consistent\n    record.fragment = cipher.output.getBytes();\n  }\n  record.fragment = forge.util.createBuffer(record.fragment);\n  record.length = record.fragment.length();\n\n  // see if data integrity checks out, update sequence number\n  var mac2 = s.macFunction(s.macKey, s.sequenceNumber, record);\n  s.updateSequenceNumber();\n  rval = compareMacs(s.macKey, mac, mac2) && rval;\n  return rval;\n}\n\n/**\n * Safely compare two MACs. This function will compare two MACs in a way\n * that protects against timing attacks.\n *\n * TODO: Expose elsewhere as a utility API.\n *\n * See: https://www.nccgroup.trust/us/about-us/newsroom-and-events/blog/2011/february/double-hmac-verification/\n *\n * @param key the MAC key to use.\n * @param mac1 as a binary-encoded string of bytes.\n * @param mac2 as a binary-encoded string of bytes.\n *\n * @return true if the MACs are the same, false if not.\n */\nfunction compareMacs(key, mac1, mac2) {\n  var hmac = forge.hmac.create();\n\n  hmac.start('SHA1', key);\n  hmac.update(mac1);\n  mac1 = hmac.digest().getBytes();\n\n  hmac.start(null, null);\n  hmac.update(mac2);\n  mac2 = hmac.digest().getBytes();\n\n  return mac1 === mac2;\n}\n","/**\n * 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 * Copyright (c) 2019 Digital Bazaar, Inc.\n */\n\nvar forge = require('./forge');\nrequire('./asn1');\nvar asn1 = forge.asn1;\n\nexports.privateKeyValidator = {\n  // PrivateKeyInfo\n  name: 'PrivateKeyInfo',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  value: [{\n    // Version (INTEGER)\n    name: 'PrivateKeyInfo.version',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.INTEGER,\n    constructed: false,\n    capture: 'privateKeyVersion'\n  }, {\n    // privateKeyAlgorithm\n    name: 'PrivateKeyInfo.privateKeyAlgorithm',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'AlgorithmIdentifier.algorithm',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OID,\n      constructed: false,\n      capture: 'privateKeyOid'\n    }]\n  }, {\n    // PrivateKey\n    name: 'PrivateKeyInfo',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.OCTETSTRING,\n    constructed: false,\n    capture: 'privateKey'\n  }]\n};\n\nexports.publicKeyValidator = {\n  name: 'SubjectPublicKeyInfo',\n  tagClass: asn1.Class.UNIVERSAL,\n  type: asn1.Type.SEQUENCE,\n  constructed: true,\n  captureAsn1: 'subjectPublicKeyInfo',\n  value: [{\n    name: 'SubjectPublicKeyInfo.AlgorithmIdentifier',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.SEQUENCE,\n    constructed: true,\n    value: [{\n      name: 'AlgorithmIdentifier.algorithm',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.OID,\n      constructed: false,\n      capture: 'publicKeyOid'\n    }]\n  },\n  // capture group for ed25519PublicKey\n  {\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.BITSTRING,\n    constructed: false,\n    composed: true,\n    captureBitStringValue: 'ed25519PublicKey'\n  }\n  // FIXME: this is capture group for rsaPublicKey, use it in this API or\n  // discard?\n  /* {\n    // subjectPublicKey\n    name: 'SubjectPublicKeyInfo.subjectPublicKey',\n    tagClass: asn1.Class.UNIVERSAL,\n    type: asn1.Type.BITSTRING,\n    constructed: false,\n    value: [{\n      // RSAPublicKey\n      name: 'SubjectPublicKeyInfo.subjectPublicKey.RSAPublicKey',\n      tagClass: asn1.Class.UNIVERSAL,\n      type: asn1.Type.SEQUENCE,\n      constructed: true,\n      optional: true,\n      captureAsn1: 'rsaPublicKey'\n    }]\n  } */\n  ]\n};\n","/**\n * JavaScript implementation of Ed25519.\n *\n * Copyright (c) 2017-2019 Digital Bazaar, Inc.\n *\n * This implementation is based on the most excellent TweetNaCl which is\n * in the public domain. Many thanks to its contributors:\n *\n * https://github.com/dchest/tweetnacl-js\n */\nvar forge = require('./forge');\nrequire('./jsbn');\nrequire('./random');\nrequire('./sha512');\nrequire('./util');\nvar asn1Validator = require('./asn1-validator');\nvar publicKeyValidator = asn1Validator.publicKeyValidator;\nvar privateKeyValidator = asn1Validator.privateKeyValidator;\n\nif(typeof BigInteger === 'undefined') {\n  var BigInteger = forge.jsbn.BigInteger;\n}\n\nvar ByteBuffer = forge.util.ByteBuffer;\nvar NativeBuffer = typeof Buffer === 'undefined' ? Uint8Array : Buffer;\n\n/*\n * Ed25519 algorithms, see RFC 8032:\n * https://tools.ietf.org/html/rfc8032\n */\nforge.pki = forge.pki || {};\nmodule.exports = forge.pki.ed25519 = forge.ed25519 = forge.ed25519 || {};\nvar ed25519 = forge.ed25519;\n\ned25519.constants = {};\ned25519.constants.PUBLIC_KEY_BYTE_LENGTH = 32;\ned25519.constants.PRIVATE_KEY_BYTE_LENGTH = 64;\ned25519.constants.SEED_BYTE_LENGTH = 32;\ned25519.constants.SIGN_BYTE_LENGTH = 64;\ned25519.constants.HASH_BYTE_LENGTH = 64;\n\ned25519.generateKeyPair = function(options) {\n  options = options || {};\n  var seed = options.seed;\n  if(seed === undefined) {\n    // generate seed\n    seed = forge.random.getBytesSync(ed25519.constants.SEED_BYTE_LENGTH);\n  } else if(typeof seed === 'string') {\n    if(seed.length !== ed25519.constants.SEED_BYTE_LENGTH) {\n      throw new TypeError(\n        '\"seed\" must be ' + ed25519.constants.SEED_BYTE_LENGTH +\n        ' bytes in length.');\n    }\n  } else if(!(seed instanceof Uint8Array)) {\n    throw new TypeError(\n      '\"seed\" must be a node.js Buffer, Uint8Array, or a binary string.');\n  }\n\n  seed = messageToNativeBuffer({message: seed, encoding: 'binary'});\n\n  var pk = new NativeBuffer(ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n  var sk = new NativeBuffer(ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n  for(var i = 0; i < 32; ++i) {\n    sk[i] = seed[i];\n  }\n  crypto_sign_keypair(pk, sk);\n  return {publicKey: pk, privateKey: sk};\n};\n\n/**\n * Converts a private key from a RFC8410 ASN.1 encoding.\n *\n * @param obj - The asn1 representation of a private key.\n *\n * @returns {Object} keyInfo - The key information.\n * @returns {Buffer|Uint8Array} keyInfo.privateKeyBytes - 32 private key bytes.\n */\ned25519.privateKeyFromAsn1 = function(obj) {\n  var capture = {};\n  var errors = [];\n  var valid = forge.asn1.validate(obj, privateKeyValidator, capture, errors);\n  if(!valid) {\n    var error = new Error('Invalid Key.');\n    error.errors = errors;\n    throw error;\n  }\n  var oid = forge.asn1.derToOid(capture.privateKeyOid);\n  var ed25519Oid = forge.oids.EdDSA25519;\n  if(oid !== ed25519Oid) {\n    throw new Error('Invalid OID \"' + oid + '\"; OID must be \"' +\n      ed25519Oid + '\".');\n  }\n  var privateKey = capture.privateKey;\n  // manually extract the private key bytes from nested octet string, see FIXME:\n  // https://github.com/digitalbazaar/forge/blob/master/lib/asn1.js#L542\n  var privateKeyBytes = messageToNativeBuffer({\n    message: forge.asn1.fromDer(privateKey).value,\n    encoding: 'binary'\n  });\n  // TODO: RFC8410 specifies a format for encoding the public key bytes along\n  // with the private key bytes. `publicKeyBytes` can be returned in the\n  // future. https://tools.ietf.org/html/rfc8410#section-10.3\n  return {privateKeyBytes: privateKeyBytes};\n};\n\n/**\n * Converts a public key from a RFC8410 ASN.1 encoding.\n *\n * @param obj - The asn1 representation of a public key.\n *\n * @return {Buffer|Uint8Array} - 32 public key bytes.\n */\ned25519.publicKeyFromAsn1 = function(obj) {\n  // get SubjectPublicKeyInfo\n  var capture = {};\n  var errors = [];\n  var valid = forge.asn1.validate(obj, publicKeyValidator, capture, errors);\n  if(!valid) {\n    var error = new Error('Invalid Key.');\n    error.errors = errors;\n    throw error;\n  }\n  var oid = forge.asn1.derToOid(capture.publicKeyOid);\n  var ed25519Oid = forge.oids.EdDSA25519;\n  if(oid !== ed25519Oid) {\n    throw new Error('Invalid OID \"' + oid + '\"; OID must be \"' +\n      ed25519Oid + '\".');\n  }\n  var publicKeyBytes = capture.ed25519PublicKey;\n  if(publicKeyBytes.length !== ed25519.constants.PUBLIC_KEY_BYTE_LENGTH) {\n    throw new Error('Key length is invalid.');\n  }\n  return messageToNativeBuffer({\n    message: publicKeyBytes,\n    encoding: 'binary'\n  });\n};\n\ned25519.publicKeyFromPrivateKey = function(options) {\n  options = options || {};\n  var privateKey = messageToNativeBuffer({\n    message: options.privateKey, encoding: 'binary'\n  });\n  if(privateKey.length !== ed25519.constants.PRIVATE_KEY_BYTE_LENGTH) {\n    throw new TypeError(\n      '\"options.privateKey\" must have a byte length of ' +\n      ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n  }\n\n  var pk = new NativeBuffer(ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n  for(var i = 0; i < pk.length; ++i) {\n    pk[i] = privateKey[32 + i];\n  }\n  return pk;\n};\n\ned25519.sign = function(options) {\n  options = options || {};\n  var msg = messageToNativeBuffer(options);\n  var privateKey = messageToNativeBuffer({\n    message: options.privateKey,\n    encoding: 'binary'\n  });\n  if(privateKey.length === ed25519.constants.SEED_BYTE_LENGTH) {\n    var keyPair = ed25519.generateKeyPair({seed: privateKey});\n    privateKey = keyPair.privateKey;\n  } else if(privateKey.length !== ed25519.constants.PRIVATE_KEY_BYTE_LENGTH) {\n    throw new TypeError(\n      '\"options.privateKey\" must have a byte length of ' +\n      ed25519.constants.SEED_BYTE_LENGTH + ' or ' +\n      ed25519.constants.PRIVATE_KEY_BYTE_LENGTH);\n  }\n\n  var signedMsg = new NativeBuffer(\n    ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n  crypto_sign(signedMsg, msg, msg.length, privateKey);\n\n  var sig = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH);\n  for(var i = 0; i < sig.length; ++i) {\n    sig[i] = signedMsg[i];\n  }\n  return sig;\n};\n\ned25519.verify = function(options) {\n  options = options || {};\n  var msg = messageToNativeBuffer(options);\n  if(options.signature === undefined) {\n    throw new TypeError(\n      '\"options.signature\" must be a node.js Buffer, a Uint8Array, a forge ' +\n      'ByteBuffer, or a binary string.');\n  }\n  var sig = messageToNativeBuffer({\n    message: options.signature,\n    encoding: 'binary'\n  });\n  if(sig.length !== ed25519.constants.SIGN_BYTE_LENGTH) {\n    throw new TypeError(\n      '\"options.signature\" must have a byte length of ' +\n      ed25519.constants.SIGN_BYTE_LENGTH);\n  }\n  var publicKey = messageToNativeBuffer({\n    message: options.publicKey,\n    encoding: 'binary'\n  });\n  if(publicKey.length !== ed25519.constants.PUBLIC_KEY_BYTE_LENGTH) {\n    throw new TypeError(\n      '\"options.publicKey\" must have a byte length of ' +\n      ed25519.constants.PUBLIC_KEY_BYTE_LENGTH);\n  }\n\n  var sm = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n  var m = new NativeBuffer(ed25519.constants.SIGN_BYTE_LENGTH + msg.length);\n  var i;\n  for(i = 0; i < ed25519.constants.SIGN_BYTE_LENGTH; ++i) {\n    sm[i] = sig[i];\n  }\n  for(i = 0; i < msg.length; ++i) {\n    sm[i + ed25519.constants.SIGN_BYTE_LENGTH] = msg[i];\n  }\n  return (crypto_sign_open(m, sm, sm.length, publicKey) >= 0);\n};\n\nfunction messageToNativeBuffer(options) {\n  var message = options.message;\n  if(message instanceof Uint8Array || message instanceof NativeBuffer) {\n    return message;\n  }\n\n  var encoding = options.encoding;\n  if(message === undefined) {\n    if(options.md) {\n      // TODO: more rigorous validation that `md` is a MessageDigest\n      message = options.md.digest().getBytes();\n      encoding = 'binary';\n    } else {\n      throw new TypeError('\"options.message\" or \"options.md\" not specified.');\n    }\n  }\n\n  if(typeof message === 'string' && !encoding) {\n    throw new TypeError('\"options.encoding\" must be \"binary\" or \"utf8\".');\n  }\n\n  if(typeof message === 'string') {\n    if(typeof Buffer !== 'undefined') {\n      return Buffer.from(message, encoding);\n    }\n    message = new ByteBuffer(message, encoding);\n  } else if(!(message instanceof ByteBuffer)) {\n    throw new TypeError(\n      '\"options.message\" must be a node.js Buffer, a Uint8Array, a forge ' +\n      'ByteBuffer, or a string with \"options.encoding\" specifying its ' +\n      'encoding.');\n  }\n\n  // convert to native buffer\n  var buffer = new NativeBuffer(message.length());\n  for(var i = 0; i < buffer.length; ++i) {\n    buffer[i] = message.at(i);\n  }\n  return buffer;\n}\n\nvar gf0 = gf();\nvar gf1 = gf([1]);\nvar D = gf([\n  0x78a3, 0x1359, 0x4dca, 0x75eb, 0xd8ab, 0x4141, 0x0a4d, 0x0070,\n  0xe898, 0x7779, 0x4079, 0x8cc7, 0xfe73, 0x2b6f, 0x6cee, 0x5203]);\nvar D2 = gf([\n  0xf159, 0x26b2, 0x9b94, 0xebd6, 0xb156, 0x8283, 0x149a, 0x00e0,\n  0xd130, 0xeef3, 0x80f2, 0x198e, 0xfce7, 0x56df, 0xd9dc, 0x2406]);\nvar X = gf([\n  0xd51a, 0x8f25, 0x2d60, 0xc956, 0xa7b2, 0x9525, 0xc760, 0x692c,\n  0xdc5c, 0xfdd6, 0xe231, 0xc0a4, 0x53fe, 0xcd6e, 0x36d3, 0x2169]);\nvar Y = gf([\n  0x6658, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666,\n  0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666, 0x6666]);\nvar L = new Float64Array([\n  0xed, 0xd3, 0xf5, 0x5c, 0x1a, 0x63, 0x12, 0x58,\n  0xd6, 0x9c, 0xf7, 0xa2, 0xde, 0xf9, 0xde, 0x14,\n  0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0x10]);\nvar I = gf([\n  0xa0b0, 0x4a0e, 0x1b27, 0xc4ee, 0xe478, 0xad2f, 0x1806, 0x2f43,\n  0xd7a7, 0x3dfb, 0x0099, 0x2b4d, 0xdf0b, 0x4fc1, 0x2480, 0x2b83]);\n\n// TODO: update forge buffer implementation to use `Buffer` or `Uint8Array`,\n// whichever is available, to improve performance\nfunction sha512(msg, msgLen) {\n  // Note: `out` and `msg` are NativeBuffer\n  var md = forge.md.sha512.create();\n  var buffer = new ByteBuffer(msg);\n  md.update(buffer.getBytes(msgLen), 'binary');\n  var hash = md.digest().getBytes();\n  if(typeof Buffer !== 'undefined') {\n    return Buffer.from(hash, 'binary');\n  }\n  var out = new NativeBuffer(ed25519.constants.HASH_BYTE_LENGTH);\n  for(var i = 0; i < 64; ++i) {\n    out[i] = hash.charCodeAt(i);\n  }\n  return out;\n}\n\nfunction crypto_sign_keypair(pk, sk) {\n  var p = [gf(), gf(), gf(), gf()];\n  var i;\n\n  var d = sha512(sk, 32);\n  d[0] &= 248;\n  d[31] &= 127;\n  d[31] |= 64;\n\n  scalarbase(p, d);\n  pack(pk, p);\n\n  for(i = 0; i < 32; ++i) {\n    sk[i + 32] = pk[i];\n  }\n  return 0;\n}\n\n// Note: difference from C - smlen returned, not passed as argument.\nfunction crypto_sign(sm, m, n, sk) {\n  var i, j, x = new Float64Array(64);\n  var p = [gf(), gf(), gf(), gf()];\n\n  var d = sha512(sk, 32);\n  d[0] &= 248;\n  d[31] &= 127;\n  d[31] |= 64;\n\n  var smlen = n + 64;\n  for(i = 0; i < n; ++i) {\n    sm[64 + i] = m[i];\n  }\n  for(i = 0; i < 32; ++i) {\n    sm[32 + i] = d[32 + i];\n  }\n\n  var r = sha512(sm.subarray(32), n + 32);\n  reduce(r);\n  scalarbase(p, r);\n  pack(sm, p);\n\n  for(i = 32; i < 64; ++i) {\n    sm[i] = sk[i];\n  }\n  var h = sha512(sm, n + 64);\n  reduce(h);\n\n  for(i = 32; i < 64; ++i) {\n    x[i] = 0;\n  }\n  for(i = 0; i < 32; ++i) {\n    x[i] = r[i];\n  }\n  for(i = 0; i < 32; ++i) {\n    for(j = 0; j < 32; j++) {\n      x[i + j] += h[i] * d[j];\n    }\n  }\n\n  modL(sm.subarray(32), x);\n  return smlen;\n}\n\nfunction crypto_sign_open(m, sm, n, pk) {\n  var i, mlen;\n  var t = new NativeBuffer(32);\n  var p = [gf(), gf(), gf(), gf()],\n      q = [gf(), gf(), gf(), gf()];\n\n  mlen = -1;\n  if(n < 64) {\n    return -1;\n  }\n\n  if(unpackneg(q, pk)) {\n    return -1;\n  }\n\n  for(i = 0; i < n; ++i) {\n    m[i] = sm[i];\n  }\n  for(i = 0; i < 32; ++i) {\n    m[i + 32] = pk[i];\n  }\n  var h = sha512(m, n);\n  reduce(h);\n  scalarmult(p, q, h);\n\n  scalarbase(q, sm.subarray(32));\n  add(p, q);\n  pack(t, p);\n\n  n -= 64;\n  if(crypto_verify_32(sm, 0, t, 0)) {\n    for(i = 0; i < n; ++i) {\n      m[i] = 0;\n    }\n    return -1;\n  }\n\n  for(i = 0; i < n; ++i) {\n    m[i] = sm[i + 64];\n  }\n  mlen = n;\n  return mlen;\n}\n\nfunction modL(r, x) {\n  var carry, i, j, k;\n  for(i = 63; i >= 32; --i) {\n    carry = 0;\n    for(j = i - 32, k = i - 12; j < k; ++j) {\n      x[j] += carry - 16 * x[i] * L[j - (i - 32)];\n      carry = (x[j] + 128) >> 8;\n      x[j] -= carry * 256;\n    }\n    x[j] += carry;\n    x[i] = 0;\n  }\n  carry = 0;\n  for(j = 0; j < 32; ++j) {\n    x[j] += carry - (x[31] >> 4) * L[j];\n    carry = x[j] >> 8;\n    x[j] &= 255;\n  }\n  for(j = 0; j < 32; ++j) {\n    x[j] -= carry * L[j];\n  }\n  for(i = 0; i < 32; ++i) {\n    x[i + 1] += x[i] >> 8;\n    r[i] = x[i] & 255;\n  }\n}\n\nfunction reduce(r) {\n  var x = new Float64Array(64);\n  for(var i = 0; i < 64; ++i) {\n    x[i] = r[i];\n    r[i] = 0;\n  }\n  modL(r, x);\n}\n\nfunction add(p, q) {\n  var a = gf(), b = gf(), c = gf(),\n      d = gf(), e = gf(), f = gf(),\n      g = gf(), h = gf(), t = gf();\n\n  Z(a, p[1], p[0]);\n  Z(t, q[1], q[0]);\n  M(a, a, t);\n  A(b, p[0], p[1]);\n  A(t, q[0], q[1]);\n  M(b, b, t);\n  M(c, p[3], q[3]);\n  M(c, c, D2);\n  M(d, p[2], q[2]);\n  A(d, d, d);\n  Z(e, b, a);\n  Z(f, d, c);\n  A(g, d, c);\n  A(h, b, a);\n\n  M(p[0], e, f);\n  M(p[1], h, g);\n  M(p[2], g, f);\n  M(p[3], e, h);\n}\n\nfunction cswap(p, q, b) {\n  for(var i = 0; i < 4; ++i) {\n    sel25519(p[i], q[i], b);\n  }\n}\n\nfunction pack(r, p) {\n  var tx = gf(), ty = gf(), zi = gf();\n  inv25519(zi, p[2]);\n  M(tx, p[0], zi);\n  M(ty, p[1], zi);\n  pack25519(r, ty);\n  r[31] ^= par25519(tx) << 7;\n}\n\nfunction pack25519(o, n) {\n  var i, j, b;\n  var m = gf(), t = gf();\n  for(i = 0; i < 16; ++i) {\n    t[i] = n[i];\n  }\n  car25519(t);\n  car25519(t);\n  car25519(t);\n  for(j = 0; j < 2; ++j) {\n    m[0] = t[0] - 0xffed;\n    for(i = 1; i < 15; ++i) {\n      m[i] = t[i] - 0xffff - ((m[i - 1] >> 16) & 1);\n      m[i-1] &= 0xffff;\n    }\n    m[15] = t[15] - 0x7fff - ((m[14] >> 16) & 1);\n    b = (m[15] >> 16) & 1;\n    m[14] &= 0xffff;\n    sel25519(t, m, 1 - b);\n  }\n  for (i = 0; i < 16; i++) {\n    o[2 * i] = t[i] & 0xff;\n    o[2 * i + 1] = t[i] >> 8;\n  }\n}\n\nfunction unpackneg(r, p) {\n  var t = gf(), chk = gf(), num = gf(),\n      den = gf(), den2 = gf(), den4 = gf(),\n      den6 = gf();\n\n  set25519(r[2], gf1);\n  unpack25519(r[1], p);\n  S(num, r[1]);\n  M(den, num, D);\n  Z(num, num, r[2]);\n  A(den, r[2], den);\n\n  S(den2, den);\n  S(den4, den2);\n  M(den6, den4, den2);\n  M(t, den6, num);\n  M(t, t, den);\n\n  pow2523(t, t);\n  M(t, t, num);\n  M(t, t, den);\n  M(t, t, den);\n  M(r[0], t, den);\n\n  S(chk, r[0]);\n  M(chk, chk, den);\n  if(neq25519(chk, num)) {\n    M(r[0], r[0], I);\n  }\n\n  S(chk, r[0]);\n  M(chk, chk, den);\n  if(neq25519(chk, num)) {\n    return -1;\n  }\n\n  if(par25519(r[0]) === (p[31] >> 7)) {\n    Z(r[0], gf0, r[0]);\n  }\n\n  M(r[3], r[0], r[1]);\n  return 0;\n}\n\nfunction unpack25519(o, n) {\n  var i;\n  for(i = 0; i < 16; ++i) {\n    o[i] = n[2 * i] + (n[2 * i + 1] << 8);\n  }\n  o[15] &= 0x7fff;\n}\n\nfunction pow2523(o, i) {\n  var c = gf();\n  var a;\n  for(a = 0; a < 16; ++a) {\n    c[a] = i[a];\n  }\n  for(a = 250; a >= 0; --a) {\n    S(c, c);\n    if(a !== 1) {\n      M(c, c, i);\n    }\n  }\n  for(a = 0; a < 16; ++a) {\n    o[a] = c[a];\n  }\n}\n\nfunction neq25519(a, b) {\n  var c = new NativeBuffer(32);\n  var d = new NativeBuffer(32);\n  pack25519(c, a);\n  pack25519(d, b);\n  return crypto_verify_32(c, 0, d, 0);\n}\n\nfunction crypto_verify_32(x, xi, y, yi) {\n  return vn(x, xi, y, yi, 32);\n}\n\nfunction vn(x, xi, y, yi, n) {\n  var i, d = 0;\n  for(i = 0; i < n; ++i) {\n    d |= x[xi + i] ^ y[yi + i];\n  }\n  return (1 & ((d - 1) >>> 8)) - 1;\n}\n\nfunction par25519(a) {\n  var d = new NativeBuffer(32);\n  pack25519(d, a);\n  return d[0] & 1;\n}\n\nfunction scalarmult(p, q, s) {\n  var b, i;\n  set25519(p[0], gf0);\n  set25519(p[1], gf1);\n  set25519(p[2], gf1);\n  set25519(p[3], gf0);\n  for(i = 255; i >= 0; --i) {\n    b = (s[(i / 8)|0] >> (i & 7)) & 1;\n    cswap(p, q, b);\n    add(q, p);\n    add(p, p);\n    cswap(p, q, b);\n  }\n}\n\nfunction scalarbase(p, s) {\n  var q = [gf(), gf(), gf(), gf()];\n  set25519(q[0], X);\n  set25519(q[1], Y);\n  set25519(q[2], gf1);\n  M(q[3], X, Y);\n  scalarmult(p, q, s);\n}\n\nfunction set25519(r, a) {\n  var i;\n  for(i = 0; i < 16; i++) {\n    r[i] = a[i] | 0;\n  }\n}\n\nfunction inv25519(o, i) {\n  var c = gf();\n  var a;\n  for(a = 0; a < 16; ++a) {\n    c[a] = i[a];\n  }\n  for(a = 253; a >= 0; --a) {\n    S(c, c);\n    if(a !== 2 && a !== 4) {\n      M(c, c, i);\n    }\n  }\n  for(a = 0; a < 16; ++a) {\n    o[a] = c[a];\n  }\n}\n\nfunction car25519(o) {\n  var i, v, c = 1;\n  for(i = 0; i < 16; ++i) {\n    v = o[i] + c + 65535;\n    c = Math.floor(v / 65536);\n    o[i] = v - c * 65536;\n  }\n  o[0] += c - 1 + 37 * (c - 1);\n}\n\nfunction sel25519(p, q, b) {\n  var t, c = ~(b - 1);\n  for(var i = 0; i < 16; ++i) {\n    t = c & (p[i] ^ q[i]);\n    p[i] ^= t;\n    q[i] ^= t;\n  }\n}\n\nfunction gf(init) {\n  var i, r = new Float64Array(16);\n  if(init) {\n    for(i = 0; i < init.length; ++i) {\n      r[i] = init[i];\n    }\n  }\n  return r;\n}\n\nfunction A(o, a, b) {\n  for(var i = 0; i < 16; ++i) {\n    o[i] = a[i] + b[i];\n  }\n}\n\nfunction Z(o, a, b) {\n  for(var i = 0; i < 16; ++i) {\n    o[i] = a[i] - b[i];\n  }\n}\n\nfunction S(o, a) {\n  M(o, a, a);\n}\n\nfunction M(o, a, b) {\n  var v, c,\n     t0 = 0,  t1 = 0,  t2 = 0,  t3 = 0,  t4 = 0,  t5 = 0,  t6 = 0,  t7 = 0,\n     t8 = 0,  t9 = 0, t10 = 0, t11 = 0, t12 = 0, t13 = 0, t14 = 0, t15 = 0,\n    t16 = 0, t17 = 0, t18 = 0, t19 = 0, t20 = 0, t21 = 0, t22 = 0, t23 = 0,\n    t24 = 0, t25 = 0, t26 = 0, t27 = 0, t28 = 0, t29 = 0, t30 = 0,\n    b0 = b[0],\n    b1 = b[1],\n    b2 = b[2],\n    b3 = b[3],\n    b4 = b[4],\n    b5 = b[5],\n    b6 = b[6],\n    b7 = b[7],\n    b8 = b[8],\n    b9 = b[9],\n    b10 = b[10],\n    b11 = b[11],\n    b12 = b[12],\n    b13 = b[13],\n    b14 = b[14],\n    b15 = b[15];\n\n  v = a[0];\n  t0 += v * b0;\n  t1 += v * b1;\n  t2 += v * b2;\n  t3 += v * b3;\n  t4 += v * b4;\n  t5 += v * b5;\n  t6 += v * b6;\n  t7 += v * b7;\n  t8 += v * b8;\n  t9 += v * b9;\n  t10 += v * b10;\n  t11 += v * b11;\n  t12 += v * b12;\n  t13 += v * b13;\n  t14 += v * b14;\n  t15 += v * b15;\n  v = a[1];\n  t1 += v * b0;\n  t2 += v * b1;\n  t3 += v * b2;\n  t4 += v * b3;\n  t5 += v * b4;\n  t6 += v * b5;\n  t7 += v * b6;\n  t8 += v * b7;\n  t9 += v * b8;\n  t10 += v * b9;\n  t11 += v * b10;\n  t12 += v * b11;\n  t13 += v * b12;\n  t14 += v * b13;\n  t15 += v * b14;\n  t16 += v * b15;\n  v = a[2];\n  t2 += v * b0;\n  t3 += v * b1;\n  t4 += v * b2;\n  t5 += v * b3;\n  t6 += v * b4;\n  t7 += v * b5;\n  t8 += v * b6;\n  t9 += v * b7;\n  t10 += v * b8;\n  t11 += v * b9;\n  t12 += v * b10;\n  t13 += v * b11;\n  t14 += v * b12;\n  t15 += v * b13;\n  t16 += v * b14;\n  t17 += v * b15;\n  v = a[3];\n  t3 += v * b0;\n  t4 += v * b1;\n  t5 += v * b2;\n  t6 += v * b3;\n  t7 += v * b4;\n  t8 += v * b5;\n  t9 += v * b6;\n  t10 += v * b7;\n  t11 += v * b8;\n  t12 += v * b9;\n  t13 += v * b10;\n  t14 += v * b11;\n  t15 += v * b12;\n  t16 += v * b13;\n  t17 += v * b14;\n  t18 += v * b15;\n  v = a[4];\n  t4 += v * b0;\n  t5 += v * b1;\n  t6 += v * b2;\n  t7 += v * b3;\n  t8 += v * b4;\n  t9 += v * b5;\n  t10 += v * b6;\n  t11 += v * b7;\n  t12 += v * b8;\n  t13 += v * b9;\n  t14 += v * b10;\n  t15 += v * b11;\n  t16 += v * b12;\n  t17 += v * b13;\n  t18 += v * b14;\n  t19 += v * b15;\n  v = a[5];\n  t5 += v * b0;\n  t6 += v * b1;\n  t7 += v * b2;\n  t8 += v * b3;\n  t9 += v * b4;\n  t10 += v * b5;\n  t11 += v * b6;\n  t12 += v * b7;\n  t13 += v * b8;\n  t14 += v * b9;\n  t15 += v * b10;\n  t16 += v * b11;\n  t17 += v * b12;\n  t18 += v * b13;\n  t19 += v * b14;\n  t20 += v * b15;\n  v = a[6];\n  t6 += v * b0;\n  t7 += v * b1;\n  t8 += v * b2;\n  t9 += v * b3;\n  t10 += v * b4;\n  t11 += v * b5;\n  t12 += v * b6;\n  t13 += v * b7;\n  t14 += v * b8;\n  t15 += v * b9;\n  t16 += v * b10;\n  t17 += v * b11;\n  t18 += v * b12;\n  t19 += v * b13;\n  t20 += v * b14;\n  t21 += v * b15;\n  v = a[7];\n  t7 += v * b0;\n  t8 += v * b1;\n  t9 += v * b2;\n  t10 += v * b3;\n  t11 += v * b4;\n  t12 += v * b5;\n  t13 += v * b6;\n  t14 += v * b7;\n  t15 += v * b8;\n  t16 += v * b9;\n  t17 += v * b10;\n  t18 += v * b11;\n  t19 += v * b12;\n  t20 += v * b13;\n  t21 += v * b14;\n  t22 += v * b15;\n  v = a[8];\n  t8 += v * b0;\n  t9 += v * b1;\n  t10 += v * b2;\n  t11 += v * b3;\n  t12 += v * b4;\n  t13 += v * b5;\n  t14 += v * b6;\n  t15 += v * b7;\n  t16 += v * b8;\n  t17 += v * b9;\n  t18 += v * b10;\n  t19 += v * b11;\n  t20 += v * b12;\n  t21 += v * b13;\n  t22 += v * b14;\n  t23 += v * b15;\n  v = a[9];\n  t9 += v * b0;\n  t10 += v * b1;\n  t11 += v * b2;\n  t12 += v * b3;\n  t13 += v * b4;\n  t14 += v * b5;\n  t15 += v * b6;\n  t16 += v * b7;\n  t17 += v * b8;\n  t18 += v * b9;\n  t19 += v * b10;\n  t20 += v * b11;\n  t21 += v * b12;\n  t22 += v * b13;\n  t23 += v * b14;\n  t24 += v * b15;\n  v = a[10];\n  t10 += v * b0;\n  t11 += v * b1;\n  t12 += v * b2;\n  t13 += v * b3;\n  t14 += v * b4;\n  t15 += v * b5;\n  t16 += v * b6;\n  t17 += v * b7;\n  t18 += v * b8;\n  t19 += v * b9;\n  t20 += v * b10;\n  t21 += v * b11;\n  t22 += v * b12;\n  t23 += v * b13;\n  t24 += v * b14;\n  t25 += v * b15;\n  v = a[11];\n  t11 += v * b0;\n  t12 += v * b1;\n  t13 += v * b2;\n  t14 += v * b3;\n  t15 += v * b4;\n  t16 += v * b5;\n  t17 += v * b6;\n  t18 += v * b7;\n  t19 += v * b8;\n  t20 += v * b9;\n  t21 += v * b10;\n  t22 += v * b11;\n  t23 += v * b12;\n  t24 += v * b13;\n  t25 += v * b14;\n  t26 += v * b15;\n  v = a[12];\n  t12 += v * b0;\n  t13 += v * b1;\n  t14 += v * b2;\n  t15 += v * b3;\n  t16 += v * b4;\n  t17 += v * b5;\n  t18 += v * b6;\n  t19 += v * b7;\n  t20 += v * b8;\n  t21 += v * b9;\n  t22 += v * b10;\n  t23 += v * b11;\n  t24 += v * b12;\n  t25 += v * b13;\n  t26 += v * b14;\n  t27 += v * b15;\n  v = a[13];\n  t13 += v * b0;\n  t14 += v * b1;\n  t15 += v * b2;\n  t16 += v * b3;\n  t17 += v * b4;\n  t18 += v * b5;\n  t19 += v * b6;\n  t20 += v * b7;\n  t21 += v * b8;\n  t22 += v * b9;\n  t23 += v * b10;\n  t24 += v * b11;\n  t25 += v * b12;\n  t26 += v * b13;\n  t27 += v * b14;\n  t28 += v * b15;\n  v = a[14];\n  t14 += v * b0;\n  t15 += v * b1;\n  t16 += v * b2;\n  t17 += v * b3;\n  t18 += v * b4;\n  t19 += v * b5;\n  t20 += v * b6;\n  t21 += v * b7;\n  t22 += v * b8;\n  t23 += v * b9;\n  t24 += v * b10;\n  t25 += v * b11;\n  t26 += v * b12;\n  t27 += v * b13;\n  t28 += v * b14;\n  t29 += v * b15;\n  v = a[15];\n  t15 += v * b0;\n  t16 += v * b1;\n  t17 += v * b2;\n  t18 += v * b3;\n  t19 += v * b4;\n  t20 += v * b5;\n  t21 += v * b6;\n  t22 += v * b7;\n  t23 += v * b8;\n  t24 += v * b9;\n  t25 += v * b10;\n  t26 += v * b11;\n  t27 += v * b12;\n  t28 += v * b13;\n  t29 += v * b14;\n  t30 += v * b15;\n\n  t0  += 38 * t16;\n  t1  += 38 * t17;\n  t2  += 38 * t18;\n  t3  += 38 * t19;\n  t4  += 38 * t20;\n  t5  += 38 * t21;\n  t6  += 38 * t22;\n  t7  += 38 * t23;\n  t8  += 38 * t24;\n  t9  += 38 * t25;\n  t10 += 38 * t26;\n  t11 += 38 * t27;\n  t12 += 38 * t28;\n  t13 += 38 * t29;\n  t14 += 38 * t30;\n  // t15 left as is\n\n  // first car\n  c = 1;\n  v =  t0 + c + 65535; c = Math.floor(v / 65536);  t0 = v - c * 65536;\n  v =  t1 + c + 65535; c = Math.floor(v / 65536);  t1 = v - c * 65536;\n  v =  t2 + c + 65535; c = Math.floor(v / 65536);  t2 = v - c * 65536;\n  v =  t3 + c + 65535; c = Math.floor(v / 65536);  t3 = v - c * 65536;\n  v =  t4 + c + 65535; c = Math.floor(v / 65536);  t4 = v - c * 65536;\n  v =  t5 + c + 65535; c = Math.floor(v / 65536);  t5 = v - c * 65536;\n  v =  t6 + c + 65535; c = Math.floor(v / 65536);  t6 = v - c * 65536;\n  v =  t7 + c + 65535; c = Math.floor(v / 65536);  t7 = v - c * 65536;\n  v =  t8 + c + 65535; c = Math.floor(v / 65536);  t8 = v - c * 65536;\n  v =  t9 + c + 65535; c = Math.floor(v / 65536);  t9 = v - c * 65536;\n  v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n  v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n  v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n  v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n  v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n  v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n  t0 += c-1 + 37 * (c-1);\n\n  // second car\n  c = 1;\n  v =  t0 + c + 65535; c = Math.floor(v / 65536);  t0 = v - c * 65536;\n  v =  t1 + c + 65535; c = Math.floor(v / 65536);  t1 = v - c * 65536;\n  v =  t2 + c + 65535; c = Math.floor(v / 65536);  t2 = v - c * 65536;\n  v =  t3 + c + 65535; c = Math.floor(v / 65536);  t3 = v - c * 65536;\n  v =  t4 + c + 65535; c = Math.floor(v / 65536);  t4 = v - c * 65536;\n  v =  t5 + c + 65535; c = Math.floor(v / 65536);  t5 = v - c * 65536;\n  v =  t6 + c + 65535; c = Math.floor(v / 65536);  t6 = v - c * 65536;\n  v =  t7 + c + 65535; c = Math.floor(v / 65536);  t7 = v - c * 65536;\n  v =  t8 + c + 65535; c = Math.floor(v / 65536);  t8 = v - c * 65536;\n  v =  t9 + c + 65535; c = Math.floor(v / 65536);  t9 = v - c * 65536;\n  v = t10 + c + 65535; c = Math.floor(v / 65536); t10 = v - c * 65536;\n  v = t11 + c + 65535; c = Math.floor(v / 65536); t11 = v - c * 65536;\n  v = t12 + c + 65535; c = Math.floor(v / 65536); t12 = v - c * 65536;\n  v = t13 + c + 65535; c = Math.floor(v / 65536); t13 = v - c * 65536;\n  v = t14 + c + 65535; c = Math.floor(v / 65536); t14 = v - c * 65536;\n  v = t15 + c + 65535; c = Math.floor(v / 65536); t15 = v - c * 65536;\n  t0 += c-1 + 37 * (c-1);\n\n  o[ 0] = t0;\n  o[ 1] = t1;\n  o[ 2] = t2;\n  o[ 3] = t3;\n  o[ 4] = t4;\n  o[ 5] = t5;\n  o[ 6] = t6;\n  o[ 7] = t7;\n  o[ 8] = t8;\n  o[ 9] = t9;\n  o[10] = t10;\n  o[11] = t11;\n  o[12] = t12;\n  o[13] = t13;\n  o[14] = t14;\n  o[15] = t15;\n}\n","/**\n * Javascript implementation of PKCS#7 v1.5.\n *\n * @author Stefan Siegl\n * @author Dave Longley\n *\n * Copyright (c) 2012 Stefan Siegl <stesie@brokenpipe.de>\n * Copyright (c) 2012-2015 Digital Bazaar, Inc.\n *\n * Currently this implementation only supports ContentType of EnvelopedData,\n * EncryptedData, or SignedData at the root level. The top level elements may\n * contain only a ContentInfo of ContentType Data, i.e. plain data. Further\n * nesting is not (yet) supported.\n *\n * The Forge validators for PKCS #7's ASN.1 structures are available from\n * a separate file pkcs7asn1.js, since those are referenced from other\n * PKCS standards like PKCS #12.\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./asn1');\nrequire('./des');\nrequire('./oids');\nrequire('./pem');\nrequire('./pkcs7asn1');\nrequire('./random');\nrequire('./util');\nrequire('./x509');\n\n// shortcut for ASN.1 API\nvar asn1 = forge.asn1;\n\n// shortcut for PKCS#7 API\nvar p7 = module.exports = forge.pkcs7 = forge.pkcs7 || {};\n\n/**\n * Converts a PKCS#7 message from PEM format.\n *\n * @param pem the PEM-formatted PKCS#7 message.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromPem = function(pem) {\n  var msg = forge.pem.decode(pem)[0];\n\n  if(msg.type !== 'PKCS7') {\n    var error = new Error('Could not convert PKCS#7 message from PEM; PEM ' +\n      'header type is not \"PKCS#7\".');\n    error.headerType = msg.type;\n    throw error;\n  }\n  if(msg.procType && msg.procType.type === 'ENCRYPTED') {\n    throw new Error('Could not convert PKCS#7 message from PEM; PEM is encrypted.');\n  }\n\n  // convert DER to ASN.1 object\n  var obj = asn1.fromDer(msg.body);\n\n  return p7.messageFromAsn1(obj);\n};\n\n/**\n * Converts a PKCS#7 message to PEM format.\n *\n * @param msg The PKCS#7 message object\n * @param maxline The maximum characters per line, defaults to 64.\n *\n * @return The PEM-formatted PKCS#7 message.\n */\np7.messageToPem = function(msg, maxline) {\n  // convert to ASN.1, then DER, then PEM-encode\n  var pemObj = {\n    type: 'PKCS7',\n    body: asn1.toDer(msg.toAsn1()).getBytes()\n  };\n  return forge.pem.encode(pemObj, {maxline: maxline});\n};\n\n/**\n * Converts a PKCS#7 message from an ASN.1 object.\n *\n * @param obj the ASN.1 representation of a ContentInfo.\n *\n * @return the PKCS#7 message.\n */\np7.messageFromAsn1 = function(obj) {\n  // validate root level ContentInfo and capture data\n  var capture = {};\n  var errors = [];\n  if(!asn1.validate(obj, p7.asn1.contentInfoValidator, capture, errors)) {\n    var error = new Error('Cannot read PKCS#7 message. ' +\n      'ASN.1 object is not an PKCS#7 ContentInfo.');\n    error.errors = errors;\n    throw error;\n  }\n\n  var contentType = asn1.derToOid(capture.contentType);\n  var msg;\n\n  switch(contentType) {\n    case forge.pki.oids.envelopedData:\n      msg = p7.createEnvelopedData();\n      break;\n\n    case forge.pki.oids.encryptedData:\n      msg = p7.createEncryptedData();\n      break;\n\n    case forge.pki.oids.signedData:\n      msg = p7.createSignedData();\n      break;\n\n    default:\n      throw new Error('Cannot read PKCS#7 message. ContentType with OID ' +\n        contentType + ' is not (yet) supported.');\n  }\n\n  msg.fromAsn1(capture.content.value[0]);\n  return msg;\n};\n\np7.createSignedData = function() {\n  var msg = null;\n  msg = {\n    type: forge.pki.oids.signedData,\n    version: 1,\n    certificates: [],\n    crls: [],\n    // TODO: add json-formatted signer stuff here?\n    signers: [],\n    // populated during sign()\n    digestAlgorithmIdentifiers: [],\n    contentInfo: null,\n    signerInfos: [],\n\n    fromAsn1: function(obj) {\n      // validate SignedData content block and capture data.\n      _fromAsn1(msg, obj, p7.asn1.signedDataValidator);\n      msg.certificates = [];\n      msg.crls = [];\n      msg.digestAlgorithmIdentifiers = [];\n      msg.contentInfo = null;\n      msg.signerInfos = [];\n\n      if(msg.rawCapture.certificates) {\n        var certs = msg.rawCapture.certificates.value;\n        for(var i = 0; i < certs.length; ++i) {\n          msg.certificates.push(forge.pki.certificateFromAsn1(certs[i]));\n        }\n      }\n\n      // TODO: parse crls\n    },\n\n    toAsn1: function() {\n      // degenerate case with no content\n      if(!msg.contentInfo) {\n        msg.sign();\n      }\n\n      var certs = [];\n      for(var i = 0; i < msg.certificates.length; ++i) {\n        certs.push(forge.pki.certificateToAsn1(msg.certificates[i]));\n      }\n\n      var crls = [];\n      // TODO: implement CRLs\n\n      // [0] SignedData\n      var signedData = asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n          // Version\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n            asn1.integerToDer(msg.version).getBytes()),\n          // DigestAlgorithmIdentifiers\n          asn1.create(\n            asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n            msg.digestAlgorithmIdentifiers),\n          // ContentInfo\n          msg.contentInfo\n        ])\n      ]);\n      if(certs.length > 0) {\n        // [0] IMPLICIT ExtendedCertificatesAndCertificates OPTIONAL\n        signedData.value[0].value.push(\n          asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, certs));\n      }\n      if(crls.length > 0) {\n        // [1] IMPLICIT CertificateRevocationLists OPTIONAL\n        signedData.value[0].value.push(\n          asn1.create(asn1.Class.CONTEXT_SPECIFIC, 1, true, crls));\n      }\n      // SignerInfos\n      signedData.value[0].value.push(\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n          msg.signerInfos));\n\n      // ContentInfo\n      return asn1.create(\n        asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n          // ContentType\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n            asn1.oidToDer(msg.type).getBytes()),\n          // [0] SignedData\n          signedData\n        ]);\n    },\n\n    /**\n     * Add (another) entity to list of signers.\n     *\n     * Note: If authenticatedAttributes are provided, then, per RFC 2315,\n     * they must include at least two attributes: content type and\n     * message digest. The message digest attribute value will be\n     * auto-calculated during signing and will be ignored if provided.\n     *\n     * Here's an example of providing these two attributes:\n     *\n     * forge.pkcs7.createSignedData();\n     * p7.addSigner({\n     *   issuer: cert.issuer.attributes,\n     *   serialNumber: cert.serialNumber,\n     *   key: privateKey,\n     *   digestAlgorithm: forge.pki.oids.sha1,\n     *   authenticatedAttributes: [{\n     *     type: forge.pki.oids.contentType,\n     *     value: forge.pki.oids.data\n     *   }, {\n     *     type: forge.pki.oids.messageDigest\n     *   }]\n     * });\n     *\n     * TODO: Support [subjectKeyIdentifier] as signer's ID.\n     *\n     * @param signer the signer information:\n     *          key the signer's private key.\n     *          [certificate] a certificate containing the public key\n     *            associated with the signer's private key; use this option as\n     *            an alternative to specifying signer.issuer and\n     *            signer.serialNumber.\n     *          [issuer] the issuer attributes (eg: cert.issuer.attributes).\n     *          [serialNumber] the signer's certificate's serial number in\n     *           hexadecimal (eg: cert.serialNumber).\n     *          [digestAlgorithm] the message digest OID, as a string, to use\n     *            (eg: forge.pki.oids.sha1).\n     *          [authenticatedAttributes] an optional array of attributes\n     *            to also sign along with the content.\n     */\n    addSigner: function(signer) {\n      var issuer = signer.issuer;\n      var serialNumber = signer.serialNumber;\n      if(signer.certificate) {\n        var cert = signer.certificate;\n        if(typeof cert === 'string') {\n          cert = forge.pki.certificateFromPem(cert);\n        }\n        issuer = cert.issuer.attributes;\n        serialNumber = cert.serialNumber;\n      }\n      var key = signer.key;\n      if(!key) {\n        throw new Error(\n          'Could not add PKCS#7 signer; no private key specified.');\n      }\n      if(typeof key === 'string') {\n        key = forge.pki.privateKeyFromPem(key);\n      }\n\n      // ensure OID known for digest algorithm\n      var digestAlgorithm = signer.digestAlgorithm || forge.pki.oids.sha1;\n      switch(digestAlgorithm) {\n      case forge.pki.oids.sha1:\n      case forge.pki.oids.sha256:\n      case forge.pki.oids.sha384:\n      case forge.pki.oids.sha512:\n      case forge.pki.oids.md5:\n        break;\n      default:\n        throw new Error(\n          'Could not add PKCS#7 signer; unknown message digest algorithm: ' +\n          digestAlgorithm);\n      }\n\n      // if authenticatedAttributes is present, then the attributes\n      // must contain at least PKCS #9 content-type and message-digest\n      var authenticatedAttributes = signer.authenticatedAttributes || [];\n      if(authenticatedAttributes.length > 0) {\n        var contentType = false;\n        var messageDigest = false;\n        for(var i = 0; i < authenticatedAttributes.length; ++i) {\n          var attr = authenticatedAttributes[i];\n          if(!contentType && attr.type === forge.pki.oids.contentType) {\n            contentType = true;\n            if(messageDigest) {\n              break;\n            }\n            continue;\n          }\n          if(!messageDigest && attr.type === forge.pki.oids.messageDigest) {\n            messageDigest = true;\n            if(contentType) {\n              break;\n            }\n            continue;\n          }\n        }\n\n        if(!contentType || !messageDigest) {\n          throw new Error('Invalid signer.authenticatedAttributes. If ' +\n            'signer.authenticatedAttributes is specified, then it must ' +\n            'contain at least two attributes, PKCS #9 content-type and ' +\n            'PKCS #9 message-digest.');\n        }\n      }\n\n      msg.signers.push({\n        key: key,\n        version: 1,\n        issuer: issuer,\n        serialNumber: serialNumber,\n        digestAlgorithm: digestAlgorithm,\n        signatureAlgorithm: forge.pki.oids.rsaEncryption,\n        signature: null,\n        authenticatedAttributes: authenticatedAttributes,\n        unauthenticatedAttributes: []\n      });\n    },\n\n    /**\n     * Signs the content.\n     * @param options Options to apply when signing:\n     *    [detached] boolean. If signing should be done in detached mode. Defaults to false.\n     */\n    sign: function(options) {\n      options = options || {};\n      // auto-generate content info\n      if(typeof msg.content !== 'object' || msg.contentInfo === null) {\n        // use Data ContentInfo\n        msg.contentInfo = asn1.create(\n          asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n            // ContentType\n            asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n              asn1.oidToDer(forge.pki.oids.data).getBytes())\n          ]);\n\n        // add actual content, if present\n        if('content' in msg) {\n          var content;\n          if(msg.content instanceof forge.util.ByteBuffer) {\n            content = msg.content.bytes();\n          } else if(typeof msg.content === 'string') {\n            content = forge.util.encodeUtf8(msg.content);\n          }\n\n          if (options.detached) {\n            msg.detachedContent = asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false, content);\n          } else {\n            msg.contentInfo.value.push(\n              // [0] EXPLICIT content\n              asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n                asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OCTETSTRING, false,\n                  content)\n              ]));\n          }\n        }\n      }\n\n      // no signers, return early (degenerate case for certificate container)\n      if(msg.signers.length === 0) {\n        return;\n      }\n\n      // generate digest algorithm identifiers\n      var mds = addDigestAlgorithmIds();\n\n      // generate signerInfos\n      addSignerInfos(mds);\n    },\n\n    verify: function() {\n      throw new Error('PKCS#7 signature verification not yet implemented.');\n    },\n\n    /**\n     * Add a certificate.\n     *\n     * @param cert the certificate to add.\n     */\n    addCertificate: function(cert) {\n      // convert from PEM\n      if(typeof cert === 'string') {\n        cert = forge.pki.certificateFromPem(cert);\n      }\n      msg.certificates.push(cert);\n    },\n\n    /**\n     * Add a certificate revokation list.\n     *\n     * @param crl the certificate revokation list to add.\n     */\n    addCertificateRevokationList: function(crl) {\n      throw new Error('PKCS#7 CRL support not yet implemented.');\n    }\n  };\n  return msg;\n\n  function addDigestAlgorithmIds() {\n    var mds = {};\n\n    for(var i = 0; i < msg.signers.length; ++i) {\n      var signer = msg.signers[i];\n      var oid = signer.digestAlgorithm;\n      if(!(oid in mds)) {\n        // content digest\n        mds[oid] = forge.md[forge.pki.oids[oid]].create();\n      }\n      if(signer.authenticatedAttributes.length === 0) {\n        // no custom attributes to digest; use content message digest\n        signer.md = mds[oid];\n      } else {\n        // custom attributes to be digested; use own message digest\n        // TODO: optimize to just copy message digest state if that\n        // feature is ever supported with message digests\n        signer.md = forge.md[forge.pki.oids[oid]].create();\n      }\n    }\n\n    // add unique digest algorithm identifiers\n    msg.digestAlgorithmIdentifiers = [];\n    for(var oid in mds) {\n      msg.digestAlgorithmIdentifiers.push(\n        // AlgorithmIdentifier\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n          // algorithm\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n            asn1.oidToDer(oid).getBytes()),\n          // parameters (null)\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.NULL, false, '')\n        ]));\n    }\n\n    return mds;\n  }\n\n  function addSignerInfos(mds) {\n    var content;\n\n    if (msg.detachedContent) {\n      // Signature has been made in detached mode.\n      content = msg.detachedContent;\n    } else {\n      // Note: ContentInfo is a SEQUENCE with 2 values, second value is\n      // the content field and is optional for a ContentInfo but required here\n      // since signers are present\n      // get ContentInfo content\n      content = msg.contentInfo.value[1];\n      // skip [0] EXPLICIT content wrapper\n      content = content.value[0];\n    }\n\n    if(!content) {\n      throw new Error(\n        'Could not sign PKCS#7 message; there is no content to sign.');\n    }\n\n    // get ContentInfo content type\n    var contentType = asn1.derToOid(msg.contentInfo.value[0].value);\n\n    // serialize content\n    var bytes = asn1.toDer(content);\n\n    // skip identifier and length per RFC 2315 9.3\n    // skip identifier (1 byte)\n    bytes.getByte();\n    // read and discard length bytes\n    asn1.getBerValueLength(bytes);\n    bytes = bytes.getBytes();\n\n    // digest content DER value bytes\n    for(var oid in mds) {\n      mds[oid].start().update(bytes);\n    }\n\n    // sign content\n    var signingTime = new Date();\n    for(var i = 0; i < msg.signers.length; ++i) {\n      var signer = msg.signers[i];\n\n      if(signer.authenticatedAttributes.length === 0) {\n        // if ContentInfo content type is not \"Data\", then\n        // authenticatedAttributes must be present per RFC 2315\n        if(contentType !== forge.pki.oids.data) {\n          throw new Error(\n            'Invalid signer; authenticatedAttributes must be present ' +\n            'when the ContentInfo content type is not PKCS#7 Data.');\n        }\n      } else {\n        // process authenticated attributes\n        // [0] IMPLICIT\n        signer.authenticatedAttributesAsn1 = asn1.create(\n          asn1.Class.CONTEXT_SPECIFIC, 0, true, []);\n\n        // per RFC 2315, attributes are to be digested using a SET container\n        // not the above [0] IMPLICIT container\n        var attrsAsn1 = asn1.create(\n          asn1.Class.UNIVERSAL, asn1.Type.SET, true, []);\n\n        for(var ai = 0; ai < signer.authenticatedAttributes.length; ++ai) {\n          var attr = signer.authenticatedAttributes[ai];\n          if(attr.type === forge.pki.oids.messageDigest) {\n            // use content message digest as value\n            attr.value = mds[signer.digestAlgorithm].digest();\n          } else if(attr.type === forge.pki.oids.signingTime) {\n            // auto-populate signing time if not already set\n            if(!attr.value) {\n              attr.value = signingTime;\n            }\n          }\n\n          // convert to ASN.1 and push onto Attributes SET (for signing) and\n          // onto authenticatedAttributesAsn1 to complete SignedData ASN.1\n          // TODO: optimize away duplication\n          attrsAsn1.value.push(_attributeToAsn1(attr));\n          signer.authenticatedAttributesAsn1.value.push(_attributeToAsn1(attr));\n        }\n\n        // DER-serialize and digest SET OF attributes only\n        bytes = asn1.toDer(attrsAsn1).getBytes();\n        signer.md.start().update(bytes);\n      }\n\n      // sign digest\n      signer.signature = signer.key.sign(signer.md, 'RSASSA-PKCS1-V1_5');\n    }\n\n    // add signer info\n    msg.signerInfos = _signersToAsn1(msg.signers);\n  }\n};\n\n/**\n * Creates an empty PKCS#7 message of type EncryptedData.\n *\n * @return the message.\n */\np7.createEncryptedData = function() {\n  var msg = null;\n  msg = {\n    type: forge.pki.oids.encryptedData,\n    version: 0,\n    encryptedContent: {\n      algorithm: forge.pki.oids['aes256-CBC']\n    },\n\n    /**\n     * Reads an EncryptedData content block (in ASN.1 format)\n     *\n     * @param obj The ASN.1 representation of the EncryptedData content block\n     */\n    fromAsn1: function(obj) {\n      // Validate EncryptedData content block and capture data.\n      _fromAsn1(msg, obj, p7.asn1.encryptedDataValidator);\n    },\n\n    /**\n     * Decrypt encrypted content\n     *\n     * @param key The (symmetric) key as a byte buffer\n     */\n    decrypt: function(key) {\n      if(key !== undefined) {\n        msg.encryptedContent.key = key;\n      }\n      _decryptContent(msg);\n    }\n  };\n  return msg;\n};\n\n/**\n * Creates an empty PKCS#7 message of type EnvelopedData.\n *\n * @return the message.\n */\np7.createEnvelopedData = function() {\n  var msg = null;\n  msg = {\n    type: forge.pki.oids.envelopedData,\n    version: 0,\n    recipients: [],\n    encryptedContent: {\n      algorithm: forge.pki.oids['aes256-CBC']\n    },\n\n    /**\n     * Reads an EnvelopedData content block (in ASN.1 format)\n     *\n     * @param obj the ASN.1 representation of the EnvelopedData content block.\n     */\n    fromAsn1: function(obj) {\n      // validate EnvelopedData content block and capture data\n      var capture = _fromAsn1(msg, obj, p7.asn1.envelopedDataValidator);\n      msg.recipients = _recipientsFromAsn1(capture.recipientInfos.value);\n    },\n\n    toAsn1: function() {\n      // ContentInfo\n      return asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n        // ContentType\n        asn1.create(asn1.Class.UNIVERSAL, asn1.Type.OID, false,\n          asn1.oidToDer(msg.type).getBytes()),\n        // [0] EnvelopedData\n        asn1.create(asn1.Class.CONTEXT_SPECIFIC, 0, true, [\n          asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true, [\n            // Version\n            asn1.create(asn1.Class.UNIVERSAL, asn1.Type.INTEGER, false,\n              asn1.integerToDer(msg.version).getBytes()),\n            // RecipientInfos\n            asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SET, true,\n              _recipientsToAsn1(msg.recipients)),\n            // EncryptedContentInfo\n            asn1.create(asn1.Class.UNIVERSAL, asn1.Type.SEQUENCE, true,\n              _encryptedContentToAsn1(msg.encryptedContent))\n          ])\n        ])\n      ]);\n    },\n\n    /**\n     * Find recipient by X.509 certificate's issuer.\n     *\n     * @param cert the certificate with the issuer to look for.\n     *\n     * @return the recipient object.\n     */\n    findRecipient: function(cert) {\n      var sAttr = cert.issuer.attributes;\n\n      for(var i = 0; i < msg.recipients.length; ++i) {\n        var r = msg.recipients[i];\n        var rAttr = r.issuer;\n\n        if(r.serialNumber !== cert.serialNumber) {\n          continue;\n        }\n\n        if(rAttr.length !== sAttr.length) {\n          continue;\n        }\n\n        var match = true;\n        for(var j = 0; j < sAttr.length; ++j) {\n          if(rAttr[j].type !== sAttr[j].type ||\n            rAttr[j].value !== sAttr[j].value) {\n            match = false;\n            break;\n          }\n        }\n\n        if(match) {\n          return r;\n        }\n      }\n\n      return null;\n    },\n\n    /**\n     * Decrypt enveloped content\n     *\n     * @param recipient The recipient object related to the private key\n     * @param privKey The (RSA) private key object\n     */\n    decrypt: function(recipient, privKey) {\n      if(msg.encryptedContent.key === undefined && recipient !== undefined &&\n        privKey !== undefined) {\n        switch(recipient.encryptedContent.algorithm) {\n          case forge.pki.oids.rsaEncryption:\n          case forge.pki.oids.desCBC:\n            var key = privKey.decrypt(recipient.encryptedContent.content);\n            msg.encryptedContent.key = forge.util.createBuffer(key);\n            break;\n\n          default:\n            throw new Error('Unsupported asymmetric cipher, ' +\n              'OID ' + recipient.encryptedContent.algorithm);\n        }\n      }\n\n      _decryptContent(msg);\n    },\n\n    /**\n     * Add (another) entity to list of recipients.\n     *\n     * @param cert The certificate of the entity to add.\n     */\n    addRecipient: function(cert) {\n      msg.recipients.push({\n        version: 0,\n        issuer: cert.issuer.attributes,\n        serialNumber: cert.serialNumber,\n        encryptedContent: {\n          // We simply assume rsaEncryption here, since forge.pki only\n          // supports RSA so far.  If the PKI module supports other\n          // ciphers one day, we need to modify this one as well.\n          algorithm: forge.pki.oids.rsaEncryption,\n          key: cert.publicKey\n        }\n      });\n    },\n\n    /**\n     * Encrypt enveloped content.\n     *\n     * This function supports two optional arguments, cipher and key, which\n     * can be used to influence symmetric encryption.  Unless cipher is\n     * provided, the cipher specified in encryptedContent.algorithm is used\n     * (defaults to AES-256-CBC).  If no key is provided, encryptedContent.key\n     * is (re-)used.  If that one's not set, a random key will be generated\n     * automatically.\n     *\n     * @param [key] The key to be used for symmetric encryption.\n     * @param [cipher] The OID of the symmetric cipher to use.\n     */\n    encrypt: function(key, cipher) {\n      // Part 1: Symmetric encryption\n      if(msg.encryptedContent.content === undefined) {\n        cipher = cipher || msg.encryptedContent.algorithm;\n        key = key || msg.encryptedContent.key;\n\n        var keyLen, ivLen, ciphFn;\n        switch(cipher) {\n          case forge.pki.oids['aes128-CBC']:\n            keyLen = 16;\n            ivLen = 16;\n            ciphFn = forge.aes.createEncryptionCipher;\n            break;\n\n          case forge.pki.oids['aes192-CBC']:\n            keyLen = 24;\n            ivLen = 16;\n            ciphFn = forge.aes.createEncryptionCipher;\n            break;\n\n          case forge.pki.oids['aes256-CBC']:\n            keyLen = 32;\n            ivLen = 16;\n            ciphFn = forge.aes.createEncryptionCipher;\n            break;\n\n          case forge.pki.oids['des-EDE3-CBC']:\n            keyLen = 24;\n            ivLen = 8;\n            ciphFn = forge.des.createEncryptionCipher;\n            break;\n\n          default:\n            throw new Error('Unsupported symmetric cipher, OID ' + cipher);\n        }\n\n        if(key === undefined) {\n          key = forge.util.createBuffer(forge.random.getBytes(keyLen));\n        } else if(key.length() != keyLen) {\n          throw new Error('Symmetric key has wrong length; ' +\n            'got ' + key.length() + ' bytes, expected ' + keyLen + '.');\n        }\n\n        // Keep a copy of the key & IV in the object, so the caller can\n        // use it for whatever reason.\n        msg.encryptedContent.algorithm = cipher;\n        msg.encryptedContent.key = key;\n        msg.encryptedContent.parameter = forge.util.createBuffer(\n          forge.random.getBytes(ivLen));\n\n        var ciph = ciphFn(key);\n        ciph.start(msg.encryptedContent.parameter.copy());\n        ciph.update(msg.content);\n\n        // The finish function does PKCS#7 padding by default, therefore\n        // no action required by us.\n        if(!ciph.finish()) {\n          throw new Error('Symmetric encryption failed.');\n        }\n\n        msg.encryptedContent.content = ciph.output;\n      }\n\n      // Part 2: asymmetric encryption for each recipient\n      for(var i = 0; i < msg.recipients.length; ++i) {\n        var recipient = msg.recipients[i];\n\n        // Nothing to do, encryption already done.\n        if(recipient.encryptedContent.content !== undefined) {\n          continue;\n        }\n\n        switch(recipient.encryptedContent.algorithm) {\n          case forge.pki.oids.rsaEncryption:\n            recipient.encryptedContent.content =\n              recipient.encryptedContent.key.encrypt(\n                msg.encryptedContent.key.data);\n            break;\n\n          default:\n            throw new Error('Unsupported asymmetric cipher, OID ' +\n              recipient.encryptedContent.algorithm);\n        }\n      }\n    }\n  };\n  return msg;\n};\n\n/**\n * Converts a single recipient from an ASN.1 object.\n *\n * @param obj the ASN.1 RecipientInfo.\n *\n * @return the recipient object.\n */\nfunction _recipientFromAsn1(obj) {\n  // validate EnvelopedData content block and capture data\n  var capture = {};\n  var errors = [];\n  if(!asn1.validate(obj, p7.asn1.recipientInfoValidator, capture, errors)) {\n    var error = new Error('Cannot read PKCS#7 RecipientInfo. ' +\n      'ASN.1 object is not an PKCS#7 RecipientInfo.');\n    error.errors = errors;\n    throw error;\n  }\n\n  return {\n    version: capture.version.charCodeAt(0),\n    issuer: forge.pki.RDNAttributesAsArray(capture.issuer),\n    serialNumber: forge.util.createBuffer(capture.serial).toHex(),\n    encryptedContent: {\n      algorithm: asn1.derToOid(capture.encAlgorithm),\n      parameter: capture.encParameter ? 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 * Node.js module for Forge.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2016 Digital Bazaar, Inc.\n */\nmodule.exports = require('./forge');\nrequire('./aes');\nrequire('./aesCipherSuites');\nrequire('./asn1');\nrequire('./cipher');\nrequire('./des');\nrequire('./ed25519');\nrequire('./hmac');\nrequire('./kem');\nrequire('./log');\nrequire('./md.all');\nrequire('./mgf1');\nrequire('./pbkdf2');\nrequire('./pem');\nrequire('./pkcs1');\nrequire('./pkcs12');\nrequire('./pkcs7');\nrequire('./pki');\nrequire('./prime');\nrequire('./prng');\nrequire('./pss');\nrequire('./random');\nrequire('./rc2');\nrequire('./ssh');\nrequire('./tls');\nrequire('./util');\n","/**\n * Javascript implementation of RSA-KEM.\n *\n * @author Lautaro Cozzani Rodriguez\n * @author Dave Longley\n *\n * Copyright (c) 2014 Lautaro Cozzani <lautaro.cozzani@scytl.com>\n * Copyright (c) 2014 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\nrequire('./random');\nrequire('./jsbn');\n\nmodule.exports = forge.kem = forge.kem || {};\n\nvar BigInteger = forge.jsbn.BigInteger;\n\n/**\n * The API for the RSA Key Encapsulation Mechanism (RSA-KEM) from ISO 18033-2.\n */\nforge.kem.rsa = {};\n\n/**\n * Creates an RSA KEM API object for generating a secret asymmetric key.\n *\n * The symmetric key may be generated via a call to 'encrypt', which will\n * produce a ciphertext to be transmitted to the recipient and a key to be\n * kept secret. The ciphertext is a parameter to be passed to 'decrypt' which\n * will produce the same secret key for the recipient to use to decrypt a\n * message that was encrypted with the secret key.\n *\n * @param kdf the KDF API to use (eg: new forge.kem.kdf1()).\n * @param options the options to use.\n *          [prng] a custom crypto-secure pseudo-random number generator to use,\n *            that must define \"getBytesSync\".\n */\nforge.kem.rsa.create = function(kdf, options) {\n  options = options || {};\n  var prng = options.prng || forge.random;\n\n  var kem = {};\n\n  /**\n   * Generates a secret key and its encapsulation.\n   *\n   * @param publicKey the RSA public key to encrypt with.\n   * @param keyLength the length, in bytes, of the secret key to generate.\n   *\n   * @return an object with:\n   *   encapsulation: the ciphertext for generating the secret key, as a\n   *     binary-encoded string of bytes.\n   *   key: the secret key to use for encrypting a message.\n   */\n  kem.encrypt = function(publicKey, keyLength) {\n    // generate a random r where 1 < r < n\n    var byteLength = Math.ceil(publicKey.n.bitLength() / 8);\n    var r;\n    do {\n      r = new BigInteger(\n        forge.util.bytesToHex(prng.getBytesSync(byteLength)),\n        16).mod(publicKey.n);\n    } while(r.compareTo(BigInteger.ONE) <= 0);\n\n    // prepend r with zeros\n    r = forge.util.hexToBytes(r.toString(16));\n    var zeros = byteLength - r.length;\n    if(zeros > 0) {\n      r = forge.util.fillString(String.fromCharCode(0), zeros) + r;\n    }\n\n    // encrypt the random\n    var encapsulation = publicKey.encrypt(r, 'NONE');\n\n    // generate the secret key\n    var key = kdf.generate(r, keyLength);\n\n    return {encapsulation: encapsulation, key: key};\n  };\n\n  /**\n   * Decrypts an encapsulated secret key.\n   *\n   * @param privateKey the RSA private key to decrypt with.\n   * @param encapsulation the ciphertext for generating the secret key, as\n   *          a binary-encoded string of bytes.\n   * @param keyLength the length, in bytes, of the secret key to generate.\n   *\n   * @return the secret key as a binary-encoded string of bytes.\n   */\n  kem.decrypt = function(privateKey, encapsulation, keyLength) {\n    // decrypt the encapsulation and generate the secret key\n    var r = privateKey.decrypt(encapsulation, 'NONE');\n    return kdf.generate(r, keyLength);\n  };\n\n  return kem;\n};\n\n// TODO: add forge.kem.kdf.create('KDF1', {md: ..., ...}) API?\n\n/**\n * Creates a key derivation API object that implements KDF1 per ISO 18033-2.\n *\n * @param md the hash API to use.\n * @param [digestLength] an optional digest length that must be positive and\n *          less than or equal to md.digestLength.\n *\n * @return a KDF1 API object.\n */\nforge.kem.kdf1 = function(md, digestLength) {\n  _createKDF(this, md, 0, digestLength || md.digestLength);\n};\n\n/**\n * Creates a key derivation API object that implements KDF2 per ISO 18033-2.\n *\n * @param md the hash API to use.\n * @param [digestLength] an optional digest length that must be positive and\n *          less than or equal to md.digestLength.\n *\n * @return a KDF2 API object.\n */\nforge.kem.kdf2 = function(md, digestLength) {\n  _createKDF(this, md, 1, digestLength || md.digestLength);\n};\n\n/**\n * Creates a KDF1 or KDF2 API object.\n *\n * @param md the hash API to use.\n * @param counterStart the starting index for the counter.\n * @param digestLength the digest length to use.\n *\n * @return the KDF API object.\n */\nfunction _createKDF(kdf, md, counterStart, digestLength) {\n  /**\n   * Generate a key of the specified length.\n   *\n   * @param x the binary-encoded byte string to generate a key from.\n   * @param length the number of bytes to generate (the size of the key).\n   *\n   * @return the key as a binary-encoded string.\n   */\n  kdf.generate = function(x, length) {\n    var key = new forge.util.ByteBuffer();\n\n    // run counter from counterStart to ceil(length / Hash.len)\n    var k = Math.ceil(length / digestLength) + counterStart;\n\n    var c = new forge.util.ByteBuffer();\n    for(var i = counterStart; i < k; ++i) {\n      // I2OSP(i, 4): convert counter to an octet string of 4 octets\n      c.putInt32(i);\n\n      // digest 'x' and the counter and add the result to the key\n      md.start();\n      md.update(x + c.getBytes());\n      var hash = md.digest();\n      key.putBytes(hash.getBytes(digestLength));\n    }\n\n    // truncate to the correct key length\n    key.truncate(key.length() - length);\n    return key.getBytes();\n  };\n}\n","/**\n * Cross-browser support for logging in a web application.\n *\n * @author David I. Lehn <dlehn@digitalbazaar.com>\n *\n * Copyright (c) 2008-2013 Digital Bazaar, Inc.\n */\nvar forge = require('./forge');\nrequire('./util');\n\n/* LOG API */\nmodule.exports = forge.log = forge.log || {};\n\n/**\n * Application logging system.\n *\n * Each logger level available as it's own function of the form:\n *   forge.log.level(category, args...)\n * The category is an arbitrary string, and the args are the same as\n * Firebug's console.log API. By default the call will be output as:\n *   'LEVEL [category] <args[0]>, args[1], ...'\n * This enables proper % formatting via the first argument.\n * Each category is enabled by default but can be enabled or disabled with\n * the setCategoryEnabled() function.\n */\n// list of known levels\nforge.log.levels = [\n  'none', 'error', 'warning', 'info', 'debug', 'verbose', 'max'];\n// info on the levels indexed by name:\n//   index: level index\n//   name: uppercased display name\nvar sLevelInfo = {};\n// list of loggers\nvar sLoggers = [];\n/**\n * Standard console logger. If no console support is enabled this will\n * remain null. Check before using.\n */\nvar sConsoleLogger = null;\n\n// logger flags\n/**\n * Lock the level at the current value. Used in cases where user config may\n * set the level such that only critical messages are seen but more verbose\n * messages are needed for debugging or other purposes.\n */\nforge.log.LEVEL_LOCKED = (1 << 1);\n/**\n * Always call log function. By default, the logging system will check the\n * message level against logger.level before calling the log function. This\n * flag allows the function to do its own check.\n */\nforge.log.NO_LEVEL_CHECK = (1 << 2);\n/**\n * Perform message interpolation with the passed arguments. \"%\" style\n * fields in log messages will be replaced by arguments as needed. Some\n * loggers, such as Firebug, may do this automatically. The original log\n * message will be available as 'message' and the interpolated version will\n * be available as 'fullMessage'.\n */\nforge.log.INTERPOLATE = (1 << 3);\n\n// setup each log level\nfor(var i = 0; i < forge.log.levels.length; ++i) {\n  var level = forge.log.levels[i];\n  sLevelInfo[level] = {\n    index: i,\n    name: level.toUpperCase()\n  };\n}\n\n/**\n * Message logger. Will dispatch a message to registered loggers as needed.\n *\n * @param message message object\n */\nforge.log.logMessage = function(message) {\n  var messageLevelIndex = sLevelInfo[message.level].index;\n  for(var i = 0; i < sLoggers.length; ++i) {\n    var logger = sLoggers[i];\n    if(logger.flags & forge.log.NO_LEVEL_CHECK) {\n      logger.f(message);\n    } else {\n      // get logger level\n      var loggerLevelIndex = sLevelInfo[logger.level].index;\n      // check level\n      if(messageLevelIndex <= loggerLevelIndex) {\n        // message critical enough, call logger\n        logger.f(logger, message);\n      }\n    }\n  }\n};\n\n/**\n * Sets the 'standard' key on a message object to:\n * \"LEVEL [category] \" + message\n *\n * @param message a message log object\n */\nforge.log.prepareStandard = function(message) {\n  if(!('standard' in message)) {\n    message.standard =\n      sLevelInfo[message.level].name +\n      //' ' + +message.timestamp +\n      ' [' + message.category + '] ' +\n      message.message;\n  }\n};\n\n/**\n * Sets the 'full' key on a message object to the original message\n * interpolated via % formatting with the message arguments.\n *\n * @param message a message log object.\n */\nforge.log.prepareFull = function(message) {\n  if(!('full' in message)) {\n    // copy args and insert message at the front\n    var args = [message.message];\n    args = args.concat([] || message['arguments']);\n    // format the message\n    message.full = forge.util.format.apply(this, args);\n  }\n};\n\n/**\n * Applies both preparseStandard() and prepareFull() to a message object and\n * store result in 'standardFull'.\n *\n * @param message a message log object.\n */\nforge.log.prepareStandardFull = function(message) {\n  if(!('standardFull' in message)) {\n    // FIXME implement 'standardFull' logging\n    forge.log.prepareStandard(message);\n    message.standardFull = message.standard;\n  }\n};\n\n// create log level functions\nif(true) {\n  // levels for which we want functions\n  var levels = ['error', 'warning', 'info', 'debug', 'verbose'];\n  for(var i = 0; i < levels.length; ++i) {\n    // wrap in a function to ensure proper level var is passed\n    (function(level) {\n      // create function for this level\n      forge.log[level] = function(category, message/*, args...*/) {\n        // convert arguments to real array, remove category and message\n        var args = Array.prototype.slice.call(arguments).slice(2);\n        // create message object\n        // Note: interpolation and standard formatting is done lazily\n        var msg = {\n          timestamp: new Date(),\n          level: level,\n          category: category,\n          message: message,\n          'arguments': args\n          /*standard*/\n          /*full*/\n          /*fullMessage*/\n        };\n        // process this message\n        forge.log.logMessage(msg);\n      };\n    })(levels[i]);\n  }\n}\n\n/**\n * Creates a new logger with specified custom logging function.\n *\n * The logging function has a signature of:\n *   function(logger, message)\n * logger: current logger\n * message: object:\n *   level: level id\n *   category: category\n *   message: string message\n *   arguments: Array of extra arguments\n *   fullMessage: interpolated message and arguments if INTERPOLATE flag set\n *\n * @param logFunction a logging function which takes a log message object\n *          as a parameter.\n *\n * @return a logger object.\n */\nforge.log.makeLogger = function(logFunction) {\n  var logger = {\n    flags: 0,\n    f: logFunction\n  };\n  forge.log.setLevel(logger, 'none');\n  return logger;\n};\n\n/**\n * Sets the current log level on a logger.\n *\n * @param logger the target logger.\n * @param level the new maximum log level as a string.\n *\n * @return true if set, false if not.\n */\nforge.log.setLevel = function(logger, level) {\n  var rval = false;\n  if(logger && !(logger.flags & forge.log.LEVEL_LOCKED)) {\n    for(var i = 0; i < forge.log.levels.length; ++i) {\n      var aValidLevel = forge.log.levels[i];\n      if(level == aValidLevel) {\n        // set level\n        logger.level = level;\n        rval = true;\n        break;\n      }\n    }\n  }\n\n  return rval;\n};\n\n/**\n * Locks the log level at its current value.\n *\n * @param logger the target logger.\n * @param lock boolean lock value, default to true.\n */\nforge.log.lock = function(logger, lock) {\n  if(typeof lock === 'undefined' || lock) {\n    logger.flags |= forge.log.LEVEL_LOCKED;\n  } else {\n    logger.flags &= ~forge.log.LEVEL_LOCKED;\n  }\n};\n\n/**\n * Adds a logger.\n *\n * @param logger the logger object.\n */\nforge.log.addLogger = function(logger) {\n  sLoggers.push(logger);\n};\n\n// setup the console logger if possible, else create fake console.log\nif(typeof(console) !== 'undefined' && 'log' in console) {\n  var logger;\n  if(console.error && console.warn && console.info && console.debug) {\n    // looks like Firebug-style logging is available\n    // level handlers map\n    var levelHandlers = {\n      error: console.error,\n      warning: console.warn,\n      info: console.info,\n      debug: console.debug,\n      verbose: console.debug\n    };\n    var f = function(logger, message) {\n      forge.log.prepareStandard(message);\n      var handler = levelHandlers[message.level];\n      // prepend standard message and concat args\n      var args = [message.standard];\n      args = args.concat(message['arguments'].slice());\n      // apply to low-level console function\n      handler.apply(console, args);\n    };\n    logger = forge.log.makeLogger(f);\n  } else {\n    // only appear to have basic console.log\n    var f = function(logger, message) {\n      forge.log.prepareStandardFull(message);\n      console.log(message.standardFull);\n    };\n    logger = forge.log.makeLogger(f);\n  }\n  forge.log.setLevel(logger, 'debug');\n  forge.log.addLogger(logger);\n  sConsoleLogger = logger;\n} else {\n  // define fake console.log to avoid potential script errors on\n  // browsers that do not have console logging\n  console = {\n    log: function() {}\n  };\n}\n\n/*\n * Check for logging control query vars in current URL.\n *\n * console.level=<level-name>\n * Set's the console log level by name.  Useful to override defaults and\n * allow more verbose logging before a user config is loaded.\n *\n * console.lock=<true|false>\n * Lock the console log level at whatever level it is set at.  This is run\n * after console.level is processed.  Useful to force a level of verbosity\n * that could otherwise be limited by a user config.\n */\nif(sConsoleLogger !== null &&\n  typeof window !== 'undefined' && window.location\n) {\n  var query = new URL(window.location.href).searchParams;\n  if(query.has('console.level')) {\n    // set with last value\n    forge.log.setLevel(\n      sConsoleLogger, query.get('console.level').slice(-1)[0]);\n  }\n  if(query.has('console.lock')) {\n    // set with last value\n    var lock = query.get('console.lock').slice(-1)[0];\n    if(lock == 'true') {\n      forge.log.lock(sConsoleLogger);\n    }\n  }\n}\n\n// provide public access to console logger\nforge.log.consoleLogger = sConsoleLogger;\n","/**\n * Node.js module for all known Forge message digests.\n *\n * @author Dave Longley\n *\n * Copyright 2011-2017 Digital Bazaar, Inc.\n */\nmodule.exports = require('./md');\n\nrequire('./md5');\nrequire('./sha1');\nrequire('./sha256');\nrequire('./sha512');\n","/**\n * Functions to output keys in SSH-friendly formats.\n *\n * This is part of the Forge project which may be used under the terms of\n * either the BSD License or the GNU General Public License (GPL) Version 2.\n *\n * See: https://github.com/digitalbazaar/forge/blob/cbebca3780658703d925b61b2caffb1d263a6c1d/LICENSE\n *\n * @author https://github.com/shellac\n */\nvar forge = require('./forge');\nrequire('./aes');\nrequire('./hmac');\nrequire('./md5');\nrequire('./sha1');\nrequire('./util');\n\nvar ssh = module.exports = forge.ssh = forge.ssh || {};\n\n/**\n * Encodes (and optionally encrypts) a private RSA key as a Putty PPK file.\n *\n * @param privateKey the key.\n * @param passphrase a passphrase to protect the key (falsy for no encryption).\n * @param comment a comment to include in the key file.\n *\n * @return the PPK file as a string.\n */\nssh.privateKeyToPutty = function(privateKey, passphrase, comment) {\n  comment = comment || '';\n  passphrase = passphrase || '';\n  var algorithm = 'ssh-rsa';\n  var encryptionAlgorithm = (passphrase === '') ? 'none' : 'aes256-cbc';\n\n  var ppk = 'PuTTY-User-Key-File-2: ' + algorithm + '\\r\\n';\n  ppk += 'Encryption: ' + encryptionAlgorithm + '\\r\\n';\n  ppk += 'Comment: ' + comment + '\\r\\n';\n\n  // public key into buffer for ppk\n  var pubbuffer = forge.util.createBuffer();\n  _addStringToBuffer(pubbuffer, algorithm);\n  _addBigIntegerToBuffer(pubbuffer, privateKey.e);\n  _addBigIntegerToBuffer(pubbuffer, privateKey.n);\n\n  // write public key\n  var pub = forge.util.encode64(pubbuffer.bytes(), 64);\n  var length = Math.floor(pub.length / 66) + 1; // 66 = 64 + \\r\\n\n  ppk += 'Public-Lines: ' + length + '\\r\\n';\n  ppk += pub;\n\n  // private key into a buffer\n  var privbuffer = forge.util.createBuffer();\n  _addBigIntegerToBuffer(privbuffer, privateKey.d);\n  _addBigIntegerToBuffer(privbuffer, privateKey.p);\n  _addBigIntegerToBuffer(privbuffer, privateKey.q);\n  _addBigIntegerToBuffer(privbuffer, privateKey.qInv);\n\n  // optionally encrypt the private key\n  var priv;\n  if(!passphrase) {\n    // use the unencrypted buffer\n    priv = forge.util.encode64(privbuffer.bytes(), 64);\n  } else {\n    // encrypt RSA key using passphrase\n    var encLen = privbuffer.length() + 16 - 1;\n    encLen -= encLen % 16;\n\n    // pad private key with sha1-d data -- needs to be a multiple of 16\n    var padding = _sha1(privbuffer.bytes());\n\n    padding.truncate(padding.length() - encLen + privbuffer.length());\n    privbuffer.putBuffer(padding);\n\n    var aeskey = forge.util.createBuffer();\n    aeskey.putBuffer(_sha1('\\x00\\x00\\x00\\x00', passphrase));\n    aeskey.putBuffer(_sha1('\\x00\\x00\\x00\\x01', passphrase));\n\n    // encrypt some bytes using CBC mode\n    // key is 40 bytes, so truncate *by* 8 bytes\n    var cipher = forge.aes.createEncryptionCipher(aeskey.truncate(8), 'CBC');\n    cipher.start(forge.util.createBuffer().fillWithByte(0, 16));\n    cipher.update(privbuffer.copy());\n    cipher.finish();\n    var encrypted = cipher.output;\n\n    // Note: this appears to differ from Putty -- is forge wrong, or putty?\n    // due to padding we finish as an exact multiple of 16\n    encrypted.truncate(16); // all padding\n\n    priv = forge.util.encode64(encrypted.bytes(), 64);\n  }\n\n  // output private key\n  length = Math.floor(priv.length / 66) + 1; // 64 + \\r\\n\n  ppk += '\\r\\nPrivate-Lines: ' + length + '\\r\\n';\n  ppk += priv;\n\n  // MAC\n  var mackey = _sha1('putty-private-key-file-mac-key', passphrase);\n\n  var macbuffer = forge.util.createBuffer();\n  _addStringToBuffer(macbuffer, algorithm);\n  _addStringToBuffer(macbuffer, encryptionAlgorithm);\n  _addStringToBuffer(macbuffer, comment);\n  macbuffer.putInt32(pubbuffer.length());\n  macbuffer.putBuffer(pubbuffer);\n  macbuffer.putInt32(privbuffer.length());\n  macbuffer.putBuffer(privbuffer);\n\n  var hmac = forge.hmac.create();\n  hmac.start('sha1', mackey);\n  hmac.update(macbuffer.bytes());\n\n  ppk += '\\r\\nPrivate-MAC: ' + hmac.digest().toHex() + '\\r\\n';\n\n  return ppk;\n};\n\n/**\n * Encodes a public RSA key as an OpenSSH file.\n *\n * @param key the key.\n * @param comment a comment.\n *\n * @return the public key in OpenSSH format.\n */\nssh.publicKeyToOpenSSH = function(key, comment) {\n  var type = 'ssh-rsa';\n  comment = comment || '';\n\n  var buffer = forge.util.createBuffer();\n  _addStringToBuffer(buffer, type);\n  _addBigIntegerToBuffer(buffer, key.e);\n  _addBigIntegerToBuffer(buffer, key.n);\n\n  return type + ' ' + forge.util.encode64(buffer.bytes()) + ' ' + comment;\n};\n\n/**\n * Encodes a private RSA key as an OpenSSH file.\n *\n * @param key the key.\n * @param passphrase a passphrase to protect the key (falsy for no encryption).\n *\n * @return the public key in OpenSSH format.\n */\nssh.privateKeyToOpenSSH = function(privateKey, passphrase) {\n  if(!passphrase) {\n    return forge.pki.privateKeyToPem(privateKey);\n  }\n  // OpenSSH private key is just a legacy format, it seems\n  return forge.pki.encryptRsaPrivateKey(privateKey, passphrase,\n    {legacy: true, algorithm: 'aes128'});\n};\n\n/**\n * Gets the SSH fingerprint for the given public key.\n *\n * @param options the options to use.\n *          [md] the message digest object to use (defaults to forge.md.md5).\n *          [encoding] an alternative output encoding, such as 'hex'\n *            (defaults to none, outputs a byte buffer).\n *          [delimiter] the delimiter to use between bytes for 'hex' encoded\n *            output, eg: ':' (defaults to none).\n *\n * @return the fingerprint as a byte buffer or other encoding based on options.\n */\nssh.getPublicKeyFingerprint = function(key, options) {\n  options = options || {};\n  var md = options.md || forge.md.md5.create();\n\n  var type = 'ssh-rsa';\n  var buffer = forge.util.createBuffer();\n  _addStringToBuffer(buffer, type);\n  _addBigIntegerToBuffer(buffer, key.e);\n  _addBigIntegerToBuffer(buffer, key.n);\n\n  // hash public key bytes\n  md.start();\n  md.update(buffer.getBytes());\n  var digest = md.digest();\n  if(options.encoding === 'hex') {\n    var hex = digest.toHex();\n    if(options.delimiter) {\n      return hex.match(/.{2}/g).join(options.delimiter);\n    }\n    return hex;\n  } else if(options.encoding === 'binary') {\n    return digest.getBytes();\n  } else if(options.encoding) {\n    throw new Error('Unknown encoding \"' + options.encoding + '\".');\n  }\n  return digest;\n};\n\n/**\n * Adds len(val) then val to a buffer.\n *\n * @param buffer the buffer to add to.\n * @param val a big integer.\n */\nfunction _addBigIntegerToBuffer(buffer, val) {\n  var hexVal = val.toString(16);\n  // ensure 2s complement +ve\n  if(hexVal[0] >= '8') {\n    hexVal = '00' + hexVal;\n  }\n  var bytes = forge.util.hexToBytes(hexVal);\n  buffer.putInt32(bytes.length);\n  buffer.putBytes(bytes);\n}\n\n/**\n * Adds len(val) then val to a buffer.\n *\n * @param buffer the buffer to add to.\n * @param val a string.\n */\nfunction _addStringToBuffer(buffer, val) {\n  buffer.putInt32(val.length);\n  buffer.putString(val);\n}\n\n/**\n * Hashes the arguments into one value using SHA-1.\n *\n * @return the sha1 hash of the provided arguments.\n */\nfunction _sha1() {\n  var sha = forge.md.sha1.create();\n  var num = arguments.length;\n  for (var i = 0; i < num; ++i) {\n    sha.update(arguments[i]);\n  }\n  return sha.digest();\n}\n","import { CertificateLoadResult, CertificateLoadReturn, NFeWizardProps } from '@Types';\nimport fs from 'fs';\nimport pem from 'pem';\nimport https from 'https';\nimport forge from 'node-forge';\n\nimport { fileURLToPath } from 'url';\nimport path from 'path';\n\nconst baseDir = path.dirname(fileURLToPath(import.meta.url));\nconst dir = process.env.NODE_ENV === 'production' ? '../resources/certs' : '../../resources/certs';\n\nclass LoadCertificate {\n    private config: NFeWizardProps;\n    private certificate: string;\n    private cert_key: string;\n    constructor(config: NFeWizardProps) {\n        this.config = config;\n        this.certificate = '';\n        this.cert_key = '';\n    }\n\n    private loadCertificateWithPEM(): Promise<CertificateLoadResult> {\n        return new Promise((resolve, reject) => {\n            try {\n\n                const pfxPath = this.config.dfe.pathCertificado;\n                const pfxPassword = this.config.dfe.senhaCertificado;\n\n                const pfxFile = fs.readFileSync(pfxPath);\n                const certsDir = path.resolve(baseDir, dir);\n                const caCerts = fs.readdirSync(certsDir).map(filename => {\n                    const tmp = `${certsDir}/${filename}`;\n                    return fs.readFileSync(tmp);\n                });\n\n                pem.readPkcs12(pfxFile, { p12Password: pfxPassword }, async (error, result) => {\n                    if (error) {\n                        if (error.message.toLowerCase().includes('mac verify error')) {\n                            return reject(new Error(\"Erro ao ler o certificado: Senha incorreta.\"));\n                        } else {\n                            return reject(new Error(`Erro ao ler o certificado: ${error.message}`));\n                        }\n                    }\n\n                    const key = result.key;\n                    this.cert_key = key;\n\n                    const cert = result.cert;\n                    this.certificate = cert;\n\n                    const certForge = forge.pki.certificateFromPem(cert);\n                    const now = new Date();\n                    if (now < certForge.validity.notBefore || now > certForge.validity.notAfter) {\n                        return reject(new Error(\"Erro ao carregar o certificado: O certificado fornecido expirou ou ainda não é válido.\"));\n                    }\n\n                    const agent = new https.Agent({\n                        key: key,\n                        cert: cert,\n                        ca: caCerts,\n                    });\n\n                    resolve({\n                        success: true,\n                        agent,\n                        message: 'Certificado Carregado com Sucesso.'\n                    });\n                });\n            } catch (error: any) {\n                reject(new Error(error.message));\n            }\n        });\n    }\n\n    private loadCertificateWithNodeForge(): Promise<CertificateLoadResult> {\n        return new Promise((resolve, reject) => {\n            try {\n                const pfxPath = this.config.dfe.pathCertificado;\n                const pfxPassword = this.config.dfe.senhaCertificado;\n\n                // Lê o arquivo PFX\n                const pfxFile = fs.readFileSync(pfxPath);\n\n                // Decodifica o arquivo PFX (PKCS#12)\n                const p12Asn1 = forge.asn1.fromDer(pfxFile.toString('binary'));\n                const p12 = forge.pkcs12.pkcs12FromAsn1(p12Asn1, pfxPassword);\n\n                // Extrai a chave privada e o certificado\n                const keyBags = p12.getBags({ bagType: forge.pki.oids.pkcs8ShroudedKeyBag });\n\n                const certBags = p12.getBags({ bagType: forge.pki.oids.certBag });\n\n                // Verificar se o 'keyBags' contém a chave esperada\n                const key = keyBags[forge.pki.oids.pkcs8ShroudedKeyBag]?.[0]?.key;\n                if (!key) {\n                    return reject(new Error(\"Erro ao carregar chave privada do certificado.\"));\n                }\n                const keyPem = forge.pki.privateKeyToPem(key);\n                this.cert_key = keyPem;\n\n                // Verificar se o 'certBags' contém o certificado esperado\n                const cert = certBags[forge.pki.oids.certBag]?.[0]?.cert;\n                if (!cert) {\n                    return reject(new Error(\"Erro ao carregar certificado.\"));\n                }\n                const certPem = forge.pki.certificateToPem(cert);\n                this.certificate = certPem;\n\n                // Converte o certificado para o formato Forge\n                const certForge = forge.pki.certificateFromPem(forge.pki.certificateToPem(cert));\n\n                // Valida a data de validade\n                const now = new Date();\n                if (now < certForge.validity.notBefore || now > certForge.validity.notAfter) {\n                    return reject(new Error(\"Erro ao carregar o certificado: O certificado fornecido expirou ou ainda não é válido.\"));\n                }\n\n                // Carrega os certificados da CA\n                const certsDir = path.resolve(baseDir, dir);\n                const caCerts = fs.readdirSync(certsDir).map(filename => {\n                    const tmp = `${certsDir}/${filename}`;\n                    return fs.readFileSync(tmp);\n                });\n\n                // Configura o agente HTTPS\n                const agent = new https.Agent({\n                    key: keyPem,\n                    cert: certPem,\n                    ca: caCerts,\n                });\n\n                resolve({\n                    success: true,\n                    agent,\n                    message: 'Certificado Carregado com Sucesso.'\n                });\n            } catch (error: any) {\n                reject(new Error(error.message));\n            }\n        });\n    }\n\n    async loadCertificate(): Promise<CertificateLoadReturn> {\n        if (this.config.lib?.useOpenSSL || this.config.lib?.useOpenSSL === undefined) {\n            const { agent } = await this.loadCertificateWithPEM();\n            return { \n                certificate: this.certificate,\n                cert_key: this.cert_key,\n                agent\n            };\n        }\n        const { agent } = await this.loadCertificateWithNodeForge();\n        return { \n            certificate: this.certificate,\n            cert_key: this.cert_key,\n            agent\n        };\n    }\n}\n\nexport default LoadCertificate;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport https from 'https';\n\nimport { NFeWizardProps } from 'src/core/types'\nimport { AxiosInstance } from 'axios';\n\nimport AxiosHttpClient from './AxiosHttpClient';\nimport HttpClientBuilder from './HttpClientBuilder';\nimport ValidateEnvironment from './ValidateEnvironment';\nimport LoadCertificate from './LoadCertificate';\n\nclass Environment {\n    config: NFeWizardProps;\n    certificate: string;\n    cert_key: string;\n    agent: https.Agent;\n    public isLoaded: boolean;\n    constructor(config: NFeWizardProps) {\n        this.config = config;\n        this.certificate = '';\n        this.cert_key = '';\n        this.agent = {} as https.Agent;\n        this.isLoaded = false;\n    }\n\n    getIsLoaded() {\n        return this.isLoaded;\n    }\n\n    getConfig() {\n        return this.config;\n    }\n\n    getCertKey() {\n        return this.cert_key;\n    }\n\n    getCert() {\n        return this.certificate;\n    }\n\n    getHttpAgent() {\n        return this.agent;\n    }\n\n\n    async loadEnvironment() {\n        /** \n         * Verifica configurações obrigatórias \n         * */\n        const validateEnvironment = new ValidateEnvironment();\n        validateEnvironment.checkRequiredSettings(this.config);\n\n\n        /** \n         * Carrega Certificados \n         * */\n        const loadCertificate = new LoadCertificate(this.config);\n        const { agent, certificate, cert_key } = await loadCertificate.loadCertificate();\n\n        this.agent = agent;\n        this.certificate = certificate;\n        this.cert_key = cert_key;\n\n\n        /** \n         * Configura HttpClient \n         * */\n        const httpClient = new AxiosHttpClient();\n        const configAgent = new HttpClientBuilder<AxiosInstance>(this.config, this.agent, httpClient);\n        const axios = configAgent.createHttpClient();\n\n        /** \n         * Armazena informação de ambiente carregado \n         * */\n        this.isLoaded = true;\n        return { axios }\n    }\n\n}\n\nexport default Environment;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\n\ninterface ObjProps {\n  [key: string]: number;\n}\n\nexport const getCodIBGE = (UF: string) => {\n    const UFs: ObjProps = {\n        RO: 11,\n        AC: 12,\n        AM: 13,\n        RR: 14,\n        PA: 15,\n        AP: 16,\n        TO: 17,\n        MA: 21,\n        PI: 22,\n        CE: 23,\n        RN: 24,\n        PB: 25,\n        PE: 26,\n        AL: 27,\n        SE: 28,\n        BA: 29,\n        MG: 31,\n        ES: 32,\n        RJ: 33,\n        SP: 35,\n        PR: 41,\n        SC: 42,\n        RS: 43,\n        MS: 50,\n        MT: 51,\n        GO: 52,\n        DF: 53,\n        AN: 91,\n      }\n    \n    return UFs[UF];\n}","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport Utility from '../../../core/utils/Utility.js';\nimport XmlParser from '../../../core/utils/XmlParser.js';\nimport { AxiosInstance, AxiosResponse } from 'axios';\nimport { SaveFilesImpl, GerarConsultaImpl } from '@Interfaces';\nimport { GenericObject } from '@Types/Utils.js';\nimport { logger } from '@Core/exceptions/logger.js';\n\nabstract class BaseNFE {\n    environment: Environment;\n    utility: Utility;\n    metodo: string;\n    xmlBuilder: XmlBuilder;\n    chaveNfe: string\n    axios: AxiosInstance;\n    saveFiles: SaveFilesImpl;\n    gerarConsulta: GerarConsultaImpl;\n\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, metodo: string, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        this.environment = environment;\n        this.utility = utility;\n        this.xmlBuilder = xmlBuilder;\n        this.metodo = metodo;\n        this.axios = axios;\n        this.saveFiles = saveFiles;\n        this.gerarConsulta = gerarConsulta;\n        this.chaveNfe = \"\";\n    }\n\n    /**\n     * Método de geração do XML - Deve ser implementado pelas subclasses\n     */\n    protected gerarXml(data?: any): string {\n        throw new Error(\"O método 'gerarXml' não foi implementado na subclasse.\");\n    }\n\n    protected setContentType() {\n        const UF = this.environment.config.dfe.UF;\n\n        const ufsAppSoad = ['MG', 'GO', 'MT', 'MS', 'AM'];\n\n        if (ufsAppSoad.includes(UF)) {\n            return 'application/soap+xml'\n        }\n        return 'text/xml; charset=utf-8'\n    }\n\n    /**\n     * Executa a requisição ao webservice SEFAZ\n     * @param {any} [data] - Dados opcionais usados para gerar o XML em algumas subclasses.\n     * @returns {Promise<any>} A resposta do webservice em JSON.\n     */\n    async Exec(data?: any): Promise<any> {\n        let xmlConsulta: string = '';\n        let xmlConsultaSoap: string = '';\n        let webServiceUrlTmp: string = '';\n        let responseInJson: GenericObject | undefined = undefined;\n        let xmlRetorno: AxiosResponse<any, any> = {} as AxiosResponse<any, any>;\n        const ContentType = this.setContentType();\n        try {\n            // Gerando XML específico\n            xmlConsulta = this.gerarXml(data);\n\n            const { xmlFormated, agent, webServiceUrl } = await this.gerarConsulta.gerarConsulta(xmlConsulta, this.metodo);\n\n            xmlConsultaSoap = xmlFormated;\n            webServiceUrlTmp = webServiceUrl;\n\n            // Efetua requisição para o webservice NFEStatusServico\n            xmlRetorno = await this.axios.post(webServiceUrl, xmlFormated, {\n                headers: {\n                    'Content-Type': ContentType,\n                },\n                httpsAgent: agent\n            });\n\n            // Instanciando classe de utilitários com lib xml-js e convertendo XML para XmlParser\n            const json = new XmlParser();\n            responseInJson = json.convertXmlToJson(xmlRetorno.data, this.metodo);\n\n            // Gera erro em caso de Rejeição\n            if (responseInJson.xMotivo.includes('Rejeição')) {\n                throw new Error(responseInJson.xMotivo)\n            }\n\n            return responseInJson;\n        } catch (error: any) {\n            // const logConfig = this.environment.config.lib?.log;\n\n            // if (logConfig) {\n            //     const { armazenarLogs } = logConfig;\n\n            //     if (armazenarLogs) {\n            //         logger.error({\n            //             message: error.message,\n            //             webServiceUrl: webServiceUrlTmp,\n            //             contentType: ContentType,\n            //             xmlSent: xmlConsultaSoap,\n            //             xmlResponse: error.response?.data || 'Sem resposta',\n            //         });\n            //     }\n            // }\n            // console.log(error)\n            throw new Error(error.message)\n        } finally {\n            this.saveFiles.salvaArquivos(xmlConsulta, responseInJson, xmlRetorno, this.metodo, xmlConsultaSoap);\n        }\n    }\n}\n\nexport default BaseNFE;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { getCodIBGE } from '@Utils/getCodIBGE.js';\nimport Environment from '@Modules/environment/Environment.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport Utility from '@Utils/Utility.js';\nimport BaseNFE from '@Modules/dfe/base/BaseNFe.js';\nimport { AxiosInstance } from 'axios';\nimport { SaveFilesImpl, GerarConsultaImpl, NFEStatusServicoServiceImpl } from '@Interfaces';\n\nclass NFEStatusServicoService extends BaseNFE implements NFEStatusServicoServiceImpl {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, 'NFEStatusServico', axios, saveFiles, gerarConsulta);\n    }\n\n    protected gerarXml(): string {\n        try {\n            const { nfe: { ambiente, versaoDF }, dfe: { UF } } = this.environment.getConfig();\n\n            const xmlObject = {\n                $: {\n                    versao: versaoDF,\n                    xmlns: 'http://www.portalfiscal.inf.br/nfe'\n                },\n                tpAmb: ambiente,\n                cUF: getCodIBGE(UF),\n                xServ: 'STATUS',\n            }\n\n            return this.xmlBuilder.gerarXml(xmlObject, 'consStatServ')\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n}\n\nexport default NFEStatusServicoService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFEconsultaProtocoloServiceImpl } from '@Interfaces';\n\nclass NFEConsultaProtocolo implements NFEconsultaProtocoloServiceImpl{\n    nfeConsultaProtocoloService: NFEconsultaProtocoloServiceImpl;\n    constructor(nfeConsultaProtocoloService: NFEconsultaProtocoloServiceImpl) {\n        this.nfeConsultaProtocoloService = nfeConsultaProtocoloService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeConsultaProtocoloService.Exec(data);\n    }\n}\n\nexport default NFEConsultaProtocolo;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFERecepcaoEventoServiceImpl } from '@Interfaces';\n\nclass NFEEpec implements NFERecepcaoEventoServiceImpl {\n    nfeEpecServiceService: NFERecepcaoEventoServiceImpl;\n    constructor(nfeEpecServiceService: NFERecepcaoEventoServiceImpl) {\n        this.nfeEpecServiceService = nfeEpecServiceService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeEpecServiceService.Exec(data);\n    }\n}\nexport default NFEEpec;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFERecepcaoEventoServiceImpl } from '@Interfaces';\n\nclass NFECancelamento implements NFERecepcaoEventoServiceImpl {\n    nfeCancelamentoServiceService: NFERecepcaoEventoServiceImpl;\n    constructor(nfeCancelamentoServiceService: NFERecepcaoEventoServiceImpl) {\n        this.nfeCancelamentoServiceService = nfeCancelamentoServiceService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeCancelamentoServiceService.Exec(data);\n    }\n}\n\n\nexport default NFECancelamento;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFERecepcaoEventoServiceImpl } from '@Interfaces';\n\nclass NFECienciaDaOperacao implements NFERecepcaoEventoServiceImpl {\n    nfeCienciaDaOperacaoServiceService: NFERecepcaoEventoServiceImpl;\n    constructor(nfeCienciaDaOperacaoServiceService: NFERecepcaoEventoServiceImpl) {\n        this.nfeCienciaDaOperacaoServiceService = nfeCienciaDaOperacaoServiceService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeCienciaDaOperacaoServiceService.Exec(data);\n    }\n}\n\nexport default NFECienciaDaOperacao;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFERecepcaoEventoServiceImpl } from '@Interfaces/NFERecepcaoEventoServiceImpl.js';\n\nclass NFEConfirmacaoDaOperacao implements NFERecepcaoEventoServiceImpl {\n    nfeConfirmacaoDaOperacaoServiceService: NFERecepcaoEventoServiceImpl;\n    constructor(nfeConfirmacaoDaOperacaoServiceService: NFERecepcaoEventoServiceImpl) {\n        this.nfeConfirmacaoDaOperacaoServiceService = nfeConfirmacaoDaOperacaoServiceService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeConfirmacaoDaOperacaoServiceService.Exec(data);\n    }\n}\n\nexport default NFEConfirmacaoDaOperacao;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFERecepcaoEventoServiceImpl } from '@Interfaces';\n\nclass NFEOperacaoNaoRealizada implements NFERecepcaoEventoServiceImpl {\n    nfeOperacaoNaoRealizadaServiceService: NFERecepcaoEventoServiceImpl;\n    constructor(nfeOperacaoNaoRealizadaServiceService: NFERecepcaoEventoServiceImpl) {\n        this.nfeOperacaoNaoRealizadaServiceService = nfeOperacaoNaoRealizadaServiceService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeOperacaoNaoRealizadaServiceService.Exec(data);\n    }\n}\n\nexport default NFEOperacaoNaoRealizada;","'use strict';\n\nconst http = require('http');\nconst https = require('https');\nconst urllib = require('url');\nconst zlib = require('zlib');\nconst PassThrough = require('stream').PassThrough;\nconst Cookies = require('./cookies');\nconst packageData = require('../../package.json');\nconst net = require('net');\n\nconst MAX_REDIRECTS = 5;\n\nmodule.exports = function (url, options) {\n    return nmfetch(url, options);\n};\n\nmodule.exports.Cookies = Cookies;\n\nfunction nmfetch(url, options) {\n    options = options || {};\n\n    options.fetchRes = options.fetchRes || new PassThrough();\n    options.cookies = options.cookies || new Cookies();\n    options.redirects = options.redirects || 0;\n    options.maxRedirects = isNaN(options.maxRedirects) ? MAX_REDIRECTS : options.maxRedirects;\n\n    if (options.cookie) {\n        [].concat(options.cookie || []).forEach(cookie => {\n            options.cookies.set(cookie, url);\n        });\n        options.cookie = false;\n    }\n\n    let fetchRes = options.fetchRes;\n    let parsed = urllib.parse(url);\n    let method = (options.method || '').toString().trim().toUpperCase() || 'GET';\n    let finished = false;\n    let cookies;\n    let body;\n\n    let handler = parsed.protocol === 'https:' ? https : http;\n\n    let headers = {\n        'accept-encoding': 'gzip,deflate',\n        'user-agent': 'nodemailer/' + packageData.version\n    };\n\n    Object.keys(options.headers || {}).forEach(key => {\n        headers[key.toLowerCase().trim()] = options.headers[key];\n    });\n\n    if (options.userAgent) {\n        headers['user-agent'] = options.userAgent;\n    }\n\n    if (parsed.auth) {\n        headers.Authorization = 'Basic ' + Buffer.from(parsed.auth).toString('base64');\n    }\n\n    if ((cookies = options.cookies.get(url))) {\n        headers.cookie = cookies;\n    }\n\n    if (options.body) {\n        if (options.contentType !== false) {\n            headers['Content-Type'] = options.contentType || 'application/x-www-form-urlencoded';\n        }\n\n        if (typeof options.body.pipe === 'function') {\n            // it's a stream\n            headers['Transfer-Encoding'] = 'chunked';\n            body = options.body;\n            body.on('error', err => {\n                if (finished) {\n                    return;\n                }\n                finished = true;\n                err.type = 'FETCH';\n                err.sourceUrl = url;\n                fetchRes.emit('error', err);\n            });\n        } else {\n            if (options.body instanceof Buffer) {\n                body = options.body;\n            } else if (typeof options.body === 'object') {\n                try {\n                    // encodeURIComponent can fail on invalid input (partial emoji etc.)\n                    body = Buffer.from(\n                        Object.keys(options.body)\n                            .map(key => {\n                                let value = options.body[key].toString().trim();\n                                return encodeURIComponent(key) + '=' + encodeURIComponent(value);\n                            })\n                            .join('&')\n                    );\n                } catch (E) {\n                    if (finished) {\n                        return;\n                    }\n                    finished = true;\n                    E.type = 'FETCH';\n                    E.sourceUrl = url;\n                    fetchRes.emit('error', E);\n                    return;\n                }\n            } else {\n                body = Buffer.from(options.body.toString().trim());\n            }\n\n            headers['Content-Type'] = options.contentType || 'application/x-www-form-urlencoded';\n            headers['Content-Length'] = body.length;\n        }\n        // if method is not provided, use POST instead of GET\n        method = (options.method || '').toString().trim().toUpperCase() || 'POST';\n    }\n\n    let req;\n    let reqOptions = {\n        method,\n        host: parsed.hostname,\n        path: parsed.path,\n        port: parsed.port ? parsed.port : parsed.protocol === 'https:' ? 443 : 80,\n        headers,\n        rejectUnauthorized: false,\n        agent: false\n    };\n\n    if (options.tls) {\n        Object.keys(options.tls).forEach(key => {\n            reqOptions[key] = options.tls[key];\n        });\n    }\n\n    if (parsed.protocol === 'https:' && parsed.hostname && parsed.hostname !== reqOptions.host && !net.isIP(parsed.hostname) && !reqOptions.servername) {\n        reqOptions.servername = parsed.hostname;\n    }\n\n    try {\n        req = handler.request(reqOptions);\n    } catch (E) {\n        finished = true;\n        setImmediate(() => {\n            E.type = 'FETCH';\n            E.sourceUrl = url;\n            fetchRes.emit('error', E);\n        });\n        return fetchRes;\n    }\n\n    if (options.timeout) {\n        req.setTimeout(options.timeout, () => {\n            if (finished) {\n                return;\n            }\n            finished = true;\n            req.abort();\n            let err = new Error('Request Timeout');\n            err.type = 'FETCH';\n            err.sourceUrl = url;\n            fetchRes.emit('error', err);\n        });\n    }\n\n    req.on('error', err => {\n        if (finished) {\n            return;\n        }\n        finished = true;\n        err.type = 'FETCH';\n        err.sourceUrl = url;\n        fetchRes.emit('error', err);\n    });\n\n    req.on('response', res => {\n        let inflate;\n\n        if (finished) {\n            return;\n        }\n\n        switch (res.headers['content-encoding']) {\n            case 'gzip':\n            case 'deflate':\n                inflate = zlib.createUnzip();\n                break;\n        }\n\n        if (res.headers['set-cookie']) {\n            [].concat(res.headers['set-cookie'] || []).forEach(cookie => {\n                options.cookies.set(cookie, url);\n            });\n        }\n\n        if ([301, 302, 303, 307, 308].includes(res.statusCode) && res.headers.location) {\n            // redirect\n            options.redirects++;\n            if (options.redirects > options.maxRedirects) {\n                finished = true;\n                let err = new Error('Maximum redirect count exceeded');\n                err.type = 'FETCH';\n                err.sourceUrl = url;\n                fetchRes.emit('error', err);\n                req.abort();\n                return;\n            }\n            // redirect does not include POST body\n            options.method = 'GET';\n            options.body = false;\n            return nmfetch(urllib.resolve(url, res.headers.location), options);\n        }\n\n        fetchRes.statusCode = res.statusCode;\n        fetchRes.headers = res.headers;\n\n        if (res.statusCode >= 300 && !options.allowErrorResponse) {\n            finished = true;\n            let err = new Error('Invalid status code ' + res.statusCode);\n            err.type = 'FETCH';\n            err.sourceUrl = url;\n            fetchRes.emit('error', err);\n            req.abort();\n            return;\n        }\n\n        res.on('error', err => {\n            if (finished) {\n                return;\n            }\n            finished = true;\n            err.type = 'FETCH';\n            err.sourceUrl = url;\n            fetchRes.emit('error', err);\n            req.abort();\n        });\n\n        if (inflate) {\n            res.pipe(inflate).pipe(fetchRes);\n            inflate.on('error', err => {\n                if (finished) {\n                    return;\n                }\n                finished = true;\n                err.type = 'FETCH';\n                err.sourceUrl = url;\n                fetchRes.emit('error', err);\n                req.abort();\n            });\n        } else {\n            res.pipe(fetchRes);\n        }\n    });\n\n    setImmediate(() => {\n        if (body) {\n            try {\n                if (typeof body.pipe === 'function') {\n                    return body.pipe(req);\n                } else {\n                    req.write(body);\n                }\n            } catch (err) {\n                finished = true;\n                err.type = 'FETCH';\n                err.sourceUrl = url;\n                fetchRes.emit('error', err);\n                return;\n            }\n        }\n        req.end();\n    });\n\n    return fetchRes;\n}\n","'use strict';\n\n// module to handle cookies\n\nconst urllib = require('url');\n\nconst SESSION_TIMEOUT = 1800; // 30 min\n\n/**\n * Creates a biskviit cookie jar for managing cookie values in memory\n *\n * @constructor\n * @param {Object} [options] Optional options object\n */\nclass Cookies {\n    constructor(options) {\n        this.options = options || {};\n        this.cookies = [];\n    }\n\n    /**\n     * Stores a cookie string to the cookie storage\n     *\n     * @param {String} cookieStr Value from the 'Set-Cookie:' header\n     * @param {String} url Current URL\n     */\n    set(cookieStr, url) {\n        let urlparts = urllib.parse(url || '');\n        let cookie = this.parse(cookieStr);\n        let domain;\n\n        if (cookie.domain) {\n            domain = cookie.domain.replace(/^\\./, '');\n\n            // do not allow cross origin cookies\n            if (\n                // can't be valid if the requested domain is shorter than current hostname\n                urlparts.hostname.length < domain.length ||\n                // prefix domains with dot to be sure that partial matches are not used\n                ('.' + urlparts.hostname).substr(-domain.length + 1) !== '.' + domain\n            ) {\n                cookie.domain = urlparts.hostname;\n            }\n        } else {\n            cookie.domain = urlparts.hostname;\n        }\n\n        if (!cookie.path) {\n            cookie.path = this.getPath(urlparts.pathname);\n        }\n\n        // if no expire date, then use sessionTimeout value\n        if (!cookie.expires) {\n            cookie.expires = new Date(Date.now() + (Number(this.options.sessionTimeout || SESSION_TIMEOUT) || SESSION_TIMEOUT) * 1000);\n        }\n\n        return this.add(cookie);\n    }\n\n    /**\n     * Returns cookie string for the 'Cookie:' header.\n     *\n     * @param {String} url URL to check for\n     * @returns {String} Cookie header or empty string if no matches were found\n     */\n    get(url) {\n        return this.list(url)\n            .map(cookie => cookie.name + '=' + cookie.value)\n            .join('; ');\n    }\n\n    /**\n     * Lists all valied cookie objects for the specified URL\n     *\n     * @param {String} url URL to check for\n     * @returns {Array} An array of cookie objects\n     */\n    list(url) {\n        let result = [];\n        let i;\n        let cookie;\n\n        for (i = this.cookies.length - 1; i >= 0; i--) {\n            cookie = this.cookies[i];\n\n            if (this.isExpired(cookie)) {\n                this.cookies.splice(i, i);\n                continue;\n            }\n\n            if (this.match(cookie, url)) {\n                result.unshift(cookie);\n            }\n        }\n\n        return result;\n    }\n\n    /**\n     * Parses cookie string from the 'Set-Cookie:' header\n     *\n     * @param {String} cookieStr String from the 'Set-Cookie:' header\n     * @returns {Object} Cookie object\n     */\n    parse(cookieStr) {\n        let cookie = {};\n\n        (cookieStr || '')\n            .toString()\n            .split(';')\n            .forEach(cookiePart => {\n                let valueParts = cookiePart.split('=');\n                let key = valueParts.shift().trim().toLowerCase();\n                let value = valueParts.join('=').trim();\n                let domain;\n\n                if (!key) {\n                    // skip empty parts\n                    return;\n                }\n\n                switch (key) {\n                    case 'expires':\n                        value = new Date(value);\n                        // ignore date if can not parse it\n                        if (value.toString() !== 'Invalid Date') {\n                            cookie.expires = value;\n                        }\n                        break;\n\n                    case 'path':\n                        cookie.path = value;\n                        break;\n\n                    case 'domain':\n                        domain = value.toLowerCase();\n                        if (domain.length && domain.charAt(0) !== '.') {\n                            domain = '.' + domain; // ensure preceeding dot for user set domains\n                        }\n                        cookie.domain = domain;\n                        break;\n\n                    case 'max-age':\n                        cookie.expires = new Date(Date.now() + (Number(value) || 0) * 1000);\n                        break;\n\n                    case 'secure':\n                        cookie.secure = true;\n                        break;\n\n                    case 'httponly':\n                        cookie.httponly = true;\n                        break;\n\n                    default:\n                        if (!cookie.name) {\n                            cookie.name = key;\n                            cookie.value = value;\n                        }\n                }\n            });\n\n        return cookie;\n    }\n\n    /**\n     * Checks if a cookie object is valid for a specified URL\n     *\n     * @param {Object} cookie Cookie object\n     * @param {String} url URL to check for\n     * @returns {Boolean} true if cookie is valid for specifiec URL\n     */\n    match(cookie, url) {\n        let urlparts = urllib.parse(url || '');\n\n        // check if hostname matches\n        // .foo.com also matches subdomains, foo.com does not\n        if (\n            urlparts.hostname !== cookie.domain &&\n            (cookie.domain.charAt(0) !== '.' || ('.' + urlparts.hostname).substr(-cookie.domain.length) !== cookie.domain)\n        ) {\n            return false;\n        }\n\n        // check if path matches\n        let path = this.getPath(urlparts.pathname);\n        if (path.substr(0, cookie.path.length) !== cookie.path) {\n            return false;\n        }\n\n        // check secure argument\n        if (cookie.secure && urlparts.protocol !== 'https:') {\n            return false;\n        }\n\n        return true;\n    }\n\n    /**\n     * Adds (or updates/removes if needed) a cookie object to the cookie storage\n     *\n     * @param {Object} cookie Cookie value to be stored\n     */\n    add(cookie) {\n        let i;\n        let len;\n\n        // nothing to do here\n        if (!cookie || !cookie.name) {\n            return false;\n        }\n\n        // overwrite if has same params\n        for (i = 0, len = this.cookies.length; i < len; i++) {\n            if (this.compare(this.cookies[i], cookie)) {\n                // check if the cookie needs to be removed instead\n                if (this.isExpired(cookie)) {\n                    this.cookies.splice(i, 1); // remove expired/unset cookie\n                    return false;\n                }\n\n                this.cookies[i] = cookie;\n                return true;\n            }\n        }\n\n        // add as new if not already expired\n        if (!this.isExpired(cookie)) {\n            this.cookies.push(cookie);\n        }\n\n        return true;\n    }\n\n    /**\n     * Checks if two cookie objects are the same\n     *\n     * @param {Object} a Cookie to check against\n     * @param {Object} b Cookie to check against\n     * @returns {Boolean} True, if the cookies are the same\n     */\n    compare(a, b) {\n        return a.name === b.name && a.path === b.path && a.domain === b.domain && a.secure === b.secure && a.httponly === a.httponly;\n    }\n\n    /**\n     * Checks if a cookie is expired\n     *\n     * @param {Object} cookie Cookie object to check against\n     * @returns {Boolean} True, if the cookie is expired\n     */\n    isExpired(cookie) {\n        return (cookie.expires && cookie.expires < new Date()) || !cookie.value;\n    }\n\n    /**\n     * Returns normalized cookie path for an URL path argument\n     *\n     * @param {String} pathname\n     * @returns {String} Normalized path\n     */\n    getPath(pathname) {\n        let path = (pathname || '/').split('/');\n        path.pop(); // remove filename part\n        path = path.join('/').trim();\n\n        // ensure path prefix /\n        if (path.charAt(0) !== '/') {\n            path = '/' + path;\n        }\n\n        // ensure path suffix /\n        if (path.substr(-1) !== '/') {\n            path += '/';\n        }\n\n        return path;\n    }\n}\n\nmodule.exports = Cookies;\n","/* eslint no-console: 0 */\n\n'use strict';\n\nconst urllib = require('url');\nconst util = require('util');\nconst fs = require('fs');\nconst nmfetch = require('../fetch');\nconst dns = require('dns');\nconst net = require('net');\nconst os = require('os');\n\nconst DNS_TTL = 5 * 60 * 1000;\n\nlet networkInterfaces;\ntry {\n    networkInterfaces = os.networkInterfaces();\n} catch (err) {\n    // fails on some systems\n}\n\nmodule.exports.networkInterfaces = networkInterfaces;\n\nconst isFamilySupported = (family, allowInternal) => {\n    let networkInterfaces = module.exports.networkInterfaces;\n    if (!networkInterfaces) {\n        // hope for the best\n        return true;\n    }\n\n    const familySupported =\n        // crux that replaces Object.values(networkInterfaces) as Object.values is not supported in nodejs v6\n        Object.keys(networkInterfaces)\n            .map(key => networkInterfaces[key])\n            // crux that replaces .flat() as it is not supported in older Node versions (v10 and older)\n            .reduce((acc, val) => acc.concat(val), [])\n            .filter(i => !i.internal || allowInternal)\n            .filter(i => i.family === 'IPv' + family || i.family === family).length > 0;\n\n    return familySupported;\n};\n\nconst resolver = (family, hostname, options, callback) => {\n    options = options || {};\n    const familySupported = isFamilySupported(family, options.allowInternalNetworkInterfaces);\n\n    if (!familySupported) {\n        return callback(null, []);\n    }\n\n    const resolver = dns.Resolver ? new dns.Resolver(options) : dns;\n    resolver['resolve' + family](hostname, (err, addresses) => {\n        if (err) {\n            switch (err.code) {\n                case dns.NODATA:\n                case dns.NOTFOUND:\n                case dns.NOTIMP:\n                case dns.SERVFAIL:\n                case dns.CONNREFUSED:\n                case dns.REFUSED:\n                case 'EAI_AGAIN':\n                    return callback(null, []);\n            }\n            return callback(err);\n        }\n        return callback(null, Array.isArray(addresses) ? addresses : [].concat(addresses || []));\n    });\n};\n\nconst dnsCache = (module.exports.dnsCache = new Map());\n\nconst formatDNSValue = (value, extra) => {\n    if (!value) {\n        return Object.assign({}, extra || {});\n    }\n\n    return Object.assign(\n        {\n            servername: value.servername,\n            host:\n                !value.addresses || !value.addresses.length\n                    ? null\n                    : value.addresses.length === 1\n                    ? value.addresses[0]\n                    : value.addresses[Math.floor(Math.random() * value.addresses.length)]\n        },\n        extra || {}\n    );\n};\n\nmodule.exports.resolveHostname = (options, callback) => {\n    options = options || {};\n\n    if (!options.host && options.servername) {\n        options.host = options.servername;\n    }\n\n    if (!options.host || net.isIP(options.host)) {\n        // nothing to do here\n        let value = {\n            addresses: [options.host],\n            servername: options.servername || false\n        };\n        return callback(\n            null,\n            formatDNSValue(value, {\n                cached: false\n            })\n        );\n    }\n\n    let cached;\n    if (dnsCache.has(options.host)) {\n        cached = dnsCache.get(options.host);\n\n        if (!cached.expires || cached.expires >= Date.now()) {\n            return callback(\n                null,\n                formatDNSValue(cached.value, {\n                    cached: true\n                })\n            );\n        }\n    }\n\n    resolver(4, options.host, options, (err, addresses) => {\n        if (err) {\n            if (cached) {\n                // ignore error, use expired value\n                return callback(\n                    null,\n                    formatDNSValue(cached.value, {\n                        cached: true,\n                        error: err\n                    })\n                );\n            }\n            return callback(err);\n        }\n\n        if (addresses && addresses.length) {\n            let value = {\n                addresses,\n                servername: options.servername || options.host\n            };\n\n            dnsCache.set(options.host, {\n                value,\n                expires: Date.now() + (options.dnsTtl || DNS_TTL)\n            });\n\n            return callback(\n                null,\n                formatDNSValue(value, {\n                    cached: false\n                })\n            );\n        }\n\n        resolver(6, options.host, options, (err, addresses) => {\n            if (err) {\n                if (cached) {\n                    // ignore error, use expired value\n                    return callback(\n                        null,\n                        formatDNSValue(cached.value, {\n                            cached: true,\n                            error: err\n                        })\n                    );\n                }\n                return callback(err);\n            }\n\n            if (addresses && addresses.length) {\n                let value = {\n                    addresses,\n                    servername: options.servername || options.host\n                };\n\n                dnsCache.set(options.host, {\n                    value,\n                    expires: Date.now() + (options.dnsTtl || DNS_TTL)\n                });\n\n                return callback(\n                    null,\n                    formatDNSValue(value, {\n                        cached: false\n                    })\n                );\n            }\n\n            try {\n                dns.lookup(options.host, { all: true }, (err, addresses) => {\n                    if (err) {\n                        if (cached) {\n                            // ignore error, use expired value\n                            return callback(\n                                null,\n                                formatDNSValue(cached.value, {\n                                    cached: true,\n                                    error: err\n                                })\n                            );\n                        }\n                        return callback(err);\n                    }\n\n                    let address = addresses\n                        ? addresses\n                              .filter(addr => isFamilySupported(addr.family))\n                              .map(addr => addr.address)\n                              .shift()\n                        : false;\n\n                    if (addresses && addresses.length && !address) {\n                        // there are addresses but none can be used\n                        console.warn(`Failed to resolve IPv${addresses[0].family} addresses with current network`);\n                    }\n\n                    if (!address && cached) {\n                        // nothing was found, fallback to cached value\n                        return callback(\n                            null,\n                            formatDNSValue(cached.value, {\n                                cached: true\n                            })\n                        );\n                    }\n\n                    let value = {\n                        addresses: address ? [address] : [options.host],\n                        servername: options.servername || options.host\n                    };\n\n                    dnsCache.set(options.host, {\n                        value,\n                        expires: Date.now() + (options.dnsTtl || DNS_TTL)\n                    });\n\n                    return callback(\n                        null,\n                        formatDNSValue(value, {\n                            cached: false\n                        })\n                    );\n                });\n            } catch (err) {\n                if (cached) {\n                    // ignore error, use expired value\n                    return callback(\n                        null,\n                        formatDNSValue(cached.value, {\n                            cached: true,\n                            error: err\n                        })\n                    );\n                }\n                return callback(err);\n            }\n        });\n    });\n};\n/**\n * Parses connection url to a structured configuration object\n *\n * @param {String} str Connection url\n * @return {Object} Configuration object\n */\nmodule.exports.parseConnectionUrl = str => {\n    str = str || '';\n    let options = {};\n\n    [urllib.parse(str, true)].forEach(url => {\n        let auth;\n\n        switch (url.protocol) {\n            case 'smtp:':\n                options.secure = false;\n                break;\n            case 'smtps:':\n                options.secure = true;\n                break;\n            case 'direct:':\n                options.direct = true;\n                break;\n        }\n\n        if (!isNaN(url.port) && Number(url.port)) {\n            options.port = Number(url.port);\n        }\n\n        if (url.hostname) {\n            options.host = url.hostname;\n        }\n\n        if (url.auth) {\n            auth = url.auth.split(':');\n\n            if (!options.auth) {\n                options.auth = {};\n            }\n\n            options.auth.user = auth.shift();\n            options.auth.pass = auth.join(':');\n        }\n\n        Object.keys(url.query || {}).forEach(key => {\n            let obj = options;\n            let lKey = key;\n            let value = url.query[key];\n\n            if (!isNaN(value)) {\n                value = Number(value);\n            }\n\n            switch (value) {\n                case 'true':\n                    value = true;\n                    break;\n                case 'false':\n                    value = false;\n                    break;\n            }\n\n            // tls is nested object\n            if (key.indexOf('tls.') === 0) {\n                lKey = key.substr(4);\n                if (!options.tls) {\n                    options.tls = {};\n                }\n                obj = options.tls;\n            } else if (key.indexOf('.') >= 0) {\n                // ignore nested properties besides tls\n                return;\n            }\n\n            if (!(lKey in obj)) {\n                obj[lKey] = value;\n            }\n        });\n    });\n\n    return options;\n};\n\nmodule.exports._logFunc = (logger, level, defaults, data, message, ...args) => {\n    let entry = {};\n\n    Object.keys(defaults || {}).forEach(key => {\n        if (key !== 'level') {\n            entry[key] = defaults[key];\n        }\n    });\n\n    Object.keys(data || {}).forEach(key => {\n        if (key !== 'level') {\n            entry[key] = data[key];\n        }\n    });\n\n    logger[level](entry, message, ...args);\n};\n\n/**\n * Returns a bunyan-compatible logger interface. Uses either provided logger or\n * creates a default console logger\n *\n * @param {Object} [options] Options object that might include 'logger' value\n * @return {Object} bunyan compatible logger\n */\nmodule.exports.getLogger = (options, defaults) => {\n    options = options || {};\n\n    let response = {};\n    let levels = ['trace', 'debug', 'info', 'warn', 'error', 'fatal'];\n\n    if (!options.logger) {\n        // use vanity logger\n        levels.forEach(level => {\n            response[level] = () => false;\n        });\n        return response;\n    }\n\n    let logger = options.logger;\n\n    if (options.logger === true) {\n        // create console logger\n        logger = createDefaultLogger(levels);\n    }\n\n    levels.forEach(level => {\n        response[level] = (data, message, ...args) => {\n            module.exports._logFunc(logger, level, defaults, data, message, ...args);\n        };\n    });\n\n    return response;\n};\n\n/**\n * Wrapper for creating a callback that either resolves or rejects a promise\n * based on input\n *\n * @param {Function} resolve Function to run if callback is called\n * @param {Function} reject Function to run if callback ends with an error\n */\nmodule.exports.callbackPromise = (resolve, reject) =>\n    function () {\n        let args = Array.from(arguments);\n        let err = args.shift();\n        if (err) {\n            reject(err);\n        } else {\n            resolve(...args);\n        }\n    };\n\nmodule.exports.parseDataURI = uri => {\n    let input = uri;\n    let commaPos = input.indexOf(',');\n    if (!commaPos) {\n        return uri;\n    }\n\n    let data = input.substring(commaPos + 1);\n    let metaStr = input.substring('data:'.length, commaPos);\n\n    let encoding;\n\n    let metaEntries = metaStr.split(';');\n    let lastMetaEntry = metaEntries.length > 1 ? metaEntries[metaEntries.length - 1] : false;\n    if (lastMetaEntry && lastMetaEntry.indexOf('=') < 0) {\n        encoding = lastMetaEntry.toLowerCase();\n        metaEntries.pop();\n    }\n\n    let contentType = metaEntries.shift() || 'application/octet-stream';\n    let params = {};\n    for (let entry of metaEntries) {\n        let sep = entry.indexOf('=');\n        if (sep >= 0) {\n            let key = entry.substring(0, sep);\n            let value = entry.substring(sep + 1);\n            params[key] = value;\n        }\n    }\n\n    switch (encoding) {\n        case 'base64':\n            data = Buffer.from(data, 'base64');\n            break;\n        case 'utf8':\n            data = Buffer.from(data);\n            break;\n        default:\n            try {\n                data = Buffer.from(decodeURIComponent(data));\n            } catch (err) {\n                data = Buffer.from(data);\n            }\n            data = Buffer.from(data);\n    }\n\n    return { data, encoding, contentType, params };\n};\n\n/**\n * Resolves a String or a Buffer value for content value. Useful if the value\n * is a Stream or a file or an URL. If the value is a Stream, overwrites\n * the stream object with the resolved value (you can't stream a value twice).\n *\n * This is useful when you want to create a plugin that needs a content value,\n * for example the `html` or `text` value as a String or a Buffer but not as\n * a file path or an URL.\n *\n * @param {Object} data An object or an Array you want to resolve an element for\n * @param {String|Number} key Property name or an Array index\n * @param {Function} callback Callback function with (err, value)\n */\nmodule.exports.resolveContent = (data, key, callback) => {\n    let promise;\n\n    if (!callback) {\n        promise = new Promise((resolve, reject) => {\n            callback = module.exports.callbackPromise(resolve, reject);\n        });\n    }\n\n    let content = (data && data[key] && data[key].content) || data[key];\n    let contentStream;\n    let encoding = ((typeof data[key] === 'object' && data[key].encoding) || 'utf8')\n        .toString()\n        .toLowerCase()\n        .replace(/[-_\\s]/g, '');\n\n    if (!content) {\n        return callback(null, content);\n    }\n\n    if (typeof content === 'object') {\n        if (typeof content.pipe === 'function') {\n            return resolveStream(content, (err, value) => {\n                if (err) {\n                    return callback(err);\n                }\n                // we can't stream twice the same content, so we need\n                // to replace the stream object with the streaming result\n                if (data[key].content) {\n                    data[key].content = value;\n                } else {\n                    data[key] = value;\n                }\n                callback(null, value);\n            });\n        } else if (/^https?:\\/\\//i.test(content.path || content.href)) {\n            contentStream = nmfetch(content.path || content.href);\n            return resolveStream(contentStream, callback);\n        } else if (/^data:/i.test(content.path || content.href)) {\n            let parsedDataUri = module.exports.parseDataURI(content.path || content.href);\n\n            if (!parsedDataUri || !parsedDataUri.data) {\n                return callback(null, Buffer.from(0));\n            }\n            return callback(null, parsedDataUri.data);\n        } else if (content.path) {\n            return resolveStream(fs.createReadStream(content.path), callback);\n        }\n    }\n\n    if (typeof data[key].content === 'string' && !['utf8', 'usascii', 'ascii'].includes(encoding)) {\n        content = Buffer.from(data[key].content, encoding);\n    }\n\n    // default action, return as is\n    setImmediate(() => callback(null, content));\n\n    return promise;\n};\n\n/**\n * Copies properties from source objects to target objects\n */\nmodule.exports.assign = function (/* target, ... sources */) {\n    let args = Array.from(arguments);\n    let target = args.shift() || {};\n\n    args.forEach(source => {\n        Object.keys(source || {}).forEach(key => {\n            if (['tls', 'auth'].includes(key) && source[key] && typeof source[key] === 'object') {\n                // tls and auth are special keys that need to be enumerated separately\n                // other objects are passed as is\n                if (!target[key]) {\n                    // ensure that target has this key\n                    target[key] = {};\n                }\n                Object.keys(source[key]).forEach(subKey => {\n                    target[key][subKey] = source[key][subKey];\n                });\n            } else {\n                target[key] = source[key];\n            }\n        });\n    });\n    return target;\n};\n\nmodule.exports.encodeXText = str => {\n    // ! 0x21\n    // + 0x2B\n    // = 0x3D\n    // ~ 0x7E\n    if (!/[^\\x21-\\x2A\\x2C-\\x3C\\x3E-\\x7E]/.test(str)) {\n        return str;\n    }\n    let buf = Buffer.from(str);\n    let result = '';\n    for (let i = 0, len = buf.length; i < len; i++) {\n        let c = buf[i];\n        if (c < 0x21 || c > 0x7e || c === 0x2b || c === 0x3d) {\n            result += '+' + (c < 0x10 ? '0' : '') + c.toString(16).toUpperCase();\n        } else {\n            result += String.fromCharCode(c);\n        }\n    }\n    return result;\n};\n\n/**\n * Streams a stream value into a Buffer\n *\n * @param {Object} stream Readable stream\n * @param {Function} callback Callback function with (err, value)\n */\nfunction resolveStream(stream, callback) {\n    let responded = false;\n    let chunks = [];\n    let chunklen = 0;\n\n    stream.on('error', err => {\n        if (responded) {\n            return;\n        }\n\n        responded = true;\n        callback(err);\n    });\n\n    stream.on('readable', () => {\n        let chunk;\n        while ((chunk = stream.read()) !== null) {\n            chunks.push(chunk);\n            chunklen += chunk.length;\n        }\n    });\n\n    stream.on('end', () => {\n        if (responded) {\n            return;\n        }\n        responded = true;\n\n        let value;\n\n        try {\n            value = Buffer.concat(chunks, chunklen);\n        } catch (E) {\n            return callback(E);\n        }\n        callback(null, value);\n    });\n}\n\n/**\n * Generates a bunyan-like logger that prints to console\n *\n * @returns {Object} Bunyan logger instance\n */\nfunction createDefaultLogger(levels) {\n    let levelMaxLen = 0;\n    let levelNames = new Map();\n    levels.forEach(level => {\n        if (level.length > levelMaxLen) {\n            levelMaxLen = level.length;\n        }\n    });\n\n    levels.forEach(level => {\n        let levelName = level.toUpperCase();\n        if (levelName.length < levelMaxLen) {\n            levelName += ' '.repeat(levelMaxLen - levelName.length);\n        }\n        levelNames.set(level, levelName);\n    });\n\n    let print = (level, entry, message, ...args) => {\n        let prefix = '';\n        if (entry) {\n            if (entry.tnx === 'server') {\n                prefix = 'S: ';\n            } else if (entry.tnx === 'client') {\n                prefix = 'C: ';\n            }\n\n            if (entry.sid) {\n                prefix = '[' + entry.sid + '] ' + prefix;\n            }\n\n            if (entry.cid) {\n                prefix = '[#' + entry.cid + '] ' + prefix;\n            }\n        }\n\n        message = util.format(message, ...args);\n        message.split(/\\r?\\n/).forEach(line => {\n            console.log('[%s] %s %s', new Date().toISOString().substr(0, 19).replace(/T/, ' '), levelNames.get(level), prefix + line);\n        });\n    };\n\n    let logger = {};\n    levels.forEach(level => {\n        logger[level] = print.bind(null, level);\n    });\n\n    return logger;\n}\n","/* eslint quote-props: 0 */\n\n'use strict';\n\nconst path = require('path');\n\nconst defaultMimeType = 'application/octet-stream';\nconst defaultExtension = 'bin';\n\nconst mimeTypes = new Map([\n    ['application/acad', 'dwg'],\n    ['application/applixware', 'aw'],\n    ['application/arj', 'arj'],\n    ['application/atom+xml', 'xml'],\n    ['application/atomcat+xml', 'atomcat'],\n    ['application/atomsvc+xml', 'atomsvc'],\n    ['application/base64', ['mm', 'mme']],\n    ['application/binhex', 'hqx'],\n    ['application/binhex4', 'hqx'],\n    ['application/book', ['book', 'boo']],\n    ['application/ccxml+xml,', 'ccxml'],\n    ['application/cdf', 'cdf'],\n    ['application/cdmi-capability', 'cdmia'],\n    ['application/cdmi-container', 'cdmic'],\n    ['application/cdmi-domain', 'cdmid'],\n    ['application/cdmi-object', 'cdmio'],\n    ['application/cdmi-queue', 'cdmiq'],\n    ['application/clariscad', 'ccad'],\n    ['application/commonground', 'dp'],\n    ['application/cu-seeme', 'cu'],\n    ['application/davmount+xml', 'davmount'],\n    ['application/drafting', 'drw'],\n    ['application/dsptype', 'tsp'],\n    ['application/dssc+der', 'dssc'],\n    ['application/dssc+xml', 'xdssc'],\n    ['application/dxf', 'dxf'],\n    ['application/ecmascript', ['js', 'es']],\n    ['application/emma+xml', 'emma'],\n    ['application/envoy', 'evy'],\n    ['application/epub+zip', 'epub'],\n    ['application/excel', ['xls', 'xl', 'xla', 'xlb', 'xlc', 'xld', 'xlk', 'xll', 'xlm', 'xlt', 'xlv', 'xlw']],\n    ['application/exi', 'exi'],\n    ['application/font-tdpfr', 'pfr'],\n    ['application/fractals', 'fif'],\n    ['application/freeloader', 'frl'],\n    ['application/futuresplash', 'spl'],\n    ['application/gnutar', 'tgz'],\n    ['application/groupwise', 'vew'],\n    ['application/hlp', 'hlp'],\n    ['application/hta', 'hta'],\n    ['application/hyperstudio', 'stk'],\n    ['application/i-deas', 'unv'],\n    ['application/iges', ['iges', 'igs']],\n    ['application/inf', 'inf'],\n    ['application/internet-property-stream', 'acx'],\n    ['application/ipfix', 'ipfix'],\n    ['application/java', 'class'],\n    ['application/java-archive', 'jar'],\n    ['application/java-byte-code', 'class'],\n    ['application/java-serialized-object', 'ser'],\n    ['application/java-vm', 'class'],\n    ['application/javascript', 'js'],\n    ['application/json', 'json'],\n    ['application/lha', 'lha'],\n    ['application/lzx', 'lzx'],\n    ['application/mac-binary', 'bin'],\n    ['application/mac-binhex', 'hqx'],\n    ['application/mac-binhex40', 'hqx'],\n    ['application/mac-compactpro', 'cpt'],\n    ['application/macbinary', 'bin'],\n    ['application/mads+xml', 'mads'],\n    ['application/marc', 'mrc'],\n    ['application/marcxml+xml', 'mrcx'],\n    ['application/mathematica', 'ma'],\n    ['application/mathml+xml', 'mathml'],\n    ['application/mbedlet', 'mbd'],\n    ['application/mbox', 'mbox'],\n    ['application/mcad', 'mcd'],\n    ['application/mediaservercontrol+xml', 'mscml'],\n    ['application/metalink4+xml', 'meta4'],\n    ['application/mets+xml', 'mets'],\n    ['application/mime', 'aps'],\n    ['application/mods+xml', 'mods'],\n    ['application/mp21', 'm21'],\n    ['application/mp4', 'mp4'],\n    ['application/mspowerpoint', ['ppt', 'pot', 'pps', 'ppz']],\n    ['application/msword', ['doc', 'dot', 'w6w', 'wiz', 'word']],\n    ['application/mswrite', 'wri'],\n    ['application/mxf', 'mxf'],\n    ['application/netmc', 'mcp'],\n    ['application/octet-stream', ['*']],\n    ['application/oda', 'oda'],\n    ['application/oebps-package+xml', 'opf'],\n    ['application/ogg', 'ogx'],\n    ['application/olescript', 'axs'],\n    ['application/onenote', 'onetoc'],\n    ['application/patch-ops-error+xml', 'xer'],\n    ['application/pdf', 'pdf'],\n    ['application/pgp-encrypted', 'asc'],\n    ['application/pgp-signature', 'pgp'],\n    ['application/pics-rules', 'prf'],\n    ['application/pkcs-12', 'p12'],\n    ['application/pkcs-crl', 'crl'],\n    ['application/pkcs10', 'p10'],\n    ['application/pkcs7-mime', ['p7c', 'p7m']],\n    ['application/pkcs7-signature', 'p7s'],\n    ['application/pkcs8', 'p8'],\n    ['application/pkix-attr-cert', 'ac'],\n    ['application/pkix-cert', ['cer', 'crt']],\n    ['application/pkix-crl', 'crl'],\n    ['application/pkix-pkipath', 'pkipath'],\n    ['application/pkixcmp', 'pki'],\n    ['application/plain', 'text'],\n    ['application/pls+xml', 'pls'],\n    ['application/postscript', ['ps', 'ai', 'eps']],\n    ['application/powerpoint', 'ppt'],\n    ['application/pro_eng', ['part', 'prt']],\n    ['application/prs.cww', 'cww'],\n    ['application/pskc+xml', 'pskcxml'],\n    ['application/rdf+xml', 'rdf'],\n    ['application/reginfo+xml', 'rif'],\n    ['application/relax-ng-compact-syntax', 'rnc'],\n    ['application/resource-lists+xml', 'rl'],\n    ['application/resource-lists-diff+xml', 'rld'],\n    ['application/ringing-tones', 'rng'],\n    ['application/rls-services+xml', 'rs'],\n    ['application/rsd+xml', 'rsd'],\n    ['application/rss+xml', 'xml'],\n    ['application/rtf', ['rtf', 'rtx']],\n    ['application/sbml+xml', 'sbml'],\n    ['application/scvp-cv-request', 'scq'],\n    ['application/scvp-cv-response', 'scs'],\n    ['application/scvp-vp-request', 'spq'],\n    ['application/scvp-vp-response', 'spp'],\n    ['application/sdp', 'sdp'],\n    ['application/sea', 'sea'],\n    ['application/set', 'set'],\n    ['application/set-payment-initiation', 'setpay'],\n    ['application/set-registration-initiation', 'setreg'],\n    ['application/shf+xml', 'shf'],\n    ['application/sla', 'stl'],\n    ['application/smil', ['smi', 'smil']],\n    ['application/smil+xml', 'smi'],\n    ['application/solids', 'sol'],\n    ['application/sounder', 'sdr'],\n    ['application/sparql-query', 'rq'],\n    ['application/sparql-results+xml', 'srx'],\n    ['application/srgs', 'gram'],\n    ['application/srgs+xml', 'grxml'],\n    ['application/sru+xml', 'sru'],\n    ['application/ssml+xml', 'ssml'],\n    ['application/step', ['step', 'stp']],\n    ['application/streamingmedia', 'ssm'],\n    ['application/tei+xml', 'tei'],\n    ['application/thraud+xml', 'tfi'],\n    ['application/timestamped-data', 'tsd'],\n    ['application/toolbook', 'tbk'],\n    ['application/vda', 'vda'],\n    ['application/vnd.3gpp.pic-bw-large', 'plb'],\n    ['application/vnd.3gpp.pic-bw-small', 'psb'],\n    ['application/vnd.3gpp.pic-bw-var', 'pvb'],\n    ['application/vnd.3gpp2.tcap', 'tcap'],\n    ['application/vnd.3m.post-it-notes', 'pwn'],\n    ['application/vnd.accpac.simply.aso', 'aso'],\n    ['application/vnd.accpac.simply.imp', 'imp'],\n    ['application/vnd.acucobol', 'acu'],\n    ['application/vnd.acucorp', 'atc'],\n    ['application/vnd.adobe.air-application-installer-package+zip', 'air'],\n    ['application/vnd.adobe.fxp', 'fxp'],\n    ['application/vnd.adobe.xdp+xml', 'xdp'],\n    ['application/vnd.adobe.xfdf', 'xfdf'],\n    ['application/vnd.ahead.space', 'ahead'],\n    ['application/vnd.airzip.filesecure.azf', 'azf'],\n    ['application/vnd.airzip.filesecure.azs', 'azs'],\n    ['application/vnd.amazon.ebook', 'azw'],\n    ['application/vnd.americandynamics.acc', 'acc'],\n    ['application/vnd.amiga.ami', 'ami'],\n    ['application/vnd.android.package-archive', 'apk'],\n    ['application/vnd.anser-web-certificate-issue-initiation', 'cii'],\n    ['application/vnd.anser-web-funds-transfer-initiation', 'fti'],\n    ['application/vnd.antix.game-component', 'atx'],\n    ['application/vnd.apple.installer+xml', 'mpkg'],\n    ['application/vnd.apple.mpegurl', 'm3u8'],\n    ['application/vnd.aristanetworks.swi', 'swi'],\n    ['application/vnd.audiograph', 'aep'],\n    ['application/vnd.blueice.multipass', 'mpm'],\n    ['application/vnd.bmi', 'bmi'],\n    ['application/vnd.businessobjects', 'rep'],\n    ['application/vnd.chemdraw+xml', 'cdxml'],\n    ['application/vnd.chipnuts.karaoke-mmd', 'mmd'],\n    ['application/vnd.cinderella', 'cdy'],\n    ['application/vnd.claymore', 'cla'],\n    ['application/vnd.cloanto.rp9', 'rp9'],\n    ['application/vnd.clonk.c4group', 'c4g'],\n    ['application/vnd.cluetrust.cartomobile-config', 'c11amc'],\n    ['application/vnd.cluetrust.cartomobile-config-pkg', 'c11amz'],\n    ['application/vnd.commonspace', 'csp'],\n    ['application/vnd.contact.cmsg', 'cdbcmsg'],\n    ['application/vnd.cosmocaller', 'cmc'],\n    ['application/vnd.crick.clicker', 'clkx'],\n    ['application/vnd.crick.clicker.keyboard', 'clkk'],\n    ['application/vnd.crick.clicker.palette', 'clkp'],\n    ['application/vnd.crick.clicker.template', 'clkt'],\n    ['application/vnd.crick.clicker.wordbank', 'clkw'],\n    ['application/vnd.criticaltools.wbs+xml', 'wbs'],\n    ['application/vnd.ctc-posml', 'pml'],\n    ['application/vnd.cups-ppd', 'ppd'],\n    ['application/vnd.curl.car', 'car'],\n    ['application/vnd.curl.pcurl', 'pcurl'],\n    ['application/vnd.data-vision.rdz', 'rdz'],\n    ['application/vnd.denovo.fcselayout-link', 'fe_launch'],\n    ['application/vnd.dna', 'dna'],\n    ['application/vnd.dolby.mlp', 'mlp'],\n    ['application/vnd.dpgraph', 'dpg'],\n    ['application/vnd.dreamfactory', 'dfac'],\n    ['application/vnd.dvb.ait', 'ait'],\n    ['application/vnd.dvb.service', 'svc'],\n    ['application/vnd.dynageo', 'geo'],\n    ['application/vnd.ecowin.chart', 'mag'],\n    ['application/vnd.enliven', 'nml'],\n    ['application/vnd.epson.esf', 'esf'],\n    ['application/vnd.epson.msf', 'msf'],\n    ['application/vnd.epson.quickanime', 'qam'],\n    ['application/vnd.epson.salt', 'slt'],\n    ['application/vnd.epson.ssf', 'ssf'],\n    ['application/vnd.eszigno3+xml', 'es3'],\n    ['application/vnd.ezpix-album', 'ez2'],\n    ['application/vnd.ezpix-package', 'ez3'],\n    ['application/vnd.fdf', 'fdf'],\n    ['application/vnd.fdsn.seed', 'seed'],\n    ['application/vnd.flographit', 'gph'],\n    ['application/vnd.fluxtime.clip', 'ftc'],\n    ['application/vnd.framemaker', 'fm'],\n    ['application/vnd.frogans.fnc', 'fnc'],\n    ['application/vnd.frogans.ltf', 'ltf'],\n    ['application/vnd.fsc.weblaunch', 'fsc'],\n    ['application/vnd.fujitsu.oasys', 'oas'],\n    ['application/vnd.fujitsu.oasys2', 'oa2'],\n    ['application/vnd.fujitsu.oasys3', 'oa3'],\n    ['application/vnd.fujitsu.oasysgp', 'fg5'],\n    ['application/vnd.fujitsu.oasysprs', 'bh2'],\n    ['application/vnd.fujixerox.ddd', 'ddd'],\n    ['application/vnd.fujixerox.docuworks', 'xdw'],\n    ['application/vnd.fujixerox.docuworks.binder', 'xbd'],\n    ['application/vnd.fuzzysheet', 'fzs'],\n    ['application/vnd.genomatix.tuxedo', 'txd'],\n    ['application/vnd.geogebra.file', 'ggb'],\n    ['application/vnd.geogebra.tool', 'ggt'],\n    ['application/vnd.geometry-explorer', 'gex'],\n    ['application/vnd.geonext', 'gxt'],\n    ['application/vnd.geoplan', 'g2w'],\n    ['application/vnd.geospace', 'g3w'],\n    ['application/vnd.gmx', 'gmx'],\n    ['application/vnd.google-earth.kml+xml', 'kml'],\n    ['application/vnd.google-earth.kmz', 'kmz'],\n    ['application/vnd.grafeq', 'gqf'],\n    ['application/vnd.groove-account', 'gac'],\n    ['application/vnd.groove-help', 'ghf'],\n    ['application/vnd.groove-identity-message', 'gim'],\n    ['application/vnd.groove-injector', 'grv'],\n    ['application/vnd.groove-tool-message', 'gtm'],\n    ['application/vnd.groove-tool-template', 'tpl'],\n    ['application/vnd.groove-vcard', 'vcg'],\n    ['application/vnd.hal+xml', 'hal'],\n    ['application/vnd.handheld-entertainment+xml', 'zmm'],\n    ['application/vnd.hbci', 'hbci'],\n    ['application/vnd.hhe.lesson-player', 'les'],\n    ['application/vnd.hp-hpgl', ['hgl', 'hpg', 'hpgl']],\n    ['application/vnd.hp-hpid', 'hpid'],\n    ['application/vnd.hp-hps', 'hps'],\n    ['application/vnd.hp-jlyt', 'jlt'],\n    ['application/vnd.hp-pcl', 'pcl'],\n    ['application/vnd.hp-pclxl', 'pclxl'],\n    ['application/vnd.hydrostatix.sof-data', 'sfd-hdstx'],\n    ['application/vnd.hzn-3d-crossword', 'x3d'],\n    ['application/vnd.ibm.minipay', 'mpy'],\n    ['application/vnd.ibm.modcap', 'afp'],\n    ['application/vnd.ibm.rights-management', 'irm'],\n    ['application/vnd.ibm.secure-container', 'sc'],\n    ['application/vnd.iccprofile', 'icc'],\n    ['application/vnd.igloader', 'igl'],\n    ['application/vnd.immervision-ivp', 'ivp'],\n    ['application/vnd.immervision-ivu', 'ivu'],\n    ['application/vnd.insors.igm', 'igm'],\n    ['application/vnd.intercon.formnet', 'xpw'],\n    ['application/vnd.intergeo', 'i2g'],\n    ['application/vnd.intu.qbo', 'qbo'],\n    ['application/vnd.intu.qfx', 'qfx'],\n    ['application/vnd.ipunplugged.rcprofile', 'rcprofile'],\n    ['application/vnd.irepository.package+xml', 'irp'],\n    ['application/vnd.is-xpr', 'xpr'],\n    ['application/vnd.isac.fcs', 'fcs'],\n    ['application/vnd.jam', 'jam'],\n    ['application/vnd.jcp.javame.midlet-rms', 'rms'],\n    ['application/vnd.jisp', 'jisp'],\n    ['application/vnd.joost.joda-archive', 'joda'],\n    ['application/vnd.kahootz', 'ktz'],\n    ['application/vnd.kde.karbon', 'karbon'],\n    ['application/vnd.kde.kchart', 'chrt'],\n    ['application/vnd.kde.kformula', 'kfo'],\n    ['application/vnd.kde.kivio', 'flw'],\n    ['application/vnd.kde.kontour', 'kon'],\n    ['application/vnd.kde.kpresenter', 'kpr'],\n    ['application/vnd.kde.kspread', 'ksp'],\n    ['application/vnd.kde.kword', 'kwd'],\n    ['application/vnd.kenameaapp', 'htke'],\n    ['application/vnd.kidspiration', 'kia'],\n    ['application/vnd.kinar', 'kne'],\n    ['application/vnd.koan', 'skp'],\n    ['application/vnd.kodak-descriptor', 'sse'],\n    ['application/vnd.las.las+xml', 'lasxml'],\n    ['application/vnd.llamagraphics.life-balance.desktop', 'lbd'],\n    ['application/vnd.llamagraphics.life-balance.exchange+xml', 'lbe'],\n    ['application/vnd.lotus-1-2-3', '123'],\n    ['application/vnd.lotus-approach', 'apr'],\n    ['application/vnd.lotus-freelance', 'pre'],\n    ['application/vnd.lotus-notes', 'nsf'],\n    ['application/vnd.lotus-organizer', 'org'],\n    ['application/vnd.lotus-screencam', 'scm'],\n    ['application/vnd.lotus-wordpro', 'lwp'],\n    ['application/vnd.macports.portpkg', 'portpkg'],\n    ['application/vnd.mcd', 'mcd'],\n    ['application/vnd.medcalcdata', 'mc1'],\n    ['application/vnd.mediastation.cdkey', 'cdkey'],\n    ['application/vnd.mfer', 'mwf'],\n    ['application/vnd.mfmp', 'mfm'],\n    ['application/vnd.micrografx.flo', 'flo'],\n    ['application/vnd.micrografx.igx', 'igx'],\n    ['application/vnd.mif', 'mif'],\n    ['application/vnd.mobius.daf', 'daf'],\n    ['application/vnd.mobius.dis', 'dis'],\n    ['application/vnd.mobius.mbk', 'mbk'],\n    ['application/vnd.mobius.mqy', 'mqy'],\n    ['application/vnd.mobius.msl', 'msl'],\n    ['application/vnd.mobius.plc', 'plc'],\n    ['application/vnd.mobius.txf', 'txf'],\n    ['application/vnd.mophun.application', 'mpn'],\n    ['application/vnd.mophun.certificate', 'mpc'],\n    ['application/vnd.mozilla.xul+xml', 'xul'],\n    ['application/vnd.ms-artgalry', 'cil'],\n    ['application/vnd.ms-cab-compressed', 'cab'],\n    ['application/vnd.ms-excel', ['xls', 'xla', 'xlc', 'xlm', 'xlt', 'xlw', 'xlb', 'xll']],\n    ['application/vnd.ms-excel.addin.macroenabled.12', 'xlam'],\n    ['application/vnd.ms-excel.sheet.binary.macroenabled.12', 'xlsb'],\n    ['application/vnd.ms-excel.sheet.macroenabled.12', 'xlsm'],\n    ['application/vnd.ms-excel.template.macroenabled.12', 'xltm'],\n    ['application/vnd.ms-fontobject', 'eot'],\n    ['application/vnd.ms-htmlhelp', 'chm'],\n    ['application/vnd.ms-ims', 'ims'],\n    ['application/vnd.ms-lrm', 'lrm'],\n    ['application/vnd.ms-officetheme', 'thmx'],\n    ['application/vnd.ms-outlook', 'msg'],\n    ['application/vnd.ms-pki.certstore', 'sst'],\n    ['application/vnd.ms-pki.pko', 'pko'],\n    ['application/vnd.ms-pki.seccat', 'cat'],\n    ['application/vnd.ms-pki.stl', 'stl'],\n    ['application/vnd.ms-pkicertstore', 'sst'],\n    ['application/vnd.ms-pkiseccat', 'cat'],\n    ['application/vnd.ms-pkistl', 'stl'],\n    ['application/vnd.ms-powerpoint', ['ppt', 'pot', 'pps', 'ppa', 'pwz']],\n    ['application/vnd.ms-powerpoint.addin.macroenabled.12', 'ppam'],\n    ['application/vnd.ms-powerpoint.presentation.macroenabled.12', 'pptm'],\n    ['application/vnd.ms-powerpoint.slide.macroenabled.12', 'sldm'],\n    ['application/vnd.ms-powerpoint.slideshow.macroenabled.12', 'ppsm'],\n    ['application/vnd.ms-powerpoint.template.macroenabled.12', 'potm'],\n    ['application/vnd.ms-project', 'mpp'],\n    ['application/vnd.ms-word.document.macroenabled.12', 'docm'],\n    ['application/vnd.ms-word.template.macroenabled.12', 'dotm'],\n    ['application/vnd.ms-works', ['wks', 'wcm', 'wdb', 'wps']],\n    ['application/vnd.ms-wpl', 'wpl'],\n    ['application/vnd.ms-xpsdocument', 'xps'],\n    ['application/vnd.mseq', 'mseq'],\n    ['application/vnd.musician', 'mus'],\n    ['application/vnd.muvee.style', 'msty'],\n    ['application/vnd.neurolanguage.nlu', 'nlu'],\n    ['application/vnd.noblenet-directory', 'nnd'],\n    ['application/vnd.noblenet-sealer', 'nns'],\n    ['application/vnd.noblenet-web', 'nnw'],\n    ['application/vnd.nokia.configuration-message', 'ncm'],\n    ['application/vnd.nokia.n-gage.data', 'ngdat'],\n    ['application/vnd.nokia.n-gage.symbian.install', 'n-gage'],\n    ['application/vnd.nokia.radio-preset', 'rpst'],\n    ['application/vnd.nokia.radio-presets', 'rpss'],\n    ['application/vnd.nokia.ringing-tone', 'rng'],\n    ['application/vnd.novadigm.edm', 'edm'],\n    ['application/vnd.novadigm.edx', 'edx'],\n    ['application/vnd.novadigm.ext', 'ext'],\n    ['application/vnd.oasis.opendocument.chart', 'odc'],\n    ['application/vnd.oasis.opendocument.chart-template', 'otc'],\n    ['application/vnd.oasis.opendocument.database', 'odb'],\n    ['application/vnd.oasis.opendocument.formula', 'odf'],\n    ['application/vnd.oasis.opendocument.formula-template', 'odft'],\n    ['application/vnd.oasis.opendocument.graphics', 'odg'],\n    ['application/vnd.oasis.opendocument.graphics-template', 'otg'],\n    ['application/vnd.oasis.opendocument.image', 'odi'],\n    ['application/vnd.oasis.opendocument.image-template', 'oti'],\n    ['application/vnd.oasis.opendocument.presentation', 'odp'],\n    ['application/vnd.oasis.opendocument.presentation-template', 'otp'],\n    ['application/vnd.oasis.opendocument.spreadsheet', 'ods'],\n    ['application/vnd.oasis.opendocument.spreadsheet-template', 'ots'],\n    ['application/vnd.oasis.opendocument.text', 'odt'],\n    ['application/vnd.oasis.opendocument.text-master', 'odm'],\n    ['application/vnd.oasis.opendocument.text-template', 'ott'],\n    ['application/vnd.oasis.opendocument.text-web', 'oth'],\n    ['application/vnd.olpc-sugar', 'xo'],\n    ['application/vnd.oma.dd2+xml', 'dd2'],\n    ['application/vnd.openofficeorg.extension', 'oxt'],\n    ['application/vnd.openxmlformats-officedocument.presentationml.presentation', 'pptx'],\n    ['application/vnd.openxmlformats-officedocument.presentationml.slide', 'sldx'],\n    ['application/vnd.openxmlformats-officedocument.presentationml.slideshow', 'ppsx'],\n    ['application/vnd.openxmlformats-officedocument.presentationml.template', 'potx'],\n    ['application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', 'xlsx'],\n    ['application/vnd.openxmlformats-officedocument.spreadsheetml.template', 'xltx'],\n    ['application/vnd.openxmlformats-officedocument.wordprocessingml.document', 'docx'],\n    ['application/vnd.openxmlformats-officedocument.wordprocessingml.template', 'dotx'],\n    ['application/vnd.osgeo.mapguide.package', 'mgp'],\n    ['application/vnd.osgi.dp', 'dp'],\n    ['application/vnd.palm', 'pdb'],\n    ['application/vnd.pawaafile', 'paw'],\n    ['application/vnd.pg.format', 'str'],\n    ['application/vnd.pg.osasli', 'ei6'],\n    ['application/vnd.picsel', 'efif'],\n    ['application/vnd.pmi.widget', 'wg'],\n    ['application/vnd.pocketlearn', 'plf'],\n    ['application/vnd.powerbuilder6', 'pbd'],\n    ['application/vnd.previewsystems.box', 'box'],\n    ['application/vnd.proteus.magazine', 'mgz'],\n    ['application/vnd.publishare-delta-tree', 'qps'],\n    ['application/vnd.pvi.ptid1', 'ptid'],\n    ['application/vnd.quark.quarkxpress', 'qxd'],\n    ['application/vnd.realvnc.bed', 'bed'],\n    ['application/vnd.recordare.musicxml', 'mxl'],\n    ['application/vnd.recordare.musicxml+xml', 'musicxml'],\n    ['application/vnd.rig.cryptonote', 'cryptonote'],\n    ['application/vnd.rim.cod', 'cod'],\n    ['application/vnd.rn-realmedia', 'rm'],\n    ['application/vnd.rn-realplayer', 'rnx'],\n    ['application/vnd.route66.link66+xml', 'link66'],\n    ['application/vnd.sailingtracker.track', 'st'],\n    ['application/vnd.seemail', 'see'],\n    ['application/vnd.sema', 'sema'],\n    ['application/vnd.semd', 'semd'],\n    ['application/vnd.semf', 'semf'],\n    ['application/vnd.shana.informed.formdata', 'ifm'],\n    ['application/vnd.shana.informed.formtemplate', 'itp'],\n    ['application/vnd.shana.informed.interchange', 'iif'],\n    ['application/vnd.shana.informed.package', 'ipk'],\n    ['application/vnd.simtech-mindmapper', 'twd'],\n    ['application/vnd.smaf', 'mmf'],\n    ['application/vnd.smart.teacher', 'teacher'],\n    ['application/vnd.solent.sdkm+xml', 'sdkm'],\n    ['application/vnd.spotfire.dxp', 'dxp'],\n    ['application/vnd.spotfire.sfs', 'sfs'],\n    ['application/vnd.stardivision.calc', 'sdc'],\n    ['application/vnd.stardivision.draw', 'sda'],\n    ['application/vnd.stardivision.impress', 'sdd'],\n    ['application/vnd.stardivision.math', 'smf'],\n    ['application/vnd.stardivision.writer', 'sdw'],\n    ['application/vnd.stardivision.writer-global', 'sgl'],\n    ['application/vnd.stepmania.stepchart', 'sm'],\n    ['application/vnd.sun.xml.calc', 'sxc'],\n    ['application/vnd.sun.xml.calc.template', 'stc'],\n    ['application/vnd.sun.xml.draw', 'sxd'],\n    ['application/vnd.sun.xml.draw.template', 'std'],\n    ['application/vnd.sun.xml.impress', 'sxi'],\n    ['application/vnd.sun.xml.impress.template', 'sti'],\n    ['application/vnd.sun.xml.math', 'sxm'],\n    ['application/vnd.sun.xml.writer', 'sxw'],\n    ['application/vnd.sun.xml.writer.global', 'sxg'],\n    ['application/vnd.sun.xml.writer.template', 'stw'],\n    ['application/vnd.sus-calendar', 'sus'],\n    ['application/vnd.svd', 'svd'],\n    ['application/vnd.symbian.install', 'sis'],\n    ['application/vnd.syncml+xml', 'xsm'],\n    ['application/vnd.syncml.dm+wbxml', 'bdm'],\n    ['application/vnd.syncml.dm+xml', 'xdm'],\n    ['application/vnd.tao.intent-module-archive', 'tao'],\n    ['application/vnd.tmobile-livetv', 'tmo'],\n    ['application/vnd.trid.tpt', 'tpt'],\n    ['application/vnd.triscape.mxs', 'mxs'],\n    ['application/vnd.trueapp', 'tra'],\n    ['application/vnd.ufdl', 'ufd'],\n    ['application/vnd.uiq.theme', 'utz'],\n    ['application/vnd.umajin', 'umj'],\n    ['application/vnd.unity', 'unityweb'],\n    ['application/vnd.uoml+xml', 'uoml'],\n    ['application/vnd.vcx', 'vcx'],\n    ['application/vnd.visio', 'vsd'],\n    ['application/vnd.visionary', 'vis'],\n    ['application/vnd.vsf', 'vsf'],\n    ['application/vnd.wap.wbxml', 'wbxml'],\n    ['application/vnd.wap.wmlc', 'wmlc'],\n    ['application/vnd.wap.wmlscriptc', 'wmlsc'],\n    ['application/vnd.webturbo', 'wtb'],\n    ['application/vnd.wolfram.player', 'nbp'],\n    ['application/vnd.wordperfect', 'wpd'],\n    ['application/vnd.wqd', 'wqd'],\n    ['application/vnd.wt.stf', 'stf'],\n    ['application/vnd.xara', ['web', 'xar']],\n    ['application/vnd.xfdl', 'xfdl'],\n    ['application/vnd.yamaha.hv-dic', 'hvd'],\n    ['application/vnd.yamaha.hv-script', 'hvs'],\n    ['application/vnd.yamaha.hv-voice', 'hvp'],\n    ['application/vnd.yamaha.openscoreformat', 'osf'],\n    ['application/vnd.yamaha.openscoreformat.osfpvg+xml', 'osfpvg'],\n    ['application/vnd.yamaha.smaf-audio', 'saf'],\n    ['application/vnd.yamaha.smaf-phrase', 'spf'],\n    ['application/vnd.yellowriver-custom-menu', 'cmp'],\n    ['application/vnd.zul', 'zir'],\n    ['application/vnd.zzazz.deck+xml', 'zaz'],\n    ['application/vocaltec-media-desc', 'vmd'],\n    ['application/vocaltec-media-file', 'vmf'],\n    ['application/voicexml+xml', 'vxml'],\n    ['application/widget', 'wgt'],\n    ['application/winhlp', 'hlp'],\n    ['application/wordperfect', ['wp', 'wp5', 'wp6', 'wpd']],\n    ['application/wordperfect6.0', ['w60', 'wp5']],\n    ['application/wordperfect6.1', 'w61'],\n    ['application/wsdl+xml', 'wsdl'],\n    ['application/wspolicy+xml', 'wspolicy'],\n    ['application/x-123', 'wk1'],\n    ['application/x-7z-compressed', '7z'],\n    ['application/x-abiword', 'abw'],\n    ['application/x-ace-compressed', 'ace'],\n    ['application/x-aim', 'aim'],\n    ['application/x-authorware-bin', 'aab'],\n    ['application/x-authorware-map', 'aam'],\n    ['application/x-authorware-seg', 'aas'],\n    ['application/x-bcpio', 'bcpio'],\n    ['application/x-binary', 'bin'],\n    ['application/x-binhex40', 'hqx'],\n    ['application/x-bittorrent', 'torrent'],\n    ['application/x-bsh', ['bsh', 'sh', 'shar']],\n    ['application/x-bytecode.elisp', 'elc'],\n    ['application/x-bytecode.python', 'pyc'],\n    ['application/x-bzip', 'bz'],\n    ['application/x-bzip2', ['boz', 'bz2']],\n    ['application/x-cdf', 'cdf'],\n    ['application/x-cdlink', 'vcd'],\n    ['application/x-chat', ['cha', 'chat']],\n    ['application/x-chess-pgn', 'pgn'],\n    ['application/x-cmu-raster', 'ras'],\n    ['application/x-cocoa', 'cco'],\n    ['application/x-compactpro', 'cpt'],\n    ['application/x-compress', 'z'],\n    ['application/x-compressed', ['tgz', 'gz', 'z', 'zip']],\n    ['application/x-conference', 'nsc'],\n    ['application/x-cpio', 'cpio'],\n    ['application/x-cpt', 'cpt'],\n    ['application/x-csh', 'csh'],\n    ['application/x-debian-package', 'deb'],\n    ['application/x-deepv', 'deepv'],\n    ['application/x-director', ['dir', 'dcr', 'dxr']],\n    ['application/x-doom', 'wad'],\n    ['application/x-dtbncx+xml', 'ncx'],\n    ['application/x-dtbook+xml', 'dtb'],\n    ['application/x-dtbresource+xml', 'res'],\n    ['application/x-dvi', 'dvi'],\n    ['application/x-elc', 'elc'],\n    ['application/x-envoy', ['env', 'evy']],\n    ['application/x-esrehber', 'es'],\n    ['application/x-excel', ['xls', 'xla', 'xlb', 'xlc', 'xld', 'xlk', 'xll', 'xlm', 'xlt', 'xlv', 'xlw']],\n    ['application/x-font-bdf', 'bdf'],\n    ['application/x-font-ghostscript', 'gsf'],\n    ['application/x-font-linux-psf', 'psf'],\n    ['application/x-font-otf', 'otf'],\n    ['application/x-font-pcf', 'pcf'],\n    ['application/x-font-snf', 'snf'],\n    ['application/x-font-ttf', 'ttf'],\n    ['application/x-font-type1', 'pfa'],\n    ['application/x-font-woff', 'woff'],\n    ['application/x-frame', 'mif'],\n    ['application/x-freelance', 'pre'],\n    ['application/x-futuresplash', 'spl'],\n    ['application/x-gnumeric', 'gnumeric'],\n    ['application/x-gsp', 'gsp'],\n    ['application/x-gss', 'gss'],\n    ['application/x-gtar', 'gtar'],\n    ['application/x-gzip', ['gz', 'gzip']],\n    ['application/x-hdf', 'hdf'],\n    ['application/x-helpfile', ['help', 'hlp']],\n    ['application/x-httpd-imap', 'imap'],\n    ['application/x-ima', 'ima'],\n    ['application/x-internet-signup', ['ins', 'isp']],\n    ['application/x-internett-signup', 'ins'],\n    ['application/x-inventor', 'iv'],\n    ['application/x-ip2', 'ip'],\n    ['application/x-iphone', 'iii'],\n    ['application/x-java-class', 'class'],\n    ['application/x-java-commerce', 'jcm'],\n    ['application/x-java-jnlp-file', 'jnlp'],\n    ['application/x-javascript', 'js'],\n    ['application/x-koan', ['skd', 'skm', 'skp', 'skt']],\n    ['application/x-ksh', 'ksh'],\n    ['application/x-latex', ['latex', 'ltx']],\n    ['application/x-lha', 'lha'],\n    ['application/x-lisp', 'lsp'],\n    ['application/x-livescreen', 'ivy'],\n    ['application/x-lotus', 'wq1'],\n    ['application/x-lotusscreencam', 'scm'],\n    ['application/x-lzh', 'lzh'],\n    ['application/x-lzx', 'lzx'],\n    ['application/x-mac-binhex40', 'hqx'],\n    ['application/x-macbinary', 'bin'],\n    ['application/x-magic-cap-package-1.0', 'mc$'],\n    ['application/x-mathcad', 'mcd'],\n    ['application/x-meme', 'mm'],\n    ['application/x-midi', ['mid', 'midi']],\n    ['application/x-mif', 'mif'],\n    ['application/x-mix-transfer', 'nix'],\n    ['application/x-mobipocket-ebook', 'prc'],\n    ['application/x-mplayer2', 'asx'],\n    ['application/x-ms-application', 'application'],\n    ['application/x-ms-wmd', 'wmd'],\n    ['application/x-ms-wmz', 'wmz'],\n    ['application/x-ms-xbap', 'xbap'],\n    ['application/x-msaccess', 'mdb'],\n    ['application/x-msbinder', 'obd'],\n    ['application/x-mscardfile', 'crd'],\n    ['application/x-msclip', 'clp'],\n    ['application/x-msdownload', ['exe', 'dll']],\n    ['application/x-msexcel', ['xls', 'xla', 'xlw']],\n    ['application/x-msmediaview', ['mvb', 'm13', 'm14']],\n    ['application/x-msmetafile', 'wmf'],\n    ['application/x-msmoney', 'mny'],\n    ['application/x-mspowerpoint', 'ppt'],\n    ['application/x-mspublisher', 'pub'],\n    ['application/x-msschedule', 'scd'],\n    ['application/x-msterminal', 'trm'],\n    ['application/x-mswrite', 'wri'],\n    ['application/x-navi-animation', 'ani'],\n    ['application/x-navidoc', 'nvd'],\n    ['application/x-navimap', 'map'],\n    ['application/x-navistyle', 'stl'],\n    ['application/x-netcdf', ['cdf', 'nc']],\n    ['application/x-newton-compatible-pkg', 'pkg'],\n    ['application/x-nokia-9000-communicator-add-on-software', 'aos'],\n    ['application/x-omc', 'omc'],\n    ['application/x-omcdatamaker', 'omcd'],\n    ['application/x-omcregerator', 'omcr'],\n    ['application/x-pagemaker', ['pm4', 'pm5']],\n    ['application/x-pcl', 'pcl'],\n    ['application/x-perfmon', ['pma', 'pmc', 'pml', 'pmr', 'pmw']],\n    ['application/x-pixclscript', 'plx'],\n    ['application/x-pkcs10', 'p10'],\n    ['application/x-pkcs12', ['p12', 'pfx']],\n    ['application/x-pkcs7-certificates', ['p7b', 'spc']],\n    ['application/x-pkcs7-certreqresp', 'p7r'],\n    ['application/x-pkcs7-mime', ['p7m', 'p7c']],\n    ['application/x-pkcs7-signature', ['p7s', 'p7a']],\n    ['application/x-pointplus', 'css'],\n    ['application/x-portable-anymap', 'pnm'],\n    ['application/x-project', ['mpc', 'mpt', 'mpv', 'mpx']],\n    ['application/x-qpro', 'wb1'],\n    ['application/x-rar-compressed', 'rar'],\n    ['application/x-rtf', 'rtf'],\n    ['application/x-sdp', 'sdp'],\n    ['application/x-sea', 'sea'],\n    ['application/x-seelogo', 'sl'],\n    ['application/x-sh', 'sh'],\n    ['application/x-shar', ['shar', 'sh']],\n    ['application/x-shockwave-flash', 'swf'],\n    ['application/x-silverlight-app', 'xap'],\n    ['application/x-sit', 'sit'],\n    ['application/x-sprite', ['spr', 'sprite']],\n    ['application/x-stuffit', 'sit'],\n    ['application/x-stuffitx', 'sitx'],\n    ['application/x-sv4cpio', 'sv4cpio'],\n    ['application/x-sv4crc', 'sv4crc'],\n    ['application/x-tar', 'tar'],\n    ['application/x-tbook', ['sbk', 'tbk']],\n    ['application/x-tcl', 'tcl'],\n    ['application/x-tex', 'tex'],\n    ['application/x-tex-tfm', 'tfm'],\n    ['application/x-texinfo', ['texi', 'texinfo']],\n    ['application/x-troff', ['roff', 't', 'tr']],\n    ['application/x-troff-man', 'man'],\n    ['application/x-troff-me', 'me'],\n    ['application/x-troff-ms', 'ms'],\n    ['application/x-troff-msvideo', 'avi'],\n    ['application/x-ustar', 'ustar'],\n    ['application/x-visio', ['vsd', 'vst', 'vsw']],\n    ['application/x-vnd.audioexplosion.mzz', 'mzz'],\n    ['application/x-vnd.ls-xpix', 'xpix'],\n    ['application/x-vrml', 'vrml'],\n    ['application/x-wais-source', ['src', 'wsrc']],\n    ['application/x-winhelp', 'hlp'],\n    ['application/x-wintalk', 'wtk'],\n    ['application/x-world', ['wrl', 'svr']],\n    ['application/x-wpwin', 'wpd'],\n    ['application/x-wri', 'wri'],\n    ['application/x-x509-ca-cert', ['cer', 'crt', 'der']],\n    ['application/x-x509-user-cert', 'crt'],\n    ['application/x-xfig', 'fig'],\n    ['application/x-xpinstall', 'xpi'],\n    ['application/x-zip-compressed', 'zip'],\n    ['application/xcap-diff+xml', 'xdf'],\n    ['application/xenc+xml', 'xenc'],\n    ['application/xhtml+xml', 'xhtml'],\n    ['application/xml', 'xml'],\n    ['application/xml-dtd', 'dtd'],\n    ['application/xop+xml', 'xop'],\n    ['application/xslt+xml', 'xslt'],\n    ['application/xspf+xml', 'xspf'],\n    ['application/xv+xml', 'mxml'],\n    ['application/yang', 'yang'],\n    ['application/yin+xml', 'yin'],\n    ['application/ynd.ms-pkipko', 'pko'],\n    ['application/zip', 'zip'],\n    ['audio/adpcm', 'adp'],\n    ['audio/aiff', ['aiff', 'aif', 'aifc']],\n    ['audio/basic', ['snd', 'au']],\n    ['audio/it', 'it'],\n    ['audio/make', ['funk', 'my', 'pfunk']],\n    ['audio/make.my.funk', 'pfunk'],\n    ['audio/mid', ['mid', 'rmi']],\n    ['audio/midi', ['midi', 'kar', 'mid']],\n    ['audio/mod', 'mod'],\n    ['audio/mp4', 'mp4a'],\n    ['audio/mpeg', ['mpga', 'mp3', 'm2a', 'mp2', 'mpa', 'mpg']],\n    ['audio/mpeg3', 'mp3'],\n    ['audio/nspaudio', ['la', 'lma']],\n    ['audio/ogg', 'oga'],\n    ['audio/s3m', 's3m'],\n    ['audio/tsp-audio', 'tsi'],\n    ['audio/tsplayer', 'tsp'],\n    ['audio/vnd.dece.audio', 'uva'],\n    ['audio/vnd.digital-winds', 'eol'],\n    ['audio/vnd.dra', 'dra'],\n    ['audio/vnd.dts', 'dts'],\n    ['audio/vnd.dts.hd', 'dtshd'],\n    ['audio/vnd.lucent.voice', 'lvp'],\n    ['audio/vnd.ms-playready.media.pya', 'pya'],\n    ['audio/vnd.nuera.ecelp4800', 'ecelp4800'],\n    ['audio/vnd.nuera.ecelp7470', 'ecelp7470'],\n    ['audio/vnd.nuera.ecelp9600', 'ecelp9600'],\n    ['audio/vnd.qcelp', 'qcp'],\n    ['audio/vnd.rip', 'rip'],\n    ['audio/voc', 'voc'],\n    ['audio/voxware', 'vox'],\n    ['audio/wav', 'wav'],\n    ['audio/webm', 'weba'],\n    ['audio/x-aac', 'aac'],\n    ['audio/x-adpcm', 'snd'],\n    ['audio/x-aiff', ['aiff', 'aif', 'aifc']],\n    ['audio/x-au', 'au'],\n    ['audio/x-gsm', ['gsd', 'gsm']],\n    ['audio/x-jam', 'jam'],\n    ['audio/x-liveaudio', 'lam'],\n    ['audio/x-mid', ['mid', 'midi']],\n    ['audio/x-midi', ['midi', 'mid']],\n    ['audio/x-mod', 'mod'],\n    ['audio/x-mpeg', 'mp2'],\n    ['audio/x-mpeg-3', 'mp3'],\n    ['audio/x-mpegurl', 'm3u'],\n    ['audio/x-mpequrl', 'm3u'],\n    ['audio/x-ms-wax', 'wax'],\n    ['audio/x-ms-wma', 'wma'],\n    ['audio/x-nspaudio', ['la', 'lma']],\n    ['audio/x-pn-realaudio', ['ra', 'ram', 'rm', 'rmm', 'rmp']],\n    ['audio/x-pn-realaudio-plugin', ['ra', 'rmp', 'rpm']],\n    ['audio/x-psid', 'sid'],\n    ['audio/x-realaudio', 'ra'],\n    ['audio/x-twinvq', 'vqf'],\n    ['audio/x-twinvq-plugin', ['vqe', 'vql']],\n    ['audio/x-vnd.audioexplosion.mjuicemediafile', 'mjf'],\n    ['audio/x-voc', 'voc'],\n    ['audio/x-wav', 'wav'],\n    ['audio/xm', 'xm'],\n    ['chemical/x-cdx', 'cdx'],\n    ['chemical/x-cif', 'cif'],\n    ['chemical/x-cmdf', 'cmdf'],\n    ['chemical/x-cml', 'cml'],\n    ['chemical/x-csml', 'csml'],\n    ['chemical/x-pdb', ['pdb', 'xyz']],\n    ['chemical/x-xyz', 'xyz'],\n    ['drawing/x-dwf', 'dwf'],\n    ['i-world/i-vrml', 'ivr'],\n    ['image/bmp', ['bmp', 'bm']],\n    ['image/cgm', 'cgm'],\n    ['image/cis-cod', 'cod'],\n    ['image/cmu-raster', ['ras', 'rast']],\n    ['image/fif', 'fif'],\n    ['image/florian', ['flo', 'turbot']],\n    ['image/g3fax', 'g3'],\n    ['image/gif', 'gif'],\n    ['image/ief', ['ief', 'iefs']],\n    ['image/jpeg', ['jpeg', 'jpe', 'jpg', 'jfif', 'jfif-tbnl']],\n    ['image/jutvision', 'jut'],\n    ['image/ktx', 'ktx'],\n    ['image/naplps', ['nap', 'naplps']],\n    ['image/pict', ['pic', 'pict']],\n    ['image/pipeg', 'jfif'],\n    ['image/pjpeg', ['jfif', 'jpe', 'jpeg', 'jpg']],\n    ['image/png', ['png', 'x-png']],\n    ['image/prs.btif', 'btif'],\n    ['image/svg+xml', 'svg'],\n    ['image/tiff', ['tif', 'tiff']],\n    ['image/vasa', 'mcf'],\n    ['image/vnd.adobe.photoshop', 'psd'],\n    ['image/vnd.dece.graphic', 'uvi'],\n    ['image/vnd.djvu', 'djvu'],\n    ['image/vnd.dvb.subtitle', 'sub'],\n    ['image/vnd.dwg', ['dwg', 'dxf', 'svf']],\n    ['image/vnd.dxf', 'dxf'],\n    ['image/vnd.fastbidsheet', 'fbs'],\n    ['image/vnd.fpx', 'fpx'],\n    ['image/vnd.fst', 'fst'],\n    ['image/vnd.fujixerox.edmics-mmr', 'mmr'],\n    ['image/vnd.fujixerox.edmics-rlc', 'rlc'],\n    ['image/vnd.ms-modi', 'mdi'],\n    ['image/vnd.net-fpx', ['fpx', 'npx']],\n    ['image/vnd.rn-realflash', 'rf'],\n    ['image/vnd.rn-realpix', 'rp'],\n    ['image/vnd.wap.wbmp', 'wbmp'],\n    ['image/vnd.xiff', 'xif'],\n    ['image/webp', 'webp'],\n    ['image/x-cmu-raster', 'ras'],\n    ['image/x-cmx', 'cmx'],\n    ['image/x-dwg', ['dwg', 'dxf', 'svf']],\n    ['image/x-freehand', 'fh'],\n    ['image/x-icon', 'ico'],\n    ['image/x-jg', 'art'],\n    ['image/x-jps', 'jps'],\n    ['image/x-niff', ['niff', 'nif']],\n    ['image/x-pcx', 'pcx'],\n    ['image/x-pict', ['pct', 'pic']],\n    ['image/x-portable-anymap', 'pnm'],\n    ['image/x-portable-bitmap', 'pbm'],\n    ['image/x-portable-graymap', 'pgm'],\n    ['image/x-portable-greymap', 'pgm'],\n    ['image/x-portable-pixmap', 'ppm'],\n    ['image/x-quicktime', ['qif', 'qti', 'qtif']],\n    ['image/x-rgb', 'rgb'],\n    ['image/x-tiff', ['tif', 'tiff']],\n    ['image/x-windows-bmp', 'bmp'],\n    ['image/x-xbitmap', 'xbm'],\n    ['image/x-xbm', 'xbm'],\n    ['image/x-xpixmap', ['xpm', 'pm']],\n    ['image/x-xwd', 'xwd'],\n    ['image/x-xwindowdump', 'xwd'],\n    ['image/xbm', 'xbm'],\n    ['image/xpm', 'xpm'],\n    ['message/rfc822', ['eml', 'mht', 'mhtml', 'nws', 'mime']],\n    ['model/iges', ['iges', 'igs']],\n    ['model/mesh', 'msh'],\n    ['model/vnd.collada+xml', 'dae'],\n    ['model/vnd.dwf', 'dwf'],\n    ['model/vnd.gdl', 'gdl'],\n    ['model/vnd.gtw', 'gtw'],\n    ['model/vnd.mts', 'mts'],\n    ['model/vnd.vtu', 'vtu'],\n    ['model/vrml', ['vrml', 'wrl', 'wrz']],\n    ['model/x-pov', 'pov'],\n    ['multipart/x-gzip', 'gzip'],\n    ['multipart/x-ustar', 'ustar'],\n    ['multipart/x-zip', 'zip'],\n    ['music/crescendo', ['mid', 'midi']],\n    ['music/x-karaoke', 'kar'],\n    ['paleovu/x-pv', 'pvu'],\n    ['text/asp', 'asp'],\n    ['text/calendar', 'ics'],\n    ['text/css', 'css'],\n    ['text/csv', 'csv'],\n    ['text/ecmascript', 'js'],\n    ['text/h323', '323'],\n    ['text/html', ['html', 'htm', 'stm', 'acgi', 'htmls', 'htx', 'shtml']],\n    ['text/iuls', 'uls'],\n    ['text/javascript', 'js'],\n    ['text/mcf', 'mcf'],\n    ['text/n3', 'n3'],\n    ['text/pascal', 'pas'],\n    [\n        'text/plain',\n        [\n            'txt',\n            'bas',\n            'c',\n            'h',\n            'c++',\n            'cc',\n            'com',\n            'conf',\n            'cxx',\n            'def',\n            'f',\n            'f90',\n            'for',\n            'g',\n            'hh',\n            'idc',\n            'jav',\n            'java',\n            'list',\n            'log',\n            'lst',\n            'm',\n            'mar',\n            'pl',\n            'sdml',\n            'text'\n        ]\n    ],\n    ['text/plain-bas', 'par'],\n    ['text/prs.lines.tag', 'dsc'],\n    ['text/richtext', ['rtx', 'rt', 'rtf']],\n    ['text/scriplet', 'wsc'],\n    ['text/scriptlet', 'sct'],\n    ['text/sgml', ['sgm', 'sgml']],\n    ['text/tab-separated-values', 'tsv'],\n    ['text/troff', 't'],\n    ['text/turtle', 'ttl'],\n    ['text/uri-list', ['uni', 'unis', 'uri', 'uris']],\n    ['text/vnd.abc', 'abc'],\n    ['text/vnd.curl', 'curl'],\n    ['text/vnd.curl.dcurl', 'dcurl'],\n    ['text/vnd.curl.mcurl', 'mcurl'],\n    ['text/vnd.curl.scurl', 'scurl'],\n    ['text/vnd.fly', 'fly'],\n    ['text/vnd.fmi.flexstor', 'flx'],\n    ['text/vnd.graphviz', 'gv'],\n    ['text/vnd.in3d.3dml', '3dml'],\n    ['text/vnd.in3d.spot', 'spot'],\n    ['text/vnd.rn-realtext', 'rt'],\n    ['text/vnd.sun.j2me.app-descriptor', 'jad'],\n    ['text/vnd.wap.wml', 'wml'],\n    ['text/vnd.wap.wmlscript', 'wmls'],\n    ['text/webviewhtml', 'htt'],\n    ['text/x-asm', ['asm', 's']],\n    ['text/x-audiosoft-intra', 'aip'],\n    ['text/x-c', ['c', 'cc', 'cpp']],\n    ['text/x-component', 'htc'],\n    ['text/x-fortran', ['for', 'f', 'f77', 'f90']],\n    ['text/x-h', ['h', 'hh']],\n    ['text/x-java-source', ['java', 'jav']],\n    ['text/x-java-source,java', 'java'],\n    ['text/x-la-asf', 'lsx'],\n    ['text/x-m', 'm'],\n    ['text/x-pascal', 'p'],\n    ['text/x-script', 'hlb'],\n    ['text/x-script.csh', 'csh'],\n    ['text/x-script.elisp', 'el'],\n    ['text/x-script.guile', 'scm'],\n    ['text/x-script.ksh', 'ksh'],\n    ['text/x-script.lisp', 'lsp'],\n    ['text/x-script.perl', 'pl'],\n    ['text/x-script.perl-module', 'pm'],\n    ['text/x-script.phyton', 'py'],\n    ['text/x-script.rexx', 'rexx'],\n    ['text/x-script.scheme', 'scm'],\n    ['text/x-script.sh', 'sh'],\n    ['text/x-script.tcl', 'tcl'],\n    ['text/x-script.tcsh', 'tcsh'],\n    ['text/x-script.zsh', 'zsh'],\n    ['text/x-server-parsed-html', ['shtml', 'ssi']],\n    ['text/x-setext', 'etx'],\n    ['text/x-sgml', ['sgm', 'sgml']],\n    ['text/x-speech', ['spc', 'talk']],\n    ['text/x-uil', 'uil'],\n    ['text/x-uuencode', ['uu', 'uue']],\n    ['text/x-vcalendar', 'vcs'],\n    ['text/x-vcard', 'vcf'],\n    ['text/xml', 'xml'],\n    ['video/3gpp', '3gp'],\n    ['video/3gpp2', '3g2'],\n    ['video/animaflex', 'afl'],\n    ['video/avi', 'avi'],\n    ['video/avs-video', 'avs'],\n    ['video/dl', 'dl'],\n    ['video/fli', 'fli'],\n    ['video/gl', 'gl'],\n    ['video/h261', 'h261'],\n    ['video/h263', 'h263'],\n    ['video/h264', 'h264'],\n    ['video/jpeg', 'jpgv'],\n    ['video/jpm', 'jpm'],\n    ['video/mj2', 'mj2'],\n    ['video/mp4', 'mp4'],\n    ['video/mpeg', ['mpeg', 'mp2', 'mpa', 'mpe', 'mpg', 'mpv2', 'm1v', 'm2v', 'mp3']],\n    ['video/msvideo', 'avi'],\n    ['video/ogg', 'ogv'],\n    ['video/quicktime', ['mov', 'qt', 'moov']],\n    ['video/vdo', 'vdo'],\n    ['video/vivo', ['viv', 'vivo']],\n    ['video/vnd.dece.hd', 'uvh'],\n    ['video/vnd.dece.mobile', 'uvm'],\n    ['video/vnd.dece.pd', 'uvp'],\n    ['video/vnd.dece.sd', 'uvs'],\n    ['video/vnd.dece.video', 'uvv'],\n    ['video/vnd.fvt', 'fvt'],\n    ['video/vnd.mpegurl', 'mxu'],\n    ['video/vnd.ms-playready.media.pyv', 'pyv'],\n    ['video/vnd.rn-realvideo', 'rv'],\n    ['video/vnd.uvvu.mp4', 'uvu'],\n    ['video/vnd.vivo', ['viv', 'vivo']],\n    ['video/vosaic', 'vos'],\n    ['video/webm', 'webm'],\n    ['video/x-amt-demorun', 'xdr'],\n    ['video/x-amt-showrun', 'xsr'],\n    ['video/x-atomic3d-feature', 'fmf'],\n    ['video/x-dl', 'dl'],\n    ['video/x-dv', ['dif', 'dv']],\n    ['video/x-f4v', 'f4v'],\n    ['video/x-fli', 'fli'],\n    ['video/x-flv', 'flv'],\n    ['video/x-gl', 'gl'],\n    ['video/x-isvideo', 'isu'],\n    ['video/x-la-asf', ['lsf', 'lsx']],\n    ['video/x-m4v', 'm4v'],\n    ['video/x-motion-jpeg', 'mjpg'],\n    ['video/x-mpeg', ['mp3', 'mp2']],\n    ['video/x-mpeq2a', 'mp2'],\n    ['video/x-ms-asf', ['asf', 'asr', 'asx']],\n    ['video/x-ms-asf-plugin', 'asx'],\n    ['video/x-ms-wm', 'wm'],\n    ['video/x-ms-wmv', 'wmv'],\n    ['video/x-ms-wmx', 'wmx'],\n    ['video/x-ms-wvx', 'wvx'],\n    ['video/x-msvideo', 'avi'],\n    ['video/x-qtc', 'qtc'],\n    ['video/x-scm', 'scm'],\n    ['video/x-sgi-movie', ['movie', 'mv']],\n    ['windows/metafile', 'wmf'],\n    ['www/mime', 'mime'],\n    ['x-conference/x-cooltalk', 'ice'],\n    ['x-music/x-midi', ['mid', 'midi']],\n    ['x-world/x-3dmf', ['3dm', '3dmf', 'qd3', 'qd3d']],\n    ['x-world/x-svr', 'svr'],\n    ['x-world/x-vrml', ['flr', 'vrml', 'wrl', 'wrz', 'xaf', 'xof']],\n    ['x-world/x-vrt', 'vrt'],\n    ['xgl/drawing', 'xgz'],\n    ['xgl/movie', 'xmz']\n]);\nconst extensions = new Map([\n    ['123', 'application/vnd.lotus-1-2-3'],\n    ['323', 'text/h323'],\n    ['*', 'application/octet-stream'],\n    ['3dm', 'x-world/x-3dmf'],\n    ['3dmf', 'x-world/x-3dmf'],\n    ['3dml', 'text/vnd.in3d.3dml'],\n    ['3g2', 'video/3gpp2'],\n    ['3gp', 'video/3gpp'],\n    ['7z', 'application/x-7z-compressed'],\n    ['a', 'application/octet-stream'],\n    ['aab', 'application/x-authorware-bin'],\n    ['aac', 'audio/x-aac'],\n    ['aam', 'application/x-authorware-map'],\n    ['aas', 'application/x-authorware-seg'],\n    ['abc', 'text/vnd.abc'],\n    ['abw', 'application/x-abiword'],\n    ['ac', 'application/pkix-attr-cert'],\n    ['acc', 'application/vnd.americandynamics.acc'],\n    ['ace', 'application/x-ace-compressed'],\n    ['acgi', 'text/html'],\n    ['acu', 'application/vnd.acucobol'],\n    ['acx', 'application/internet-property-stream'],\n    ['adp', 'audio/adpcm'],\n    ['aep', 'application/vnd.audiograph'],\n    ['afl', 'video/animaflex'],\n    ['afp', 'application/vnd.ibm.modcap'],\n    ['ahead', 'application/vnd.ahead.space'],\n    ['ai', 'application/postscript'],\n    ['aif', ['audio/aiff', 'audio/x-aiff']],\n    ['aifc', ['audio/aiff', 'audio/x-aiff']],\n    ['aiff', ['audio/aiff', 'audio/x-aiff']],\n    ['aim', 'application/x-aim'],\n    ['aip', 'text/x-audiosoft-intra'],\n    ['air', 'application/vnd.adobe.air-application-installer-package+zip'],\n    ['ait', 'application/vnd.dvb.ait'],\n    ['ami', 'application/vnd.amiga.ami'],\n    ['ani', 'application/x-navi-animation'],\n    ['aos', 'application/x-nokia-9000-communicator-add-on-software'],\n    ['apk', 'application/vnd.android.package-archive'],\n    ['application', 'application/x-ms-application'],\n    ['apr', 'application/vnd.lotus-approach'],\n    ['aps', 'application/mime'],\n    ['arc', 'application/octet-stream'],\n    ['arj', ['application/arj', 'application/octet-stream']],\n    ['art', 'image/x-jg'],\n    ['asf', 'video/x-ms-asf'],\n    ['asm', 'text/x-asm'],\n    ['aso', 'application/vnd.accpac.simply.aso'],\n    ['asp', 'text/asp'],\n    ['asr', 'video/x-ms-asf'],\n    ['asx', ['video/x-ms-asf', 'application/x-mplayer2', 'video/x-ms-asf-plugin']],\n    ['atc', 'application/vnd.acucorp'],\n    ['atomcat', 'application/atomcat+xml'],\n    ['atomsvc', 'application/atomsvc+xml'],\n    ['atx', 'application/vnd.antix.game-component'],\n    ['au', ['audio/basic', 'audio/x-au']],\n    ['avi', ['video/avi', 'video/msvideo', 'application/x-troff-msvideo', 'video/x-msvideo']],\n    ['avs', 'video/avs-video'],\n    ['aw', 'application/applixware'],\n    ['axs', 'application/olescript'],\n    ['azf', 'application/vnd.airzip.filesecure.azf'],\n    ['azs', 'application/vnd.airzip.filesecure.azs'],\n    ['azw', 'application/vnd.amazon.ebook'],\n    ['bas', 'text/plain'],\n    ['bcpio', 'application/x-bcpio'],\n    ['bdf', 'application/x-font-bdf'],\n    ['bdm', 'application/vnd.syncml.dm+wbxml'],\n    ['bed', 'application/vnd.realvnc.bed'],\n    ['bh2', 'application/vnd.fujitsu.oasysprs'],\n    ['bin', ['application/octet-stream', 'application/mac-binary', 'application/macbinary', 'application/x-macbinary', 'application/x-binary']],\n    ['bm', 'image/bmp'],\n    ['bmi', 'application/vnd.bmi'],\n    ['bmp', ['image/bmp', 'image/x-windows-bmp']],\n    ['boo', 'application/book'],\n    ['book', 'application/book'],\n    ['box', 'application/vnd.previewsystems.box'],\n    ['boz', 'application/x-bzip2'],\n    ['bsh', 'application/x-bsh'],\n    ['btif', 'image/prs.btif'],\n    ['bz', 'application/x-bzip'],\n    ['bz2', 'application/x-bzip2'],\n    ['c', ['text/plain', 'text/x-c']],\n    ['c++', 'text/plain'],\n    ['c11amc', 'application/vnd.cluetrust.cartomobile-config'],\n    ['c11amz', 'application/vnd.cluetrust.cartomobile-config-pkg'],\n    ['c4g', 'application/vnd.clonk.c4group'],\n    ['cab', 'application/vnd.ms-cab-compressed'],\n    ['car', 'application/vnd.curl.car'],\n    ['cat', ['application/vnd.ms-pkiseccat', 'application/vnd.ms-pki.seccat']],\n    ['cc', ['text/plain', 'text/x-c']],\n    ['ccad', 'application/clariscad'],\n    ['cco', 'application/x-cocoa'],\n    ['ccxml', 'application/ccxml+xml,'],\n    ['cdbcmsg', 'application/vnd.contact.cmsg'],\n    ['cdf', ['application/cdf', 'application/x-cdf', 'application/x-netcdf']],\n    ['cdkey', 'application/vnd.mediastation.cdkey'],\n    ['cdmia', 'application/cdmi-capability'],\n    ['cdmic', 'application/cdmi-container'],\n    ['cdmid', 'application/cdmi-domain'],\n    ['cdmio', 'application/cdmi-object'],\n    ['cdmiq', 'application/cdmi-queue'],\n    ['cdx', 'chemical/x-cdx'],\n    ['cdxml', 'application/vnd.chemdraw+xml'],\n    ['cdy', 'application/vnd.cinderella'],\n    ['cer', ['application/pkix-cert', 'application/x-x509-ca-cert']],\n    ['cgm', 'image/cgm'],\n    ['cha', 'application/x-chat'],\n    ['chat', 'application/x-chat'],\n    ['chm', 'application/vnd.ms-htmlhelp'],\n    ['chrt', 'application/vnd.kde.kchart'],\n    ['cif', 'chemical/x-cif'],\n    ['cii', 'application/vnd.anser-web-certificate-issue-initiation'],\n    ['cil', 'application/vnd.ms-artgalry'],\n    ['cla', 'application/vnd.claymore'],\n    ['class', ['application/octet-stream', 'application/java', 'application/java-byte-code', 'application/java-vm', 'application/x-java-class']],\n    ['clkk', 'application/vnd.crick.clicker.keyboard'],\n    ['clkp', 'application/vnd.crick.clicker.palette'],\n    ['clkt', 'application/vnd.crick.clicker.template'],\n    ['clkw', 'application/vnd.crick.clicker.wordbank'],\n    ['clkx', 'application/vnd.crick.clicker'],\n    ['clp', 'application/x-msclip'],\n    ['cmc', 'application/vnd.cosmocaller'],\n    ['cmdf', 'chemical/x-cmdf'],\n    ['cml', 'chemical/x-cml'],\n    ['cmp', 'application/vnd.yellowriver-custom-menu'],\n    ['cmx', 'image/x-cmx'],\n    ['cod', ['image/cis-cod', 'application/vnd.rim.cod']],\n    ['com', ['application/octet-stream', 'text/plain']],\n    ['conf', 'text/plain'],\n    ['cpio', 'application/x-cpio'],\n    ['cpp', 'text/x-c'],\n    ['cpt', ['application/mac-compactpro', 'application/x-compactpro', 'application/x-cpt']],\n    ['crd', 'application/x-mscardfile'],\n    ['crl', ['application/pkix-crl', 'application/pkcs-crl']],\n    ['crt', ['application/pkix-cert', 'application/x-x509-user-cert', 'application/x-x509-ca-cert']],\n    ['cryptonote', 'application/vnd.rig.cryptonote'],\n    ['csh', ['text/x-script.csh', 'application/x-csh']],\n    ['csml', 'chemical/x-csml'],\n    ['csp', 'application/vnd.commonspace'],\n    ['css', ['text/css', 'application/x-pointplus']],\n    ['csv', 'text/csv'],\n    ['cu', 'application/cu-seeme'],\n    ['curl', 'text/vnd.curl'],\n    ['cww', 'application/prs.cww'],\n    ['cxx', 'text/plain'],\n    ['dae', 'model/vnd.collada+xml'],\n    ['daf', 'application/vnd.mobius.daf'],\n    ['davmount', 'application/davmount+xml'],\n    ['dcr', 'application/x-director'],\n    ['dcurl', 'text/vnd.curl.dcurl'],\n    ['dd2', 'application/vnd.oma.dd2+xml'],\n    ['ddd', 'application/vnd.fujixerox.ddd'],\n    ['deb', 'application/x-debian-package'],\n    ['deepv', 'application/x-deepv'],\n    ['def', 'text/plain'],\n    ['der', 'application/x-x509-ca-cert'],\n    ['dfac', 'application/vnd.dreamfactory'],\n    ['dif', 'video/x-dv'],\n    ['dir', 'application/x-director'],\n    ['dis', 'application/vnd.mobius.dis'],\n    ['djvu', 'image/vnd.djvu'],\n    ['dl', ['video/dl', 'video/x-dl']],\n    ['dll', 'application/x-msdownload'],\n    ['dms', 'application/octet-stream'],\n    ['dna', 'application/vnd.dna'],\n    ['doc', 'application/msword'],\n    ['docm', 'application/vnd.ms-word.document.macroenabled.12'],\n    ['docx', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document'],\n    ['dot', 'application/msword'],\n    ['dotm', 'application/vnd.ms-word.template.macroenabled.12'],\n    ['dotx', 'application/vnd.openxmlformats-officedocument.wordprocessingml.template'],\n    ['dp', ['application/commonground', 'application/vnd.osgi.dp']],\n    ['dpg', 'application/vnd.dpgraph'],\n    ['dra', 'audio/vnd.dra'],\n    ['drw', 'application/drafting'],\n    ['dsc', 'text/prs.lines.tag'],\n    ['dssc', 'application/dssc+der'],\n    ['dtb', 'application/x-dtbook+xml'],\n    ['dtd', 'application/xml-dtd'],\n    ['dts', 'audio/vnd.dts'],\n    ['dtshd', 'audio/vnd.dts.hd'],\n    ['dump', 'application/octet-stream'],\n    ['dv', 'video/x-dv'],\n    ['dvi', 'application/x-dvi'],\n    ['dwf', ['model/vnd.dwf', 'drawing/x-dwf']],\n    ['dwg', ['application/acad', 'image/vnd.dwg', 'image/x-dwg']],\n    ['dxf', ['application/dxf', 'image/vnd.dwg', 'image/vnd.dxf', 'image/x-dwg']],\n    ['dxp', 'application/vnd.spotfire.dxp'],\n    ['dxr', 'application/x-director'],\n    ['ecelp4800', 'audio/vnd.nuera.ecelp4800'],\n    ['ecelp7470', 'audio/vnd.nuera.ecelp7470'],\n    ['ecelp9600', 'audio/vnd.nuera.ecelp9600'],\n    ['edm', 'application/vnd.novadigm.edm'],\n    ['edx', 'application/vnd.novadigm.edx'],\n    ['efif', 'application/vnd.picsel'],\n    ['ei6', 'application/vnd.pg.osasli'],\n    ['el', 'text/x-script.elisp'],\n    ['elc', ['application/x-elc', 'application/x-bytecode.elisp']],\n    ['eml', 'message/rfc822'],\n    ['emma', 'application/emma+xml'],\n    ['env', 'application/x-envoy'],\n    ['eol', 'audio/vnd.digital-winds'],\n    ['eot', 'application/vnd.ms-fontobject'],\n    ['eps', 'application/postscript'],\n    ['epub', 'application/epub+zip'],\n    ['es', ['application/ecmascript', 'application/x-esrehber']],\n    ['es3', 'application/vnd.eszigno3+xml'],\n    ['esf', 'application/vnd.epson.esf'],\n    ['etx', 'text/x-setext'],\n    ['evy', ['application/envoy', 'application/x-envoy']],\n    ['exe', ['application/octet-stream', 'application/x-msdownload']],\n    ['exi', 'application/exi'],\n    ['ext', 'application/vnd.novadigm.ext'],\n    ['ez2', 'application/vnd.ezpix-album'],\n    ['ez3', 'application/vnd.ezpix-package'],\n    ['f', ['text/plain', 'text/x-fortran']],\n    ['f4v', 'video/x-f4v'],\n    ['f77', 'text/x-fortran'],\n    ['f90', ['text/plain', 'text/x-fortran']],\n    ['fbs', 'image/vnd.fastbidsheet'],\n    ['fcs', 'application/vnd.isac.fcs'],\n    ['fdf', 'application/vnd.fdf'],\n    ['fe_launch', 'application/vnd.denovo.fcselayout-link'],\n    ['fg5', 'application/vnd.fujitsu.oasysgp'],\n    ['fh', 'image/x-freehand'],\n    ['fif', ['application/fractals', 'image/fif']],\n    ['fig', 'application/x-xfig'],\n    ['fli', ['video/fli', 'video/x-fli']],\n    ['flo', ['image/florian', 'application/vnd.micrografx.flo']],\n    ['flr', 'x-world/x-vrml'],\n    ['flv', 'video/x-flv'],\n    ['flw', 'application/vnd.kde.kivio'],\n    ['flx', 'text/vnd.fmi.flexstor'],\n    ['fly', 'text/vnd.fly'],\n    ['fm', 'application/vnd.framemaker'],\n    ['fmf', 'video/x-atomic3d-feature'],\n    ['fnc', 'application/vnd.frogans.fnc'],\n    ['for', ['text/plain', 'text/x-fortran']],\n    ['fpx', ['image/vnd.fpx', 'image/vnd.net-fpx']],\n    ['frl', 'application/freeloader'],\n    ['fsc', 'application/vnd.fsc.weblaunch'],\n    ['fst', 'image/vnd.fst'],\n    ['ftc', 'application/vnd.fluxtime.clip'],\n    ['fti', 'application/vnd.anser-web-funds-transfer-initiation'],\n    ['funk', 'audio/make'],\n    ['fvt', 'video/vnd.fvt'],\n    ['fxp', 'application/vnd.adobe.fxp'],\n    ['fzs', 'application/vnd.fuzzysheet'],\n    ['g', 'text/plain'],\n    ['g2w', 'application/vnd.geoplan'],\n    ['g3', 'image/g3fax'],\n    ['g3w', 'application/vnd.geospace'],\n    ['gac', 'application/vnd.groove-account'],\n    ['gdl', 'model/vnd.gdl'],\n    ['geo', 'application/vnd.dynageo'],\n    ['gex', 'application/vnd.geometry-explorer'],\n    ['ggb', 'application/vnd.geogebra.file'],\n    ['ggt', 'application/vnd.geogebra.tool'],\n    ['ghf', 'application/vnd.groove-help'],\n    ['gif', 'image/gif'],\n    ['gim', 'application/vnd.groove-identity-message'],\n    ['gl', ['video/gl', 'video/x-gl']],\n    ['gmx', 'application/vnd.gmx'],\n    ['gnumeric', 'application/x-gnumeric'],\n    ['gph', 'application/vnd.flographit'],\n    ['gqf', 'application/vnd.grafeq'],\n    ['gram', 'application/srgs'],\n    ['grv', 'application/vnd.groove-injector'],\n    ['grxml', 'application/srgs+xml'],\n    ['gsd', 'audio/x-gsm'],\n    ['gsf', 'application/x-font-ghostscript'],\n    ['gsm', 'audio/x-gsm'],\n    ['gsp', 'application/x-gsp'],\n    ['gss', 'application/x-gss'],\n    ['gtar', 'application/x-gtar'],\n    ['gtm', 'application/vnd.groove-tool-message'],\n    ['gtw', 'model/vnd.gtw'],\n    ['gv', 'text/vnd.graphviz'],\n    ['gxt', 'application/vnd.geonext'],\n    ['gz', ['application/x-gzip', 'application/x-compressed']],\n    ['gzip', ['multipart/x-gzip', 'application/x-gzip']],\n    ['h', ['text/plain', 'text/x-h']],\n    ['h261', 'video/h261'],\n    ['h263', 'video/h263'],\n    ['h264', 'video/h264'],\n    ['hal', 'application/vnd.hal+xml'],\n    ['hbci', 'application/vnd.hbci'],\n    ['hdf', 'application/x-hdf'],\n    ['help', 'application/x-helpfile'],\n    ['hgl', 'application/vnd.hp-hpgl'],\n    ['hh', ['text/plain', 'text/x-h']],\n    ['hlb', 'text/x-script'],\n    ['hlp', ['application/winhlp', 'application/hlp', 'application/x-helpfile', 'application/x-winhelp']],\n    ['hpg', 'application/vnd.hp-hpgl'],\n    ['hpgl', 'application/vnd.hp-hpgl'],\n    ['hpid', 'application/vnd.hp-hpid'],\n    ['hps', 'application/vnd.hp-hps'],\n    [\n        'hqx',\n        [\n            'application/mac-binhex40',\n            'application/binhex',\n            'application/binhex4',\n            'application/mac-binhex',\n            'application/x-binhex40',\n            'application/x-mac-binhex40'\n        ]\n    ],\n    ['hta', 'application/hta'],\n    ['htc', 'text/x-component'],\n    ['htke', 'application/vnd.kenameaapp'],\n    ['htm', 'text/html'],\n    ['html', 'text/html'],\n    ['htmls', 'text/html'],\n    ['htt', 'text/webviewhtml'],\n    ['htx', 'text/html'],\n    ['hvd', 'application/vnd.yamaha.hv-dic'],\n    ['hvp', 'application/vnd.yamaha.hv-voice'],\n    ['hvs', 'application/vnd.yamaha.hv-script'],\n    ['i2g', 'application/vnd.intergeo'],\n    ['icc', 'application/vnd.iccprofile'],\n    ['ice', 'x-conference/x-cooltalk'],\n    ['ico', 'image/x-icon'],\n    ['ics', 'text/calendar'],\n    ['idc', 'text/plain'],\n    ['ief', 'image/ief'],\n    ['iefs', 'image/ief'],\n    ['ifm', 'application/vnd.shana.informed.formdata'],\n    ['iges', ['application/iges', 'model/iges']],\n    ['igl', 'application/vnd.igloader'],\n    ['igm', 'application/vnd.insors.igm'],\n    ['igs', ['application/iges', 'model/iges']],\n    ['igx', 'application/vnd.micrografx.igx'],\n    ['iif', 'application/vnd.shana.informed.interchange'],\n    ['iii', 'application/x-iphone'],\n    ['ima', 'application/x-ima'],\n    ['imap', 'application/x-httpd-imap'],\n    ['imp', 'application/vnd.accpac.simply.imp'],\n    ['ims', 'application/vnd.ms-ims'],\n    ['inf', 'application/inf'],\n    ['ins', ['application/x-internet-signup', 'application/x-internett-signup']],\n    ['ip', 'application/x-ip2'],\n    ['ipfix', 'application/ipfix'],\n    ['ipk', 'application/vnd.shana.informed.package'],\n    ['irm', 'application/vnd.ibm.rights-management'],\n    ['irp', 'application/vnd.irepository.package+xml'],\n    ['isp', 'application/x-internet-signup'],\n    ['isu', 'video/x-isvideo'],\n    ['it', 'audio/it'],\n    ['itp', 'application/vnd.shana.informed.formtemplate'],\n    ['iv', 'application/x-inventor'],\n    ['ivp', 'application/vnd.immervision-ivp'],\n    ['ivr', 'i-world/i-vrml'],\n    ['ivu', 'application/vnd.immervision-ivu'],\n    ['ivy', 'application/x-livescreen'],\n    ['jad', 'text/vnd.sun.j2me.app-descriptor'],\n    ['jam', ['application/vnd.jam', 'audio/x-jam']],\n    ['jar', 'application/java-archive'],\n    ['jav', ['text/plain', 'text/x-java-source']],\n    ['java', ['text/plain', 'text/x-java-source,java', 'text/x-java-source']],\n    ['jcm', 'application/x-java-commerce'],\n    ['jfif', ['image/pipeg', 'image/jpeg', 'image/pjpeg']],\n    ['jfif-tbnl', 'image/jpeg'],\n    ['jisp', 'application/vnd.jisp'],\n    ['jlt', 'application/vnd.hp-jlyt'],\n    ['jnlp', 'application/x-java-jnlp-file'],\n    ['joda', 'application/vnd.joost.joda-archive'],\n    ['jpe', ['image/jpeg', 'image/pjpeg']],\n    ['jpeg', ['image/jpeg', 'image/pjpeg']],\n    ['jpg', ['image/jpeg', 'image/pjpeg']],\n    ['jpgv', 'video/jpeg'],\n    ['jpm', 'video/jpm'],\n    ['jps', 'image/x-jps'],\n    ['js', ['application/javascript', 'application/ecmascript', 'text/javascript', 'text/ecmascript', 'application/x-javascript']],\n    ['json', 'application/json'],\n    ['jut', 'image/jutvision'],\n    ['kar', ['audio/midi', 'music/x-karaoke']],\n    ['karbon', 'application/vnd.kde.karbon'],\n    ['kfo', 'application/vnd.kde.kformula'],\n    ['kia', 'application/vnd.kidspiration'],\n    ['kml', 'application/vnd.google-earth.kml+xml'],\n    ['kmz', 'application/vnd.google-earth.kmz'],\n    ['kne', 'application/vnd.kinar'],\n    ['kon', 'application/vnd.kde.kontour'],\n    ['kpr', 'application/vnd.kde.kpresenter'],\n    ['ksh', ['application/x-ksh', 'text/x-script.ksh']],\n    ['ksp', 'application/vnd.kde.kspread'],\n    ['ktx', 'image/ktx'],\n    ['ktz', 'application/vnd.kahootz'],\n    ['kwd', 'application/vnd.kde.kword'],\n    ['la', ['audio/nspaudio', 'audio/x-nspaudio']],\n    ['lam', 'audio/x-liveaudio'],\n    ['lasxml', 'application/vnd.las.las+xml'],\n    ['latex', 'application/x-latex'],\n    ['lbd', 'application/vnd.llamagraphics.life-balance.desktop'],\n    ['lbe', 'application/vnd.llamagraphics.life-balance.exchange+xml'],\n    ['les', 'application/vnd.hhe.lesson-player'],\n    ['lha', ['application/octet-stream', 'application/lha', 'application/x-lha']],\n    ['lhx', 'application/octet-stream'],\n    ['link66', 'application/vnd.route66.link66+xml'],\n    ['list', 'text/plain'],\n    ['lma', ['audio/nspaudio', 'audio/x-nspaudio']],\n    ['log', 'text/plain'],\n    ['lrm', 'application/vnd.ms-lrm'],\n    ['lsf', 'video/x-la-asf'],\n    ['lsp', ['application/x-lisp', 'text/x-script.lisp']],\n    ['lst', 'text/plain'],\n    ['lsx', ['video/x-la-asf', 'text/x-la-asf']],\n    ['ltf', 'application/vnd.frogans.ltf'],\n    ['ltx', 'application/x-latex'],\n    ['lvp', 'audio/vnd.lucent.voice'],\n    ['lwp', 'application/vnd.lotus-wordpro'],\n    ['lzh', ['application/octet-stream', 'application/x-lzh']],\n    ['lzx', ['application/lzx', 'application/octet-stream', 'application/x-lzx']],\n    ['m', ['text/plain', 'text/x-m']],\n    ['m13', 'application/x-msmediaview'],\n    ['m14', 'application/x-msmediaview'],\n    ['m1v', 'video/mpeg'],\n    ['m21', 'application/mp21'],\n    ['m2a', 'audio/mpeg'],\n    ['m2v', 'video/mpeg'],\n    ['m3u', ['audio/x-mpegurl', 'audio/x-mpequrl']],\n    ['m3u8', 'application/vnd.apple.mpegurl'],\n    ['m4v', 'video/x-m4v'],\n    ['ma', 'application/mathematica'],\n    ['mads', 'application/mads+xml'],\n    ['mag', 'application/vnd.ecowin.chart'],\n    ['man', 'application/x-troff-man'],\n    ['map', 'application/x-navimap'],\n    ['mar', 'text/plain'],\n    ['mathml', 'application/mathml+xml'],\n    ['mbd', 'application/mbedlet'],\n    ['mbk', 'application/vnd.mobius.mbk'],\n    ['mbox', 'application/mbox'],\n    ['mc$', 'application/x-magic-cap-package-1.0'],\n    ['mc1', 'application/vnd.medcalcdata'],\n    ['mcd', ['application/mcad', 'application/vnd.mcd', 'application/x-mathcad']],\n    ['mcf', ['image/vasa', 'text/mcf']],\n    ['mcp', 'application/netmc'],\n    ['mcurl', 'text/vnd.curl.mcurl'],\n    ['mdb', 'application/x-msaccess'],\n    ['mdi', 'image/vnd.ms-modi'],\n    ['me', 'application/x-troff-me'],\n    ['meta4', 'application/metalink4+xml'],\n    ['mets', 'application/mets+xml'],\n    ['mfm', 'application/vnd.mfmp'],\n    ['mgp', 'application/vnd.osgeo.mapguide.package'],\n    ['mgz', 'application/vnd.proteus.magazine'],\n    ['mht', 'message/rfc822'],\n    ['mhtml', 'message/rfc822'],\n    ['mid', ['audio/mid', 'audio/midi', 'music/crescendo', 'x-music/x-midi', 'audio/x-midi', 'application/x-midi', 'audio/x-mid']],\n    ['midi', ['audio/midi', 'music/crescendo', 'x-music/x-midi', 'audio/x-midi', 'application/x-midi', 'audio/x-mid']],\n    ['mif', ['application/vnd.mif', 'application/x-mif', 'application/x-frame']],\n    ['mime', ['message/rfc822', 'www/mime']],\n    ['mj2', 'video/mj2'],\n    ['mjf', 'audio/x-vnd.audioexplosion.mjuicemediafile'],\n    ['mjpg', 'video/x-motion-jpeg'],\n    ['mlp', 'application/vnd.dolby.mlp'],\n    ['mm', ['application/base64', 'application/x-meme']],\n    ['mmd', 'application/vnd.chipnuts.karaoke-mmd'],\n    ['mme', 'application/base64'],\n    ['mmf', 'application/vnd.smaf'],\n    ['mmr', 'image/vnd.fujixerox.edmics-mmr'],\n    ['mny', 'application/x-msmoney'],\n    ['mod', ['audio/mod', 'audio/x-mod']],\n    ['mods', 'application/mods+xml'],\n    ['moov', 'video/quicktime'],\n    ['mov', 'video/quicktime'],\n    ['movie', 'video/x-sgi-movie'],\n    ['mp2', ['video/mpeg', 'audio/mpeg', 'video/x-mpeg', 'audio/x-mpeg', 'video/x-mpeq2a']],\n    ['mp3', ['audio/mpeg', 'audio/mpeg3', 'video/mpeg', 'audio/x-mpeg-3', 'video/x-mpeg']],\n    ['mp4', ['video/mp4', 'application/mp4']],\n    ['mp4a', 'audio/mp4'],\n    ['mpa', ['video/mpeg', 'audio/mpeg']],\n    ['mpc', ['application/vnd.mophun.certificate', 'application/x-project']],\n    ['mpe', 'video/mpeg'],\n    ['mpeg', 'video/mpeg'],\n    ['mpg', ['video/mpeg', 'audio/mpeg']],\n    ['mpga', 'audio/mpeg'],\n    ['mpkg', 'application/vnd.apple.installer+xml'],\n    ['mpm', 'application/vnd.blueice.multipass'],\n    ['mpn', 'application/vnd.mophun.application'],\n    ['mpp', 'application/vnd.ms-project'],\n    ['mpt', 'application/x-project'],\n    ['mpv', 'application/x-project'],\n    ['mpv2', 'video/mpeg'],\n    ['mpx', 'application/x-project'],\n    ['mpy', 'application/vnd.ibm.minipay'],\n    ['mqy', 'application/vnd.mobius.mqy'],\n    ['mrc', 'application/marc'],\n    ['mrcx', 'application/marcxml+xml'],\n    ['ms', 'application/x-troff-ms'],\n    ['mscml', 'application/mediaservercontrol+xml'],\n    ['mseq', 'application/vnd.mseq'],\n    ['msf', 'application/vnd.epson.msf'],\n    ['msg', 'application/vnd.ms-outlook'],\n    ['msh', 'model/mesh'],\n    ['msl', 'application/vnd.mobius.msl'],\n    ['msty', 'application/vnd.muvee.style'],\n    ['mts', 'model/vnd.mts'],\n    ['mus', 'application/vnd.musician'],\n    ['musicxml', 'application/vnd.recordare.musicxml+xml'],\n    ['mv', 'video/x-sgi-movie'],\n    ['mvb', 'application/x-msmediaview'],\n    ['mwf', 'application/vnd.mfer'],\n    ['mxf', 'application/mxf'],\n    ['mxl', 'application/vnd.recordare.musicxml'],\n    ['mxml', 'application/xv+xml'],\n    ['mxs', 'application/vnd.triscape.mxs'],\n    ['mxu', 'video/vnd.mpegurl'],\n    ['my', 'audio/make'],\n    ['mzz', 'application/x-vnd.audioexplosion.mzz'],\n    ['n-gage', 'application/vnd.nokia.n-gage.symbian.install'],\n    ['n3', 'text/n3'],\n    ['nap', 'image/naplps'],\n    ['naplps', 'image/naplps'],\n    ['nbp', 'application/vnd.wolfram.player'],\n    ['nc', 'application/x-netcdf'],\n    ['ncm', 'application/vnd.nokia.configuration-message'],\n    ['ncx', 'application/x-dtbncx+xml'],\n    ['ngdat', 'application/vnd.nokia.n-gage.data'],\n    ['nif', 'image/x-niff'],\n    ['niff', 'image/x-niff'],\n    ['nix', 'application/x-mix-transfer'],\n    ['nlu', 'application/vnd.neurolanguage.nlu'],\n    ['nml', 'application/vnd.enliven'],\n    ['nnd', 'application/vnd.noblenet-directory'],\n    ['nns', 'application/vnd.noblenet-sealer'],\n    ['nnw', 'application/vnd.noblenet-web'],\n    ['npx', 'image/vnd.net-fpx'],\n    ['nsc', 'application/x-conference'],\n    ['nsf', 'application/vnd.lotus-notes'],\n    ['nvd', 'application/x-navidoc'],\n    ['nws', 'message/rfc822'],\n    ['o', 'application/octet-stream'],\n    ['oa2', 'application/vnd.fujitsu.oasys2'],\n    ['oa3', 'application/vnd.fujitsu.oasys3'],\n    ['oas', 'application/vnd.fujitsu.oasys'],\n    ['obd', 'application/x-msbinder'],\n    ['oda', 'application/oda'],\n    ['odb', 'application/vnd.oasis.opendocument.database'],\n    ['odc', 'application/vnd.oasis.opendocument.chart'],\n    ['odf', 'application/vnd.oasis.opendocument.formula'],\n    ['odft', 'application/vnd.oasis.opendocument.formula-template'],\n    ['odg', 'application/vnd.oasis.opendocument.graphics'],\n    ['odi', 'application/vnd.oasis.opendocument.image'],\n    ['odm', 'application/vnd.oasis.opendocument.text-master'],\n    ['odp', 'application/vnd.oasis.opendocument.presentation'],\n    ['ods', 'application/vnd.oasis.opendocument.spreadsheet'],\n    ['odt', 'application/vnd.oasis.opendocument.text'],\n    ['oga', 'audio/ogg'],\n    ['ogv', 'video/ogg'],\n    ['ogx', 'application/ogg'],\n    ['omc', 'application/x-omc'],\n    ['omcd', 'application/x-omcdatamaker'],\n    ['omcr', 'application/x-omcregerator'],\n    ['onetoc', 'application/onenote'],\n    ['opf', 'application/oebps-package+xml'],\n    ['org', 'application/vnd.lotus-organizer'],\n    ['osf', 'application/vnd.yamaha.openscoreformat'],\n    ['osfpvg', 'application/vnd.yamaha.openscoreformat.osfpvg+xml'],\n    ['otc', 'application/vnd.oasis.opendocument.chart-template'],\n    ['otf', 'application/x-font-otf'],\n    ['otg', 'application/vnd.oasis.opendocument.graphics-template'],\n    ['oth', 'application/vnd.oasis.opendocument.text-web'],\n    ['oti', 'application/vnd.oasis.opendocument.image-template'],\n    ['otp', 'application/vnd.oasis.opendocument.presentation-template'],\n    ['ots', 'application/vnd.oasis.opendocument.spreadsheet-template'],\n    ['ott', 'application/vnd.oasis.opendocument.text-template'],\n    ['oxt', 'application/vnd.openofficeorg.extension'],\n    ['p', 'text/x-pascal'],\n    ['p10', ['application/pkcs10', 'application/x-pkcs10']],\n    ['p12', ['application/pkcs-12', 'application/x-pkcs12']],\n    ['p7a', 'application/x-pkcs7-signature'],\n    ['p7b', 'application/x-pkcs7-certificates'],\n    ['p7c', ['application/pkcs7-mime', 'application/x-pkcs7-mime']],\n    ['p7m', ['application/pkcs7-mime', 'application/x-pkcs7-mime']],\n    ['p7r', 'application/x-pkcs7-certreqresp'],\n    ['p7s', ['application/pkcs7-signature', 'application/x-pkcs7-signature']],\n    ['p8', 'application/pkcs8'],\n    ['par', 'text/plain-bas'],\n    ['part', 'application/pro_eng'],\n    ['pas', 'text/pascal'],\n    ['paw', 'application/vnd.pawaafile'],\n    ['pbd', 'application/vnd.powerbuilder6'],\n    ['pbm', 'image/x-portable-bitmap'],\n    ['pcf', 'application/x-font-pcf'],\n    ['pcl', ['application/vnd.hp-pcl', 'application/x-pcl']],\n    ['pclxl', 'application/vnd.hp-pclxl'],\n    ['pct', 'image/x-pict'],\n    ['pcurl', 'application/vnd.curl.pcurl'],\n    ['pcx', 'image/x-pcx'],\n    ['pdb', ['application/vnd.palm', 'chemical/x-pdb']],\n    ['pdf', 'application/pdf'],\n    ['pfa', 'application/x-font-type1'],\n    ['pfr', 'application/font-tdpfr'],\n    ['pfunk', ['audio/make', 'audio/make.my.funk']],\n    ['pfx', 'application/x-pkcs12'],\n    ['pgm', ['image/x-portable-graymap', 'image/x-portable-greymap']],\n    ['pgn', 'application/x-chess-pgn'],\n    ['pgp', 'application/pgp-signature'],\n    ['pic', ['image/pict', 'image/x-pict']],\n    ['pict', 'image/pict'],\n    ['pkg', 'application/x-newton-compatible-pkg'],\n    ['pki', 'application/pkixcmp'],\n    ['pkipath', 'application/pkix-pkipath'],\n    ['pko', ['application/ynd.ms-pkipko', 'application/vnd.ms-pki.pko']],\n    ['pl', ['text/plain', 'text/x-script.perl']],\n    ['plb', 'application/vnd.3gpp.pic-bw-large'],\n    ['plc', 'application/vnd.mobius.plc'],\n    ['plf', 'application/vnd.pocketlearn'],\n    ['pls', 'application/pls+xml'],\n    ['plx', 'application/x-pixclscript'],\n    ['pm', ['text/x-script.perl-module', 'image/x-xpixmap']],\n    ['pm4', 'application/x-pagemaker'],\n    ['pm5', 'application/x-pagemaker'],\n    ['pma', 'application/x-perfmon'],\n    ['pmc', 'application/x-perfmon'],\n    ['pml', ['application/vnd.ctc-posml', 'application/x-perfmon']],\n    ['pmr', 'application/x-perfmon'],\n    ['pmw', 'application/x-perfmon'],\n    ['png', 'image/png'],\n    ['pnm', ['application/x-portable-anymap', 'image/x-portable-anymap']],\n    ['portpkg', 'application/vnd.macports.portpkg'],\n    ['pot', ['application/vnd.ms-powerpoint', 'application/mspowerpoint']],\n    ['potm', 'application/vnd.ms-powerpoint.template.macroenabled.12'],\n    ['potx', 'application/vnd.openxmlformats-officedocument.presentationml.template'],\n    ['pov', 'model/x-pov'],\n    ['ppa', 'application/vnd.ms-powerpoint'],\n    ['ppam', 'application/vnd.ms-powerpoint.addin.macroenabled.12'],\n    ['ppd', 'application/vnd.cups-ppd'],\n    ['ppm', 'image/x-portable-pixmap'],\n    ['pps', ['application/vnd.ms-powerpoint', 'application/mspowerpoint']],\n    ['ppsm', 'application/vnd.ms-powerpoint.slideshow.macroenabled.12'],\n    ['ppsx', 'application/vnd.openxmlformats-officedocument.presentationml.slideshow'],\n    ['ppt', ['application/vnd.ms-powerpoint', 'application/mspowerpoint', 'application/powerpoint', 'application/x-mspowerpoint']],\n    ['pptm', 'application/vnd.ms-powerpoint.presentation.macroenabled.12'],\n    ['pptx', 'application/vnd.openxmlformats-officedocument.presentationml.presentation'],\n    ['ppz', 'application/mspowerpoint'],\n    ['prc', 'application/x-mobipocket-ebook'],\n    ['pre', ['application/vnd.lotus-freelance', 'application/x-freelance']],\n    ['prf', 'application/pics-rules'],\n    ['prt', 'application/pro_eng'],\n    ['ps', 'application/postscript'],\n    ['psb', 'application/vnd.3gpp.pic-bw-small'],\n    ['psd', ['application/octet-stream', 'image/vnd.adobe.photoshop']],\n    ['psf', 'application/x-font-linux-psf'],\n    ['pskcxml', 'application/pskc+xml'],\n    ['ptid', 'application/vnd.pvi.ptid1'],\n    ['pub', 'application/x-mspublisher'],\n    ['pvb', 'application/vnd.3gpp.pic-bw-var'],\n    ['pvu', 'paleovu/x-pv'],\n    ['pwn', 'application/vnd.3m.post-it-notes'],\n    ['pwz', 'application/vnd.ms-powerpoint'],\n    ['py', 'text/x-script.phyton'],\n    ['pya', 'audio/vnd.ms-playready.media.pya'],\n    ['pyc', 'application/x-bytecode.python'],\n    ['pyv', 'video/vnd.ms-playready.media.pyv'],\n    ['qam', 'application/vnd.epson.quickanime'],\n    ['qbo', 'application/vnd.intu.qbo'],\n    ['qcp', 'audio/vnd.qcelp'],\n    ['qd3', 'x-world/x-3dmf'],\n    ['qd3d', 'x-world/x-3dmf'],\n    ['qfx', 'application/vnd.intu.qfx'],\n    ['qif', 'image/x-quicktime'],\n    ['qps', 'application/vnd.publishare-delta-tree'],\n    ['qt', 'video/quicktime'],\n    ['qtc', 'video/x-qtc'],\n    ['qti', 'image/x-quicktime'],\n    ['qtif', 'image/x-quicktime'],\n    ['qxd', 'application/vnd.quark.quarkxpress'],\n    ['ra', ['audio/x-realaudio', 'audio/x-pn-realaudio', 'audio/x-pn-realaudio-plugin']],\n    ['ram', 'audio/x-pn-realaudio'],\n    ['rar', 'application/x-rar-compressed'],\n    ['ras', ['image/cmu-raster', 'application/x-cmu-raster', 'image/x-cmu-raster']],\n    ['rast', 'image/cmu-raster'],\n    ['rcprofile', 'application/vnd.ipunplugged.rcprofile'],\n    ['rdf', 'application/rdf+xml'],\n    ['rdz', 'application/vnd.data-vision.rdz'],\n    ['rep', 'application/vnd.businessobjects'],\n    ['res', 'application/x-dtbresource+xml'],\n    ['rexx', 'text/x-script.rexx'],\n    ['rf', 'image/vnd.rn-realflash'],\n    ['rgb', 'image/x-rgb'],\n    ['rif', 'application/reginfo+xml'],\n    ['rip', 'audio/vnd.rip'],\n    ['rl', 'application/resource-lists+xml'],\n    ['rlc', 'image/vnd.fujixerox.edmics-rlc'],\n    ['rld', 'application/resource-lists-diff+xml'],\n    ['rm', ['application/vnd.rn-realmedia', 'audio/x-pn-realaudio']],\n    ['rmi', 'audio/mid'],\n    ['rmm', 'audio/x-pn-realaudio'],\n    ['rmp', ['audio/x-pn-realaudio-plugin', 'audio/x-pn-realaudio']],\n    ['rms', 'application/vnd.jcp.javame.midlet-rms'],\n    ['rnc', 'application/relax-ng-compact-syntax'],\n    ['rng', ['application/ringing-tones', 'application/vnd.nokia.ringing-tone']],\n    ['rnx', 'application/vnd.rn-realplayer'],\n    ['roff', 'application/x-troff'],\n    ['rp', 'image/vnd.rn-realpix'],\n    ['rp9', 'application/vnd.cloanto.rp9'],\n    ['rpm', 'audio/x-pn-realaudio-plugin'],\n    ['rpss', 'application/vnd.nokia.radio-presets'],\n    ['rpst', 'application/vnd.nokia.radio-preset'],\n    ['rq', 'application/sparql-query'],\n    ['rs', 'application/rls-services+xml'],\n    ['rsd', 'application/rsd+xml'],\n    ['rt', ['text/richtext', 'text/vnd.rn-realtext']],\n    ['rtf', ['application/rtf', 'text/richtext', 'application/x-rtf']],\n    ['rtx', ['text/richtext', 'application/rtf']],\n    ['rv', 'video/vnd.rn-realvideo'],\n    ['s', 'text/x-asm'],\n    ['s3m', 'audio/s3m'],\n    ['saf', 'application/vnd.yamaha.smaf-audio'],\n    ['saveme', 'application/octet-stream'],\n    ['sbk', 'application/x-tbook'],\n    ['sbml', 'application/sbml+xml'],\n    ['sc', 'application/vnd.ibm.secure-container'],\n    ['scd', 'application/x-msschedule'],\n    ['scm', ['application/vnd.lotus-screencam', 'video/x-scm', 'text/x-script.guile', 'application/x-lotusscreencam', 'text/x-script.scheme']],\n    ['scq', 'application/scvp-cv-request'],\n    ['scs', 'application/scvp-cv-response'],\n    ['sct', 'text/scriptlet'],\n    ['scurl', 'text/vnd.curl.scurl'],\n    ['sda', 'application/vnd.stardivision.draw'],\n    ['sdc', 'application/vnd.stardivision.calc'],\n    ['sdd', 'application/vnd.stardivision.impress'],\n    ['sdkm', 'application/vnd.solent.sdkm+xml'],\n    ['sdml', 'text/plain'],\n    ['sdp', ['application/sdp', 'application/x-sdp']],\n    ['sdr', 'application/sounder'],\n    ['sdw', 'application/vnd.stardivision.writer'],\n    ['sea', ['application/sea', 'application/x-sea']],\n    ['see', 'application/vnd.seemail'],\n    ['seed', 'application/vnd.fdsn.seed'],\n    ['sema', 'application/vnd.sema'],\n    ['semd', 'application/vnd.semd'],\n    ['semf', 'application/vnd.semf'],\n    ['ser', 'application/java-serialized-object'],\n    ['set', 'application/set'],\n    ['setpay', 'application/set-payment-initiation'],\n    ['setreg', 'application/set-registration-initiation'],\n    ['sfd-hdstx', 'application/vnd.hydrostatix.sof-data'],\n    ['sfs', 'application/vnd.spotfire.sfs'],\n    ['sgl', 'application/vnd.stardivision.writer-global'],\n    ['sgm', ['text/sgml', 'text/x-sgml']],\n    ['sgml', ['text/sgml', 'text/x-sgml']],\n    ['sh', ['application/x-shar', 'application/x-bsh', 'application/x-sh', 'text/x-script.sh']],\n    ['shar', ['application/x-bsh', 'application/x-shar']],\n    ['shf', 'application/shf+xml'],\n    ['shtml', ['text/html', 'text/x-server-parsed-html']],\n    ['sid', 'audio/x-psid'],\n    ['sis', 'application/vnd.symbian.install'],\n    ['sit', ['application/x-stuffit', 'application/x-sit']],\n    ['sitx', 'application/x-stuffitx'],\n    ['skd', 'application/x-koan'],\n    ['skm', 'application/x-koan'],\n    ['skp', ['application/vnd.koan', 'application/x-koan']],\n    ['skt', 'application/x-koan'],\n    ['sl', 'application/x-seelogo'],\n    ['sldm', 'application/vnd.ms-powerpoint.slide.macroenabled.12'],\n    ['sldx', 'application/vnd.openxmlformats-officedocument.presentationml.slide'],\n    ['slt', 'application/vnd.epson.salt'],\n    ['sm', 'application/vnd.stepmania.stepchart'],\n    ['smf', 'application/vnd.stardivision.math'],\n    ['smi', ['application/smil', 'application/smil+xml']],\n    ['smil', 'application/smil'],\n    ['snd', ['audio/basic', 'audio/x-adpcm']],\n    ['snf', 'application/x-font-snf'],\n    ['sol', 'application/solids'],\n    ['spc', ['text/x-speech', 'application/x-pkcs7-certificates']],\n    ['spf', 'application/vnd.yamaha.smaf-phrase'],\n    ['spl', ['application/futuresplash', 'application/x-futuresplash']],\n    ['spot', 'text/vnd.in3d.spot'],\n    ['spp', 'application/scvp-vp-response'],\n    ['spq', 'application/scvp-vp-request'],\n    ['spr', 'application/x-sprite'],\n    ['sprite', 'application/x-sprite'],\n    ['src', 'application/x-wais-source'],\n    ['sru', 'application/sru+xml'],\n    ['srx', 'application/sparql-results+xml'],\n    ['sse', 'application/vnd.kodak-descriptor'],\n    ['ssf', 'application/vnd.epson.ssf'],\n    ['ssi', 'text/x-server-parsed-html'],\n    ['ssm', 'application/streamingmedia'],\n    ['ssml', 'application/ssml+xml'],\n    ['sst', ['application/vnd.ms-pkicertstore', 'application/vnd.ms-pki.certstore']],\n    ['st', 'application/vnd.sailingtracker.track'],\n    ['stc', 'application/vnd.sun.xml.calc.template'],\n    ['std', 'application/vnd.sun.xml.draw.template'],\n    ['step', 'application/step'],\n    ['stf', 'application/vnd.wt.stf'],\n    ['sti', 'application/vnd.sun.xml.impress.template'],\n    ['stk', 'application/hyperstudio'],\n    ['stl', ['application/vnd.ms-pkistl', 'application/sla', 'application/vnd.ms-pki.stl', 'application/x-navistyle']],\n    ['stm', 'text/html'],\n    ['stp', 'application/step'],\n    ['str', 'application/vnd.pg.format'],\n    ['stw', 'application/vnd.sun.xml.writer.template'],\n    ['sub', 'image/vnd.dvb.subtitle'],\n    ['sus', 'application/vnd.sus-calendar'],\n    ['sv4cpio', 'application/x-sv4cpio'],\n    ['sv4crc', 'application/x-sv4crc'],\n    ['svc', 'application/vnd.dvb.service'],\n    ['svd', 'application/vnd.svd'],\n    ['svf', ['image/vnd.dwg', 'image/x-dwg']],\n    ['svg', 'image/svg+xml'],\n    ['svr', ['x-world/x-svr', 'application/x-world']],\n    ['swf', 'application/x-shockwave-flash'],\n    ['swi', 'application/vnd.aristanetworks.swi'],\n    ['sxc', 'application/vnd.sun.xml.calc'],\n    ['sxd', 'application/vnd.sun.xml.draw'],\n    ['sxg', 'application/vnd.sun.xml.writer.global'],\n    ['sxi', 'application/vnd.sun.xml.impress'],\n    ['sxm', 'application/vnd.sun.xml.math'],\n    ['sxw', 'application/vnd.sun.xml.writer'],\n    ['t', ['text/troff', 'application/x-troff']],\n    ['talk', 'text/x-speech'],\n    ['tao', 'application/vnd.tao.intent-module-archive'],\n    ['tar', 'application/x-tar'],\n    ['tbk', ['application/toolbook', 'application/x-tbook']],\n    ['tcap', 'application/vnd.3gpp2.tcap'],\n    ['tcl', ['text/x-script.tcl', 'application/x-tcl']],\n    ['tcsh', 'text/x-script.tcsh'],\n    ['teacher', 'application/vnd.smart.teacher'],\n    ['tei', 'application/tei+xml'],\n    ['tex', 'application/x-tex'],\n    ['texi', 'application/x-texinfo'],\n    ['texinfo', 'application/x-texinfo'],\n    ['text', ['application/plain', 'text/plain']],\n    ['tfi', 'application/thraud+xml'],\n    ['tfm', 'application/x-tex-tfm'],\n    ['tgz', ['application/gnutar', 'application/x-compressed']],\n    ['thmx', 'application/vnd.ms-officetheme'],\n    ['tif', ['image/tiff', 'image/x-tiff']],\n    ['tiff', ['image/tiff', 'image/x-tiff']],\n    ['tmo', 'application/vnd.tmobile-livetv'],\n    ['torrent', 'application/x-bittorrent'],\n    ['tpl', 'application/vnd.groove-tool-template'],\n    ['tpt', 'application/vnd.trid.tpt'],\n    ['tr', 'application/x-troff'],\n    ['tra', 'application/vnd.trueapp'],\n    ['trm', 'application/x-msterminal'],\n    ['tsd', 'application/timestamped-data'],\n    ['tsi', 'audio/tsp-audio'],\n    ['tsp', ['application/dsptype', 'audio/tsplayer']],\n    ['tsv', 'text/tab-separated-values'],\n    ['ttf', 'application/x-font-ttf'],\n    ['ttl', 'text/turtle'],\n    ['turbot', 'image/florian'],\n    ['twd', 'application/vnd.simtech-mindmapper'],\n    ['txd', 'application/vnd.genomatix.tuxedo'],\n    ['txf', 'application/vnd.mobius.txf'],\n    ['txt', 'text/plain'],\n    ['ufd', 'application/vnd.ufdl'],\n    ['uil', 'text/x-uil'],\n    ['uls', 'text/iuls'],\n    ['umj', 'application/vnd.umajin'],\n    ['uni', 'text/uri-list'],\n    ['unis', 'text/uri-list'],\n    ['unityweb', 'application/vnd.unity'],\n    ['unv', 'application/i-deas'],\n    ['uoml', 'application/vnd.uoml+xml'],\n    ['uri', 'text/uri-list'],\n    ['uris', 'text/uri-list'],\n    ['ustar', ['application/x-ustar', 'multipart/x-ustar']],\n    ['utz', 'application/vnd.uiq.theme'],\n    ['uu', ['application/octet-stream', 'text/x-uuencode']],\n    ['uue', 'text/x-uuencode'],\n    ['uva', 'audio/vnd.dece.audio'],\n    ['uvh', 'video/vnd.dece.hd'],\n    ['uvi', 'image/vnd.dece.graphic'],\n    ['uvm', 'video/vnd.dece.mobile'],\n    ['uvp', 'video/vnd.dece.pd'],\n    ['uvs', 'video/vnd.dece.sd'],\n    ['uvu', 'video/vnd.uvvu.mp4'],\n    ['uvv', 'video/vnd.dece.video'],\n    ['vcd', 'application/x-cdlink'],\n    ['vcf', 'text/x-vcard'],\n    ['vcg', 'application/vnd.groove-vcard'],\n    ['vcs', 'text/x-vcalendar'],\n    ['vcx', 'application/vnd.vcx'],\n    ['vda', 'application/vda'],\n    ['vdo', 'video/vdo'],\n    ['vew', 'application/groupwise'],\n    ['vis', 'application/vnd.visionary'],\n    ['viv', ['video/vivo', 'video/vnd.vivo']],\n    ['vivo', ['video/vivo', 'video/vnd.vivo']],\n    ['vmd', 'application/vocaltec-media-desc'],\n    ['vmf', 'application/vocaltec-media-file'],\n    ['voc', ['audio/voc', 'audio/x-voc']],\n    ['vos', 'video/vosaic'],\n    ['vox', 'audio/voxware'],\n    ['vqe', 'audio/x-twinvq-plugin'],\n    ['vqf', 'audio/x-twinvq'],\n    ['vql', 'audio/x-twinvq-plugin'],\n    ['vrml', ['model/vrml', 'x-world/x-vrml', 'application/x-vrml']],\n    ['vrt', 'x-world/x-vrt'],\n    ['vsd', ['application/vnd.visio', 'application/x-visio']],\n    ['vsf', 'application/vnd.vsf'],\n    ['vst', 'application/x-visio'],\n    ['vsw', 'application/x-visio'],\n    ['vtu', 'model/vnd.vtu'],\n    ['vxml', 'application/voicexml+xml'],\n    ['w60', 'application/wordperfect6.0'],\n    ['w61', 'application/wordperfect6.1'],\n    ['w6w', 'application/msword'],\n    ['wad', 'application/x-doom'],\n    ['wav', ['audio/wav', 'audio/x-wav']],\n    ['wax', 'audio/x-ms-wax'],\n    ['wb1', 'application/x-qpro'],\n    ['wbmp', 'image/vnd.wap.wbmp'],\n    ['wbs', 'application/vnd.criticaltools.wbs+xml'],\n    ['wbxml', 'application/vnd.wap.wbxml'],\n    ['wcm', 'application/vnd.ms-works'],\n    ['wdb', 'application/vnd.ms-works'],\n    ['web', 'application/vnd.xara'],\n    ['weba', 'audio/webm'],\n    ['webm', 'video/webm'],\n    ['webp', 'image/webp'],\n    ['wg', 'application/vnd.pmi.widget'],\n    ['wgt', 'application/widget'],\n    ['wiz', 'application/msword'],\n    ['wk1', 'application/x-123'],\n    ['wks', 'application/vnd.ms-works'],\n    ['wm', 'video/x-ms-wm'],\n    ['wma', 'audio/x-ms-wma'],\n    ['wmd', 'application/x-ms-wmd'],\n    ['wmf', ['windows/metafile', 'application/x-msmetafile']],\n    ['wml', 'text/vnd.wap.wml'],\n    ['wmlc', 'application/vnd.wap.wmlc'],\n    ['wmls', 'text/vnd.wap.wmlscript'],\n    ['wmlsc', 'application/vnd.wap.wmlscriptc'],\n    ['wmv', 'video/x-ms-wmv'],\n    ['wmx', 'video/x-ms-wmx'],\n    ['wmz', 'application/x-ms-wmz'],\n    ['woff', 'application/x-font-woff'],\n    ['word', 'application/msword'],\n    ['wp', 'application/wordperfect'],\n    ['wp5', ['application/wordperfect', 'application/wordperfect6.0']],\n    ['wp6', 'application/wordperfect'],\n    ['wpd', ['application/wordperfect', 'application/vnd.wordperfect', 'application/x-wpwin']],\n    ['wpl', 'application/vnd.ms-wpl'],\n    ['wps', 'application/vnd.ms-works'],\n    ['wq1', 'application/x-lotus'],\n    ['wqd', 'application/vnd.wqd'],\n    ['wri', ['application/mswrite', 'application/x-wri', 'application/x-mswrite']],\n    ['wrl', ['model/vrml', 'x-world/x-vrml', 'application/x-world']],\n    ['wrz', ['model/vrml', 'x-world/x-vrml']],\n    ['wsc', 'text/scriplet'],\n    ['wsdl', 'application/wsdl+xml'],\n    ['wspolicy', 'application/wspolicy+xml'],\n    ['wsrc', 'application/x-wais-source'],\n    ['wtb', 'application/vnd.webturbo'],\n    ['wtk', 'application/x-wintalk'],\n    ['wvx', 'video/x-ms-wvx'],\n    ['x-png', 'image/png'],\n    ['x3d', 'application/vnd.hzn-3d-crossword'],\n    ['xaf', 'x-world/x-vrml'],\n    ['xap', 'application/x-silverlight-app'],\n    ['xar', 'application/vnd.xara'],\n    ['xbap', 'application/x-ms-xbap'],\n    ['xbd', 'application/vnd.fujixerox.docuworks.binder'],\n    ['xbm', ['image/xbm', 'image/x-xbm', 'image/x-xbitmap']],\n    ['xdf', 'application/xcap-diff+xml'],\n    ['xdm', 'application/vnd.syncml.dm+xml'],\n    ['xdp', 'application/vnd.adobe.xdp+xml'],\n    ['xdr', 'video/x-amt-demorun'],\n    ['xdssc', 'application/dssc+xml'],\n    ['xdw', 'application/vnd.fujixerox.docuworks'],\n    ['xenc', 'application/xenc+xml'],\n    ['xer', 'application/patch-ops-error+xml'],\n    ['xfdf', 'application/vnd.adobe.xfdf'],\n    ['xfdl', 'application/vnd.xfdl'],\n    ['xgz', 'xgl/drawing'],\n    ['xhtml', 'application/xhtml+xml'],\n    ['xif', 'image/vnd.xiff'],\n    ['xl', 'application/excel'],\n    ['xla', ['application/vnd.ms-excel', 'application/excel', 'application/x-msexcel', 'application/x-excel']],\n    ['xlam', 'application/vnd.ms-excel.addin.macroenabled.12'],\n    ['xlb', ['application/excel', 'application/vnd.ms-excel', 'application/x-excel']],\n    ['xlc', ['application/vnd.ms-excel', 'application/excel', 'application/x-excel']],\n    ['xld', ['application/excel', 'application/x-excel']],\n    ['xlk', ['application/excel', 'application/x-excel']],\n    ['xll', ['application/excel', 'application/vnd.ms-excel', 'application/x-excel']],\n    ['xlm', ['application/vnd.ms-excel', 'application/excel', 'application/x-excel']],\n    ['xls', ['application/vnd.ms-excel', 'application/excel', 'application/x-msexcel', 'application/x-excel']],\n    ['xlsb', 'application/vnd.ms-excel.sheet.binary.macroenabled.12'],\n    ['xlsm', 'application/vnd.ms-excel.sheet.macroenabled.12'],\n    ['xlsx', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'],\n    ['xlt', ['application/vnd.ms-excel', 'application/excel', 'application/x-excel']],\n    ['xltm', 'application/vnd.ms-excel.template.macroenabled.12'],\n    ['xltx', 'application/vnd.openxmlformats-officedocument.spreadsheetml.template'],\n    ['xlv', ['application/excel', 'application/x-excel']],\n    ['xlw', ['application/vnd.ms-excel', 'application/excel', 'application/x-msexcel', 'application/x-excel']],\n    ['xm', 'audio/xm'],\n    ['xml', ['application/xml', 'text/xml', 'application/atom+xml', 'application/rss+xml']],\n    ['xmz', 'xgl/movie'],\n    ['xo', 'application/vnd.olpc-sugar'],\n    ['xof', 'x-world/x-vrml'],\n    ['xop', 'application/xop+xml'],\n    ['xpi', 'application/x-xpinstall'],\n    ['xpix', 'application/x-vnd.ls-xpix'],\n    ['xpm', ['image/xpm', 'image/x-xpixmap']],\n    ['xpr', 'application/vnd.is-xpr'],\n    ['xps', 'application/vnd.ms-xpsdocument'],\n    ['xpw', 'application/vnd.intercon.formnet'],\n    ['xslt', 'application/xslt+xml'],\n    ['xsm', 'application/vnd.syncml+xml'],\n    ['xspf', 'application/xspf+xml'],\n    ['xsr', 'video/x-amt-showrun'],\n    ['xul', 'application/vnd.mozilla.xul+xml'],\n    ['xwd', ['image/x-xwd', 'image/x-xwindowdump']],\n    ['xyz', ['chemical/x-xyz', 'chemical/x-pdb']],\n    ['yang', 'application/yang'],\n    ['yin', 'application/yin+xml'],\n    ['z', ['application/x-compressed', 'application/x-compress']],\n    ['zaz', 'application/vnd.zzazz.deck+xml'],\n    ['zip', ['application/zip', 'multipart/x-zip', 'application/x-zip-compressed', 'application/x-compressed']],\n    ['zir', 'application/vnd.zul'],\n    ['zmm', 'application/vnd.handheld-entertainment+xml'],\n    ['zoo', 'application/octet-stream'],\n    ['zsh', 'text/x-script.zsh']\n]);\n\nmodule.exports = {\n    detectMimeType(filename) {\n        if (!filename) {\n            return defaultMimeType;\n        }\n\n        let parsed = path.parse(filename);\n        let extension = (parsed.ext.substr(1) || parsed.name || '').split('?').shift().trim().toLowerCase();\n        let value = defaultMimeType;\n\n        if (extensions.has(extension)) {\n            value = extensions.get(extension);\n        }\n\n        if (Array.isArray(value)) {\n            return value[0];\n        }\n        return value;\n    },\n\n    detectExtension(mimeType) {\n        if (!mimeType) {\n            return defaultExtension;\n        }\n        let parts = (mimeType || '').toLowerCase().trim().split('/');\n        let rootType = parts.shift().trim();\n        let subType = parts.join('/').trim();\n\n        if (mimeTypes.has(rootType + '/' + subType)) {\n            let value = mimeTypes.get(rootType + '/' + subType);\n            if (Array.isArray(value)) {\n                return value[0];\n            }\n            return value;\n        }\n\n        switch (rootType) {\n            case 'text':\n                return 'txt';\n            default:\n                return 'bin';\n        }\n    }\n};\n","/*\n\nCopied from https://github.com/mathiasbynens/punycode.js/blob/ef3505c8abb5143a00d53ce59077c9f7f4b2ac47/punycode.js\n\nCopyright Mathias Bynens <https://mathiasbynens.be/>\n\nPermission is hereby granted, free of charge, to any person obtaining\na copy of this software and associated documentation files (the\n\"Software\"), to deal in the Software without restriction, including\nwithout limitation the rights to use, copy, modify, merge, publish,\ndistribute, sublicense, and/or sell copies of the Software, and to\npermit persons to whom the Software is furnished to do so, subject to\nthe following conditions:\n\nThe above copyright notice and this permission notice shall be\nincluded in all copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND,\nEXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\nMERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND\nNONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE\nLIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION\nOF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\nWITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n*/\n/* eslint callback-return: 0, no-bitwise: 0, eqeqeq: 0, prefer-arrow-callback: 0, object-shorthand: 0 */\n\n'use strict';\n\n/** Highest positive signed 32-bit float value */\nconst maxInt = 2147483647; // aka. 0x7FFFFFFF or 2^31-1\n\n/** Bootstring parameters */\nconst base = 36;\nconst tMin = 1;\nconst tMax = 26;\nconst skew = 38;\nconst damp = 700;\nconst initialBias = 72;\nconst initialN = 128; // 0x80\nconst delimiter = '-'; // '\\x2D'\n\n/** Regular expressions */\nconst regexPunycode = /^xn--/;\nconst regexNonASCII = /[^\\0-\\x7F]/; // Note: U+007F DEL is excluded too.\nconst regexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g; // RFC 3490 separators\n\n/** Error messages */\nconst errors = {\n    overflow: 'Overflow: input needs wider integers to process',\n    'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n    'invalid-input': 'Invalid input'\n};\n\n/** Convenience shortcuts */\nconst baseMinusTMin = base - tMin;\nconst floor = Math.floor;\nconst stringFromCharCode = String.fromCharCode;\n\n/*--------------------------------------------------------------------------*/\n\n/**\n * A generic error utility function.\n * @private\n * @param {String} type The error type.\n * @returns {Error} Throws a `RangeError` with the applicable error message.\n */\nfunction error(type) {\n    throw new RangeError(errors[type]);\n}\n\n/**\n * A generic `Array#map` utility function.\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} callback The function that gets called for every array\n * item.\n * @returns {Array} A new array of values returned by the callback function.\n */\nfunction map(array, callback) {\n    const result = [];\n    let length = array.length;\n    while (length--) {\n        result[length] = callback(array[length]);\n    }\n    return result;\n}\n\n/**\n * A simple `Array#map`-like wrapper to work with domain name strings or email\n * addresses.\n * @private\n * @param {String} domain The domain name or email address.\n * @param {Function} callback The function that gets called for every\n * character.\n * @returns {String} A new string of characters returned by the callback\n * function.\n */\nfunction mapDomain(domain, callback) {\n    const parts = domain.split('@');\n    let result = '';\n    if (parts.length > 1) {\n        // In email addresses, only the domain name should be punycoded. Leave\n        // the local part (i.e. everything up to `@`) intact.\n        result = parts[0] + '@';\n        domain = parts[1];\n    }\n    // Avoid `split(regex)` for IE8 compatibility. See #17.\n    domain = domain.replace(regexSeparators, '\\x2E');\n    const labels = domain.split('.');\n    const encoded = map(labels, callback).join('.');\n    return result + encoded;\n}\n\n/**\n * Creates an array containing the numeric code points of each Unicode\n * character in the string. While JavaScript uses UCS-2 internally,\n * this function will convert a pair of surrogate halves (each of which\n * UCS-2 exposes as separate characters) into a single code point,\n * matching UTF-16.\n * @see `punycode.ucs2.encode`\n * @see <https://mathiasbynens.be/notes/javascript-encoding>\n * @memberOf punycode.ucs2\n * @name decode\n * @param {String} string The Unicode input string (UCS-2).\n * @returns {Array} The new array of code points.\n */\nfunction ucs2decode(string) {\n    const output = [];\n    let counter = 0;\n    const length = string.length;\n    while (counter < length) {\n        const value = string.charCodeAt(counter++);\n        if (value >= 0xd800 && value <= 0xdbff && counter < length) {\n            // It's a high surrogate, and there is a next character.\n            const extra = string.charCodeAt(counter++);\n            if ((extra & 0xfc00) == 0xdc00) {\n                // Low surrogate.\n                output.push(((value & 0x3ff) << 10) + (extra & 0x3ff) + 0x10000);\n            } else {\n                // It's an unmatched surrogate; only append this code unit, in case the\n                // next code unit is the high surrogate of a surrogate pair.\n                output.push(value);\n                counter--;\n            }\n        } else {\n            output.push(value);\n        }\n    }\n    return output;\n}\n\n/**\n * Creates a string based on an array of numeric code points.\n * @see `punycode.ucs2.decode`\n * @memberOf punycode.ucs2\n * @name encode\n * @param {Array} codePoints The array of numeric code points.\n * @returns {String} The new Unicode string (UCS-2).\n */\nconst ucs2encode = codePoints => String.fromCodePoint(...codePoints);\n\n/**\n * Converts a basic code point into a digit/integer.\n * @see `digitToBasic()`\n * @private\n * @param {Number} codePoint The basic numeric code point value.\n * @returns {Number} The numeric value of a basic code point (for use in\n * representing integers) in the range `0` to `base - 1`, or `base` if\n * the code point does not represent a value.\n */\nconst basicToDigit = function (codePoint) {\n    if (codePoint >= 0x30 && codePoint < 0x3a) {\n        return 26 + (codePoint - 0x30);\n    }\n    if (codePoint >= 0x41 && codePoint < 0x5b) {\n        return codePoint - 0x41;\n    }\n    if (codePoint >= 0x61 && codePoint < 0x7b) {\n        return codePoint - 0x61;\n    }\n    return base;\n};\n\n/**\n * Converts a digit/integer into a basic code point.\n * @see `basicToDigit()`\n * @private\n * @param {Number} digit The numeric value of a basic code point.\n * @returns {Number} The basic code point whose value (when used for\n * representing integers) is `digit`, which needs to be in the range\n * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n * used; else, the lowercase form is used. The behavior is undefined\n * if `flag` is non-zero and `digit` has no uppercase form.\n */\nconst digitToBasic = function (digit, flag) {\n    //  0..25 map to ASCII a..z or A..Z\n    // 26..35 map to ASCII 0..9\n    return digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n};\n\n/**\n * Bias adaptation function as per section 3.4 of RFC 3492.\n * https://tools.ietf.org/html/rfc3492#section-3.4\n * @private\n */\nconst adapt = function (delta, numPoints, firstTime) {\n    let k = 0;\n    delta = firstTime ? floor(delta / damp) : delta >> 1;\n    delta += floor(delta / numPoints);\n    for (; /* no initialization */ delta > (baseMinusTMin * tMax) >> 1; k += base) {\n        delta = floor(delta / baseMinusTMin);\n    }\n    return floor(k + ((baseMinusTMin + 1) * delta) / (delta + skew));\n};\n\n/**\n * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n * symbols.\n * @memberOf punycode\n * @param {String} input The Punycode string of ASCII-only symbols.\n * @returns {String} The resulting string of Unicode symbols.\n */\nconst decode = function (input) {\n    // Don't use UCS-2.\n    const output = [];\n    const inputLength = input.length;\n    let i = 0;\n    let n = initialN;\n    let bias = initialBias;\n\n    // Handle the basic code points: let `basic` be the number of input code\n    // points before the last delimiter, or `0` if there is none, then copy\n    // the first basic code points to the output.\n\n    let basic = input.lastIndexOf(delimiter);\n    if (basic < 0) {\n        basic = 0;\n    }\n\n    for (let j = 0; j < basic; ++j) {\n        // if it's not a basic code point\n        if (input.charCodeAt(j) >= 0x80) {\n            error('not-basic');\n        }\n        output.push(input.charCodeAt(j));\n    }\n\n    // Main decoding loop: start just after the last delimiter if any basic code\n    // points were copied; start at the beginning otherwise.\n\n    for (let index = basic > 0 ? basic + 1 : 0; index < inputLength /* no final expression */; ) {\n        // `index` is the index of the next character to be consumed.\n        // Decode a generalized variable-length integer into `delta`,\n        // which gets added to `i`. The overflow checking is easier\n        // if we increase `i` as we go, then subtract off its starting\n        // value at the end to obtain `delta`.\n        const oldi = i;\n        for (let w = 1, k = base /* no condition */; ; k += base) {\n            if (index >= inputLength) {\n                error('invalid-input');\n            }\n\n            const digit = basicToDigit(input.charCodeAt(index++));\n\n            if (digit >= base) {\n                error('invalid-input');\n            }\n            if (digit > floor((maxInt - i) / w)) {\n                error('overflow');\n            }\n\n            i += digit * w;\n            const t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n\n            if (digit < t) {\n                break;\n            }\n\n            const baseMinusT = base - t;\n            if (w > floor(maxInt / baseMinusT)) {\n                error('overflow');\n            }\n\n            w *= baseMinusT;\n        }\n\n        const out = output.length + 1;\n        bias = adapt(i - oldi, out, oldi == 0);\n\n        // `i` was supposed to wrap around from `out` to `0`,\n        // incrementing `n` each time, so we'll fix that now:\n        if (floor(i / out) > maxInt - n) {\n            error('overflow');\n        }\n\n        n += floor(i / out);\n        i %= out;\n\n        // Insert `n` at position `i` of the output.\n        output.splice(i++, 0, n);\n    }\n\n    return String.fromCodePoint(...output);\n};\n\n/**\n * Converts a string of Unicode symbols (e.g. a domain name label) to a\n * Punycode string of ASCII-only symbols.\n * @memberOf punycode\n * @param {String} input The string of Unicode symbols.\n * @returns {String} The resulting Punycode string of ASCII-only symbols.\n */\nconst encode = function (input) {\n    const output = [];\n\n    // Convert the input in UCS-2 to an array of Unicode code points.\n    input = ucs2decode(input);\n\n    // Cache the length.\n    const inputLength = input.length;\n\n    // Initialize the state.\n    let n = initialN;\n    let delta = 0;\n    let bias = initialBias;\n\n    // Handle the basic code points.\n    for (const currentValue of input) {\n        if (currentValue < 0x80) {\n            output.push(stringFromCharCode(currentValue));\n        }\n    }\n\n    const basicLength = output.length;\n    let handledCPCount = basicLength;\n\n    // `handledCPCount` is the number of code points that have been handled;\n    // `basicLength` is the number of basic code points.\n\n    // Finish the basic string with a delimiter unless it's empty.\n    if (basicLength) {\n        output.push(delimiter);\n    }\n\n    // Main encoding loop:\n    while (handledCPCount < inputLength) {\n        // All non-basic code points < n have been handled already. Find the next\n        // larger one:\n        let m = maxInt;\n        for (const currentValue of input) {\n            if (currentValue >= n && currentValue < m) {\n                m = currentValue;\n            }\n        }\n\n        // Increase `delta` enough to advance the decoder's <n,i> state to <m,0>,\n        // but guard against overflow.\n        const handledCPCountPlusOne = handledCPCount + 1;\n        if (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n            error('overflow');\n        }\n\n        delta += (m - n) * handledCPCountPlusOne;\n        n = m;\n\n        for (const currentValue of input) {\n            if (currentValue < n && ++delta > maxInt) {\n                error('overflow');\n            }\n            if (currentValue === n) {\n                // Represent delta as a generalized variable-length integer.\n                let q = delta;\n                for (let k = base /* no condition */; ; k += base) {\n                    const t = k <= bias ? tMin : k >= bias + tMax ? tMax : k - bias;\n                    if (q < t) {\n                        break;\n                    }\n                    const qMinusT = q - t;\n                    const baseMinusT = base - t;\n                    output.push(stringFromCharCode(digitToBasic(t + (qMinusT % baseMinusT), 0)));\n                    q = floor(qMinusT / baseMinusT);\n                }\n\n                output.push(stringFromCharCode(digitToBasic(q, 0)));\n                bias = adapt(delta, handledCPCountPlusOne, handledCPCount === basicLength);\n                delta = 0;\n                ++handledCPCount;\n            }\n        }\n\n        ++delta;\n        ++n;\n    }\n    return output.join('');\n};\n\n/**\n * Converts a Punycode string representing a domain name or an email address\n * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n * it doesn't matter if you call it on a string that has already been\n * converted to Unicode.\n * @memberOf punycode\n * @param {String} input The Punycoded domain name or email address to\n * convert to Unicode.\n * @returns {String} The Unicode representation of the given Punycode\n * string.\n */\nconst toUnicode = function (input) {\n    return mapDomain(input, function (string) {\n        return regexPunycode.test(string) ? decode(string.slice(4).toLowerCase()) : string;\n    });\n};\n\n/**\n * Converts a Unicode string representing a domain name or an email address to\n * Punycode. Only the non-ASCII parts of the domain name will be converted,\n * i.e. it doesn't matter if you call it with a domain that's already in\n * ASCII.\n * @memberOf punycode\n * @param {String} input The domain name or email address to convert, as a\n * Unicode string.\n * @returns {String} The Punycode representation of the given domain name or\n * email address.\n */\nconst toASCII = function (input) {\n    return mapDomain(input, function (string) {\n        return regexNonASCII.test(string) ? 'xn--' + encode(string) : string;\n    });\n};\n\n/*--------------------------------------------------------------------------*/\n\n/** Define the public API */\nconst punycode = {\n    /**\n     * A string representing the current Punycode.js version number.\n     * @memberOf punycode\n     * @type String\n     */\n    version: '2.3.1',\n    /**\n     * An object of methods to convert from JavaScript's internal character\n     * representation (UCS-2) to Unicode code points, and back.\n     * @see <https://mathiasbynens.be/notes/javascript-encoding>\n     * @memberOf punycode\n     * @type Object\n     */\n    ucs2: {\n        decode: ucs2decode,\n        encode: ucs2encode\n    },\n    decode: decode,\n    encode: encode,\n    toASCII: toASCII,\n    toUnicode: toUnicode\n};\n\nmodule.exports = punycode;\n","'use strict';\n\nconst Transform = require('stream').Transform;\n\n/**\n * Encodes a Buffer into a base64 encoded string\n *\n * @param {Buffer} buffer Buffer to convert\n * @returns {String} base64 encoded string\n */\nfunction encode(buffer) {\n    if (typeof buffer === 'string') {\n        buffer = Buffer.from(buffer, 'utf-8');\n    }\n\n    return buffer.toString('base64');\n}\n\n/**\n * Adds soft line breaks to a base64 string\n *\n * @param {String} str base64 encoded string that might need line wrapping\n * @param {Number} [lineLength=76] Maximum allowed length for a line\n * @returns {String} Soft-wrapped base64 encoded string\n */\nfunction wrap(str, lineLength) {\n    str = (str || '').toString();\n    lineLength = lineLength || 76;\n\n    if (str.length <= lineLength) {\n        return str;\n    }\n\n    let result = [];\n    let pos = 0;\n    let chunkLength = lineLength * 1024;\n    while (pos < str.length) {\n        let wrappedLines = str\n            .substr(pos, chunkLength)\n            .replace(new RegExp('.{' + lineLength + '}', 'g'), '$&\\r\\n')\n            .trim();\n        result.push(wrappedLines);\n        pos += chunkLength;\n    }\n\n    return result.join('\\r\\n').trim();\n}\n\n/**\n * Creates a transform stream for encoding data to base64 encoding\n *\n * @constructor\n * @param {Object} options Stream options\n * @param {Number} [options.lineLength=76] Maximum length for lines, set to false to disable wrapping\n */\nclass Encoder extends Transform {\n    constructor(options) {\n        super();\n        // init Transform\n        this.options = options || {};\n\n        if (this.options.lineLength !== false) {\n            this.options.lineLength = this.options.lineLength || 76;\n        }\n\n        this._curLine = '';\n        this._remainingBytes = false;\n\n        this.inputBytes = 0;\n        this.outputBytes = 0;\n    }\n\n    _transform(chunk, encoding, done) {\n        if (encoding !== 'buffer') {\n            chunk = Buffer.from(chunk, encoding);\n        }\n\n        if (!chunk || !chunk.length) {\n            return setImmediate(done);\n        }\n\n        this.inputBytes += chunk.length;\n\n        if (this._remainingBytes && this._remainingBytes.length) {\n            chunk = Buffer.concat([this._remainingBytes, chunk], this._remainingBytes.length + chunk.length);\n            this._remainingBytes = false;\n        }\n\n        if (chunk.length % 3) {\n            this._remainingBytes = chunk.slice(chunk.length - (chunk.length % 3));\n            chunk = chunk.slice(0, chunk.length - (chunk.length % 3));\n        } else {\n            this._remainingBytes = false;\n        }\n\n        let b64 = this._curLine + encode(chunk);\n\n        if (this.options.lineLength) {\n            b64 = wrap(b64, this.options.lineLength);\n\n            // remove last line as it is still most probably incomplete\n            let lastLF = b64.lastIndexOf('\\n');\n            if (lastLF < 0) {\n                this._curLine = b64;\n                b64 = '';\n            } else if (lastLF === b64.length - 1) {\n                this._curLine = '';\n            } else {\n                this._curLine = b64.substr(lastLF + 1);\n                b64 = b64.substr(0, lastLF + 1);\n            }\n        }\n\n        if (b64) {\n            this.outputBytes += b64.length;\n            this.push(Buffer.from(b64, 'ascii'));\n        }\n\n        setImmediate(done);\n    }\n\n    _flush(done) {\n        if (this._remainingBytes && this._remainingBytes.length) {\n            this._curLine += encode(this._remainingBytes);\n        }\n\n        if (this._curLine) {\n            this._curLine = wrap(this._curLine, this.options.lineLength);\n            this.outputBytes += this._curLine.length;\n            this.push(this._curLine, 'ascii');\n            this._curLine = '';\n        }\n        done();\n    }\n}\n\n// expose to the world\nmodule.exports = {\n    encode,\n    wrap,\n    Encoder\n};\n","'use strict';\n\nconst Transform = require('stream').Transform;\n\n/**\n * Encodes a Buffer into a Quoted-Printable encoded string\n *\n * @param {Buffer} buffer Buffer to convert\n * @returns {String} Quoted-Printable encoded string\n */\nfunction encode(buffer) {\n    if (typeof buffer === 'string') {\n        buffer = Buffer.from(buffer, 'utf-8');\n    }\n\n    // usable characters that do not need encoding\n    let ranges = [\n        // https://tools.ietf.org/html/rfc2045#section-6.7\n        [0x09], // <TAB>\n        [0x0a], // <LF>\n        [0x0d], // <CR>\n        [0x20, 0x3c], // <SP>!\"#$%&'()*+,-./0123456789:;\n        [0x3e, 0x7e] // >?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}\n    ];\n    let result = '';\n    let ord;\n\n    for (let i = 0, len = buffer.length; i < len; i++) {\n        ord = buffer[i];\n        // if the char is in allowed range, then keep as is, unless it is a WS in the end of a line\n        if (checkRanges(ord, ranges) && !((ord === 0x20 || ord === 0x09) && (i === len - 1 || buffer[i + 1] === 0x0a || buffer[i + 1] === 0x0d))) {\n            result += String.fromCharCode(ord);\n            continue;\n        }\n        result += '=' + (ord < 0x10 ? '0' : '') + ord.toString(16).toUpperCase();\n    }\n\n    return result;\n}\n\n/**\n * Adds soft line breaks to a Quoted-Printable string\n *\n * @param {String} str Quoted-Printable encoded string that might need line wrapping\n * @param {Number} [lineLength=76] Maximum allowed length for a line\n * @returns {String} Soft-wrapped Quoted-Printable encoded string\n */\nfunction wrap(str, lineLength) {\n    str = (str || '').toString();\n    lineLength = lineLength || 76;\n\n    if (str.length <= lineLength) {\n        return str;\n    }\n\n    let pos = 0;\n    let len = str.length;\n    let match, code, line;\n    let lineMargin = Math.floor(lineLength / 3);\n    let result = '';\n\n    // insert soft linebreaks where needed\n    while (pos < len) {\n        line = str.substr(pos, lineLength);\n        if ((match = line.match(/\\r\\n/))) {\n            line = line.substr(0, match.index + match[0].length);\n            result += line;\n            pos += line.length;\n            continue;\n        }\n\n        if (line.substr(-1) === '\\n') {\n            // nothing to change here\n            result += line;\n            pos += line.length;\n            continue;\n        } else if ((match = line.substr(-lineMargin).match(/\\n.*?$/))) {\n            // truncate to nearest line break\n            line = line.substr(0, line.length - (match[0].length - 1));\n            result += line;\n            pos += line.length;\n            continue;\n        } else if (line.length > lineLength - lineMargin && (match = line.substr(-lineMargin).match(/[ \\t.,!?][^ \\t.,!?]*$/))) {\n            // truncate to nearest space\n            line = line.substr(0, line.length - (match[0].length - 1));\n        } else if (line.match(/[=][\\da-f]{0,2}$/i)) {\n            // push incomplete encoding sequences to the next line\n            if ((match = line.match(/[=][\\da-f]{0,1}$/i))) {\n                line = line.substr(0, line.length - match[0].length);\n            }\n\n            // ensure that utf-8 sequences are not split\n            while (line.length > 3 && line.length < len - pos && !line.match(/^(?:=[\\da-f]{2}){1,4}$/i) && (match = line.match(/[=][\\da-f]{2}$/gi))) {\n                code = parseInt(match[0].substr(1, 2), 16);\n                if (code < 128) {\n                    break;\n                }\n\n                line = line.substr(0, line.length - 3);\n\n                if (code >= 0xc0) {\n                    break;\n                }\n            }\n        }\n\n        if (pos + line.length < len && line.substr(-1) !== '\\n') {\n            if (line.length === lineLength && line.match(/[=][\\da-f]{2}$/i)) {\n                line = line.substr(0, line.length - 3);\n            } else if (line.length === lineLength) {\n                line = line.substr(0, line.length - 1);\n            }\n            pos += line.length;\n            line += '=\\r\\n';\n        } else {\n            pos += line.length;\n        }\n\n        result += line;\n    }\n\n    return result;\n}\n\n/**\n * Helper function to check if a number is inside provided ranges\n *\n * @param {Number} nr Number to check for\n * @param {Array} ranges An Array of allowed values\n * @returns {Boolean} True if the value was found inside allowed ranges, false otherwise\n */\nfunction checkRanges(nr, ranges) {\n    for (let i = ranges.length - 1; i >= 0; i--) {\n        if (!ranges[i].length) {\n            continue;\n        }\n        if (ranges[i].length === 1 && nr === ranges[i][0]) {\n            return true;\n        }\n        if (ranges[i].length === 2 && nr >= ranges[i][0] && nr <= ranges[i][1]) {\n            return true;\n        }\n    }\n    return false;\n}\n\n/**\n * Creates a transform stream for encoding data to Quoted-Printable encoding\n *\n * @constructor\n * @param {Object} options Stream options\n * @param {Number} [options.lineLength=76] Maximum length for lines, set to false to disable wrapping\n */\nclass Encoder extends Transform {\n    constructor(options) {\n        super();\n\n        // init Transform\n        this.options = options || {};\n\n        if (this.options.lineLength !== false) {\n            this.options.lineLength = this.options.lineLength || 76;\n        }\n\n        this._curLine = '';\n\n        this.inputBytes = 0;\n        this.outputBytes = 0;\n    }\n\n    _transform(chunk, encoding, done) {\n        let qp;\n\n        if (encoding !== 'buffer') {\n            chunk = Buffer.from(chunk, encoding);\n        }\n\n        if (!chunk || !chunk.length) {\n            return done();\n        }\n\n        this.inputBytes += chunk.length;\n\n        if (this.options.lineLength) {\n            qp = this._curLine + encode(chunk);\n            qp = wrap(qp, this.options.lineLength);\n            qp = qp.replace(/(^|\\n)([^\\n]*)$/, (match, lineBreak, lastLine) => {\n                this._curLine = lastLine;\n                return lineBreak;\n            });\n\n            if (qp) {\n                this.outputBytes += qp.length;\n                this.push(qp);\n            }\n        } else {\n            qp = encode(chunk);\n            this.outputBytes += qp.length;\n            this.push(qp, 'ascii');\n        }\n\n        done();\n    }\n\n    _flush(done) {\n        if (this._curLine) {\n            this.outputBytes += this._curLine.length;\n            this.push(this._curLine, 'ascii');\n        }\n        done();\n    }\n}\n\n// expose to the world\nmodule.exports = {\n    encode,\n    wrap,\n    Encoder\n};\n","/* eslint no-control-regex:0 */\n\n'use strict';\n\nconst base64 = require('../base64');\nconst qp = require('../qp');\nconst mimeTypes = require('./mime-types');\n\nmodule.exports = {\n    /**\n     * Checks if a value is plaintext string (uses only printable 7bit chars)\n     *\n     * @param {String} value String to be tested\n     * @returns {Boolean} true if it is a plaintext string\n     */\n    isPlainText(value, isParam) {\n        const re = isParam ? /[\\x00-\\x08\\x0b\\x0c\\x0e-\\x1f\"\\u0080-\\uFFFF]/ : /[\\x00-\\x08\\x0b\\x0c\\x0e-\\x1f\\u0080-\\uFFFF]/;\n        if (typeof value !== 'string' || re.test(value)) {\n            return false;\n        } else {\n            return true;\n        }\n    },\n\n    /**\n     * Checks if a multi line string containes lines longer than the selected value.\n     *\n     * Useful when detecting if a mail message needs any processing at all –\n     * if only plaintext characters are used and lines are short, then there is\n     * no need to encode the values in any way. If the value is plaintext but has\n     * longer lines then allowed, then use format=flowed\n     *\n     * @param {Number} lineLength Max line length to check for\n     * @returns {Boolean} Returns true if there is at least one line longer than lineLength chars\n     */\n    hasLongerLines(str, lineLength) {\n        if (str.length > 128 * 1024) {\n            // do not test strings longer than 128kB\n            return true;\n        }\n        return new RegExp('^.{' + (lineLength + 1) + ',}', 'm').test(str);\n    },\n\n    /**\n     * Encodes a string or an Buffer to an UTF-8 MIME Word (rfc2047)\n     *\n     * @param {String|Buffer} data String to be encoded\n     * @param {String} mimeWordEncoding='Q' Encoding for the mime word, either Q or B\n     * @param {Number} [maxLength=0] If set, split mime words into several chunks if needed\n     * @return {String} Single or several mime words joined together\n     */\n    encodeWord(data, mimeWordEncoding, maxLength) {\n        mimeWordEncoding = (mimeWordEncoding || 'Q').toString().toUpperCase().trim().charAt(0);\n        maxLength = maxLength || 0;\n\n        let encodedStr;\n        let toCharset = 'UTF-8';\n\n        if (maxLength && maxLength > 7 + toCharset.length) {\n            maxLength -= 7 + toCharset.length;\n        }\n\n        if (mimeWordEncoding === 'Q') {\n            // https://tools.ietf.org/html/rfc2047#section-5 rule (3)\n            encodedStr = qp.encode(data).replace(/[^a-z0-9!*+\\-/=]/gi, chr => {\n                let ord = chr.charCodeAt(0).toString(16).toUpperCase();\n                if (chr === ' ') {\n                    return '_';\n                } else {\n                    return '=' + (ord.length === 1 ? '0' + ord : ord);\n                }\n            });\n        } else if (mimeWordEncoding === 'B') {\n            encodedStr = typeof data === 'string' ? data : base64.encode(data);\n            maxLength = maxLength ? Math.max(3, ((maxLength - (maxLength % 4)) / 4) * 3) : 0;\n        }\n\n        if (maxLength && (mimeWordEncoding !== 'B' ? encodedStr : base64.encode(data)).length > maxLength) {\n            if (mimeWordEncoding === 'Q') {\n                encodedStr = this.splitMimeEncodedString(encodedStr, maxLength).join('?= =?' + toCharset + '?' + mimeWordEncoding + '?');\n            } else {\n                // RFC2047 6.3 (2) states that encoded-word must include an integral number of characters, so no chopping unicode sequences\n                let parts = [];\n                let lpart = '';\n                for (let i = 0, len = encodedStr.length; i < len; i++) {\n                    let chr = encodedStr.charAt(i);\n\n                    if (/[\\ud83c\\ud83d\\ud83e]/.test(chr) && i < len - 1) {\n                        // composite emoji byte, so add the next byte as well\n                        chr += encodedStr.charAt(++i);\n                    }\n\n                    // check if we can add this character to the existing string\n                    // without breaking byte length limit\n                    if (Buffer.byteLength(lpart + chr) <= maxLength || i === 0) {\n                        lpart += chr;\n                    } else {\n                        // we hit the length limit, so push the existing string and start over\n                        parts.push(base64.encode(lpart));\n                        lpart = chr;\n                    }\n                }\n                if (lpart) {\n                    parts.push(base64.encode(lpart));\n                }\n\n                if (parts.length > 1) {\n                    encodedStr = parts.join('?= =?' + toCharset + '?' + mimeWordEncoding + '?');\n                } else {\n                    encodedStr = parts.join('');\n                }\n            }\n        } else if (mimeWordEncoding === 'B') {\n            encodedStr = base64.encode(data);\n        }\n\n        return '=?' + toCharset + '?' + mimeWordEncoding + '?' + encodedStr + (encodedStr.substr(-2) === '?=' ? '' : '?=');\n    },\n\n    /**\n     * Finds word sequences with non ascii text and converts these to mime words\n     *\n     * @param {String} value String to be encoded\n     * @param {String} mimeWordEncoding='Q' Encoding for the mime word, either Q or B\n     * @param {Number} [maxLength=0] If set, split mime words into several chunks if needed\n     * @param {Boolean} [encodeAll=false] If true and the value needs encoding then encodes entire string, not just the smallest match\n     * @return {String} String with possible mime words\n     */\n    encodeWords(value, mimeWordEncoding, maxLength, encodeAll) {\n        maxLength = maxLength || 0;\n\n        let encodedValue;\n\n        // find first word with a non-printable ascii or special symbol in it\n        let firstMatch = value.match(/(?:^|\\s)([^\\s]*[\"\\u0080-\\uFFFF])/);\n        if (!firstMatch) {\n            return value;\n        }\n\n        if (encodeAll) {\n            // if it is requested to encode everything or the string contains something that resebles encoded word, then encode everything\n\n            return this.encodeWord(value, mimeWordEncoding, maxLength);\n        }\n\n        // find the last word with a non-printable ascii in it\n        let lastMatch = value.match(/([\"\\u0080-\\uFFFF][^\\s]*)[^\"\\u0080-\\uFFFF]*$/);\n        if (!lastMatch) {\n            // should not happen\n            return value;\n        }\n\n        let startIndex =\n            firstMatch.index +\n            (\n                firstMatch[0].match(/[^\\s]/) || {\n                    index: 0\n                }\n            ).index;\n        let endIndex = lastMatch.index + (lastMatch[1] || '').length;\n\n        encodedValue =\n            (startIndex ? value.substr(0, startIndex) : '') +\n            this.encodeWord(value.substring(startIndex, endIndex), mimeWordEncoding || 'Q', maxLength) +\n            (endIndex < value.length ? value.substr(endIndex) : '');\n\n        return encodedValue;\n    },\n\n    /**\n     * Joins parsed header value together as 'value; param1=value1; param2=value2'\n     * PS: We are following RFC 822 for the list of special characters that we need to keep in quotes.\n     *      Refer: https://www.w3.org/Protocols/rfc1341/4_Content-Type.html\n     * @param {Object} structured Parsed header value\n     * @return {String} joined header value\n     */\n    buildHeaderValue(structured) {\n        let paramsArray = [];\n\n        Object.keys(structured.params || {}).forEach(param => {\n            // filename might include unicode characters so it is a special case\n            // other values probably do not\n            let value = structured.params[param];\n            if (!this.isPlainText(value, true) || value.length >= 75) {\n                this.buildHeaderParam(param, value, 50).forEach(encodedParam => {\n                    if (!/[\\s\"\\\\;:/=(),<>@[\\]?]|^[-']|'$/.test(encodedParam.value) || encodedParam.key.substr(-1) === '*') {\n                        paramsArray.push(encodedParam.key + '=' + encodedParam.value);\n                    } else {\n                        paramsArray.push(encodedParam.key + '=' + JSON.stringify(encodedParam.value));\n                    }\n                });\n            } else if (/[\\s'\"\\\\;:/=(),<>@[\\]?]|^-/.test(value)) {\n                paramsArray.push(param + '=' + JSON.stringify(value));\n            } else {\n                paramsArray.push(param + '=' + value);\n            }\n        });\n\n        return structured.value + (paramsArray.length ? '; ' + paramsArray.join('; ') : '');\n    },\n\n    /**\n     * Encodes a string or an Buffer to an UTF-8 Parameter Value Continuation encoding (rfc2231)\n     * Useful for splitting long parameter values.\n     *\n     * For example\n     *      title=\"unicode string\"\n     * becomes\n     *     title*0*=utf-8''unicode\n     *     title*1*=%20string\n     *\n     * @param {String|Buffer} data String to be encoded\n     * @param {Number} [maxLength=50] Max length for generated chunks\n     * @param {String} [fromCharset='UTF-8'] Source sharacter set\n     * @return {Array} A list of encoded keys and headers\n     */\n    buildHeaderParam(key, data, maxLength) {\n        let list = [];\n        let encodedStr = typeof data === 'string' ? data : (data || '').toString();\n        let encodedStrArr;\n        let chr, ord;\n        let line;\n        let startPos = 0;\n        let i, len;\n\n        maxLength = maxLength || 50;\n\n        // process ascii only text\n        if (this.isPlainText(data, true)) {\n            // check if conversion is even needed\n            if (encodedStr.length <= maxLength) {\n                return [\n                    {\n                        key,\n                        value: encodedStr\n                    }\n                ];\n            }\n\n            encodedStr = encodedStr.replace(new RegExp('.{' + maxLength + '}', 'g'), str => {\n                list.push({\n                    line: str\n                });\n                return '';\n            });\n\n            if (encodedStr) {\n                list.push({\n                    line: encodedStr\n                });\n            }\n        } else {\n            if (/[\\uD800-\\uDBFF]/.test(encodedStr)) {\n                // string containts surrogate pairs, so normalize it to an array of bytes\n                encodedStrArr = [];\n                for (i = 0, len = encodedStr.length; i < len; i++) {\n                    chr = encodedStr.charAt(i);\n                    ord = chr.charCodeAt(0);\n                    if (ord >= 0xd800 && ord <= 0xdbff && i < len - 1) {\n                        chr += encodedStr.charAt(i + 1);\n                        encodedStrArr.push(chr);\n                        i++;\n                    } else {\n                        encodedStrArr.push(chr);\n                    }\n                }\n                encodedStr = encodedStrArr;\n            }\n\n            // first line includes the charset and language info and needs to be encoded\n            // even if it does not contain any unicode characters\n            line = 'utf-8\\x27\\x27';\n            let encoded = true;\n            startPos = 0;\n\n            // process text with unicode or special chars\n            for (i = 0, len = encodedStr.length; i < len; i++) {\n                chr = encodedStr[i];\n\n                if (encoded) {\n                    chr = this.safeEncodeURIComponent(chr);\n                } else {\n                    // try to urlencode current char\n                    chr = chr === ' ' ? chr : this.safeEncodeURIComponent(chr);\n                    // By default it is not required to encode a line, the need\n                    // only appears when the string contains unicode or special chars\n                    // in this case we start processing the line over and encode all chars\n                    if (chr !== encodedStr[i]) {\n                        // Check if it is even possible to add the encoded char to the line\n                        // If not, there is no reason to use this line, just push it to the list\n                        // and start a new line with the char that needs encoding\n                        if ((this.safeEncodeURIComponent(line) + chr).length >= maxLength) {\n                            list.push({\n                                line,\n                                encoded\n                            });\n                            line = '';\n                            startPos = i - 1;\n                        } else {\n                            encoded = true;\n                            i = startPos;\n                            line = '';\n                            continue;\n                        }\n                    }\n                }\n\n                // if the line is already too long, push it to the list and start a new one\n                if ((line + chr).length >= maxLength) {\n                    list.push({\n                        line,\n                        encoded\n                    });\n                    line = chr = encodedStr[i] === ' ' ? ' ' : this.safeEncodeURIComponent(encodedStr[i]);\n                    if (chr === encodedStr[i]) {\n                        encoded = false;\n                        startPos = i - 1;\n                    } else {\n                        encoded = true;\n                    }\n                } else {\n                    line += chr;\n                }\n            }\n\n            if (line) {\n                list.push({\n                    line,\n                    encoded\n                });\n            }\n        }\n\n        return list.map((item, i) => ({\n            // encoded lines: {name}*{part}*\n            // unencoded lines: {name}*{part}\n            // if any line needs to be encoded then the first line (part==0) is always encoded\n            key: key + '*' + i + (item.encoded ? '*' : ''),\n            value: item.line\n        }));\n    },\n\n    /**\n     * Parses a header value with key=value arguments into a structured\n     * object.\n     *\n     *   parseHeaderValue('content-type: text/plain; CHARSET='UTF-8'') ->\n     *   {\n     *     'value': 'text/plain',\n     *     'params': {\n     *       'charset': 'UTF-8'\n     *     }\n     *   }\n     *\n     * @param {String} str Header value\n     * @return {Object} Header value as a parsed structure\n     */\n    parseHeaderValue(str) {\n        let response = {\n            value: false,\n            params: {}\n        };\n        let key = false;\n        let value = '';\n        let type = 'value';\n        let quote = false;\n        let escaped = false;\n        let chr;\n\n        for (let i = 0, len = str.length; i < len; i++) {\n            chr = str.charAt(i);\n            if (type === 'key') {\n                if (chr === '=') {\n                    key = value.trim().toLowerCase();\n                    type = 'value';\n                    value = '';\n                    continue;\n                }\n                value += chr;\n            } else {\n                if (escaped) {\n                    value += chr;\n                } else if (chr === '\\\\') {\n                    escaped = true;\n                    continue;\n                } else if (quote && chr === quote) {\n                    quote = false;\n                } else if (!quote && chr === '\"') {\n                    quote = chr;\n                } else if (!quote && chr === ';') {\n                    if (key === false) {\n                        response.value = value.trim();\n                    } else {\n                        response.params[key] = value.trim();\n                    }\n                    type = 'key';\n                    value = '';\n                } else {\n                    value += chr;\n                }\n                escaped = false;\n            }\n        }\n\n        if (type === 'value') {\n            if (key === false) {\n                response.value = value.trim();\n            } else {\n                response.params[key] = value.trim();\n            }\n        } else if (value.trim()) {\n            response.params[value.trim().toLowerCase()] = '';\n        }\n\n        // handle parameter value continuations\n        // https://tools.ietf.org/html/rfc2231#section-3\n\n        // preprocess values\n        Object.keys(response.params).forEach(key => {\n            let actualKey, nr, match, value;\n            if ((match = key.match(/(\\*(\\d+)|\\*(\\d+)\\*|\\*)$/))) {\n                actualKey = key.substr(0, match.index);\n                nr = Number(match[2] || match[3]) || 0;\n\n                if (!response.params[actualKey] || typeof response.params[actualKey] !== 'object') {\n                    response.params[actualKey] = {\n                        charset: false,\n                        values: []\n                    };\n                }\n\n                value = response.params[key];\n\n                if (nr === 0 && match[0].substr(-1) === '*' && (match = value.match(/^([^']*)'[^']*'(.*)$/))) {\n                    response.params[actualKey].charset = match[1] || 'iso-8859-1';\n                    value = match[2];\n                }\n\n                response.params[actualKey].values[nr] = value;\n\n                // remove the old reference\n                delete response.params[key];\n            }\n        });\n\n        // concatenate split rfc2231 strings and convert encoded strings to mime encoded words\n        Object.keys(response.params).forEach(key => {\n            let value;\n            if (response.params[key] && Array.isArray(response.params[key].values)) {\n                value = response.params[key].values.map(val => val || '').join('');\n\n                if (response.params[key].charset) {\n                    // convert \"%AB\" to \"=?charset?Q?=AB?=\"\n                    response.params[key] =\n                        '=?' +\n                        response.params[key].charset +\n                        '?Q?' +\n                        value\n                            // fix invalidly encoded chars\n                            .replace(/[=?_\\s]/g, s => {\n                                let c = s.charCodeAt(0).toString(16);\n                                if (s === ' ') {\n                                    return '_';\n                                } else {\n                                    return '%' + (c.length < 2 ? '0' : '') + c;\n                                }\n                            })\n                            // change from urlencoding to percent encoding\n                            .replace(/%/g, '=') +\n                        '?=';\n                } else {\n                    response.params[key] = value;\n                }\n            }\n        });\n\n        return response;\n    },\n\n    /**\n     * Returns file extension for a content type string. If no suitable extensions\n     * are found, 'bin' is used as the default extension\n     *\n     * @param {String} mimeType Content type to be checked for\n     * @return {String} File extension\n     */\n    detectExtension: mimeType => mimeTypes.detectExtension(mimeType),\n\n    /**\n     * Returns content type for a file extension. If no suitable content types\n     * are found, 'application/octet-stream' is used as the default content type\n     *\n     * @param {String} extension Extension to be checked for\n     * @return {String} File extension\n     */\n    detectMimeType: extension => mimeTypes.detectMimeType(extension),\n\n    /**\n     * Folds long lines, useful for folding header lines (afterSpace=false) and\n     * flowed text (afterSpace=true)\n     *\n     * @param {String} str String to be folded\n     * @param {Number} [lineLength=76] Maximum length of a line\n     * @param {Boolean} afterSpace If true, leave a space in th end of a line\n     * @return {String} String with folded lines\n     */\n    foldLines(str, lineLength, afterSpace) {\n        str = (str || '').toString();\n        lineLength = lineLength || 76;\n\n        let pos = 0,\n            len = str.length,\n            result = '',\n            line,\n            match;\n\n        while (pos < len) {\n            line = str.substr(pos, lineLength);\n            if (line.length < lineLength) {\n                result += line;\n                break;\n            }\n            if ((match = line.match(/^[^\\n\\r]*(\\r?\\n|\\r)/))) {\n                line = match[0];\n                result += line;\n                pos += line.length;\n                continue;\n            } else if ((match = line.match(/(\\s+)[^\\s]*$/)) && match[0].length - (afterSpace ? (match[1] || '').length : 0) < line.length) {\n                line = line.substr(0, line.length - (match[0].length - (afterSpace ? (match[1] || '').length : 0)));\n            } else if ((match = str.substr(pos + line.length).match(/^[^\\s]+(\\s*)/))) {\n                line = line + match[0].substr(0, match[0].length - (!afterSpace ? (match[1] || '').length : 0));\n            }\n\n            result += line;\n            pos += line.length;\n            if (pos < len) {\n                result += '\\r\\n';\n            }\n        }\n\n        return result;\n    },\n\n    /**\n     * Splits a mime encoded string. Needed for dividing mime words into smaller chunks\n     *\n     * @param {String} str Mime encoded string to be split up\n     * @param {Number} maxlen Maximum length of characters for one part (minimum 12)\n     * @return {Array} Split string\n     */\n    splitMimeEncodedString: (str, maxlen) => {\n        let curLine,\n            match,\n            chr,\n            done,\n            lines = [];\n\n        // require at least 12 symbols to fit possible 4 octet UTF-8 sequences\n        maxlen = Math.max(maxlen || 0, 12);\n\n        while (str.length) {\n            curLine = str.substr(0, maxlen);\n\n            // move incomplete escaped char back to main\n            if ((match = curLine.match(/[=][0-9A-F]?$/i))) {\n                curLine = curLine.substr(0, match.index);\n            }\n\n            done = false;\n            while (!done) {\n                done = true;\n                // check if not middle of a unicode char sequence\n                if ((match = str.substr(curLine.length).match(/^[=]([0-9A-F]{2})/i))) {\n                    chr = parseInt(match[1], 16);\n                    // invalid sequence, move one char back anc recheck\n                    if (chr < 0xc2 && chr > 0x7f) {\n                        curLine = curLine.substr(0, curLine.length - 3);\n                        done = false;\n                    }\n                }\n            }\n\n            if (curLine.length) {\n                lines.push(curLine);\n            }\n            str = str.substr(curLine.length);\n        }\n\n        return lines;\n    },\n\n    encodeURICharComponent: chr => {\n        let res = '';\n        let ord = chr.charCodeAt(0).toString(16).toUpperCase();\n\n        if (ord.length % 2) {\n            ord = '0' + ord;\n        }\n\n        if (ord.length > 2) {\n            for (let i = 0, len = ord.length / 2; i < len; i++) {\n                res += '%' + ord.substr(i, 2);\n            }\n        } else {\n            res += '%' + ord;\n        }\n\n        return res;\n    },\n\n    safeEncodeURIComponent(str) {\n        str = (str || '').toString();\n\n        try {\n            // might throw if we try to encode invalid sequences, eg. partial emoji\n            str = encodeURIComponent(str);\n        } catch (E) {\n            // should never run\n            return str.replace(/[^\\x00-\\x1F *'()<>@,;:\\\\\"[\\]?=\\u007F-\\uFFFF]+/g, '');\n        }\n\n        // ensure chars that are not handled by encodeURICompent are converted as well\n        return str.replace(/[\\x00-\\x1F *'()<>@,;:\\\\\"[\\]?=\\u007F-\\uFFFF]/g, chr => this.encodeURICharComponent(chr));\n    }\n};\n","'use strict';\n\n/**\n * Converts tokens for a single address into an address object\n *\n * @param {Array} tokens Tokens object\n * @return {Object} Address object\n */\nfunction _handleAddress(tokens) {\n    let token;\n    let isGroup = false;\n    let state = 'text';\n    let address;\n    let addresses = [];\n    let data = {\n        address: [],\n        comment: [],\n        group: [],\n        text: []\n    };\n    let i;\n    let len;\n\n    // Filter out <addresses>, (comments) and regular text\n    for (i = 0, len = tokens.length; i < len; i++) {\n        token = tokens[i];\n        if (token.type === 'operator') {\n            switch (token.value) {\n                case '<':\n                    state = 'address';\n                    break;\n                case '(':\n                    state = 'comment';\n                    break;\n                case ':':\n                    state = 'group';\n                    isGroup = true;\n                    break;\n                default:\n                    state = 'text';\n            }\n        } else if (token.value) {\n            if (state === 'address') {\n                // handle use case where unquoted name includes a \"<\"\n                // Apple Mail truncates everything between an unexpected < and an address\n                // and so will we\n                token.value = token.value.replace(/^[^<]*<\\s*/, '');\n            }\n            data[state].push(token.value);\n        }\n    }\n\n    // If there is no text but a comment, replace the two\n    if (!data.text.length && data.comment.length) {\n        data.text = data.comment;\n        data.comment = [];\n    }\n\n    if (isGroup) {\n        // http://tools.ietf.org/html/rfc2822#appendix-A.1.3\n        data.text = data.text.join(' ');\n        addresses.push({\n            name: data.text || (address && address.name),\n            group: data.group.length ? addressparser(data.group.join(',')) : []\n        });\n    } else {\n        // If no address was found, try to detect one from regular text\n        if (!data.address.length && data.text.length) {\n            for (i = data.text.length - 1; i >= 0; i--) {\n                if (data.text[i].match(/^[^@\\s]+@[^@\\s]+$/)) {\n                    data.address = data.text.splice(i, 1);\n                    break;\n                }\n            }\n\n            let _regexHandler = function (address) {\n                if (!data.address.length) {\n                    data.address = [address.trim()];\n                    return ' ';\n                } else {\n                    return address;\n                }\n            };\n\n            // still no address\n            if (!data.address.length) {\n                for (i = data.text.length - 1; i >= 0; i--) {\n                    // fixed the regex to parse email address correctly when email address has more than one @\n                    data.text[i] = data.text[i].replace(/\\s*\\b[^@\\s]+@[^\\s]+\\b\\s*/, _regexHandler).trim();\n                    if (data.address.length) {\n                        break;\n                    }\n                }\n            }\n        }\n\n        // If there's still is no text but a comment exixts, replace the two\n        if (!data.text.length && data.comment.length) {\n            data.text = data.comment;\n            data.comment = [];\n        }\n\n        // Keep only the first address occurence, push others to regular text\n        if (data.address.length > 1) {\n            data.text = data.text.concat(data.address.splice(1));\n        }\n\n        // Join values with spaces\n        data.text = data.text.join(' ');\n        data.address = data.address.join(' ');\n\n        if (!data.address && isGroup) {\n            return [];\n        } else {\n            address = {\n                address: data.address || data.text || '',\n                name: data.text || data.address || ''\n            };\n\n            if (address.address === address.name) {\n                if ((address.address || '').match(/@/)) {\n                    address.name = '';\n                } else {\n                    address.address = '';\n                }\n            }\n\n            addresses.push(address);\n        }\n    }\n\n    return addresses;\n}\n\n/**\n * Creates a Tokenizer object for tokenizing address field strings\n *\n * @constructor\n * @param {String} str Address field string\n */\nclass Tokenizer {\n    constructor(str) {\n        this.str = (str || '').toString();\n        this.operatorCurrent = '';\n        this.operatorExpecting = '';\n        this.node = null;\n        this.escaped = false;\n\n        this.list = [];\n        /**\n         * Operator tokens and which tokens are expected to end the sequence\n         */\n        this.operators = {\n            '\"': '\"',\n            '(': ')',\n            '<': '>',\n            ',': '',\n            ':': ';',\n            // Semicolons are not a legal delimiter per the RFC2822 grammar other\n            // than for terminating a group, but they are also not valid for any\n            // other use in this context.  Given that some mail clients have\n            // historically allowed the semicolon as a delimiter equivalent to the\n            // comma in their UI, it makes sense to treat them the same as a comma\n            // when used outside of a group.\n            ';': ''\n        };\n    }\n\n    /**\n     * Tokenizes the original input string\n     *\n     * @return {Array} An array of operator|text tokens\n     */\n    tokenize() {\n        let chr,\n            list = [];\n        for (let i = 0, len = this.str.length; i < len; i++) {\n            chr = this.str.charAt(i);\n            this.checkChar(chr);\n        }\n\n        this.list.forEach(node => {\n            node.value = (node.value || '').toString().trim();\n            if (node.value) {\n                list.push(node);\n            }\n        });\n\n        return list;\n    }\n\n    /**\n     * Checks if a character is an operator or text and acts accordingly\n     *\n     * @param {String} chr Character from the address field\n     */\n    checkChar(chr) {\n        if (this.escaped) {\n            // ignore next condition blocks\n        } else if (chr === this.operatorExpecting) {\n            this.node = {\n                type: 'operator',\n                value: chr\n            };\n            this.list.push(this.node);\n            this.node = null;\n            this.operatorExpecting = '';\n            this.escaped = false;\n            return;\n        } else if (!this.operatorExpecting && chr in this.operators) {\n            this.node = {\n                type: 'operator',\n                value: chr\n            };\n            this.list.push(this.node);\n            this.node = null;\n            this.operatorExpecting = this.operators[chr];\n            this.escaped = false;\n            return;\n        } else if (['\"', \"'\"].includes(this.operatorExpecting) && chr === '\\\\') {\n            this.escaped = true;\n            return;\n        }\n\n        if (!this.node) {\n            this.node = {\n                type: 'text',\n                value: ''\n            };\n            this.list.push(this.node);\n        }\n\n        if (chr === '\\n') {\n            // Convert newlines to spaces. Carriage return is ignored as \\r and \\n usually\n            // go together anyway and there already is a WS for \\n. Lone \\r means something is fishy.\n            chr = ' ';\n        }\n\n        if (chr.charCodeAt(0) >= 0x21 || [' ', '\\t'].includes(chr)) {\n            // skip command bytes\n            this.node.value += chr;\n        }\n\n        this.escaped = false;\n    }\n}\n\n/**\n * Parses structured e-mail addresses from an address field\n *\n * Example:\n *\n *    'Name <address@domain>'\n *\n * will be converted to\n *\n *     [{name: 'Name', address: 'address@domain'}]\n *\n * @param {String} str Address field\n * @return {Array} An array of address objects\n */\nfunction addressparser(str, options) {\n    options = options || {};\n\n    let tokenizer = new Tokenizer(str);\n    let tokens = tokenizer.tokenize();\n\n    let addresses = [];\n    let address = [];\n    let parsedAddresses = [];\n\n    tokens.forEach(token => {\n        if (token.type === 'operator' && (token.value === ',' || token.value === ';')) {\n            if (address.length) {\n                addresses.push(address);\n            }\n            address = [];\n        } else {\n            address.push(token);\n        }\n    });\n\n    if (address.length) {\n        addresses.push(address);\n    }\n\n    addresses.forEach(address => {\n        address = _handleAddress(address);\n        if (address.length) {\n            parsedAddresses = parsedAddresses.concat(address);\n        }\n    });\n\n    if (options.flatten) {\n        let addresses = [];\n        let walkAddressList = list => {\n            list.forEach(address => {\n                if (address.group) {\n                    return walkAddressList(address.group);\n                } else {\n                    addresses.push(address);\n                }\n            });\n        };\n        walkAddressList(parsedAddresses);\n        return addresses;\n    }\n\n    return parsedAddresses;\n}\n\n// expose to the world\nmodule.exports = addressparser;\n","'use strict';\n\nconst stream = require('stream');\nconst Transform = stream.Transform;\n\n/**\n * Ensures that only <CR><LF> sequences are used for linebreaks\n *\n * @param {Object} options Stream options\n */\nclass LeWindows extends Transform {\n    constructor(options) {\n        super(options);\n        // init Transform\n        this.options = options || {};\n        this.lastByte = false;\n    }\n\n    /**\n     * Escapes dots\n     */\n    _transform(chunk, encoding, done) {\n        let buf;\n        let lastPos = 0;\n\n        for (let i = 0, len = chunk.length; i < len; i++) {\n            if (chunk[i] === 0x0a) {\n                // \\n\n                if ((i && chunk[i - 1] !== 0x0d) || (!i && this.lastByte !== 0x0d)) {\n                    if (i > lastPos) {\n                        buf = chunk.slice(lastPos, i);\n                        this.push(buf);\n                    }\n                    this.push(Buffer.from('\\r\\n'));\n                    lastPos = i + 1;\n                }\n            }\n        }\n\n        if (lastPos && lastPos < chunk.length) {\n            buf = chunk.slice(lastPos);\n            this.push(buf);\n        } else if (!lastPos) {\n            this.push(chunk);\n        }\n\n        this.lastByte = chunk[chunk.length - 1];\n        done();\n    }\n}\n\nmodule.exports = LeWindows;\n","/* eslint no-undefined: 0, prefer-spread: 0, no-control-regex: 0 */\n\n'use strict';\n\nconst crypto = require('crypto');\nconst fs = require('fs');\nconst punycode = require('../punycode');\nconst PassThrough = require('stream').PassThrough;\nconst shared = require('../shared');\n\nconst mimeFuncs = require('../mime-funcs');\nconst qp = require('../qp');\nconst base64 = require('../base64');\nconst addressparser = require('../addressparser');\nconst nmfetch = require('../fetch');\nconst LastNewline = require('./last-newline');\n\nconst LeWindows = require('./le-windows');\nconst LeUnix = require('./le-unix');\n\n/**\n * Creates a new mime tree node. Assumes 'multipart/*' as the content type\n * if it is a branch, anything else counts as leaf. If rootNode is missing from\n * the options, assumes this is the root.\n *\n * @param {String} contentType Define the content type for the node. Can be left blank for attachments (derived from filename)\n * @param {Object} [options] optional options\n * @param {Object} [options.rootNode] root node for this tree\n * @param {Object} [options.parentNode] immediate parent for this node\n * @param {Object} [options.filename] filename for an attachment node\n * @param {String} [options.baseBoundary] shared part of the unique multipart boundary\n * @param {Boolean} [options.keepBcc] If true, do not exclude Bcc from the generated headers\n * @param {Function} [options.normalizeHeaderKey] method to normalize header keys for custom caseing\n * @param {String} [options.textEncoding] either 'Q' (the default) or 'B'\n */\nclass MimeNode {\n    constructor(contentType, options) {\n        this.nodeCounter = 0;\n\n        options = options || {};\n\n        /**\n         * shared part of the unique multipart boundary\n         */\n        this.baseBoundary = options.baseBoundary || crypto.randomBytes(8).toString('hex');\n        this.boundaryPrefix = options.boundaryPrefix || '--_NmP';\n\n        this.disableFileAccess = !!options.disableFileAccess;\n        this.disableUrlAccess = !!options.disableUrlAccess;\n\n        this.normalizeHeaderKey = options.normalizeHeaderKey;\n\n        /**\n         * If date headers is missing and current node is the root, this value is used instead\n         */\n        this.date = new Date();\n\n        /**\n         * Root node for current mime tree\n         */\n        this.rootNode = options.rootNode || this;\n\n        /**\n         * If true include Bcc in generated headers (if available)\n         */\n        this.keepBcc = !!options.keepBcc;\n\n        /**\n         * If filename is specified but contentType is not (probably an attachment)\n         * detect the content type from filename extension\n         */\n        if (options.filename) {\n            /**\n             * Filename for this node. Useful with attachments\n             */\n            this.filename = options.filename;\n            if (!contentType) {\n                contentType = mimeFuncs.detectMimeType(this.filename.split('.').pop());\n            }\n        }\n\n        /**\n         * Indicates which encoding should be used for header strings: \"Q\" or \"B\"\n         */\n        this.textEncoding = (options.textEncoding || '').toString().trim().charAt(0).toUpperCase();\n\n        /**\n         * Immediate parent for this node (or undefined if not set)\n         */\n        this.parentNode = options.parentNode;\n\n        /**\n         * Hostname for default message-id values\n         */\n        this.hostname = options.hostname;\n\n        /**\n         * If set to 'win' then uses \\r\\n, if 'linux' then \\n. If not set (or `raw` is used) then newlines are kept as is.\n         */\n        this.newline = options.newline;\n\n        /**\n         * An array for possible child nodes\n         */\n        this.childNodes = [];\n\n        /**\n         * Used for generating unique boundaries (prepended to the shared base)\n         */\n        this._nodeId = ++this.rootNode.nodeCounter;\n\n        /**\n         * A list of header values for this node in the form of [{key:'', value:''}]\n         */\n        this._headers = [];\n\n        /**\n         * True if the content only uses ASCII printable characters\n         * @type {Boolean}\n         */\n        this._isPlainText = false;\n\n        /**\n         * True if the content is plain text but has longer lines than allowed\n         * @type {Boolean}\n         */\n        this._hasLongLines = false;\n\n        /**\n         * If set, use instead this value for envelopes instead of generating one\n         * @type {Boolean}\n         */\n        this._envelope = false;\n\n        /**\n         * If set then use this value as the stream content instead of building it\n         * @type {String|Buffer|Stream}\n         */\n        this._raw = false;\n\n        /**\n         * Additional transform streams that the message will be piped before\n         * exposing by createReadStream\n         * @type {Array}\n         */\n        this._transforms = [];\n\n        /**\n         * Additional process functions that the message will be piped through before\n         * exposing by createReadStream. These functions are run after transforms\n         * @type {Array}\n         */\n        this._processFuncs = [];\n\n        /**\n         * If content type is set (or derived from the filename) add it to headers\n         */\n        if (contentType) {\n            this.setHeader('Content-Type', contentType);\n        }\n    }\n\n    /////// PUBLIC METHODS\n\n    /**\n     * Creates and appends a child node.Arguments provided are passed to MimeNode constructor\n     *\n     * @param {String} [contentType] Optional content type\n     * @param {Object} [options] Optional options object\n     * @return {Object} Created node object\n     */\n    createChild(contentType, options) {\n        if (!options && typeof contentType === 'object') {\n            options = contentType;\n            contentType = undefined;\n        }\n        let node = new MimeNode(contentType, options);\n        this.appendChild(node);\n        return node;\n    }\n\n    /**\n     * Appends an existing node to the mime tree. Removes the node from an existing\n     * tree if needed\n     *\n     * @param {Object} childNode node to be appended\n     * @return {Object} Appended node object\n     */\n    appendChild(childNode) {\n        if (childNode.rootNode !== this.rootNode) {\n            childNode.rootNode = this.rootNode;\n            childNode._nodeId = ++this.rootNode.nodeCounter;\n        }\n\n        childNode.parentNode = this;\n\n        this.childNodes.push(childNode);\n        return childNode;\n    }\n\n    /**\n     * Replaces current node with another node\n     *\n     * @param {Object} node Replacement node\n     * @return {Object} Replacement node\n     */\n    replace(node) {\n        if (node === this) {\n            return this;\n        }\n\n        this.parentNode.childNodes.forEach((childNode, i) => {\n            if (childNode === this) {\n                node.rootNode = this.rootNode;\n                node.parentNode = this.parentNode;\n                node._nodeId = this._nodeId;\n\n                this.rootNode = this;\n                this.parentNode = undefined;\n\n                node.parentNode.childNodes[i] = node;\n            }\n        });\n\n        return node;\n    }\n\n    /**\n     * Removes current node from the mime tree\n     *\n     * @return {Object} removed node\n     */\n    remove() {\n        if (!this.parentNode) {\n            return this;\n        }\n\n        for (let i = this.parentNode.childNodes.length - 1; i >= 0; i--) {\n            if (this.parentNode.childNodes[i] === this) {\n                this.parentNode.childNodes.splice(i, 1);\n                this.parentNode = undefined;\n                this.rootNode = this;\n                return this;\n            }\n        }\n    }\n\n    /**\n     * Sets a header value. If the value for selected key exists, it is overwritten.\n     * You can set multiple values as well by using [{key:'', value:''}] or\n     * {key: 'value'} as the first argument.\n     *\n     * @param {String|Array|Object} key Header key or a list of key value pairs\n     * @param {String} value Header value\n     * @return {Object} current node\n     */\n    setHeader(key, value) {\n        let added = false,\n            headerValue;\n\n        // Allow setting multiple headers at once\n        if (!value && key && typeof key === 'object') {\n            // allow {key:'content-type', value: 'text/plain'}\n            if (key.key && 'value' in key) {\n                this.setHeader(key.key, key.value);\n            } else if (Array.isArray(key)) {\n                // allow [{key:'content-type', value: 'text/plain'}]\n                key.forEach(i => {\n                    this.setHeader(i.key, i.value);\n                });\n            } else {\n                // allow {'content-type': 'text/plain'}\n                Object.keys(key).forEach(i => {\n                    this.setHeader(i, key[i]);\n                });\n            }\n            return this;\n        }\n\n        key = this._normalizeHeaderKey(key);\n\n        headerValue = {\n            key,\n            value\n        };\n\n        // Check if the value exists and overwrite\n        for (let i = 0, len = this._headers.length; i < len; i++) {\n            if (this._headers[i].key === key) {\n                if (!added) {\n                    // replace the first match\n                    this._headers[i] = headerValue;\n                    added = true;\n                } else {\n                    // remove following matches\n                    this._headers.splice(i, 1);\n                    i--;\n                    len--;\n                }\n            }\n        }\n\n        // match not found, append the value\n        if (!added) {\n            this._headers.push(headerValue);\n        }\n\n        return this;\n    }\n\n    /**\n     * Adds a header value. If the value for selected key exists, the value is appended\n     * as a new field and old one is not touched.\n     * You can set multiple values as well by using [{key:'', value:''}] or\n     * {key: 'value'} as the first argument.\n     *\n     * @param {String|Array|Object} key Header key or a list of key value pairs\n     * @param {String} value Header value\n     * @return {Object} current node\n     */\n    addHeader(key, value) {\n        // Allow setting multiple headers at once\n        if (!value && key && typeof key === 'object') {\n            // allow {key:'content-type', value: 'text/plain'}\n            if (key.key && key.value) {\n                this.addHeader(key.key, key.value);\n            } else if (Array.isArray(key)) {\n                // allow [{key:'content-type', value: 'text/plain'}]\n                key.forEach(i => {\n                    this.addHeader(i.key, i.value);\n                });\n            } else {\n                // allow {'content-type': 'text/plain'}\n                Object.keys(key).forEach(i => {\n                    this.addHeader(i, key[i]);\n                });\n            }\n            return this;\n        } else if (Array.isArray(value)) {\n            value.forEach(val => {\n                this.addHeader(key, val);\n            });\n            return this;\n        }\n\n        this._headers.push({\n            key: this._normalizeHeaderKey(key),\n            value\n        });\n\n        return this;\n    }\n\n    /**\n     * Retrieves the first mathcing value of a selected key\n     *\n     * @param {String} key Key to search for\n     * @retun {String} Value for the key\n     */\n    getHeader(key) {\n        key = this._normalizeHeaderKey(key);\n        for (let i = 0, len = this._headers.length; i < len; i++) {\n            if (this._headers[i].key === key) {\n                return this._headers[i].value;\n            }\n        }\n    }\n\n    /**\n     * Sets body content for current node. If the value is a string, charset is added automatically\n     * to Content-Type (if it is text/*). If the value is a Buffer, you need to specify\n     * the charset yourself\n     *\n     * @param (String|Buffer) content Body content\n     * @return {Object} current node\n     */\n    setContent(content) {\n        this.content = content;\n        if (typeof this.content.pipe === 'function') {\n            // pre-stream handler. might be triggered if a stream is set as content\n            // and 'error' fires before anything is done with this stream\n            this._contentErrorHandler = err => {\n                this.content.removeListener('error', this._contentErrorHandler);\n                this.content = err;\n            };\n            this.content.once('error', this._contentErrorHandler);\n        } else if (typeof this.content === 'string') {\n            this._isPlainText = mimeFuncs.isPlainText(this.content);\n            if (this._isPlainText && mimeFuncs.hasLongerLines(this.content, 76)) {\n                // If there are lines longer than 76 symbols/bytes do not use 7bit\n                this._hasLongLines = true;\n            }\n        }\n        return this;\n    }\n\n    build(callback) {\n        let promise;\n\n        if (!callback) {\n            promise = new Promise((resolve, reject) => {\n                callback = shared.callbackPromise(resolve, reject);\n            });\n        }\n\n        let stream = this.createReadStream();\n        let buf = [];\n        let buflen = 0;\n        let returned = false;\n\n        stream.on('readable', () => {\n            let chunk;\n\n            while ((chunk = stream.read()) !== null) {\n                buf.push(chunk);\n                buflen += chunk.length;\n            }\n        });\n\n        stream.once('error', err => {\n            if (returned) {\n                return;\n            }\n            returned = true;\n\n            return callback(err);\n        });\n\n        stream.once('end', chunk => {\n            if (returned) {\n                return;\n            }\n            returned = true;\n\n            if (chunk && chunk.length) {\n                buf.push(chunk);\n                buflen += chunk.length;\n            }\n            return callback(null, Buffer.concat(buf, buflen));\n        });\n\n        return promise;\n    }\n\n    getTransferEncoding() {\n        let transferEncoding = false;\n        let contentType = (this.getHeader('Content-Type') || '').toString().toLowerCase().trim();\n\n        if (this.content) {\n            transferEncoding = (this.getHeader('Content-Transfer-Encoding') || '').toString().toLowerCase().trim();\n            if (!transferEncoding || !['base64', 'quoted-printable'].includes(transferEncoding)) {\n                if (/^text\\//i.test(contentType)) {\n                    // If there are no special symbols, no need to modify the text\n                    if (this._isPlainText && !this._hasLongLines) {\n                        transferEncoding = '7bit';\n                    } else if (typeof this.content === 'string' || this.content instanceof Buffer) {\n                        // detect preferred encoding for string value\n                        transferEncoding = this._getTextEncoding(this.content) === 'Q' ? 'quoted-printable' : 'base64';\n                    } else {\n                        // we can not check content for a stream, so either use preferred encoding or fallback to QP\n                        transferEncoding = this.textEncoding === 'B' ? 'base64' : 'quoted-printable';\n                    }\n                } else if (!/^(multipart|message)\\//i.test(contentType)) {\n                    transferEncoding = transferEncoding || 'base64';\n                }\n            }\n        }\n        return transferEncoding;\n    }\n\n    /**\n     * Builds the header block for the mime node. Append \\r\\n\\r\\n before writing the content\n     *\n     * @returns {String} Headers\n     */\n    buildHeaders() {\n        let transferEncoding = this.getTransferEncoding();\n        let headers = [];\n\n        if (transferEncoding) {\n            this.setHeader('Content-Transfer-Encoding', transferEncoding);\n        }\n\n        if (this.filename && !this.getHeader('Content-Disposition')) {\n            this.setHeader('Content-Disposition', 'attachment');\n        }\n\n        // Ensure mandatory header fields\n        if (this.rootNode === this) {\n            if (!this.getHeader('Date')) {\n                this.setHeader('Date', this.date.toUTCString().replace(/GMT/, '+0000'));\n            }\n\n            // ensure that Message-Id is present\n            this.messageId();\n\n            if (!this.getHeader('MIME-Version')) {\n                this.setHeader('MIME-Version', '1.0');\n            }\n\n            // Ensure that Content-Type is the last header for the root node\n            for (let i = this._headers.length - 2; i >= 0; i--) {\n                let header = this._headers[i];\n                if (header.key === 'Content-Type') {\n                    this._headers.splice(i, 1);\n                    this._headers.push(header);\n                }\n            }\n        }\n\n        this._headers.forEach(header => {\n            let key = header.key;\n            let value = header.value;\n            let structured;\n            let param;\n            let options = {};\n            let formattedHeaders = ['From', 'Sender', 'To', 'Cc', 'Bcc', 'Reply-To', 'Date', 'References'];\n\n            if (value && typeof value === 'object' && !formattedHeaders.includes(key)) {\n                Object.keys(value).forEach(key => {\n                    if (key !== 'value') {\n                        options[key] = value[key];\n                    }\n                });\n                value = (value.value || '').toString();\n                if (!value.trim()) {\n                    return;\n                }\n            }\n\n            if (options.prepared) {\n                // header value is\n                if (options.foldLines) {\n                    headers.push(mimeFuncs.foldLines(key + ': ' + value));\n                } else {\n                    headers.push(key + ': ' + value);\n                }\n                return;\n            }\n\n            switch (header.key) {\n                case 'Content-Disposition':\n                    structured = mimeFuncs.parseHeaderValue(value);\n                    if (this.filename) {\n                        structured.params.filename = this.filename;\n                    }\n                    value = mimeFuncs.buildHeaderValue(structured);\n                    break;\n\n                case 'Content-Type':\n                    structured = mimeFuncs.parseHeaderValue(value);\n\n                    this._handleContentType(structured);\n\n                    if (structured.value.match(/^text\\/plain\\b/) && typeof this.content === 'string' && /[\\u0080-\\uFFFF]/.test(this.content)) {\n                        structured.params.charset = 'utf-8';\n                    }\n\n                    value = mimeFuncs.buildHeaderValue(structured);\n\n                    if (this.filename) {\n                        // add support for non-compliant clients like QQ webmail\n                        // we can't build the value with buildHeaderValue as the value is non standard and\n                        // would be converted to parameter continuation encoding that we do not want\n                        param = this._encodeWords(this.filename);\n\n                        if (param !== this.filename || /[\\s'\"\\\\;:/=(),<>@[\\]?]|^-/.test(param)) {\n                            // include value in quotes if needed\n                            param = '\"' + param + '\"';\n                        }\n                        value += '; name=' + param;\n                    }\n                    break;\n\n                case 'Bcc':\n                    if (!this.keepBcc) {\n                        // skip BCC values\n                        return;\n                    }\n                    break;\n            }\n\n            value = this._encodeHeaderValue(key, value);\n\n            // skip empty lines\n            if (!(value || '').toString().trim()) {\n                return;\n            }\n\n            if (typeof this.normalizeHeaderKey === 'function') {\n                let normalized = this.normalizeHeaderKey(key, value);\n                if (normalized && typeof normalized === 'string' && normalized.length) {\n                    key = normalized;\n                }\n            }\n\n            headers.push(mimeFuncs.foldLines(key + ': ' + value, 76));\n        });\n\n        return headers.join('\\r\\n');\n    }\n\n    /**\n     * Streams the rfc2822 message from the current node. If this is a root node,\n     * mandatory header fields are set if missing (Date, Message-Id, MIME-Version)\n     *\n     * @return {String} Compiled message\n     */\n    createReadStream(options) {\n        options = options || {};\n\n        let stream = new PassThrough(options);\n        let outputStream = stream;\n        let transform;\n\n        this.stream(stream, options, err => {\n            if (err) {\n                outputStream.emit('error', err);\n                return;\n            }\n            stream.end();\n        });\n\n        for (let i = 0, len = this._transforms.length; i < len; i++) {\n            transform = typeof this._transforms[i] === 'function' ? this._transforms[i]() : this._transforms[i];\n            outputStream.once('error', err => {\n                transform.emit('error', err);\n            });\n            outputStream = outputStream.pipe(transform);\n        }\n\n        // ensure terminating newline after possible user transforms\n        transform = new LastNewline();\n        outputStream.once('error', err => {\n            transform.emit('error', err);\n        });\n        outputStream = outputStream.pipe(transform);\n\n        // dkim and stuff\n        for (let i = 0, len = this._processFuncs.length; i < len; i++) {\n            transform = this._processFuncs[i];\n            outputStream = transform(outputStream);\n        }\n\n        if (this.newline) {\n            const winbreak = ['win', 'windows', 'dos', '\\r\\n'].includes(this.newline.toString().toLowerCase());\n            const newlineTransform = winbreak ? new LeWindows() : new LeUnix();\n\n            const stream = outputStream.pipe(newlineTransform);\n            outputStream.on('error', err => stream.emit('error', err));\n            return stream;\n        }\n\n        return outputStream;\n    }\n\n    /**\n     * Appends a transform stream object to the transforms list. Final output\n     * is passed through this stream before exposing\n     *\n     * @param {Object} transform Read-Write stream\n     */\n    transform(transform) {\n        this._transforms.push(transform);\n    }\n\n    /**\n     * Appends a post process function. The functon is run after transforms and\n     * uses the following syntax\n     *\n     *   processFunc(input) -> outputStream\n     *\n     * @param {Object} processFunc Read-Write stream\n     */\n    processFunc(processFunc) {\n        this._processFuncs.push(processFunc);\n    }\n\n    stream(outputStream, options, done) {\n        let transferEncoding = this.getTransferEncoding();\n        let contentStream;\n        let localStream;\n\n        // protect actual callback against multiple triggering\n        let returned = false;\n        let callback = err => {\n            if (returned) {\n                return;\n            }\n            returned = true;\n            done(err);\n        };\n\n        // for multipart nodes, push child nodes\n        // for content nodes end the stream\n        let finalize = () => {\n            let childId = 0;\n            let processChildNode = () => {\n                if (childId >= this.childNodes.length) {\n                    outputStream.write('\\r\\n--' + this.boundary + '--\\r\\n');\n                    return callback();\n                }\n                let child = this.childNodes[childId++];\n                outputStream.write((childId > 1 ? '\\r\\n' : '') + '--' + this.boundary + '\\r\\n');\n                child.stream(outputStream, options, err => {\n                    if (err) {\n                        return callback(err);\n                    }\n                    setImmediate(processChildNode);\n                });\n            };\n\n            if (this.multipart) {\n                setImmediate(processChildNode);\n            } else {\n                return callback();\n            }\n        };\n\n        // pushes node content\n        let sendContent = () => {\n            if (this.content) {\n                if (Object.prototype.toString.call(this.content) === '[object Error]') {\n                    // content is already errored\n                    return callback(this.content);\n                }\n\n                if (typeof this.content.pipe === 'function') {\n                    this.content.removeListener('error', this._contentErrorHandler);\n                    this._contentErrorHandler = err => callback(err);\n                    this.content.once('error', this._contentErrorHandler);\n                }\n\n                let createStream = () => {\n                    if (['quoted-printable', 'base64'].includes(transferEncoding)) {\n                        contentStream = new (transferEncoding === 'base64' ? base64 : qp).Encoder(options);\n\n                        contentStream.pipe(outputStream, {\n                            end: false\n                        });\n                        contentStream.once('end', finalize);\n                        contentStream.once('error', err => callback(err));\n\n                        localStream = this._getStream(this.content);\n                        localStream.pipe(contentStream);\n                    } else {\n                        // anything that is not QP or Base54 passes as-is\n                        localStream = this._getStream(this.content);\n                        localStream.pipe(outputStream, {\n                            end: false\n                        });\n                        localStream.once('end', finalize);\n                    }\n\n                    localStream.once('error', err => callback(err));\n                };\n\n                if (this.content._resolve) {\n                    let chunks = [];\n                    let chunklen = 0;\n                    let returned = false;\n                    let sourceStream = this._getStream(this.content);\n                    sourceStream.on('error', err => {\n                        if (returned) {\n                            return;\n                        }\n                        returned = true;\n                        callback(err);\n                    });\n                    sourceStream.on('readable', () => {\n                        let chunk;\n                        while ((chunk = sourceStream.read()) !== null) {\n                            chunks.push(chunk);\n                            chunklen += chunk.length;\n                        }\n                    });\n                    sourceStream.on('end', () => {\n                        if (returned) {\n                            return;\n                        }\n                        returned = true;\n                        this.content._resolve = false;\n                        this.content._resolvedValue = Buffer.concat(chunks, chunklen);\n                        setImmediate(createStream);\n                    });\n                } else {\n                    setImmediate(createStream);\n                }\n                return;\n            } else {\n                return setImmediate(finalize);\n            }\n        };\n\n        if (this._raw) {\n            setImmediate(() => {\n                if (Object.prototype.toString.call(this._raw) === '[object Error]') {\n                    // content is already errored\n                    return callback(this._raw);\n                }\n\n                // remove default error handler (if set)\n                if (typeof this._raw.pipe === 'function') {\n                    this._raw.removeListener('error', this._contentErrorHandler);\n                }\n\n                let raw = this._getStream(this._raw);\n                raw.pipe(outputStream, {\n                    end: false\n                });\n                raw.on('error', err => outputStream.emit('error', err));\n                raw.on('end', finalize);\n            });\n        } else {\n            outputStream.write(this.buildHeaders() + '\\r\\n\\r\\n');\n            setImmediate(sendContent);\n        }\n    }\n\n    /**\n     * Sets envelope to be used instead of the generated one\n     *\n     * @return {Object} SMTP envelope in the form of {from: 'from@example.com', to: ['to@example.com']}\n     */\n    setEnvelope(envelope) {\n        let list;\n\n        this._envelope = {\n            from: false,\n            to: []\n        };\n\n        if (envelope.from) {\n            list = [];\n            this._convertAddresses(this._parseAddresses(envelope.from), list);\n            list = list.filter(address => address && address.address);\n            if (list.length && list[0]) {\n                this._envelope.from = list[0].address;\n            }\n        }\n        ['to', 'cc', 'bcc'].forEach(key => {\n            if (envelope[key]) {\n                this._convertAddresses(this._parseAddresses(envelope[key]), this._envelope.to);\n            }\n        });\n\n        this._envelope.to = this._envelope.to.map(to => to.address).filter(address => address);\n\n        let standardFields = ['to', 'cc', 'bcc', 'from'];\n        Object.keys(envelope).forEach(key => {\n            if (!standardFields.includes(key)) {\n                this._envelope[key] = envelope[key];\n            }\n        });\n\n        return this;\n    }\n\n    /**\n     * Generates and returns an object with parsed address fields\n     *\n     * @return {Object} Address object\n     */\n    getAddresses() {\n        let addresses = {};\n\n        this._headers.forEach(header => {\n            let key = header.key.toLowerCase();\n            if (['from', 'sender', 'reply-to', 'to', 'cc', 'bcc'].includes(key)) {\n                if (!Array.isArray(addresses[key])) {\n                    addresses[key] = [];\n                }\n\n                this._convertAddresses(this._parseAddresses(header.value), addresses[key]);\n            }\n        });\n\n        return addresses;\n    }\n\n    /**\n     * Generates and returns SMTP envelope with the sender address and a list of recipients addresses\n     *\n     * @return {Object} SMTP envelope in the form of {from: 'from@example.com', to: ['to@example.com']}\n     */\n    getEnvelope() {\n        if (this._envelope) {\n            return this._envelope;\n        }\n\n        let envelope = {\n            from: false,\n            to: []\n        };\n        this._headers.forEach(header => {\n            let list = [];\n            if (header.key === 'From' || (!envelope.from && ['Reply-To', 'Sender'].includes(header.key))) {\n                this._convertAddresses(this._parseAddresses(header.value), list);\n                if (list.length && list[0]) {\n                    envelope.from = list[0].address;\n                }\n            } else if (['To', 'Cc', 'Bcc'].includes(header.key)) {\n                this._convertAddresses(this._parseAddresses(header.value), envelope.to);\n            }\n        });\n\n        envelope.to = envelope.to.map(to => to.address);\n\n        return envelope;\n    }\n\n    /**\n     * Returns Message-Id value. If it does not exist, then creates one\n     *\n     * @return {String} Message-Id value\n     */\n    messageId() {\n        let messageId = this.getHeader('Message-ID');\n        // You really should define your own Message-Id field!\n        if (!messageId) {\n            messageId = this._generateMessageId();\n            this.setHeader('Message-ID', messageId);\n        }\n        return messageId;\n    }\n\n    /**\n     * Sets pregenerated content that will be used as the output of this node\n     *\n     * @param {String|Buffer|Stream} Raw MIME contents\n     */\n    setRaw(raw) {\n        this._raw = raw;\n\n        if (this._raw && typeof this._raw.pipe === 'function') {\n            // pre-stream handler. might be triggered if a stream is set as content\n            // and 'error' fires before anything is done with this stream\n            this._contentErrorHandler = err => {\n                this._raw.removeListener('error', this._contentErrorHandler);\n                this._raw = err;\n            };\n            this._raw.once('error', this._contentErrorHandler);\n        }\n\n        return this;\n    }\n\n    /////// PRIVATE METHODS\n\n    /**\n     * Detects and returns handle to a stream related with the content.\n     *\n     * @param {Mixed} content Node content\n     * @returns {Object} Stream object\n     */\n    _getStream(content) {\n        let contentStream;\n\n        if (content._resolvedValue) {\n            // pass string or buffer content as a stream\n            contentStream = new PassThrough();\n\n            setImmediate(() => {\n                try {\n                    contentStream.end(content._resolvedValue);\n                } catch (err) {\n                    contentStream.emit('error', err);\n                }\n            });\n\n            return contentStream;\n        } else if (typeof content.pipe === 'function') {\n            // assume as stream\n            return content;\n        } else if (content && typeof content.path === 'string' && !content.href) {\n            if (this.disableFileAccess) {\n                contentStream = new PassThrough();\n                setImmediate(() => contentStream.emit('error', new Error('File access rejected for ' + content.path)));\n                return contentStream;\n            }\n            // read file\n            return fs.createReadStream(content.path);\n        } else if (content && typeof content.href === 'string') {\n            if (this.disableUrlAccess) {\n                contentStream = new PassThrough();\n                setImmediate(() => contentStream.emit('error', new Error('Url access rejected for ' + content.href)));\n                return contentStream;\n            }\n            // fetch URL\n            return nmfetch(content.href, { headers: content.httpHeaders });\n        } else {\n            // pass string or buffer content as a stream\n            contentStream = new PassThrough();\n\n            setImmediate(() => {\n                try {\n                    contentStream.end(content || '');\n                } catch (err) {\n                    contentStream.emit('error', err);\n                }\n            });\n            return contentStream;\n        }\n    }\n\n    /**\n     * Parses addresses. Takes in a single address or an array or an\n     * array of address arrays (eg. To: [[first group], [second group],...])\n     *\n     * @param {Mixed} addresses Addresses to be parsed\n     * @return {Array} An array of address objects\n     */\n    _parseAddresses(addresses) {\n        return [].concat.apply(\n            [],\n            [].concat(addresses).map(address => {\n                // eslint-disable-line prefer-spread\n                if (address && address.address) {\n                    address.address = this._normalizeAddress(address.address);\n                    address.name = address.name || '';\n                    return [address];\n                }\n                return addressparser(address);\n            })\n        );\n    }\n\n    /**\n     * Normalizes a header key, uses Camel-Case form, except for uppercase MIME-\n     *\n     * @param {String} key Key to be normalized\n     * @return {String} key in Camel-Case form\n     */\n    _normalizeHeaderKey(key) {\n        key = (key || '')\n            .toString()\n            // no newlines in keys\n            .replace(/\\r?\\n|\\r/g, ' ')\n            .trim()\n            .toLowerCase()\n            // use uppercase words, except MIME\n            .replace(/^X-SMTPAPI$|^(MIME|DKIM|ARC|BIMI)\\b|^[a-z]|-(SPF|FBL|ID|MD5)$|-[a-z]/gi, c => c.toUpperCase())\n            // special case\n            .replace(/^Content-Features$/i, 'Content-features');\n\n        return key;\n    }\n\n    /**\n     * Checks if the content type is multipart and defines boundary if needed.\n     * Doesn't return anything, modifies object argument instead.\n     *\n     * @param {Object} structured Parsed header value for 'Content-Type' key\n     */\n    _handleContentType(structured) {\n        this.contentType = structured.value.trim().toLowerCase();\n\n        this.multipart = /^multipart\\//i.test(this.contentType) ? this.contentType.substr(this.contentType.indexOf('/') + 1) : false;\n\n        if (this.multipart) {\n            this.boundary = structured.params.boundary = structured.params.boundary || this.boundary || this._generateBoundary();\n        } else {\n            this.boundary = false;\n        }\n    }\n\n    /**\n     * Generates a multipart boundary value\n     *\n     * @return {String} boundary value\n     */\n    _generateBoundary() {\n        return this.rootNode.boundaryPrefix + '-' + this.rootNode.baseBoundary + '-Part_' + this._nodeId;\n    }\n\n    /**\n     * Encodes a header value for use in the generated rfc2822 email.\n     *\n     * @param {String} key Header key\n     * @param {String} value Header value\n     */\n    _encodeHeaderValue(key, value) {\n        key = this._normalizeHeaderKey(key);\n\n        switch (key) {\n            // Structured headers\n            case 'From':\n            case 'Sender':\n            case 'To':\n            case 'Cc':\n            case 'Bcc':\n            case 'Reply-To':\n                return this._convertAddresses(this._parseAddresses(value));\n\n            // values enclosed in <>\n            case 'Message-ID':\n            case 'In-Reply-To':\n            case 'Content-Id':\n                value = (value || '').toString().replace(/\\r?\\n|\\r/g, ' ');\n\n                if (value.charAt(0) !== '<') {\n                    value = '<' + value;\n                }\n\n                if (value.charAt(value.length - 1) !== '>') {\n                    value = value + '>';\n                }\n                return value;\n\n            // space separated list of values enclosed in <>\n            case 'References':\n                value = [].concat\n                    .apply(\n                        [],\n                        [].concat(value || '').map(elm => {\n                            // eslint-disable-line prefer-spread\n                            elm = (elm || '')\n                                .toString()\n                                .replace(/\\r?\\n|\\r/g, ' ')\n                                .trim();\n                            return elm.replace(/<[^>]*>/g, str => str.replace(/\\s/g, '')).split(/\\s+/);\n                        })\n                    )\n                    .map(elm => {\n                        if (elm.charAt(0) !== '<') {\n                            elm = '<' + elm;\n                        }\n                        if (elm.charAt(elm.length - 1) !== '>') {\n                            elm = elm + '>';\n                        }\n                        return elm;\n                    });\n\n                return value.join(' ').trim();\n\n            case 'Date':\n                if (Object.prototype.toString.call(value) === '[object Date]') {\n                    return value.toUTCString().replace(/GMT/, '+0000');\n                }\n\n                value = (value || '').toString().replace(/\\r?\\n|\\r/g, ' ');\n                return this._encodeWords(value);\n\n            case 'Content-Type':\n            case 'Content-Disposition':\n                // if it includes a filename then it is already encoded\n                return (value || '').toString().replace(/\\r?\\n|\\r/g, ' ');\n\n            default:\n                value = (value || '').toString().replace(/\\r?\\n|\\r/g, ' ');\n                // encodeWords only encodes if needed, otherwise the original string is returned\n                return this._encodeWords(value);\n        }\n    }\n\n    /**\n     * Rebuilds address object using punycode and other adjustments\n     *\n     * @param {Array} addresses An array of address objects\n     * @param {Array} [uniqueList] An array to be populated with addresses\n     * @return {String} address string\n     */\n    _convertAddresses(addresses, uniqueList) {\n        let values = [];\n\n        uniqueList = uniqueList || [];\n\n        [].concat(addresses || []).forEach(address => {\n            if (address.address) {\n                address.address = this._normalizeAddress(address.address);\n\n                if (!address.name) {\n                    values.push(address.address.indexOf(' ') >= 0 ? `<${address.address}>` : `${address.address}`);\n                } else if (address.name) {\n                    values.push(`${this._encodeAddressName(address.name)} <${address.address}>`);\n                }\n\n                if (address.address) {\n                    if (!uniqueList.filter(a => a.address === address.address).length) {\n                        uniqueList.push(address);\n                    }\n                }\n            } else if (address.group) {\n                let groupListAddresses = (address.group.length ? this._convertAddresses(address.group, uniqueList) : '').trim();\n                values.push(`${this._encodeAddressName(address.name)}:${groupListAddresses};`);\n            }\n        });\n\n        return values.join(', ');\n    }\n\n    /**\n     * Normalizes an email address\n     *\n     * @param {Array} address An array of address objects\n     * @return {String} address string\n     */\n    _normalizeAddress(address) {\n        address = (address || '')\n            .toString()\n            .replace(/[\\x00-\\x1F<>]+/g, ' ') // remove unallowed characters\n            .trim();\n\n        let lastAt = address.lastIndexOf('@');\n        if (lastAt < 0) {\n            // Bare username\n            return address;\n        }\n\n        let user = address.substr(0, lastAt);\n        let domain = address.substr(lastAt + 1);\n\n        // Usernames are not touched and are kept as is even if these include unicode\n        // Domains are punycoded by default\n        // 'jõgeva.ee' will be converted to 'xn--jgeva-dua.ee'\n        // non-unicode domains are left as is\n\n        let encodedDomain;\n\n        try {\n            encodedDomain = punycode.toASCII(domain.toLowerCase());\n        } catch (err) {\n            // keep as is?\n        }\n\n        if (user.indexOf(' ') >= 0) {\n            if (user.charAt(0) !== '\"') {\n                user = '\"' + user;\n            }\n            if (user.substr(-1) !== '\"') {\n                user = user + '\"';\n            }\n        }\n\n        return `${user}@${encodedDomain}`;\n    }\n\n    /**\n     * If needed, mime encodes the name part\n     *\n     * @param {String} name Name part of an address\n     * @returns {String} Mime word encoded string if needed\n     */\n    _encodeAddressName(name) {\n        if (!/^[\\w ]*$/.test(name)) {\n            if (/^[\\x20-\\x7e]*$/.test(name)) {\n                return '\"' + name.replace(/([\\\\\"])/g, '\\\\$1') + '\"';\n            } else {\n                return mimeFuncs.encodeWord(name, this._getTextEncoding(name), 52);\n            }\n        }\n        return name;\n    }\n\n    /**\n     * If needed, mime encodes the name part\n     *\n     * @param {String} name Name part of an address\n     * @returns {String} Mime word encoded string if needed\n     */\n    _encodeWords(value) {\n        // set encodeAll parameter to true even though it is against the recommendation of RFC2047,\n        // by default only words that include non-ascii should be converted into encoded words\n        // but some clients (eg. Zimbra) do not handle it properly and remove surrounding whitespace\n        return mimeFuncs.encodeWords(value, this._getTextEncoding(value), 52, true);\n    }\n\n    /**\n     * Detects best mime encoding for a text value\n     *\n     * @param {String} value Value to check for\n     * @return {String} either 'Q' or 'B'\n     */\n    _getTextEncoding(value) {\n        value = (value || '').toString();\n\n        let encoding = this.textEncoding;\n        let latinLen;\n        let nonLatinLen;\n\n        if (!encoding) {\n            // count latin alphabet symbols and 8-bit range symbols + control symbols\n            // if there are more latin characters, then use quoted-printable\n            // encoding, otherwise use base64\n            nonLatinLen = (value.match(/[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F\\u0080-\\uFFFF]/g) || []).length; // eslint-disable-line no-control-regex\n            latinLen = (value.match(/[a-z]/gi) || []).length;\n            // if there are more latin symbols than binary/unicode, then prefer Q, otherwise B\n            encoding = nonLatinLen < latinLen ? 'Q' : 'B';\n        }\n        return encoding;\n    }\n\n    /**\n     * Generates a message id\n     *\n     * @return {String} Random Message-ID value\n     */\n    _generateMessageId() {\n        return (\n            '<' +\n            [2, 2, 2, 6].reduce(\n                // crux to generate UUID-like random strings\n                (prev, len) => prev + '-' + crypto.randomBytes(len).toString('hex'),\n                crypto.randomBytes(4).toString('hex')\n            ) +\n            '@' +\n            // try to use the domain of the FROM address or fallback to server hostname\n            (this.getEnvelope().from || this.hostname || 'localhost').split('@').pop() +\n            '>'\n        );\n    }\n}\n\nmodule.exports = MimeNode;\n","'use strict';\n\nconst Transform = require('stream').Transform;\n\nclass LastNewline extends Transform {\n    constructor() {\n        super();\n        this.lastByte = false;\n    }\n\n    _transform(chunk, encoding, done) {\n        if (chunk.length) {\n            this.lastByte = chunk[chunk.length - 1];\n        }\n\n        this.push(chunk);\n        done();\n    }\n\n    _flush(done) {\n        if (this.lastByte === 0x0a) {\n            return done();\n        }\n        if (this.lastByte === 0x0d) {\n            this.push(Buffer.from('\\n'));\n            return done();\n        }\n        this.push(Buffer.from('\\r\\n'));\n        return done();\n    }\n}\n\nmodule.exports = LastNewline;\n","'use strict';\n\nconst stream = require('stream');\nconst Transform = stream.Transform;\n\n/**\n * Ensures that only <LF> is used for linebreaks\n *\n * @param {Object} options Stream options\n */\nclass LeWindows extends Transform {\n    constructor(options) {\n        super(options);\n        // init Transform\n        this.options = options || {};\n    }\n\n    /**\n     * Escapes dots\n     */\n    _transform(chunk, encoding, done) {\n        let buf;\n        let lastPos = 0;\n\n        for (let i = 0, len = chunk.length; i < len; i++) {\n            if (chunk[i] === 0x0d) {\n                // \\n\n                buf = chunk.slice(lastPos, i);\n                lastPos = i + 1;\n                this.push(buf);\n            }\n        }\n        if (lastPos && lastPos < chunk.length) {\n            buf = chunk.slice(lastPos);\n            this.push(buf);\n        } else if (!lastPos) {\n            this.push(chunk);\n        }\n        done();\n    }\n}\n\nmodule.exports = LeWindows;\n","'use strict';\n\nconst punycode = require('../punycode');\nconst mimeFuncs = require('../mime-funcs');\nconst crypto = require('crypto');\n\n/**\n * Returns DKIM signature header line\n *\n * @param {Object} headers Parsed headers object from MessageParser\n * @param {String} bodyHash Base64 encoded hash of the message\n * @param {Object} options DKIM options\n * @param {String} options.domainName Domain name to be signed for\n * @param {String} options.keySelector DKIM key selector to use\n * @param {String} options.privateKey DKIM private key to use\n * @return {String} Complete header line\n */\n\nmodule.exports = (headers, hashAlgo, bodyHash, options) => {\n    options = options || {};\n\n    // all listed fields from RFC4871 #5.5\n    let defaultFieldNames =\n        'From:Sender:Reply-To:Subject:Date:Message-ID:To:' +\n        'Cc:MIME-Version:Content-Type:Content-Transfer-Encoding:Content-ID:' +\n        'Content-Description:Resent-Date:Resent-From:Resent-Sender:' +\n        'Resent-To:Resent-Cc:Resent-Message-ID:In-Reply-To:References:' +\n        'List-Id:List-Help:List-Unsubscribe:List-Subscribe:List-Post:' +\n        'List-Owner:List-Archive';\n\n    let fieldNames = options.headerFieldNames || defaultFieldNames;\n\n    let canonicalizedHeaderData = relaxedHeaders(headers, fieldNames, options.skipFields);\n    let dkimHeader = generateDKIMHeader(options.domainName, options.keySelector, canonicalizedHeaderData.fieldNames, hashAlgo, bodyHash);\n\n    let signer, signature;\n\n    canonicalizedHeaderData.headers += 'dkim-signature:' + relaxedHeaderLine(dkimHeader);\n\n    signer = crypto.createSign(('rsa-' + hashAlgo).toUpperCase());\n    signer.update(canonicalizedHeaderData.headers);\n    try {\n        signature = signer.sign(options.privateKey, 'base64');\n    } catch (E) {\n        return false;\n    }\n\n    return dkimHeader + signature.replace(/(^.{73}|.{75}(?!\\r?\\n|\\r))/g, '$&\\r\\n ').trim();\n};\n\nmodule.exports.relaxedHeaders = relaxedHeaders;\n\nfunction generateDKIMHeader(domainName, keySelector, fieldNames, hashAlgo, bodyHash) {\n    let dkim = [\n        'v=1',\n        'a=rsa-' + hashAlgo,\n        'c=relaxed/relaxed',\n        'd=' + punycode.toASCII(domainName),\n        'q=dns/txt',\n        's=' + keySelector,\n        'bh=' + bodyHash,\n        'h=' + fieldNames\n    ].join('; ');\n\n    return mimeFuncs.foldLines('DKIM-Signature: ' + dkim, 76) + ';\\r\\n b=';\n}\n\nfunction relaxedHeaders(headers, fieldNames, skipFields) {\n    let includedFields = new Set();\n    let skip = new Set();\n    let headerFields = new Map();\n\n    (skipFields || '')\n        .toLowerCase()\n        .split(':')\n        .forEach(field => {\n            skip.add(field.trim());\n        });\n\n    (fieldNames || '')\n        .toLowerCase()\n        .split(':')\n        .filter(field => !skip.has(field.trim()))\n        .forEach(field => {\n            includedFields.add(field.trim());\n        });\n\n    for (let i = headers.length - 1; i >= 0; i--) {\n        let line = headers[i];\n        // only include the first value from bottom to top\n        if (includedFields.has(line.key) && !headerFields.has(line.key)) {\n            headerFields.set(line.key, relaxedHeaderLine(line.line));\n        }\n    }\n\n    let headersList = [];\n    let fields = [];\n    includedFields.forEach(field => {\n        if (headerFields.has(field)) {\n            fields.push(field);\n            headersList.push(field + ':' + headerFields.get(field));\n        }\n    });\n\n    return {\n        headers: headersList.join('\\r\\n') + '\\r\\n',\n        fieldNames: fields.join(':')\n    };\n}\n\nfunction relaxedHeaderLine(line) {\n    return line\n        .substr(line.indexOf(':') + 1)\n        .replace(/\\r?\\n/g, '')\n        .replace(/\\s+/g, ' ')\n        .trim();\n}\n","'use strict';\n\n// FIXME:\n// replace this Transform mess with a method that pipes input argument to output argument\n\nconst MessageParser = require('./message-parser');\nconst RelaxedBody = require('./relaxed-body');\nconst sign = require('./sign');\nconst PassThrough = require('stream').PassThrough;\nconst fs = require('fs');\nconst path = require('path');\nconst crypto = require('crypto');\n\nconst DKIM_ALGO = 'sha256';\nconst MAX_MESSAGE_SIZE = 128 * 1024; // buffer messages larger than this to disk\n\n/*\n// Usage:\n\nlet dkim = new DKIM({\n    domainName: 'example.com',\n    keySelector: 'key-selector',\n    privateKey,\n    cacheDir: '/tmp'\n});\ndkim.sign(input).pipe(process.stdout);\n\n// Where inputStream is a rfc822 message (either a stream, string or Buffer)\n// and outputStream is a DKIM signed rfc822 message\n*/\n\nclass DKIMSigner {\n    constructor(options, keys, input, output) {\n        this.options = options || {};\n        this.keys = keys;\n\n        this.cacheTreshold = Number(this.options.cacheTreshold) || MAX_MESSAGE_SIZE;\n        this.hashAlgo = this.options.hashAlgo || DKIM_ALGO;\n\n        this.cacheDir = this.options.cacheDir || false;\n\n        this.chunks = [];\n        this.chunklen = 0;\n        this.readPos = 0;\n        this.cachePath = this.cacheDir ? path.join(this.cacheDir, 'message.' + Date.now() + '-' + crypto.randomBytes(14).toString('hex')) : false;\n        this.cache = false;\n\n        this.headers = false;\n        this.bodyHash = false;\n        this.parser = false;\n        this.relaxedBody = false;\n\n        this.input = input;\n        this.output = output;\n        this.output.usingCache = false;\n\n        this.hasErrored = false;\n\n        this.input.on('error', err => {\n            this.hasErrored = true;\n            this.cleanup();\n            output.emit('error', err);\n        });\n    }\n\n    cleanup() {\n        if (!this.cache || !this.cachePath) {\n            return;\n        }\n        fs.unlink(this.cachePath, () => false);\n    }\n\n    createReadCache() {\n        // pipe remainings to cache file\n        this.cache = fs.createReadStream(this.cachePath);\n        this.cache.once('error', err => {\n            this.cleanup();\n            this.output.emit('error', err);\n        });\n        this.cache.once('close', () => {\n            this.cleanup();\n        });\n        this.cache.pipe(this.output);\n    }\n\n    sendNextChunk() {\n        if (this.hasErrored) {\n            return;\n        }\n\n        if (this.readPos >= this.chunks.length) {\n            if (!this.cache) {\n                return this.output.end();\n            }\n            return this.createReadCache();\n        }\n        let chunk = this.chunks[this.readPos++];\n        if (this.output.write(chunk) === false) {\n            return this.output.once('drain', () => {\n                this.sendNextChunk();\n            });\n        }\n        setImmediate(() => this.sendNextChunk());\n    }\n\n    sendSignedOutput() {\n        let keyPos = 0;\n        let signNextKey = () => {\n            if (keyPos >= this.keys.length) {\n                this.output.write(this.parser.rawHeaders);\n                return setImmediate(() => this.sendNextChunk());\n            }\n            let key = this.keys[keyPos++];\n            let dkimField = sign(this.headers, this.hashAlgo, this.bodyHash, {\n                domainName: key.domainName,\n                keySelector: key.keySelector,\n                privateKey: key.privateKey,\n                headerFieldNames: this.options.headerFieldNames,\n                skipFields: this.options.skipFields\n            });\n            if (dkimField) {\n                this.output.write(Buffer.from(dkimField + '\\r\\n'));\n            }\n            return setImmediate(signNextKey);\n        };\n\n        if (this.bodyHash && this.headers) {\n            return signNextKey();\n        }\n\n        this.output.write(this.parser.rawHeaders);\n        this.sendNextChunk();\n    }\n\n    createWriteCache() {\n        this.output.usingCache = true;\n        // pipe remainings to cache file\n        this.cache = fs.createWriteStream(this.cachePath);\n        this.cache.once('error', err => {\n            this.cleanup();\n            // drain input\n            this.relaxedBody.unpipe(this.cache);\n            this.relaxedBody.on('readable', () => {\n                while (this.relaxedBody.read() !== null) {\n                    // do nothing\n                }\n            });\n            this.hasErrored = true;\n            // emit error\n            this.output.emit('error', err);\n        });\n        this.cache.once('close', () => {\n            this.sendSignedOutput();\n        });\n        this.relaxedBody.removeAllListeners('readable');\n        this.relaxedBody.pipe(this.cache);\n    }\n\n    signStream() {\n        this.parser = new MessageParser();\n        this.relaxedBody = new RelaxedBody({\n            hashAlgo: this.hashAlgo\n        });\n\n        this.parser.on('headers', value => {\n            this.headers = value;\n        });\n\n        this.relaxedBody.on('hash', value => {\n            this.bodyHash = value;\n        });\n\n        this.relaxedBody.on('readable', () => {\n            let chunk;\n            if (this.cache) {\n                return;\n            }\n            while ((chunk = this.relaxedBody.read()) !== null) {\n                this.chunks.push(chunk);\n                this.chunklen += chunk.length;\n                if (this.chunklen >= this.cacheTreshold && this.cachePath) {\n                    return this.createWriteCache();\n                }\n            }\n        });\n\n        this.relaxedBody.on('end', () => {\n            if (this.cache) {\n                return;\n            }\n            this.sendSignedOutput();\n        });\n\n        this.parser.pipe(this.relaxedBody);\n        setImmediate(() => this.input.pipe(this.parser));\n    }\n}\n\nclass DKIM {\n    constructor(options) {\n        this.options = options || {};\n        this.keys = [].concat(\n            this.options.keys || {\n                domainName: options.domainName,\n                keySelector: options.keySelector,\n                privateKey: options.privateKey\n            }\n        );\n    }\n\n    sign(input, extraOptions) {\n        let output = new PassThrough();\n        let inputStream = input;\n        let writeValue = false;\n\n        if (Buffer.isBuffer(input)) {\n            writeValue = input;\n            inputStream = new PassThrough();\n        } else if (typeof input === 'string') {\n            writeValue = Buffer.from(input);\n            inputStream = new PassThrough();\n        }\n\n        let options = this.options;\n        if (extraOptions && Object.keys(extraOptions).length) {\n            options = {};\n            Object.keys(this.options || {}).forEach(key => {\n                options[key] = this.options[key];\n            });\n            Object.keys(extraOptions || {}).forEach(key => {\n                if (!(key in options)) {\n                    options[key] = extraOptions[key];\n                }\n            });\n        }\n\n        let signer = new DKIMSigner(options, this.keys, inputStream, output);\n        setImmediate(() => {\n            signer.signStream();\n            if (writeValue) {\n                setImmediate(() => {\n                    inputStream.end(writeValue);\n                });\n            }\n        });\n\n        return output;\n    }\n}\n\nmodule.exports = DKIM;\n","'use strict';\n\nconst Transform = require('stream').Transform;\n\n/**\n * MessageParser instance is a transform stream that separates message headers\n * from the rest of the body. Headers are emitted with the 'headers' event. Message\n * body is passed on as the resulting stream.\n */\nclass MessageParser extends Transform {\n    constructor(options) {\n        super(options);\n        this.lastBytes = Buffer.alloc(4);\n        this.headersParsed = false;\n        this.headerBytes = 0;\n        this.headerChunks = [];\n        this.rawHeaders = false;\n        this.bodySize = 0;\n    }\n\n    /**\n     * Keeps count of the last 4 bytes in order to detect line breaks on chunk boundaries\n     *\n     * @param {Buffer} data Next data chunk from the stream\n     */\n    updateLastBytes(data) {\n        let lblen = this.lastBytes.length;\n        let nblen = Math.min(data.length, lblen);\n\n        // shift existing bytes\n        for (let i = 0, len = lblen - nblen; i < len; i++) {\n            this.lastBytes[i] = this.lastBytes[i + nblen];\n        }\n\n        // add new bytes\n        for (let i = 1; i <= nblen; i++) {\n            this.lastBytes[lblen - i] = data[data.length - i];\n        }\n    }\n\n    /**\n     * Finds and removes message headers from the remaining body. We want to keep\n     * headers separated until final delivery to be able to modify these\n     *\n     * @param {Buffer} data Next chunk of data\n     * @return {Boolean} Returns true if headers are already found or false otherwise\n     */\n    checkHeaders(data) {\n        if (this.headersParsed) {\n            return true;\n        }\n\n        let lblen = this.lastBytes.length;\n        let headerPos = 0;\n        this.curLinePos = 0;\n        for (let i = 0, len = this.lastBytes.length + data.length; i < len; i++) {\n            let chr;\n            if (i < lblen) {\n                chr = this.lastBytes[i];\n            } else {\n                chr = data[i - lblen];\n            }\n            if (chr === 0x0a && i) {\n                let pr1 = i - 1 < lblen ? this.lastBytes[i - 1] : data[i - 1 - lblen];\n                let pr2 = i > 1 ? (i - 2 < lblen ? this.lastBytes[i - 2] : data[i - 2 - lblen]) : false;\n                if (pr1 === 0x0a) {\n                    this.headersParsed = true;\n                    headerPos = i - lblen + 1;\n                    this.headerBytes += headerPos;\n                    break;\n                } else if (pr1 === 0x0d && pr2 === 0x0a) {\n                    this.headersParsed = true;\n                    headerPos = i - lblen + 1;\n                    this.headerBytes += headerPos;\n                    break;\n                }\n            }\n        }\n\n        if (this.headersParsed) {\n            this.headerChunks.push(data.slice(0, headerPos));\n            this.rawHeaders = Buffer.concat(this.headerChunks, this.headerBytes);\n            this.headerChunks = null;\n            this.emit('headers', this.parseHeaders());\n            if (data.length - 1 > headerPos) {\n                let chunk = data.slice(headerPos);\n                this.bodySize += chunk.length;\n                // this would be the first chunk of data sent downstream\n                setImmediate(() => this.push(chunk));\n            }\n            return false;\n        } else {\n            this.headerBytes += data.length;\n            this.headerChunks.push(data);\n        }\n\n        // store last 4 bytes to catch header break\n        this.updateLastBytes(data);\n\n        return false;\n    }\n\n    _transform(chunk, encoding, callback) {\n        if (!chunk || !chunk.length) {\n            return callback();\n        }\n\n        if (typeof chunk === 'string') {\n            chunk = Buffer.from(chunk, encoding);\n        }\n\n        let headersFound;\n\n        try {\n            headersFound = this.checkHeaders(chunk);\n        } catch (E) {\n            return callback(E);\n        }\n\n        if (headersFound) {\n            this.bodySize += chunk.length;\n            this.push(chunk);\n        }\n\n        setImmediate(callback);\n    }\n\n    _flush(callback) {\n        if (this.headerChunks) {\n            let chunk = Buffer.concat(this.headerChunks, this.headerBytes);\n            this.bodySize += chunk.length;\n            this.push(chunk);\n            this.headerChunks = null;\n        }\n        callback();\n    }\n\n    parseHeaders() {\n        let lines = (this.rawHeaders || '').toString().split(/\\r?\\n/);\n        for (let i = lines.length - 1; i > 0; i--) {\n            if (/^\\s/.test(lines[i])) {\n                lines[i - 1] += '\\n' + lines[i];\n                lines.splice(i, 1);\n            }\n        }\n        return lines\n            .filter(line => line.trim())\n            .map(line => ({\n                key: line.substr(0, line.indexOf(':')).trim().toLowerCase(),\n                line\n            }));\n    }\n}\n\nmodule.exports = MessageParser;\n","'use strict';\n\n// streams through a message body and calculates relaxed body hash\n\nconst Transform = require('stream').Transform;\nconst crypto = require('crypto');\n\nclass RelaxedBody extends Transform {\n    constructor(options) {\n        super();\n        options = options || {};\n        this.chunkBuffer = [];\n        this.chunkBufferLen = 0;\n        this.bodyHash = crypto.createHash(options.hashAlgo || 'sha1');\n        this.remainder = '';\n        this.byteLength = 0;\n\n        this.debug = options.debug;\n        this._debugBody = options.debug ? [] : false;\n    }\n\n    updateHash(chunk) {\n        let bodyStr;\n\n        // find next remainder\n        let nextRemainder = '';\n\n        // This crux finds and removes the spaces from the last line and the newline characters after the last non-empty line\n        // If we get another chunk that does not match this description then we can restore the previously processed data\n        let state = 'file';\n        for (let i = chunk.length - 1; i >= 0; i--) {\n            let c = chunk[i];\n\n            if (state === 'file' && (c === 0x0a || c === 0x0d)) {\n                // do nothing, found \\n or \\r at the end of chunk, stil end of file\n            } else if (state === 'file' && (c === 0x09 || c === 0x20)) {\n                // switch to line ending mode, this is the last non-empty line\n                state = 'line';\n            } else if (state === 'line' && (c === 0x09 || c === 0x20)) {\n                // do nothing, found ' ' or \\t at the end of line, keep processing the last non-empty line\n            } else if (state === 'file' || state === 'line') {\n                // non line/file ending character found, switch to body mode\n                state = 'body';\n                if (i === chunk.length - 1) {\n                    // final char is not part of line end or file end, so do nothing\n                    break;\n                }\n            }\n\n            if (i === 0) {\n                // reached to the beginning of the chunk, check if it is still about the ending\n                // and if the remainder also matches\n                if (\n                    (state === 'file' && (!this.remainder || /[\\r\\n]$/.test(this.remainder))) ||\n                    (state === 'line' && (!this.remainder || /[ \\t]$/.test(this.remainder)))\n                ) {\n                    // keep everything\n                    this.remainder += chunk.toString('binary');\n                    return;\n                } else if (state === 'line' || state === 'file') {\n                    // process existing remainder as normal line but store the current chunk\n                    nextRemainder = chunk.toString('binary');\n                    chunk = false;\n                    break;\n                }\n            }\n\n            if (state !== 'body') {\n                continue;\n            }\n\n            // reached first non ending byte\n            nextRemainder = chunk.slice(i + 1).toString('binary');\n            chunk = chunk.slice(0, i + 1);\n            break;\n        }\n\n        let needsFixing = !!this.remainder;\n        if (chunk && !needsFixing) {\n            // check if we even need to change anything\n            for (let i = 0, len = chunk.length; i < len; i++) {\n                if (i && chunk[i] === 0x0a && chunk[i - 1] !== 0x0d) {\n                    // missing \\r before \\n\n                    needsFixing = true;\n                    break;\n                } else if (i && chunk[i] === 0x0d && chunk[i - 1] === 0x20) {\n                    // trailing WSP found\n                    needsFixing = true;\n                    break;\n                } else if (i && chunk[i] === 0x20 && chunk[i - 1] === 0x20) {\n                    // multiple spaces found, needs to be replaced with just one\n                    needsFixing = true;\n                    break;\n                } else if (chunk[i] === 0x09) {\n                    // TAB found, needs to be replaced with a space\n                    needsFixing = true;\n                    break;\n                }\n            }\n        }\n\n        if (needsFixing) {\n            bodyStr = this.remainder + (chunk ? chunk.toString('binary') : '');\n            this.remainder = nextRemainder;\n            bodyStr = bodyStr\n                .replace(/\\r?\\n/g, '\\n') // use js line endings\n                .replace(/[ \\t]*$/gm, '') // remove line endings, rtrim\n                .replace(/[ \\t]+/gm, ' ') // single spaces\n                .replace(/\\n/g, '\\r\\n'); // restore rfc822 line endings\n            chunk = Buffer.from(bodyStr, 'binary');\n        } else if (nextRemainder) {\n            this.remainder = nextRemainder;\n        }\n\n        if (this.debug) {\n            this._debugBody.push(chunk);\n        }\n        this.bodyHash.update(chunk);\n    }\n\n    _transform(chunk, encoding, callback) {\n        if (!chunk || !chunk.length) {\n            return callback();\n        }\n\n        if (typeof chunk === 'string') {\n            chunk = Buffer.from(chunk, encoding);\n        }\n\n        this.updateHash(chunk);\n\n        this.byteLength += chunk.length;\n        this.push(chunk);\n        callback();\n    }\n\n    _flush(callback) {\n        // generate final hash and emit it\n        if (/[\\r\\n]$/.test(this.remainder) && this.byteLength > 2) {\n            // add terminating line end\n            this.bodyHash.update(Buffer.from('\\r\\n'));\n        }\n        if (!this.byteLength) {\n            // emit empty line buffer to keep the stream flowing\n            this.push(Buffer.from('\\r\\n'));\n            // this.bodyHash.update(Buffer.from('\\r\\n'));\n        }\n\n        this.emit('hash', this.bodyHash.digest('base64'), this.debug ? Buffer.concat(this._debugBody) : false);\n        callback();\n    }\n}\n\nmodule.exports = RelaxedBody;\n","'use strict';\n\nconst EventEmitter = require('events');\nconst shared = require('../shared');\nconst mimeTypes = require('../mime-funcs/mime-types');\nconst MailComposer = require('../mail-composer');\nconst DKIM = require('../dkim');\nconst httpProxyClient = require('../smtp-connection/http-proxy-client');\nconst util = require('util');\nconst urllib = require('url');\nconst packageData = require('../../package.json');\nconst MailMessage = require('./mail-message');\nconst net = require('net');\nconst dns = require('dns');\nconst crypto = require('crypto');\n\n/**\n * Creates an object for exposing the Mail API\n *\n * @constructor\n * @param {Object} transporter Transport object instance to pass the mails to\n */\nclass Mail extends EventEmitter {\n    constructor(transporter, options, defaults) {\n        super();\n\n        this.options = options || {};\n        this._defaults = defaults || {};\n\n        this._defaultPlugins = {\n            compile: [(...args) => this._convertDataImages(...args)],\n            stream: []\n        };\n\n        this._userPlugins = {\n            compile: [],\n            stream: []\n        };\n\n        this.meta = new Map();\n\n        this.dkim = this.options.dkim ? new DKIM(this.options.dkim) : false;\n\n        this.transporter = transporter;\n        this.transporter.mailer = this;\n\n        this.logger = shared.getLogger(this.options, {\n            component: this.options.component || 'mail'\n        });\n\n        this.logger.debug(\n            {\n                tnx: 'create'\n            },\n            'Creating transport: %s',\n            this.getVersionString()\n        );\n\n        // setup emit handlers for the transporter\n        if (typeof this.transporter.on === 'function') {\n            // deprecated log interface\n            this.transporter.on('log', log => {\n                this.logger.debug(\n                    {\n                        tnx: 'transport'\n                    },\n                    '%s: %s',\n                    log.type,\n                    log.message\n                );\n            });\n\n            // transporter errors\n            this.transporter.on('error', err => {\n                this.logger.error(\n                    {\n                        err,\n                        tnx: 'transport'\n                    },\n                    'Transport Error: %s',\n                    err.message\n                );\n                this.emit('error', err);\n            });\n\n            // indicates if the sender has became idle\n            this.transporter.on('idle', (...args) => {\n                this.emit('idle', ...args);\n            });\n        }\n\n        /**\n         * Optional methods passed to the underlying transport object\n         */\n        ['close', 'isIdle', 'verify'].forEach(method => {\n            this[method] = (...args) => {\n                if (typeof this.transporter[method] === 'function') {\n                    if (method === 'verify' && typeof this.getSocket === 'function') {\n                        this.transporter.getSocket = this.getSocket;\n                        this.getSocket = false;\n                    }\n                    return this.transporter[method](...args);\n                } else {\n                    this.logger.warn(\n                        {\n                            tnx: 'transport',\n                            methodName: method\n                        },\n                        'Non existing method %s called for transport',\n                        method\n                    );\n                    return false;\n                }\n            };\n        });\n\n        // setup proxy handling\n        if (this.options.proxy && typeof this.options.proxy === 'string') {\n            this.setupProxy(this.options.proxy);\n        }\n    }\n\n    use(step, plugin) {\n        step = (step || '').toString();\n        if (!this._userPlugins.hasOwnProperty(step)) {\n            this._userPlugins[step] = [plugin];\n        } else {\n            this._userPlugins[step].push(plugin);\n        }\n\n        return this;\n    }\n\n    /**\n     * Sends an email using the preselected transport object\n     *\n     * @param {Object} data E-data description\n     * @param {Function?} callback Callback to run once the sending succeeded or failed\n     */\n    sendMail(data, callback = null) {\n        let promise;\n\n        if (!callback) {\n            promise = new Promise((resolve, reject) => {\n                callback = shared.callbackPromise(resolve, reject);\n            });\n        }\n\n        if (typeof this.getSocket === 'function') {\n            this.transporter.getSocket = this.getSocket;\n            this.getSocket = false;\n        }\n\n        let mail = new MailMessage(this, data);\n\n        this.logger.debug(\n            {\n                tnx: 'transport',\n                name: this.transporter.name,\n                version: this.transporter.version,\n                action: 'send'\n            },\n            'Sending mail using %s/%s',\n            this.transporter.name,\n            this.transporter.version\n        );\n\n        this._processPlugins('compile', mail, err => {\n            if (err) {\n                this.logger.error(\n                    {\n                        err,\n                        tnx: 'plugin',\n                        action: 'compile'\n                    },\n                    'PluginCompile Error: %s',\n                    err.message\n                );\n                return callback(err);\n            }\n\n            mail.message = new MailComposer(mail.data).compile();\n\n            mail.setMailerHeader();\n            mail.setPriorityHeaders();\n            mail.setListHeaders();\n\n            this._processPlugins('stream', mail, err => {\n                if (err) {\n                    this.logger.error(\n                        {\n                            err,\n                            tnx: 'plugin',\n                            action: 'stream'\n                        },\n                        'PluginStream Error: %s',\n                        err.message\n                    );\n                    return callback(err);\n                }\n\n                if (mail.data.dkim || this.dkim) {\n                    mail.message.processFunc(input => {\n                        let dkim = mail.data.dkim ? new DKIM(mail.data.dkim) : this.dkim;\n                        this.logger.debug(\n                            {\n                                tnx: 'DKIM',\n                                messageId: mail.message.messageId(),\n                                dkimDomains: dkim.keys.map(key => key.keySelector + '.' + key.domainName).join(', ')\n                            },\n                            'Signing outgoing message with %s keys',\n                            dkim.keys.length\n                        );\n                        return dkim.sign(input, mail.data._dkim);\n                    });\n                }\n\n                this.transporter.send(mail, (...args) => {\n                    if (args[0]) {\n                        this.logger.error(\n                            {\n                                err: args[0],\n                                tnx: 'transport',\n                                action: 'send'\n                            },\n                            'Send Error: %s',\n                            args[0].message\n                        );\n                    }\n                    callback(...args);\n                });\n            });\n        });\n\n        return promise;\n    }\n\n    getVersionString() {\n        return util.format('%s (%s; +%s; %s/%s)', packageData.name, packageData.version, packageData.homepage, this.transporter.name, this.transporter.version);\n    }\n\n    _processPlugins(step, mail, callback) {\n        step = (step || '').toString();\n\n        if (!this._userPlugins.hasOwnProperty(step)) {\n            return callback();\n        }\n\n        let userPlugins = this._userPlugins[step] || [];\n        let defaultPlugins = this._defaultPlugins[step] || [];\n\n        if (userPlugins.length) {\n            this.logger.debug(\n                {\n                    tnx: 'transaction',\n                    pluginCount: userPlugins.length,\n                    step\n                },\n                'Using %s plugins for %s',\n                userPlugins.length,\n                step\n            );\n        }\n\n        if (userPlugins.length + defaultPlugins.length === 0) {\n            return callback();\n        }\n\n        let pos = 0;\n        let block = 'default';\n        let processPlugins = () => {\n            let curplugins = block === 'default' ? defaultPlugins : userPlugins;\n            if (pos >= curplugins.length) {\n                if (block === 'default' && userPlugins.length) {\n                    block = 'user';\n                    pos = 0;\n                    curplugins = userPlugins;\n                } else {\n                    return callback();\n                }\n            }\n            let plugin = curplugins[pos++];\n            plugin(mail, err => {\n                if (err) {\n                    return callback(err);\n                }\n                processPlugins();\n            });\n        };\n\n        processPlugins();\n    }\n\n    /**\n     * Sets up proxy handler for a Nodemailer object\n     *\n     * @param {String} proxyUrl Proxy configuration url\n     */\n    setupProxy(proxyUrl) {\n        let proxy = urllib.parse(proxyUrl);\n\n        // setup socket handler for the mailer object\n        this.getSocket = (options, callback) => {\n            let protocol = proxy.protocol.replace(/:$/, '').toLowerCase();\n\n            if (this.meta.has('proxy_handler_' + protocol)) {\n                return this.meta.get('proxy_handler_' + protocol)(proxy, options, callback);\n            }\n\n            switch (protocol) {\n                // Connect using a HTTP CONNECT method\n                case 'http':\n                case 'https':\n                    httpProxyClient(proxy.href, options.port, options.host, (err, socket) => {\n                        if (err) {\n                            return callback(err);\n                        }\n                        return callback(null, {\n                            connection: socket\n                        });\n                    });\n                    return;\n                case 'socks':\n                case 'socks5':\n                case 'socks4':\n                case 'socks4a': {\n                    if (!this.meta.has('proxy_socks_module')) {\n                        return callback(new Error('Socks module not loaded'));\n                    }\n                    let connect = ipaddress => {\n                        let proxyV2 = !!this.meta.get('proxy_socks_module').SocksClient;\n                        let socksClient = proxyV2 ? this.meta.get('proxy_socks_module').SocksClient : this.meta.get('proxy_socks_module');\n                        let proxyType = Number(proxy.protocol.replace(/\\D/g, '')) || 5;\n                        let connectionOpts = {\n                            proxy: {\n                                ipaddress,\n                                port: Number(proxy.port),\n                                type: proxyType\n                            },\n                            [proxyV2 ? 'destination' : 'target']: {\n                                host: options.host,\n                                port: options.port\n                            },\n                            command: 'connect'\n                        };\n\n                        if (proxy.auth) {\n                            let username = decodeURIComponent(proxy.auth.split(':').shift());\n                            let password = decodeURIComponent(proxy.auth.split(':').pop());\n                            if (proxyV2) {\n                                connectionOpts.proxy.userId = username;\n                                connectionOpts.proxy.password = password;\n                            } else if (proxyType === 4) {\n                                connectionOpts.userid = username;\n                            } else {\n                                connectionOpts.authentication = {\n                                    username,\n                                    password\n                                };\n                            }\n                        }\n\n                        socksClient.createConnection(connectionOpts, (err, info) => {\n                            if (err) {\n                                return callback(err);\n                            }\n                            return callback(null, {\n                                connection: info.socket || info\n                            });\n                        });\n                    };\n\n                    if (net.isIP(proxy.hostname)) {\n                        return connect(proxy.hostname);\n                    }\n\n                    return dns.resolve(proxy.hostname, (err, address) => {\n                        if (err) {\n                            return callback(err);\n                        }\n                        connect(Array.isArray(address) ? address[0] : address);\n                    });\n                }\n            }\n            callback(new Error('Unknown proxy configuration'));\n        };\n    }\n\n    _convertDataImages(mail, callback) {\n        if ((!this.options.attachDataUrls && !mail.data.attachDataUrls) || !mail.data.html) {\n            return callback();\n        }\n        mail.resolveContent(mail.data, 'html', (err, html) => {\n            if (err) {\n                return callback(err);\n            }\n            let cidCounter = 0;\n            html = (html || '')\n                .toString()\n                .replace(/(<img\\b[^<>]{0,1024} src\\s{0,20}=[\\s\"']{0,20})(data:([^;]+);[^\"'>\\s]+)/gi, (match, prefix, dataUri, mimeType) => {\n                    let cid = crypto.randomBytes(10).toString('hex') + '@localhost';\n                    if (!mail.data.attachments) {\n                        mail.data.attachments = [];\n                    }\n                    if (!Array.isArray(mail.data.attachments)) {\n                        mail.data.attachments = [].concat(mail.data.attachments || []);\n                    }\n                    mail.data.attachments.push({\n                        path: dataUri,\n                        cid,\n                        filename: 'image-' + ++cidCounter + '.' + mimeTypes.detectExtension(mimeType)\n                    });\n                    return prefix + 'cid:' + cid;\n                });\n            mail.data.html = html;\n            callback();\n        });\n    }\n\n    set(key, value) {\n        return this.meta.set(key, value);\n    }\n\n    get(key) {\n        return this.meta.get(key);\n    }\n}\n\nmodule.exports = Mail;\n","/* eslint no-undefined: 0 */\n\n'use strict';\n\nconst MimeNode = require('../mime-node');\nconst mimeFuncs = require('../mime-funcs');\nconst parseDataURI = require('../shared').parseDataURI;\n\n/**\n * Creates the object for composing a MimeNode instance out from the mail options\n *\n * @constructor\n * @param {Object} mail Mail options\n */\nclass MailComposer {\n    constructor(mail) {\n        this.mail = mail || {};\n        this.message = false;\n    }\n\n    /**\n     * Builds MimeNode instance\n     */\n    compile() {\n        this._alternatives = this.getAlternatives();\n        this._htmlNode = this._alternatives.filter(alternative => /^text\\/html\\b/i.test(alternative.contentType)).pop();\n        this._attachments = this.getAttachments(!!this._htmlNode);\n\n        this._useRelated = !!(this._htmlNode && this._attachments.related.length);\n        this._useAlternative = this._alternatives.length > 1;\n        this._useMixed = this._attachments.attached.length > 1 || (this._alternatives.length && this._attachments.attached.length === 1);\n\n        // Compose MIME tree\n        if (this.mail.raw) {\n            this.message = new MimeNode('message/rfc822', { newline: this.mail.newline }).setRaw(this.mail.raw);\n        } else if (this._useMixed) {\n            this.message = this._createMixed();\n        } else if (this._useAlternative) {\n            this.message = this._createAlternative();\n        } else if (this._useRelated) {\n            this.message = this._createRelated();\n        } else {\n            this.message = this._createContentNode(\n                false,\n                []\n                    .concat(this._alternatives || [])\n                    .concat(this._attachments.attached || [])\n                    .shift() || {\n                    contentType: 'text/plain',\n                    content: ''\n                }\n            );\n        }\n\n        // Add custom headers\n        if (this.mail.headers) {\n            this.message.addHeader(this.mail.headers);\n        }\n\n        // Add headers to the root node, always overrides custom headers\n        ['from', 'sender', 'to', 'cc', 'bcc', 'reply-to', 'in-reply-to', 'references', 'subject', 'message-id', 'date'].forEach(header => {\n            let key = header.replace(/-(\\w)/g, (o, c) => c.toUpperCase());\n            if (this.mail[key]) {\n                this.message.setHeader(header, this.mail[key]);\n            }\n        });\n\n        // Sets custom envelope\n        if (this.mail.envelope) {\n            this.message.setEnvelope(this.mail.envelope);\n        }\n\n        // ensure Message-Id value\n        this.message.messageId();\n\n        return this.message;\n    }\n\n    /**\n     * List all attachments. Resulting attachment objects can be used as input for MimeNode nodes\n     *\n     * @param {Boolean} findRelated If true separate related attachments from attached ones\n     * @returns {Object} An object of arrays (`related` and `attached`)\n     */\n    getAttachments(findRelated) {\n        let icalEvent, eventObject;\n        let attachments = [].concat(this.mail.attachments || []).map((attachment, i) => {\n            let data;\n            let isMessageNode = /^message\\//i.test(attachment.contentType);\n\n            if (/^data:/i.test(attachment.path || attachment.href)) {\n                attachment = this._processDataUrl(attachment);\n            }\n\n            let contentType = attachment.contentType || mimeFuncs.detectMimeType(attachment.filename || attachment.path || attachment.href || 'bin');\n            let isImage = /^image\\//i.test(contentType);\n            let contentDisposition = attachment.contentDisposition || (isMessageNode || (isImage && attachment.cid) ? 'inline' : 'attachment');\n\n            data = {\n                contentType,\n                contentDisposition,\n                contentTransferEncoding: 'contentTransferEncoding' in attachment ? attachment.contentTransferEncoding : 'base64'\n            };\n\n            if (attachment.filename) {\n                data.filename = attachment.filename;\n            } else if (!isMessageNode && attachment.filename !== false) {\n                data.filename = (attachment.path || attachment.href || '').split('/').pop().split('?').shift() || 'attachment-' + (i + 1);\n                if (data.filename.indexOf('.') < 0) {\n                    data.filename += '.' + mimeFuncs.detectExtension(data.contentType);\n                }\n            }\n\n            if (/^https?:\\/\\//i.test(attachment.path)) {\n                attachment.href = attachment.path;\n                attachment.path = undefined;\n            }\n\n            if (attachment.cid) {\n                data.cid = attachment.cid;\n            }\n\n            if (attachment.raw) {\n                data.raw = attachment.raw;\n            } else if (attachment.path) {\n                data.content = {\n                    path: attachment.path\n                };\n            } else if (attachment.href) {\n                data.content = {\n                    href: attachment.href,\n                    httpHeaders: attachment.httpHeaders\n                };\n            } else {\n                data.content = attachment.content || '';\n            }\n\n            if (attachment.encoding) {\n                data.encoding = attachment.encoding;\n            }\n\n            if (attachment.headers) {\n                data.headers = attachment.headers;\n            }\n\n            return data;\n        });\n\n        if (this.mail.icalEvent) {\n            if (\n                typeof this.mail.icalEvent === 'object' &&\n                (this.mail.icalEvent.content || this.mail.icalEvent.path || this.mail.icalEvent.href || this.mail.icalEvent.raw)\n            ) {\n                icalEvent = this.mail.icalEvent;\n            } else {\n                icalEvent = {\n                    content: this.mail.icalEvent\n                };\n            }\n\n            eventObject = {};\n            Object.keys(icalEvent).forEach(key => {\n                eventObject[key] = icalEvent[key];\n            });\n\n            eventObject.contentType = 'application/ics';\n            if (!eventObject.headers) {\n                eventObject.headers = {};\n            }\n            eventObject.filename = eventObject.filename || 'invite.ics';\n            eventObject.headers['Content-Disposition'] = 'attachment';\n            eventObject.headers['Content-Transfer-Encoding'] = 'base64';\n        }\n\n        if (!findRelated) {\n            return {\n                attached: attachments.concat(eventObject || []),\n                related: []\n            };\n        } else {\n            return {\n                attached: attachments.filter(attachment => !attachment.cid).concat(eventObject || []),\n                related: attachments.filter(attachment => !!attachment.cid)\n            };\n        }\n    }\n\n    /**\n     * List alternatives. Resulting objects can be used as input for MimeNode nodes\n     *\n     * @returns {Array} An array of alternative elements. Includes the `text` and `html` values as well\n     */\n    getAlternatives() {\n        let alternatives = [],\n            text,\n            html,\n            watchHtml,\n            amp,\n            icalEvent,\n            eventObject;\n\n        if (this.mail.text) {\n            if (typeof this.mail.text === 'object' && (this.mail.text.content || this.mail.text.path || this.mail.text.href || this.mail.text.raw)) {\n                text = this.mail.text;\n            } else {\n                text = {\n                    content: this.mail.text\n                };\n            }\n            text.contentType = 'text/plain; charset=utf-8';\n        }\n\n        if (this.mail.watchHtml) {\n            if (\n                typeof this.mail.watchHtml === 'object' &&\n                (this.mail.watchHtml.content || this.mail.watchHtml.path || this.mail.watchHtml.href || this.mail.watchHtml.raw)\n            ) {\n                watchHtml = this.mail.watchHtml;\n            } else {\n                watchHtml = {\n                    content: this.mail.watchHtml\n                };\n            }\n            watchHtml.contentType = 'text/watch-html; charset=utf-8';\n        }\n\n        if (this.mail.amp) {\n            if (typeof this.mail.amp === 'object' && (this.mail.amp.content || this.mail.amp.path || this.mail.amp.href || this.mail.amp.raw)) {\n                amp = this.mail.amp;\n            } else {\n                amp = {\n                    content: this.mail.amp\n                };\n            }\n            amp.contentType = 'text/x-amp-html; charset=utf-8';\n        }\n\n        // NB! when including attachments with a calendar alternative you might end up in a blank screen on some clients\n        if (this.mail.icalEvent) {\n            if (\n                typeof this.mail.icalEvent === 'object' &&\n                (this.mail.icalEvent.content || this.mail.icalEvent.path || this.mail.icalEvent.href || this.mail.icalEvent.raw)\n            ) {\n                icalEvent = this.mail.icalEvent;\n            } else {\n                icalEvent = {\n                    content: this.mail.icalEvent\n                };\n            }\n\n            eventObject = {};\n            Object.keys(icalEvent).forEach(key => {\n                eventObject[key] = icalEvent[key];\n            });\n\n            if (eventObject.content && typeof eventObject.content === 'object') {\n                // we are going to have the same attachment twice, so mark this to be\n                // resolved just once\n                eventObject.content._resolve = true;\n            }\n\n            eventObject.filename = false;\n            eventObject.contentType = 'text/calendar; charset=utf-8; method=' + (eventObject.method || 'PUBLISH').toString().trim().toUpperCase();\n            if (!eventObject.headers) {\n                eventObject.headers = {};\n            }\n        }\n\n        if (this.mail.html) {\n            if (typeof this.mail.html === 'object' && (this.mail.html.content || this.mail.html.path || this.mail.html.href || this.mail.html.raw)) {\n                html = this.mail.html;\n            } else {\n                html = {\n                    content: this.mail.html\n                };\n            }\n            html.contentType = 'text/html; charset=utf-8';\n        }\n\n        []\n            .concat(text || [])\n            .concat(watchHtml || [])\n            .concat(amp || [])\n            .concat(html || [])\n            .concat(eventObject || [])\n            .concat(this.mail.alternatives || [])\n            .forEach(alternative => {\n                let data;\n\n                if (/^data:/i.test(alternative.path || alternative.href)) {\n                    alternative = this._processDataUrl(alternative);\n                }\n\n                data = {\n                    contentType: alternative.contentType || mimeFuncs.detectMimeType(alternative.filename || alternative.path || alternative.href || 'txt'),\n                    contentTransferEncoding: alternative.contentTransferEncoding\n                };\n\n                if (alternative.filename) {\n                    data.filename = alternative.filename;\n                }\n\n                if (/^https?:\\/\\//i.test(alternative.path)) {\n                    alternative.href = alternative.path;\n                    alternative.path = undefined;\n                }\n\n                if (alternative.raw) {\n                    data.raw = alternative.raw;\n                } else if (alternative.path) {\n                    data.content = {\n                        path: alternative.path\n                    };\n                } else if (alternative.href) {\n                    data.content = {\n                        href: alternative.href\n                    };\n                } else {\n                    data.content = alternative.content || '';\n                }\n\n                if (alternative.encoding) {\n                    data.encoding = alternative.encoding;\n                }\n\n                if (alternative.headers) {\n                    data.headers = alternative.headers;\n                }\n\n                alternatives.push(data);\n            });\n\n        return alternatives;\n    }\n\n    /**\n     * Builds multipart/mixed node. It should always contain different type of elements on the same level\n     * eg. text + attachments\n     *\n     * @param {Object} parentNode Parent for this note. If it does not exist, a root node is created\n     * @returns {Object} MimeNode node element\n     */\n    _createMixed(parentNode) {\n        let node;\n\n        if (!parentNode) {\n            node = new MimeNode('multipart/mixed', {\n                baseBoundary: this.mail.baseBoundary,\n                textEncoding: this.mail.textEncoding,\n                boundaryPrefix: this.mail.boundaryPrefix,\n                disableUrlAccess: this.mail.disableUrlAccess,\n                disableFileAccess: this.mail.disableFileAccess,\n                normalizeHeaderKey: this.mail.normalizeHeaderKey,\n                newline: this.mail.newline\n            });\n        } else {\n            node = parentNode.createChild('multipart/mixed', {\n                disableUrlAccess: this.mail.disableUrlAccess,\n                disableFileAccess: this.mail.disableFileAccess,\n                normalizeHeaderKey: this.mail.normalizeHeaderKey,\n                newline: this.mail.newline\n            });\n        }\n\n        if (this._useAlternative) {\n            this._createAlternative(node);\n        } else if (this._useRelated) {\n            this._createRelated(node);\n        }\n\n        []\n            .concat((!this._useAlternative && this._alternatives) || [])\n            .concat(this._attachments.attached || [])\n            .forEach(element => {\n                // if the element is a html node from related subpart then ignore it\n                if (!this._useRelated || element !== this._htmlNode) {\n                    this._createContentNode(node, element);\n                }\n            });\n\n        return node;\n    }\n\n    /**\n     * Builds multipart/alternative node. It should always contain same type of elements on the same level\n     * eg. text + html view of the same data\n     *\n     * @param {Object} parentNode Parent for this note. If it does not exist, a root node is created\n     * @returns {Object} MimeNode node element\n     */\n    _createAlternative(parentNode) {\n        let node;\n\n        if (!parentNode) {\n            node = new MimeNode('multipart/alternative', {\n                baseBoundary: this.mail.baseBoundary,\n                textEncoding: this.mail.textEncoding,\n                boundaryPrefix: this.mail.boundaryPrefix,\n                disableUrlAccess: this.mail.disableUrlAccess,\n                disableFileAccess: this.mail.disableFileAccess,\n                normalizeHeaderKey: this.mail.normalizeHeaderKey,\n                newline: this.mail.newline\n            });\n        } else {\n            node = parentNode.createChild('multipart/alternative', {\n                disableUrlAccess: this.mail.disableUrlAccess,\n                disableFileAccess: this.mail.disableFileAccess,\n                normalizeHeaderKey: this.mail.normalizeHeaderKey,\n                newline: this.mail.newline\n            });\n        }\n\n        this._alternatives.forEach(alternative => {\n            if (this._useRelated && this._htmlNode === alternative) {\n                this._createRelated(node);\n            } else {\n                this._createContentNode(node, alternative);\n            }\n        });\n\n        return node;\n    }\n\n    /**\n     * Builds multipart/related node. It should always contain html node with related attachments\n     *\n     * @param {Object} parentNode Parent for this note. If it does not exist, a root node is created\n     * @returns {Object} MimeNode node element\n     */\n    _createRelated(parentNode) {\n        let node;\n\n        if (!parentNode) {\n            node = new MimeNode('multipart/related; type=\"text/html\"', {\n                baseBoundary: this.mail.baseBoundary,\n                textEncoding: this.mail.textEncoding,\n                boundaryPrefix: this.mail.boundaryPrefix,\n                disableUrlAccess: this.mail.disableUrlAccess,\n                disableFileAccess: this.mail.disableFileAccess,\n                normalizeHeaderKey: this.mail.normalizeHeaderKey,\n                newline: this.mail.newline\n            });\n        } else {\n            node = parentNode.createChild('multipart/related; type=\"text/html\"', {\n                disableUrlAccess: this.mail.disableUrlAccess,\n                disableFileAccess: this.mail.disableFileAccess,\n                normalizeHeaderKey: this.mail.normalizeHeaderKey,\n                newline: this.mail.newline\n            });\n        }\n\n        this._createContentNode(node, this._htmlNode);\n\n        this._attachments.related.forEach(alternative => this._createContentNode(node, alternative));\n\n        return node;\n    }\n\n    /**\n     * Creates a regular node with contents\n     *\n     * @param {Object} parentNode Parent for this note. If it does not exist, a root node is created\n     * @param {Object} element Node data\n     * @returns {Object} MimeNode node element\n     */\n    _createContentNode(parentNode, element) {\n        element = element || {};\n        element.content = element.content || '';\n\n        let node;\n        let encoding = (element.encoding || 'utf8')\n            .toString()\n            .toLowerCase()\n            .replace(/[-_\\s]/g, '');\n\n        if (!parentNode) {\n            node = new MimeNode(element.contentType, {\n                filename: element.filename,\n                baseBoundary: this.mail.baseBoundary,\n                textEncoding: this.mail.textEncoding,\n                boundaryPrefix: this.mail.boundaryPrefix,\n                disableUrlAccess: this.mail.disableUrlAccess,\n                disableFileAccess: this.mail.disableFileAccess,\n                normalizeHeaderKey: this.mail.normalizeHeaderKey,\n                newline: this.mail.newline\n            });\n        } else {\n            node = parentNode.createChild(element.contentType, {\n                filename: element.filename,\n                textEncoding: this.mail.textEncoding,\n                disableUrlAccess: this.mail.disableUrlAccess,\n                disableFileAccess: this.mail.disableFileAccess,\n                normalizeHeaderKey: this.mail.normalizeHeaderKey,\n                newline: this.mail.newline\n            });\n        }\n\n        // add custom headers\n        if (element.headers) {\n            node.addHeader(element.headers);\n        }\n\n        if (element.cid) {\n            node.setHeader('Content-Id', '<' + element.cid.replace(/[<>]/g, '') + '>');\n        }\n\n        if (element.contentTransferEncoding) {\n            node.setHeader('Content-Transfer-Encoding', element.contentTransferEncoding);\n        } else if (this.mail.encoding && /^text\\//i.test(element.contentType)) {\n            node.setHeader('Content-Transfer-Encoding', this.mail.encoding);\n        }\n\n        if (!/^text\\//i.test(element.contentType) || element.contentDisposition) {\n            node.setHeader(\n                'Content-Disposition',\n                element.contentDisposition || (element.cid && /^image\\//i.test(element.contentType) ? 'inline' : 'attachment')\n            );\n        }\n\n        if (typeof element.content === 'string' && !['utf8', 'usascii', 'ascii'].includes(encoding)) {\n            element.content = Buffer.from(element.content, encoding);\n        }\n\n        // prefer pregenerated raw content\n        if (element.raw) {\n            node.setRaw(element.raw);\n        } else {\n            node.setContent(element.content);\n        }\n\n        return node;\n    }\n\n    /**\n     * Parses data uri and converts it to a Buffer\n     *\n     * @param {Object} element Content element\n     * @return {Object} Parsed element\n     */\n    _processDataUrl(element) {\n        let parsedDataUri;\n        if ((element.path || element.href).match(/^data:/)) {\n            parsedDataUri = parseDataURI(element.path || element.href);\n        }\n\n        if (!parsedDataUri) {\n            return element;\n        }\n\n        element.content = parsedDataUri.data;\n        element.contentType = element.contentType || parsedDataUri.contentType;\n\n        if ('path' in element) {\n            element.path = false;\n        }\n\n        if ('href' in element) {\n            element.href = false;\n        }\n\n        return element;\n    }\n}\n\nmodule.exports = MailComposer;\n","'use strict';\n\n/**\n * Minimal HTTP/S proxy client\n */\n\nconst net = require('net');\nconst tls = require('tls');\nconst urllib = require('url');\n\n/**\n * Establishes proxied connection to destinationPort\n *\n * httpProxyClient(\"http://localhost:3128/\", 80, \"google.com\", function(err, socket){\n *     socket.write(\"GET / HTTP/1.0\\r\\n\\r\\n\");\n * });\n *\n * @param {String} proxyUrl proxy configuration, etg \"http://proxy.host:3128/\"\n * @param {Number} destinationPort Port to open in destination host\n * @param {String} destinationHost Destination hostname\n * @param {Function} callback Callback to run with the rocket object once connection is established\n */\nfunction httpProxyClient(proxyUrl, destinationPort, destinationHost, callback) {\n    let proxy = urllib.parse(proxyUrl);\n\n    // create a socket connection to the proxy server\n    let options;\n    let connect;\n    let socket;\n\n    options = {\n        host: proxy.hostname,\n        port: Number(proxy.port) ? Number(proxy.port) : proxy.protocol === 'https:' ? 443 : 80\n    };\n\n    if (proxy.protocol === 'https:') {\n        // we can use untrusted proxies as long as we verify actual SMTP certificates\n        options.rejectUnauthorized = false;\n        connect = tls.connect.bind(tls);\n    } else {\n        connect = net.connect.bind(net);\n    }\n\n    // Error harness for initial connection. Once connection is established, the responsibility\n    // to handle errors is passed to whoever uses this socket\n    let finished = false;\n    let tempSocketErr = err => {\n        if (finished) {\n            return;\n        }\n        finished = true;\n        try {\n            socket.destroy();\n        } catch (E) {\n            // ignore\n        }\n        callback(err);\n    };\n\n    let timeoutErr = () => {\n        let err = new Error('Proxy socket timed out');\n        err.code = 'ETIMEDOUT';\n        tempSocketErr(err);\n    };\n\n    socket = connect(options, () => {\n        if (finished) {\n            return;\n        }\n\n        let reqHeaders = {\n            Host: destinationHost + ':' + destinationPort,\n            Connection: 'close'\n        };\n        if (proxy.auth) {\n            reqHeaders['Proxy-Authorization'] = 'Basic ' + Buffer.from(proxy.auth).toString('base64');\n        }\n\n        socket.write(\n            // HTTP method\n            'CONNECT ' +\n                destinationHost +\n                ':' +\n                destinationPort +\n                ' HTTP/1.1\\r\\n' +\n                // HTTP request headers\n                Object.keys(reqHeaders)\n                    .map(key => key + ': ' + reqHeaders[key])\n                    .join('\\r\\n') +\n                // End request\n                '\\r\\n\\r\\n'\n        );\n\n        let headers = '';\n        let onSocketData = chunk => {\n            let match;\n            let remainder;\n\n            if (finished) {\n                return;\n            }\n\n            headers += chunk.toString('binary');\n            if ((match = headers.match(/\\r\\n\\r\\n/))) {\n                socket.removeListener('data', onSocketData);\n\n                remainder = headers.substr(match.index + match[0].length);\n                headers = headers.substr(0, match.index);\n                if (remainder) {\n                    socket.unshift(Buffer.from(remainder, 'binary'));\n                }\n\n                // proxy connection is now established\n                finished = true;\n\n                // check response code\n                match = headers.match(/^HTTP\\/\\d+\\.\\d+ (\\d+)/i);\n                if (!match || (match[1] || '').charAt(0) !== '2') {\n                    try {\n                        socket.destroy();\n                    } catch (E) {\n                        // ignore\n                    }\n                    return callback(new Error('Invalid response from proxy' + ((match && ': ' + match[1]) || '')));\n                }\n\n                socket.removeListener('error', tempSocketErr);\n                socket.removeListener('timeout', timeoutErr);\n                socket.setTimeout(0);\n\n                return callback(null, socket);\n            }\n        };\n        socket.on('data', onSocketData);\n    });\n\n    socket.setTimeout(httpProxyClient.timeout || 30 * 1000);\n    socket.on('timeout', timeoutErr);\n\n    socket.once('error', tempSocketErr);\n}\n\nmodule.exports = httpProxyClient;\n","'use strict';\n\nconst shared = require('../shared');\nconst MimeNode = require('../mime-node');\nconst mimeFuncs = require('../mime-funcs');\n\nclass MailMessage {\n    constructor(mailer, data) {\n        this.mailer = mailer;\n        this.data = {};\n        this.message = null;\n\n        data = data || {};\n        let options = mailer.options || {};\n        let defaults = mailer._defaults || {};\n\n        Object.keys(data).forEach(key => {\n            this.data[key] = data[key];\n        });\n\n        this.data.headers = this.data.headers || {};\n\n        // apply defaults\n        Object.keys(defaults).forEach(key => {\n            if (!(key in this.data)) {\n                this.data[key] = defaults[key];\n            } else if (key === 'headers') {\n                // headers is a special case. Allow setting individual default headers\n                Object.keys(defaults.headers).forEach(key => {\n                    if (!(key in this.data.headers)) {\n                        this.data.headers[key] = defaults.headers[key];\n                    }\n                });\n            }\n        });\n\n        // force specific keys from transporter options\n        ['disableFileAccess', 'disableUrlAccess', 'normalizeHeaderKey'].forEach(key => {\n            if (key in options) {\n                this.data[key] = options[key];\n            }\n        });\n    }\n\n    resolveContent(...args) {\n        return shared.resolveContent(...args);\n    }\n\n    resolveAll(callback) {\n        let keys = [\n            [this.data, 'html'],\n            [this.data, 'text'],\n            [this.data, 'watchHtml'],\n            [this.data, 'amp'],\n            [this.data, 'icalEvent']\n        ];\n\n        if (this.data.alternatives && this.data.alternatives.length) {\n            this.data.alternatives.forEach((alternative, i) => {\n                keys.push([this.data.alternatives, i]);\n            });\n        }\n\n        if (this.data.attachments && this.data.attachments.length) {\n            this.data.attachments.forEach((attachment, i) => {\n                if (!attachment.filename) {\n                    attachment.filename = (attachment.path || attachment.href || '').split('/').pop().split('?').shift() || 'attachment-' + (i + 1);\n                    if (attachment.filename.indexOf('.') < 0) {\n                        attachment.filename += '.' + mimeFuncs.detectExtension(attachment.contentType);\n                    }\n                }\n\n                if (!attachment.contentType) {\n                    attachment.contentType = mimeFuncs.detectMimeType(attachment.filename || attachment.path || attachment.href || 'bin');\n                }\n\n                keys.push([this.data.attachments, i]);\n            });\n        }\n\n        let mimeNode = new MimeNode();\n\n        let addressKeys = ['from', 'to', 'cc', 'bcc', 'sender', 'replyTo'];\n\n        addressKeys.forEach(address => {\n            let value;\n            if (this.message) {\n                value = [].concat(mimeNode._parseAddresses(this.message.getHeader(address === 'replyTo' ? 'reply-to' : address)) || []);\n            } else if (this.data[address]) {\n                value = [].concat(mimeNode._parseAddresses(this.data[address]) || []);\n            }\n            if (value && value.length) {\n                this.data[address] = value;\n            } else if (address in this.data) {\n                this.data[address] = null;\n            }\n        });\n\n        let singleKeys = ['from', 'sender'];\n        singleKeys.forEach(address => {\n            if (this.data[address]) {\n                this.data[address] = this.data[address].shift();\n            }\n        });\n\n        let pos = 0;\n        let resolveNext = () => {\n            if (pos >= keys.length) {\n                return callback(null, this.data);\n            }\n            let args = keys[pos++];\n            if (!args[0] || !args[0][args[1]]) {\n                return resolveNext();\n            }\n            shared.resolveContent(...args, (err, value) => {\n                if (err) {\n                    return callback(err);\n                }\n\n                let node = {\n                    content: value\n                };\n                if (args[0][args[1]] && typeof args[0][args[1]] === 'object' && !Buffer.isBuffer(args[0][args[1]])) {\n                    Object.keys(args[0][args[1]]).forEach(key => {\n                        if (!(key in node) && !['content', 'path', 'href', 'raw'].includes(key)) {\n                            node[key] = args[0][args[1]][key];\n                        }\n                    });\n                }\n\n                args[0][args[1]] = node;\n                resolveNext();\n            });\n        };\n\n        setImmediate(() => resolveNext());\n    }\n\n    normalize(callback) {\n        let envelope = this.data.envelope || this.message.getEnvelope();\n        let messageId = this.message.messageId();\n\n        this.resolveAll((err, data) => {\n            if (err) {\n                return callback(err);\n            }\n\n            data.envelope = envelope;\n            data.messageId = messageId;\n\n            ['html', 'text', 'watchHtml', 'amp'].forEach(key => {\n                if (data[key] && data[key].content) {\n                    if (typeof data[key].content === 'string') {\n                        data[key] = data[key].content;\n                    } else if (Buffer.isBuffer(data[key].content)) {\n                        data[key] = data[key].content.toString();\n                    }\n                }\n            });\n\n            if (data.icalEvent && Buffer.isBuffer(data.icalEvent.content)) {\n                data.icalEvent.content = data.icalEvent.content.toString('base64');\n                data.icalEvent.encoding = 'base64';\n            }\n\n            if (data.alternatives && data.alternatives.length) {\n                data.alternatives.forEach(alternative => {\n                    if (alternative && alternative.content && Buffer.isBuffer(alternative.content)) {\n                        alternative.content = alternative.content.toString('base64');\n                        alternative.encoding = 'base64';\n                    }\n                });\n            }\n\n            if (data.attachments && data.attachments.length) {\n                data.attachments.forEach(attachment => {\n                    if (attachment && attachment.content && Buffer.isBuffer(attachment.content)) {\n                        attachment.content = attachment.content.toString('base64');\n                        attachment.encoding = 'base64';\n                    }\n                });\n            }\n\n            data.normalizedHeaders = {};\n            Object.keys(data.headers || {}).forEach(key => {\n                let value = [].concat(data.headers[key] || []).shift();\n                value = (value && value.value) || value;\n                if (value) {\n                    if (['references', 'in-reply-to', 'message-id', 'content-id'].includes(key)) {\n                        value = this.message._encodeHeaderValue(key, value);\n                    }\n                    data.normalizedHeaders[key] = value;\n                }\n            });\n\n            if (data.list && typeof data.list === 'object') {\n                let listHeaders = this._getListHeaders(data.list);\n                listHeaders.forEach(entry => {\n                    data.normalizedHeaders[entry.key] = entry.value.map(val => (val && val.value) || val).join(', ');\n                });\n            }\n\n            if (data.references) {\n                data.normalizedHeaders.references = this.message._encodeHeaderValue('references', data.references);\n            }\n\n            if (data.inReplyTo) {\n                data.normalizedHeaders['in-reply-to'] = this.message._encodeHeaderValue('in-reply-to', data.inReplyTo);\n            }\n\n            return callback(null, data);\n        });\n    }\n\n    setMailerHeader() {\n        if (!this.message || !this.data.xMailer) {\n            return;\n        }\n        this.message.setHeader('X-Mailer', this.data.xMailer);\n    }\n\n    setPriorityHeaders() {\n        if (!this.message || !this.data.priority) {\n            return;\n        }\n        switch ((this.data.priority || '').toString().toLowerCase()) {\n            case 'high':\n                this.message.setHeader('X-Priority', '1 (Highest)');\n                this.message.setHeader('X-MSMail-Priority', 'High');\n                this.message.setHeader('Importance', 'High');\n                break;\n            case 'low':\n                this.message.setHeader('X-Priority', '5 (Lowest)');\n                this.message.setHeader('X-MSMail-Priority', 'Low');\n                this.message.setHeader('Importance', 'Low');\n                break;\n            default:\n            // do not add anything, since all messages are 'Normal' by default\n        }\n    }\n\n    setListHeaders() {\n        if (!this.message || !this.data.list || typeof this.data.list !== 'object') {\n            return;\n        }\n        // add optional List-* headers\n        if (this.data.list && typeof this.data.list === 'object') {\n            this._getListHeaders(this.data.list).forEach(listHeader => {\n                listHeader.value.forEach(value => {\n                    this.message.addHeader(listHeader.key, value);\n                });\n            });\n        }\n    }\n\n    _getListHeaders(listData) {\n        // make sure an url looks like <protocol:url>\n        return Object.keys(listData).map(key => ({\n            key: 'list-' + key.toLowerCase().trim(),\n            value: [].concat(listData[key] || []).map(value => ({\n                prepared: true,\n                foldLines: true,\n                value: []\n                    .concat(value || [])\n                    .map(value => {\n                        if (typeof value === 'string') {\n                            value = {\n                                url: value\n                            };\n                        }\n\n                        if (value && value.url) {\n                            if (key.toLowerCase().trim() === 'id') {\n                                // List-ID: \"comment\" <domain>\n                                let comment = value.comment || '';\n                                if (mimeFuncs.isPlainText(comment)) {\n                                    comment = '\"' + comment + '\"';\n                                } else {\n                                    comment = mimeFuncs.encodeWord(comment);\n                                }\n\n                                return (value.comment ? comment + ' ' : '') + this._formatListUrl(value.url).replace(/^<[^:]+\\/{,2}/, '');\n                            }\n\n                            // List-*: <http://domain> (comment)\n                            let comment = value.comment || '';\n                            if (!mimeFuncs.isPlainText(comment)) {\n                                comment = mimeFuncs.encodeWord(comment);\n                            }\n\n                            return this._formatListUrl(value.url) + (value.comment ? ' (' + comment + ')' : '');\n                        }\n\n                        return '';\n                    })\n                    .filter(value => value)\n                    .join(', ')\n            }))\n        }));\n    }\n\n    _formatListUrl(url) {\n        url = url.replace(/[\\s<]+|[\\s>]+/g, '');\n        if (/^(https?|mailto|ftp):/.test(url)) {\n            return '<' + url + '>';\n        }\n        if (/^[^@]+@[^@]+$/.test(url)) {\n            return '<mailto:' + url + '>';\n        }\n\n        return '<http://' + url + '>';\n    }\n}\n\nmodule.exports = MailMessage;\n","'use strict';\n\nconst packageInfo = require('../../package.json');\nconst EventEmitter = require('events').EventEmitter;\nconst net = require('net');\nconst tls = require('tls');\nconst os = require('os');\nconst crypto = require('crypto');\nconst DataStream = require('./data-stream');\nconst PassThrough = require('stream').PassThrough;\nconst shared = require('../shared');\n\n// default timeout values in ms\nconst CONNECTION_TIMEOUT = 2 * 60 * 1000; // how much to wait for the connection to be established\nconst SOCKET_TIMEOUT = 10 * 60 * 1000; // how much to wait for socket inactivity before disconnecting the client\nconst GREETING_TIMEOUT = 30 * 1000; // how much to wait after connection is established but SMTP greeting is not receieved\nconst DNS_TIMEOUT = 30 * 1000; // how much to wait for resolveHostname\n\n/**\n * Generates a SMTP connection object\n *\n * Optional options object takes the following possible properties:\n *\n *  * **port** - is the port to connect to (defaults to 587 or 465)\n *  * **host** - is the hostname or IP address to connect to (defaults to 'localhost')\n *  * **secure** - use SSL\n *  * **ignoreTLS** - ignore server support for STARTTLS\n *  * **requireTLS** - forces the client to use STARTTLS\n *  * **name** - the name of the client server\n *  * **localAddress** - outbound address to bind to (see: http://nodejs.org/api/net.html#net_net_connect_options_connectionlistener)\n *  * **greetingTimeout** - Time to wait in ms until greeting message is received from the server (defaults to 10000)\n *  * **connectionTimeout** - how many milliseconds to wait for the connection to establish\n *  * **socketTimeout** - Time of inactivity until the connection is closed (defaults to 1 hour)\n *  * **dnsTimeout** - Time to wait in ms for the DNS requests to be resolved (defaults to 30 seconds)\n *  * **lmtp** - if true, uses LMTP instead of SMTP protocol\n *  * **logger** - bunyan compatible logger interface\n *  * **debug** - if true pass SMTP traffic to the logger\n *  * **tls** - options for createCredentials\n *  * **socket** - existing socket to use instead of creating a new one (see: http://nodejs.org/api/net.html#net_class_net_socket)\n *  * **secured** - boolean indicates that the provided socket has already been upgraded to tls\n *\n * @constructor\n * @namespace SMTP Client module\n * @param {Object} [options] Option properties\n */\nclass SMTPConnection extends EventEmitter {\n    constructor(options) {\n        super(options);\n\n        this.id = crypto.randomBytes(8).toString('base64').replace(/\\W/g, '');\n        this.stage = 'init';\n\n        this.options = options || {};\n\n        this.secureConnection = !!this.options.secure;\n        this.alreadySecured = !!this.options.secured;\n\n        this.port = Number(this.options.port) || (this.secureConnection ? 465 : 587);\n        this.host = this.options.host || 'localhost';\n\n        this.servername = this.options.servername ? this.options.servername : !net.isIP(this.host) ? this.host : false;\n\n        this.allowInternalNetworkInterfaces = this.options.allowInternalNetworkInterfaces || false;\n\n        if (typeof this.options.secure === 'undefined' && this.port === 465) {\n            // if secure option is not set but port is 465, then default to secure\n            this.secureConnection = true;\n        }\n\n        this.name = this.options.name || this._getHostname();\n\n        this.logger = shared.getLogger(this.options, {\n            component: this.options.component || 'smtp-connection',\n            sid: this.id\n        });\n\n        this.customAuth = new Map();\n        Object.keys(this.options.customAuth || {}).forEach(key => {\n            let mapKey = (key || '').toString().trim().toUpperCase();\n            if (!mapKey) {\n                return;\n            }\n            this.customAuth.set(mapKey, this.options.customAuth[key]);\n        });\n\n        /**\n         * Expose version nr, just for the reference\n         * @type {String}\n         */\n        this.version = packageInfo.version;\n\n        /**\n         * If true, then the user is authenticated\n         * @type {Boolean}\n         */\n        this.authenticated = false;\n\n        /**\n         * If set to true, this instance is no longer active\n         * @private\n         */\n        this.destroyed = false;\n\n        /**\n         * Defines if the current connection is secure or not. If not,\n         * STARTTLS can be used if available\n         * @private\n         */\n        this.secure = !!this.secureConnection;\n\n        /**\n         * Store incomplete messages coming from the server\n         * @private\n         */\n        this._remainder = '';\n\n        /**\n         * Unprocessed responses from the server\n         * @type {Array}\n         */\n        this._responseQueue = [];\n\n        this.lastServerResponse = false;\n\n        /**\n         * The socket connecting to the server\n         * @publick\n         */\n        this._socket = false;\n\n        /**\n         * Lists supported auth mechanisms\n         * @private\n         */\n        this._supportedAuth = [];\n\n        /**\n         * Set to true, if EHLO response includes \"AUTH\".\n         * If false then authentication is not tried\n         */\n        this.allowsAuth = false;\n\n        /**\n         * Includes current envelope (from, to)\n         * @private\n         */\n        this._envelope = false;\n\n        /**\n         * Lists supported extensions\n         * @private\n         */\n        this._supportedExtensions = [];\n\n        /**\n         * Defines the maximum allowed size for a single message\n         * @private\n         */\n        this._maxAllowedSize = 0;\n\n        /**\n         * Function queue to run if a data chunk comes from the server\n         * @private\n         */\n        this._responseActions = [];\n        this._recipientQueue = [];\n\n        /**\n         * Timeout variable for waiting the greeting\n         * @private\n         */\n        this._greetingTimeout = false;\n\n        /**\n         * Timeout variable for waiting the connection to start\n         * @private\n         */\n        this._connectionTimeout = false;\n\n        /**\n         * If the socket is deemed already closed\n         * @private\n         */\n        this._destroyed = false;\n\n        /**\n         * If the socket is already being closed\n         * @private\n         */\n        this._closing = false;\n\n        /**\n         * Callbacks for socket's listeners\n         */\n        this._onSocketData = chunk => this._onData(chunk);\n        this._onSocketError = error => this._onError(error, 'ESOCKET', false, 'CONN');\n        this._onSocketClose = () => this._onClose();\n        this._onSocketEnd = () => this._onEnd();\n        this._onSocketTimeout = () => this._onTimeout();\n    }\n\n    /**\n     * Creates a connection to a SMTP server and sets up connection\n     * listener\n     */\n    connect(connectCallback) {\n        if (typeof connectCallback === 'function') {\n            this.once('connect', () => {\n                this.logger.debug(\n                    {\n                        tnx: 'smtp'\n                    },\n                    'SMTP handshake finished'\n                );\n                connectCallback();\n            });\n\n            const isDestroyedMessage = this._isDestroyedMessage('connect');\n            if (isDestroyedMessage) {\n                return connectCallback(this._formatError(isDestroyedMessage, 'ECONNECTION', false, 'CONN'));\n            }\n        }\n\n        let opts = {\n            port: this.port,\n            host: this.host,\n            allowInternalNetworkInterfaces: this.allowInternalNetworkInterfaces,\n            timeout: this.options.dnsTimeout || DNS_TIMEOUT\n        };\n\n        if (this.options.localAddress) {\n            opts.localAddress = this.options.localAddress;\n        }\n\n        let setupConnectionHandlers = () => {\n            this._connectionTimeout = setTimeout(() => {\n                this._onError('Connection timeout', 'ETIMEDOUT', false, 'CONN');\n            }, this.options.connectionTimeout || CONNECTION_TIMEOUT);\n\n            this._socket.on('error', this._onSocketError);\n        };\n\n        if (this.options.connection) {\n            // connection is already opened\n            this._socket = this.options.connection;\n            if (this.secureConnection && !this.alreadySecured) {\n                setImmediate(() =>\n                    this._upgradeConnection(err => {\n                        if (err) {\n                            this._onError(new Error('Error initiating TLS - ' + (err.message || err)), 'ETLS', false, 'CONN');\n                            return;\n                        }\n                        this._onConnect();\n                    })\n                );\n            } else {\n                setImmediate(() => this._onConnect());\n            }\n            return;\n        } else if (this.options.socket) {\n            // socket object is set up but not yet connected\n            this._socket = this.options.socket;\n            return shared.resolveHostname(opts, (err, resolved) => {\n                if (err) {\n                    return setImmediate(() => this._onError(err, 'EDNS', false, 'CONN'));\n                }\n                this.logger.debug(\n                    {\n                        tnx: 'dns',\n                        source: opts.host,\n                        resolved: resolved.host,\n                        cached: !!resolved.cached\n                    },\n                    'Resolved %s as %s [cache %s]',\n                    opts.host,\n                    resolved.host,\n                    resolved.cached ? 'hit' : 'miss'\n                );\n                Object.keys(resolved).forEach(key => {\n                    if (key.charAt(0) !== '_' && resolved[key]) {\n                        opts[key] = resolved[key];\n                    }\n                });\n                try {\n                    this._socket.connect(this.port, this.host, () => {\n                        this._socket.setKeepAlive(true);\n                        this._onConnect();\n                    });\n                    setupConnectionHandlers();\n                } catch (E) {\n                    return setImmediate(() => this._onError(E, 'ECONNECTION', false, 'CONN'));\n                }\n            });\n        } else if (this.secureConnection) {\n            // connect using tls\n            if (this.options.tls) {\n                Object.keys(this.options.tls).forEach(key => {\n                    opts[key] = this.options.tls[key];\n                });\n            }\n\n            // ensure servername for SNI\n            if (this.servername && !opts.servername) {\n                opts.servername = this.servername;\n            }\n\n            return shared.resolveHostname(opts, (err, resolved) => {\n                if (err) {\n                    return setImmediate(() => this._onError(err, 'EDNS', false, 'CONN'));\n                }\n                this.logger.debug(\n                    {\n                        tnx: 'dns',\n                        source: opts.host,\n                        resolved: resolved.host,\n                        cached: !!resolved.cached\n                    },\n                    'Resolved %s as %s [cache %s]',\n                    opts.host,\n                    resolved.host,\n                    resolved.cached ? 'hit' : 'miss'\n                );\n                Object.keys(resolved).forEach(key => {\n                    if (key.charAt(0) !== '_' && resolved[key]) {\n                        opts[key] = resolved[key];\n                    }\n                });\n                try {\n                    this._socket = tls.connect(opts, () => {\n                        this._socket.setKeepAlive(true);\n                        this._onConnect();\n                    });\n                    setupConnectionHandlers();\n                } catch (E) {\n                    return setImmediate(() => this._onError(E, 'ECONNECTION', false, 'CONN'));\n                }\n            });\n        } else {\n            // connect using plaintext\n            return shared.resolveHostname(opts, (err, resolved) => {\n                if (err) {\n                    return setImmediate(() => this._onError(err, 'EDNS', false, 'CONN'));\n                }\n                this.logger.debug(\n                    {\n                        tnx: 'dns',\n                        source: opts.host,\n                        resolved: resolved.host,\n                        cached: !!resolved.cached\n                    },\n                    'Resolved %s as %s [cache %s]',\n                    opts.host,\n                    resolved.host,\n                    resolved.cached ? 'hit' : 'miss'\n                );\n                Object.keys(resolved).forEach(key => {\n                    if (key.charAt(0) !== '_' && resolved[key]) {\n                        opts[key] = resolved[key];\n                    }\n                });\n                try {\n                    this._socket = net.connect(opts, () => {\n                        this._socket.setKeepAlive(true);\n                        this._onConnect();\n                    });\n                    setupConnectionHandlers();\n                } catch (E) {\n                    return setImmediate(() => this._onError(E, 'ECONNECTION', false, 'CONN'));\n                }\n            });\n        }\n    }\n\n    /**\n     * Sends QUIT\n     */\n    quit() {\n        this._sendCommand('QUIT');\n        this._responseActions.push(this.close);\n    }\n\n    /**\n     * Closes the connection to the server\n     */\n    close() {\n        clearTimeout(this._connectionTimeout);\n        clearTimeout(this._greetingTimeout);\n        this._responseActions = [];\n\n        // allow to run this function only once\n        if (this._closing) {\n            return;\n        }\n        this._closing = true;\n\n        let closeMethod = 'end';\n\n        if (this.stage === 'init') {\n            // Close the socket immediately when connection timed out\n            closeMethod = 'destroy';\n        }\n\n        this.logger.debug(\n            {\n                tnx: 'smtp'\n            },\n            'Closing connection to the server using \"%s\"',\n            closeMethod\n        );\n\n        let socket = (this._socket && this._socket.socket) || this._socket;\n\n        if (socket && !socket.destroyed) {\n            try {\n                this._socket[closeMethod]();\n            } catch (E) {\n                // just ignore\n            }\n        }\n\n        this._destroy();\n    }\n\n    /**\n     * Authenticate user\n     */\n    login(authData, callback) {\n        const isDestroyedMessage = this._isDestroyedMessage('login');\n        if (isDestroyedMessage) {\n            return callback(this._formatError(isDestroyedMessage, 'ECONNECTION', false, 'API'));\n        }\n\n        this._auth = authData || {};\n        // Select SASL authentication method\n        this._authMethod = (this._auth.method || '').toString().trim().toUpperCase() || false;\n\n        if (!this._authMethod && this._auth.oauth2 && !this._auth.credentials) {\n            this._authMethod = 'XOAUTH2';\n        } else if (!this._authMethod || (this._authMethod === 'XOAUTH2' && !this._auth.oauth2)) {\n            // use first supported\n            this._authMethod = (this._supportedAuth[0] || 'PLAIN').toUpperCase().trim();\n        }\n\n        if (this._authMethod !== 'XOAUTH2' && (!this._auth.credentials || !this._auth.credentials.user || !this._auth.credentials.pass)) {\n            if ((this._auth.user && this._auth.pass) || this.customAuth.has(this._authMethod)) {\n                this._auth.credentials = {\n                    user: this._auth.user,\n                    pass: this._auth.pass,\n                    options: this._auth.options\n                };\n            } else {\n                return callback(this._formatError('Missing credentials for \"' + this._authMethod + '\"', 'EAUTH', false, 'API'));\n            }\n        }\n\n        if (this.customAuth.has(this._authMethod)) {\n            let handler = this.customAuth.get(this._authMethod);\n            let lastResponse;\n            let returned = false;\n\n            let resolve = () => {\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                this.logger.info(\n                    {\n                        tnx: 'smtp',\n                        username: this._auth.user,\n                        action: 'authenticated',\n                        method: this._authMethod\n                    },\n                    'User %s authenticated',\n                    JSON.stringify(this._auth.user)\n                );\n                this.authenticated = true;\n                callback(null, true);\n            };\n\n            let reject = err => {\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                callback(this._formatError(err, 'EAUTH', lastResponse, 'AUTH ' + this._authMethod));\n            };\n\n            let handlerResponse = handler({\n                auth: this._auth,\n                method: this._authMethod,\n\n                extensions: [].concat(this._supportedExtensions),\n                authMethods: [].concat(this._supportedAuth),\n                maxAllowedSize: this._maxAllowedSize || false,\n\n                sendCommand: (cmd, done) => {\n                    let promise;\n\n                    if (!done) {\n                        promise = new Promise((resolve, reject) => {\n                            done = shared.callbackPromise(resolve, reject);\n                        });\n                    }\n\n                    this._responseActions.push(str => {\n                        lastResponse = str;\n\n                        let codes = str.match(/^(\\d+)(?:\\s(\\d+\\.\\d+\\.\\d+))?\\s/);\n                        let data = {\n                            command: cmd,\n                            response: str\n                        };\n                        if (codes) {\n                            data.status = Number(codes[1]) || 0;\n                            if (codes[2]) {\n                                data.code = codes[2];\n                            }\n                            data.text = str.substr(codes[0].length);\n                        } else {\n                            data.text = str;\n                            data.status = 0; // just in case we need to perform numeric comparisons\n                        }\n                        done(null, data);\n                    });\n                    setImmediate(() => this._sendCommand(cmd));\n\n                    return promise;\n                },\n\n                resolve,\n                reject\n            });\n\n            if (handlerResponse && typeof handlerResponse.catch === 'function') {\n                // a promise was returned\n                handlerResponse.then(resolve).catch(reject);\n            }\n\n            return;\n        }\n\n        switch (this._authMethod) {\n            case 'XOAUTH2':\n                this._handleXOauth2Token(false, callback);\n                return;\n            case 'LOGIN':\n                this._responseActions.push(str => {\n                    this._actionAUTH_LOGIN_USER(str, callback);\n                });\n                this._sendCommand('AUTH LOGIN');\n                return;\n            case 'PLAIN':\n                this._responseActions.push(str => {\n                    this._actionAUTHComplete(str, callback);\n                });\n                this._sendCommand(\n                    'AUTH PLAIN ' +\n                        Buffer.from(\n                            //this._auth.user+'\\u0000'+\n                            '\\u0000' + // skip authorization identity as it causes problems with some servers\n                                this._auth.credentials.user +\n                                '\\u0000' +\n                                this._auth.credentials.pass,\n                            'utf-8'\n                        ).toString('base64'),\n                    // log entry without passwords\n                    'AUTH PLAIN ' +\n                        Buffer.from(\n                            //this._auth.user+'\\u0000'+\n                            '\\u0000' + // skip authorization identity as it causes problems with some servers\n                                this._auth.credentials.user +\n                                '\\u0000' +\n                                '/* secret */',\n                            'utf-8'\n                        ).toString('base64')\n                );\n                return;\n            case 'CRAM-MD5':\n                this._responseActions.push(str => {\n                    this._actionAUTH_CRAM_MD5(str, callback);\n                });\n                this._sendCommand('AUTH CRAM-MD5');\n                return;\n        }\n\n        return callback(this._formatError('Unknown authentication method \"' + this._authMethod + '\"', 'EAUTH', false, 'API'));\n    }\n\n    /**\n     * Sends a message\n     *\n     * @param {Object} envelope Envelope object, {from: addr, to: [addr]}\n     * @param {Object} message String, Buffer or a Stream\n     * @param {Function} callback Callback to return once sending is completed\n     */\n    send(envelope, message, done) {\n        if (!message) {\n            return done(this._formatError('Empty message', 'EMESSAGE', false, 'API'));\n        }\n\n        const isDestroyedMessage = this._isDestroyedMessage('send message');\n        if (isDestroyedMessage) {\n            return done(this._formatError(isDestroyedMessage, 'ECONNECTION', false, 'API'));\n        }\n\n        // reject larger messages than allowed\n        if (this._maxAllowedSize && envelope.size > this._maxAllowedSize) {\n            return setImmediate(() => {\n                done(this._formatError('Message size larger than allowed ' + this._maxAllowedSize, 'EMESSAGE', false, 'MAIL FROM'));\n            });\n        }\n\n        // ensure that callback is only called once\n        let returned = false;\n        let callback = function () {\n            if (returned) {\n                return;\n            }\n            returned = true;\n\n            done(...arguments);\n        };\n\n        if (typeof message.on === 'function') {\n            message.on('error', err => callback(this._formatError(err, 'ESTREAM', false, 'API')));\n        }\n\n        let startTime = Date.now();\n        this._setEnvelope(envelope, (err, info) => {\n            if (err) {\n                return callback(err);\n            }\n            let envelopeTime = Date.now();\n            let stream = this._createSendStream((err, str) => {\n                if (err) {\n                    return callback(err);\n                }\n\n                info.envelopeTime = envelopeTime - startTime;\n                info.messageTime = Date.now() - envelopeTime;\n                info.messageSize = stream.outByteCount;\n                info.response = str;\n\n                return callback(null, info);\n            });\n            if (typeof message.pipe === 'function') {\n                message.pipe(stream);\n            } else {\n                stream.write(message);\n                stream.end();\n            }\n        });\n    }\n\n    /**\n     * Resets connection state\n     *\n     * @param {Function} callback Callback to return once connection is reset\n     */\n    reset(callback) {\n        this._sendCommand('RSET');\n        this._responseActions.push(str => {\n            if (str.charAt(0) !== '2') {\n                return callback(this._formatError('Could not reset session state. response=' + str, 'EPROTOCOL', str, 'RSET'));\n            }\n            this._envelope = false;\n            return callback(null, true);\n        });\n    }\n\n    /**\n     * Connection listener that is run when the connection to\n     * the server is opened\n     *\n     * @event\n     */\n    _onConnect() {\n        clearTimeout(this._connectionTimeout);\n\n        this.logger.info(\n            {\n                tnx: 'network',\n                localAddress: this._socket.localAddress,\n                localPort: this._socket.localPort,\n                remoteAddress: this._socket.remoteAddress,\n                remotePort: this._socket.remotePort\n            },\n            '%s established to %s:%s',\n            this.secure ? 'Secure connection' : 'Connection',\n            this._socket.remoteAddress,\n            this._socket.remotePort\n        );\n\n        if (this._destroyed) {\n            // Connection was established after we already had canceled it\n            this.close();\n            return;\n        }\n\n        this.stage = 'connected';\n\n        // clear existing listeners for the socket\n        this._socket.removeListener('data', this._onSocketData);\n        this._socket.removeListener('timeout', this._onSocketTimeout);\n        this._socket.removeListener('close', this._onSocketClose);\n        this._socket.removeListener('end', this._onSocketEnd);\n\n        this._socket.on('data', this._onSocketData);\n        this._socket.once('close', this._onSocketClose);\n        this._socket.once('end', this._onSocketEnd);\n\n        this._socket.setTimeout(this.options.socketTimeout || SOCKET_TIMEOUT);\n        this._socket.on('timeout', this._onSocketTimeout);\n\n        this._greetingTimeout = setTimeout(() => {\n            // if still waiting for greeting, give up\n            if (this._socket && !this._destroyed && this._responseActions[0] === this._actionGreeting) {\n                this._onError('Greeting never received', 'ETIMEDOUT', false, 'CONN');\n            }\n        }, this.options.greetingTimeout || GREETING_TIMEOUT);\n\n        this._responseActions.push(this._actionGreeting);\n\n        // we have a 'data' listener set up so resume socket if it was paused\n        this._socket.resume();\n    }\n\n    /**\n     * 'data' listener for data coming from the server\n     *\n     * @event\n     * @param {Buffer} chunk Data chunk coming from the server\n     */\n    _onData(chunk) {\n        if (this._destroyed || !chunk || !chunk.length) {\n            return;\n        }\n\n        let data = (chunk || '').toString('binary');\n        let lines = (this._remainder + data).split(/\\r?\\n/);\n        let lastline;\n\n        this._remainder = lines.pop();\n\n        for (let i = 0, len = lines.length; i < len; i++) {\n            if (this._responseQueue.length) {\n                lastline = this._responseQueue[this._responseQueue.length - 1];\n                if (/^\\d+-/.test(lastline.split('\\n').pop())) {\n                    this._responseQueue[this._responseQueue.length - 1] += '\\n' + lines[i];\n                    continue;\n                }\n            }\n            this._responseQueue.push(lines[i]);\n        }\n\n        if (this._responseQueue.length) {\n            lastline = this._responseQueue[this._responseQueue.length - 1];\n            if (/^\\d+-/.test(lastline.split('\\n').pop())) {\n                return;\n            }\n        }\n\n        this._processResponse();\n    }\n\n    /**\n     * 'error' listener for the socket\n     *\n     * @event\n     * @param {Error} err Error object\n     * @param {String} type Error name\n     */\n    _onError(err, type, data, command) {\n        clearTimeout(this._connectionTimeout);\n        clearTimeout(this._greetingTimeout);\n\n        if (this._destroyed) {\n            // just ignore, already closed\n            // this might happen when a socket is canceled because of reached timeout\n            // but the socket timeout error itself receives only after\n            return;\n        }\n\n        err = this._formatError(err, type, data, command);\n\n        this.logger.error(data, err.message);\n\n        this.emit('error', err);\n        this.close();\n    }\n\n    _formatError(message, type, response, command) {\n        let err;\n\n        if (/Error\\]$/i.test(Object.prototype.toString.call(message))) {\n            err = message;\n        } else {\n            err = new Error(message);\n        }\n\n        if (type && type !== 'Error') {\n            err.code = type;\n        }\n\n        if (response) {\n            err.response = response;\n            err.message += ': ' + response;\n        }\n\n        let responseCode = (typeof response === 'string' && Number((response.match(/^\\d+/) || [])[0])) || false;\n        if (responseCode) {\n            err.responseCode = responseCode;\n        }\n\n        if (command) {\n            err.command = command;\n        }\n\n        return err;\n    }\n\n    /**\n     * 'close' listener for the socket\n     *\n     * @event\n     */\n    _onClose() {\n        let serverResponse = false;\n\n        if (this._remainder && this._remainder.trim()) {\n            if (this.options.debug || this.options.transactionLog) {\n                this.logger.debug(\n                    {\n                        tnx: 'server'\n                    },\n                    this._remainder.replace(/\\r?\\n$/, '')\n                );\n            }\n            this.lastServerResponse = serverResponse = this._remainder.trim();\n        }\n\n        this.logger.info(\n            {\n                tnx: 'network'\n            },\n            'Connection closed'\n        );\n\n        if (this.upgrading && !this._destroyed) {\n            return this._onError(new Error('Connection closed unexpectedly'), 'ETLS', serverResponse, 'CONN');\n        } else if (![this._actionGreeting, this.close].includes(this._responseActions[0]) && !this._destroyed) {\n            return this._onError(new Error('Connection closed unexpectedly'), 'ECONNECTION', serverResponse, 'CONN');\n        } else if (/^[45]\\d{2}\\b/.test(serverResponse)) {\n            return this._onError(new Error('Connection closed unexpectedly'), 'ECONNECTION', serverResponse, 'CONN');\n        }\n\n        this._destroy();\n    }\n\n    /**\n     * 'end' listener for the socket\n     *\n     * @event\n     */\n    _onEnd() {\n        if (this._socket && !this._socket.destroyed) {\n            this._socket.destroy();\n        }\n    }\n\n    /**\n     * 'timeout' listener for the socket\n     *\n     * @event\n     */\n    _onTimeout() {\n        return this._onError(new Error('Timeout'), 'ETIMEDOUT', false, 'CONN');\n    }\n\n    /**\n     * Destroys the client, emits 'end'\n     */\n    _destroy() {\n        if (this._destroyed) {\n            return;\n        }\n        this._destroyed = true;\n        this.emit('end');\n    }\n\n    /**\n     * Upgrades the connection to TLS\n     *\n     * @param {Function} callback Callback function to run when the connection\n     *        has been secured\n     */\n    _upgradeConnection(callback) {\n        // do not remove all listeners or it breaks node v0.10 as there's\n        // apparently a 'finish' event set that would be cleared as well\n\n        // we can safely keep 'error', 'end', 'close' etc. events\n        this._socket.removeListener('data', this._onSocketData); // incoming data is going to be gibberish from this point onwards\n        this._socket.removeListener('timeout', this._onSocketTimeout); // timeout will be re-set for the new socket object\n\n        let socketPlain = this._socket;\n        let opts = {\n            socket: this._socket,\n            host: this.host\n        };\n\n        Object.keys(this.options.tls || {}).forEach(key => {\n            opts[key] = this.options.tls[key];\n        });\n\n        // ensure servername for SNI\n        if (this.servername && !opts.servername) {\n            opts.servername = this.servername;\n        }\n\n        this.upgrading = true;\n        // tls.connect is not an asynchronous function however it may still throw errors and requires to be wrapped with try/catch\n        try {\n            this._socket = tls.connect(opts, () => {\n                this.secure = true;\n                this.upgrading = false;\n                this._socket.on('data', this._onSocketData);\n\n                socketPlain.removeListener('close', this._onSocketClose);\n                socketPlain.removeListener('end', this._onSocketEnd);\n\n                return callback(null, true);\n            });\n        } catch (err) {\n            return callback(err);\n        }\n\n        this._socket.on('error', this._onSocketError);\n        this._socket.once('close', this._onSocketClose);\n        this._socket.once('end', this._onSocketEnd);\n\n        this._socket.setTimeout(this.options.socketTimeout || SOCKET_TIMEOUT); // 10 min.\n        this._socket.on('timeout', this._onSocketTimeout);\n\n        // resume in case the socket was paused\n        socketPlain.resume();\n    }\n\n    /**\n     * Processes queued responses from the server\n     *\n     * @param {Boolean} force If true, ignores _processing flag\n     */\n    _processResponse() {\n        if (!this._responseQueue.length) {\n            return false;\n        }\n\n        let str = (this.lastServerResponse = (this._responseQueue.shift() || '').toString());\n\n        if (/^\\d+-/.test(str.split('\\n').pop())) {\n            // keep waiting for the final part of multiline response\n            return;\n        }\n\n        if (this.options.debug || this.options.transactionLog) {\n            this.logger.debug(\n                {\n                    tnx: 'server'\n                },\n                str.replace(/\\r?\\n$/, '')\n            );\n        }\n\n        if (!str.trim()) {\n            // skip unexpected empty lines\n            setImmediate(() => this._processResponse());\n        }\n\n        let action = this._responseActions.shift();\n\n        if (typeof action === 'function') {\n            action.call(this, str);\n            setImmediate(() => this._processResponse());\n        } else {\n            return this._onError(new Error('Unexpected Response'), 'EPROTOCOL', str, 'CONN');\n        }\n    }\n\n    /**\n     * Send a command to the server, append \\r\\n\n     *\n     * @param {String} str String to be sent to the server\n     * @param {String} logStr Optional string to be used for logging instead of the actual string\n     */\n    _sendCommand(str, logStr) {\n        if (this._destroyed) {\n            // Connection already closed, can't send any more data\n            return;\n        }\n\n        if (this._socket.destroyed) {\n            return this.close();\n        }\n\n        if (this.options.debug || this.options.transactionLog) {\n            this.logger.debug(\n                {\n                    tnx: 'client'\n                },\n                (logStr || str || '').toString().replace(/\\r?\\n$/, '')\n            );\n        }\n\n        this._socket.write(Buffer.from(str + '\\r\\n', 'utf-8'));\n    }\n\n    /**\n     * Initiates a new message by submitting envelope data, starting with\n     * MAIL FROM: command\n     *\n     * @param {Object} envelope Envelope object in the form of\n     *        {from:'...', to:['...']}\n     *        or\n     *        {from:{address:'...',name:'...'}, to:[address:'...',name:'...']}\n     */\n    _setEnvelope(envelope, callback) {\n        let args = [];\n        let useSmtpUtf8 = false;\n\n        this._envelope = envelope || {};\n        this._envelope.from = ((this._envelope.from && this._envelope.from.address) || this._envelope.from || '').toString().trim();\n\n        this._envelope.to = [].concat(this._envelope.to || []).map(to => ((to && to.address) || to || '').toString().trim());\n\n        if (!this._envelope.to.length) {\n            return callback(this._formatError('No recipients defined', 'EENVELOPE', false, 'API'));\n        }\n\n        if (this._envelope.from && /[\\r\\n<>]/.test(this._envelope.from)) {\n            return callback(this._formatError('Invalid sender ' + JSON.stringify(this._envelope.from), 'EENVELOPE', false, 'API'));\n        }\n\n        // check if the sender address uses only ASCII characters,\n        // otherwise require usage of SMTPUTF8 extension\n        if (/[\\x80-\\uFFFF]/.test(this._envelope.from)) {\n            useSmtpUtf8 = true;\n        }\n\n        for (let i = 0, len = this._envelope.to.length; i < len; i++) {\n            if (!this._envelope.to[i] || /[\\r\\n<>]/.test(this._envelope.to[i])) {\n                return callback(this._formatError('Invalid recipient ' + JSON.stringify(this._envelope.to[i]), 'EENVELOPE', false, 'API'));\n            }\n\n            // check if the recipients addresses use only ASCII characters,\n            // otherwise require usage of SMTPUTF8 extension\n            if (/[\\x80-\\uFFFF]/.test(this._envelope.to[i])) {\n                useSmtpUtf8 = true;\n            }\n        }\n\n        // clone the recipients array for latter manipulation\n        this._envelope.rcptQueue = JSON.parse(JSON.stringify(this._envelope.to || []));\n        this._envelope.rejected = [];\n        this._envelope.rejectedErrors = [];\n        this._envelope.accepted = [];\n\n        if (this._envelope.dsn) {\n            try {\n                this._envelope.dsn = this._setDsnEnvelope(this._envelope.dsn);\n            } catch (err) {\n                return callback(this._formatError('Invalid DSN ' + err.message, 'EENVELOPE', false, 'API'));\n            }\n        }\n\n        this._responseActions.push(str => {\n            this._actionMAIL(str, callback);\n        });\n\n        // If the server supports SMTPUTF8 and the envelope includes an internationalized\n        // email address then append SMTPUTF8 keyword to the MAIL FROM command\n        if (useSmtpUtf8 && this._supportedExtensions.includes('SMTPUTF8')) {\n            args.push('SMTPUTF8');\n            this._usingSmtpUtf8 = true;\n        }\n\n        // If the server supports 8BITMIME and the message might contain non-ascii bytes\n        // then append the 8BITMIME keyword to the MAIL FROM command\n        if (this._envelope.use8BitMime && this._supportedExtensions.includes('8BITMIME')) {\n            args.push('BODY=8BITMIME');\n            this._using8BitMime = true;\n        }\n\n        if (this._envelope.size && this._supportedExtensions.includes('SIZE')) {\n            args.push('SIZE=' + this._envelope.size);\n        }\n\n        // If the server supports DSN and the envelope includes an DSN prop\n        // then append DSN params to the MAIL FROM command\n        if (this._envelope.dsn && this._supportedExtensions.includes('DSN')) {\n            if (this._envelope.dsn.ret) {\n                args.push('RET=' + shared.encodeXText(this._envelope.dsn.ret));\n            }\n            if (this._envelope.dsn.envid) {\n                args.push('ENVID=' + shared.encodeXText(this._envelope.dsn.envid));\n            }\n        }\n\n        this._sendCommand('MAIL FROM:<' + this._envelope.from + '>' + (args.length ? ' ' + args.join(' ') : ''));\n    }\n\n    _setDsnEnvelope(params) {\n        let ret = (params.ret || params.return || '').toString().toUpperCase() || null;\n        if (ret) {\n            switch (ret) {\n                case 'HDRS':\n                case 'HEADERS':\n                    ret = 'HDRS';\n                    break;\n                case 'FULL':\n                case 'BODY':\n                    ret = 'FULL';\n                    break;\n            }\n        }\n\n        if (ret && !['FULL', 'HDRS'].includes(ret)) {\n            throw new Error('ret: ' + JSON.stringify(ret));\n        }\n\n        let envid = (params.envid || params.id || '').toString() || null;\n\n        let notify = params.notify || null;\n        if (notify) {\n            if (typeof notify === 'string') {\n                notify = notify.split(',');\n            }\n            notify = notify.map(n => n.trim().toUpperCase());\n            let validNotify = ['NEVER', 'SUCCESS', 'FAILURE', 'DELAY'];\n            let invaliNotify = notify.filter(n => !validNotify.includes(n));\n            if (invaliNotify.length || (notify.length > 1 && notify.includes('NEVER'))) {\n                throw new Error('notify: ' + JSON.stringify(notify.join(',')));\n            }\n            notify = notify.join(',');\n        }\n\n        let orcpt = (params.recipient || params.orcpt || '').toString() || null;\n        if (orcpt && orcpt.indexOf(';') < 0) {\n            orcpt = 'rfc822;' + orcpt;\n        }\n\n        return {\n            ret,\n            envid,\n            notify,\n            orcpt\n        };\n    }\n\n    _getDsnRcptToArgs() {\n        let args = [];\n        // If the server supports DSN and the envelope includes an DSN prop\n        // then append DSN params to the RCPT TO command\n        if (this._envelope.dsn && this._supportedExtensions.includes('DSN')) {\n            if (this._envelope.dsn.notify) {\n                args.push('NOTIFY=' + shared.encodeXText(this._envelope.dsn.notify));\n            }\n            if (this._envelope.dsn.orcpt) {\n                args.push('ORCPT=' + shared.encodeXText(this._envelope.dsn.orcpt));\n            }\n        }\n        return args.length ? ' ' + args.join(' ') : '';\n    }\n\n    _createSendStream(callback) {\n        let dataStream = new DataStream();\n        let logStream;\n\n        if (this.options.lmtp) {\n            this._envelope.accepted.forEach((recipient, i) => {\n                let final = i === this._envelope.accepted.length - 1;\n                this._responseActions.push(str => {\n                    this._actionLMTPStream(recipient, final, str, callback);\n                });\n            });\n        } else {\n            this._responseActions.push(str => {\n                this._actionSMTPStream(str, callback);\n            });\n        }\n\n        dataStream.pipe(this._socket, {\n            end: false\n        });\n\n        if (this.options.debug) {\n            logStream = new PassThrough();\n            logStream.on('readable', () => {\n                let chunk;\n                while ((chunk = logStream.read())) {\n                    this.logger.debug(\n                        {\n                            tnx: 'message'\n                        },\n                        chunk.toString('binary').replace(/\\r?\\n$/, '')\n                    );\n                }\n            });\n            dataStream.pipe(logStream);\n        }\n\n        dataStream.once('end', () => {\n            this.logger.info(\n                {\n                    tnx: 'message',\n                    inByteCount: dataStream.inByteCount,\n                    outByteCount: dataStream.outByteCount\n                },\n                '<%s bytes encoded mime message (source size %s bytes)>',\n                dataStream.outByteCount,\n                dataStream.inByteCount\n            );\n        });\n\n        return dataStream;\n    }\n\n    /** ACTIONS **/\n\n    /**\n     * Will be run after the connection is created and the server sends\n     * a greeting. If the incoming message starts with 220 initiate\n     * SMTP session by sending EHLO command\n     *\n     * @param {String} str Message from the server\n     */\n    _actionGreeting(str) {\n        clearTimeout(this._greetingTimeout);\n\n        if (str.substr(0, 3) !== '220') {\n            this._onError(new Error('Invalid greeting. response=' + str), 'EPROTOCOL', str, 'CONN');\n            return;\n        }\n\n        if (this.options.lmtp) {\n            this._responseActions.push(this._actionLHLO);\n            this._sendCommand('LHLO ' + this.name);\n        } else {\n            this._responseActions.push(this._actionEHLO);\n            this._sendCommand('EHLO ' + this.name);\n        }\n    }\n\n    /**\n     * Handles server response for LHLO command. If it yielded in\n     * error, emit 'error', otherwise treat this as an EHLO response\n     *\n     * @param {String} str Message from the server\n     */\n    _actionLHLO(str) {\n        if (str.charAt(0) !== '2') {\n            this._onError(new Error('Invalid LHLO. response=' + str), 'EPROTOCOL', str, 'LHLO');\n            return;\n        }\n\n        this._actionEHLO(str);\n    }\n\n    /**\n     * Handles server response for EHLO command. If it yielded in\n     * error, try HELO instead, otherwise initiate TLS negotiation\n     * if STARTTLS is supported by the server or move into the\n     * authentication phase.\n     *\n     * @param {String} str Message from the server\n     */\n    _actionEHLO(str) {\n        let match;\n\n        if (str.substr(0, 3) === '421') {\n            this._onError(new Error('Server terminates connection. response=' + str), 'ECONNECTION', str, 'EHLO');\n            return;\n        }\n\n        if (str.charAt(0) !== '2') {\n            if (this.options.requireTLS) {\n                this._onError(new Error('EHLO failed but HELO does not support required STARTTLS. response=' + str), 'ECONNECTION', str, 'EHLO');\n                return;\n            }\n\n            // Try HELO instead\n            this._responseActions.push(this._actionHELO);\n            this._sendCommand('HELO ' + this.name);\n            return;\n        }\n\n        this._ehloLines = str\n            .split(/\\r?\\n/)\n            .map(line => line.replace(/^\\d+[ -]/, '').trim())\n            .filter(line => line)\n            .slice(1);\n\n        // Detect if the server supports STARTTLS\n        if (!this.secure && !this.options.ignoreTLS && (/[ -]STARTTLS\\b/im.test(str) || this.options.requireTLS)) {\n            this._sendCommand('STARTTLS');\n            this._responseActions.push(this._actionSTARTTLS);\n            return;\n        }\n\n        // Detect if the server supports SMTPUTF8\n        if (/[ -]SMTPUTF8\\b/im.test(str)) {\n            this._supportedExtensions.push('SMTPUTF8');\n        }\n\n        // Detect if the server supports DSN\n        if (/[ -]DSN\\b/im.test(str)) {\n            this._supportedExtensions.push('DSN');\n        }\n\n        // Detect if the server supports 8BITMIME\n        if (/[ -]8BITMIME\\b/im.test(str)) {\n            this._supportedExtensions.push('8BITMIME');\n        }\n\n        // Detect if the server supports PIPELINING\n        if (/[ -]PIPELINING\\b/im.test(str)) {\n            this._supportedExtensions.push('PIPELINING');\n        }\n\n        // Detect if the server supports AUTH\n        if (/[ -]AUTH\\b/i.test(str)) {\n            this.allowsAuth = true;\n        }\n\n        // Detect if the server supports PLAIN auth\n        if (/[ -]AUTH(?:(\\s+|=)[^\\n]*\\s+|\\s+|=)PLAIN/i.test(str)) {\n            this._supportedAuth.push('PLAIN');\n        }\n\n        // Detect if the server supports LOGIN auth\n        if (/[ -]AUTH(?:(\\s+|=)[^\\n]*\\s+|\\s+|=)LOGIN/i.test(str)) {\n            this._supportedAuth.push('LOGIN');\n        }\n\n        // Detect if the server supports CRAM-MD5 auth\n        if (/[ -]AUTH(?:(\\s+|=)[^\\n]*\\s+|\\s+|=)CRAM-MD5/i.test(str)) {\n            this._supportedAuth.push('CRAM-MD5');\n        }\n\n        // Detect if the server supports XOAUTH2 auth\n        if (/[ -]AUTH(?:(\\s+|=)[^\\n]*\\s+|\\s+|=)XOAUTH2/i.test(str)) {\n            this._supportedAuth.push('XOAUTH2');\n        }\n\n        // Detect if the server supports SIZE extensions (and the max allowed size)\n        if ((match = str.match(/[ -]SIZE(?:[ \\t]+(\\d+))?/im))) {\n            this._supportedExtensions.push('SIZE');\n            this._maxAllowedSize = Number(match[1]) || 0;\n        }\n\n        this.emit('connect');\n    }\n\n    /**\n     * Handles server response for HELO command. If it yielded in\n     * error, emit 'error', otherwise move into the authentication phase.\n     *\n     * @param {String} str Message from the server\n     */\n    _actionHELO(str) {\n        if (str.charAt(0) !== '2') {\n            this._onError(new Error('Invalid HELO. response=' + str), 'EPROTOCOL', str, 'HELO');\n            return;\n        }\n\n        // assume that authentication is enabled (most probably is not though)\n        this.allowsAuth = true;\n\n        this.emit('connect');\n    }\n\n    /**\n     * Handles server response for STARTTLS command. If there's an error\n     * try HELO instead, otherwise initiate TLS upgrade. If the upgrade\n     * succeedes restart the EHLO\n     *\n     * @param {String} str Message from the server\n     */\n    _actionSTARTTLS(str) {\n        if (str.charAt(0) !== '2') {\n            if (this.options.opportunisticTLS) {\n                this.logger.info(\n                    {\n                        tnx: 'smtp'\n                    },\n                    'Failed STARTTLS upgrade, continuing unencrypted'\n                );\n                return this.emit('connect');\n            }\n            this._onError(new Error('Error upgrading connection with STARTTLS'), 'ETLS', str, 'STARTTLS');\n            return;\n        }\n\n        this._upgradeConnection((err, secured) => {\n            if (err) {\n                this._onError(new Error('Error initiating TLS - ' + (err.message || err)), 'ETLS', false, 'STARTTLS');\n                return;\n            }\n\n            this.logger.info(\n                {\n                    tnx: 'smtp'\n                },\n                'Connection upgraded with STARTTLS'\n            );\n\n            if (secured) {\n                // restart session\n                if (this.options.lmtp) {\n                    this._responseActions.push(this._actionLHLO);\n                    this._sendCommand('LHLO ' + this.name);\n                } else {\n                    this._responseActions.push(this._actionEHLO);\n                    this._sendCommand('EHLO ' + this.name);\n                }\n            } else {\n                this.emit('connect');\n            }\n        });\n    }\n\n    /**\n     * Handle the response for AUTH LOGIN command. We are expecting\n     * '334 VXNlcm5hbWU6' (base64 for 'Username:'). Data to be sent as\n     * response needs to be base64 encoded username. We do not need\n     * exact match but settle with 334 response in general as some\n     * hosts invalidly use a longer message than VXNlcm5hbWU6\n     *\n     * @param {String} str Message from the server\n     */\n    _actionAUTH_LOGIN_USER(str, callback) {\n        if (!/^334[ -]/.test(str)) {\n            // expecting '334 VXNlcm5hbWU6'\n            callback(this._formatError('Invalid login sequence while waiting for \"334 VXNlcm5hbWU6\"', 'EAUTH', str, 'AUTH LOGIN'));\n            return;\n        }\n\n        this._responseActions.push(str => {\n            this._actionAUTH_LOGIN_PASS(str, callback);\n        });\n\n        this._sendCommand(Buffer.from(this._auth.credentials.user + '', 'utf-8').toString('base64'));\n    }\n\n    /**\n     * Handle the response for AUTH CRAM-MD5 command. We are expecting\n     * '334 <challenge string>'. Data to be sent as response needs to be\n     * base64 decoded challenge string, MD5 hashed using the password as\n     * a HMAC key, prefixed by the username and a space, and finally all\n     * base64 encoded again.\n     *\n     * @param {String} str Message from the server\n     */\n    _actionAUTH_CRAM_MD5(str, callback) {\n        let challengeMatch = str.match(/^334\\s+(.+)$/);\n        let challengeString = '';\n\n        if (!challengeMatch) {\n            return callback(this._formatError('Invalid login sequence while waiting for server challenge string', 'EAUTH', str, 'AUTH CRAM-MD5'));\n        } else {\n            challengeString = challengeMatch[1];\n        }\n\n        // Decode from base64\n        let base64decoded = Buffer.from(challengeString, 'base64').toString('ascii'),\n            hmacMD5 = crypto.createHmac('md5', this._auth.credentials.pass);\n\n        hmacMD5.update(base64decoded);\n\n        let prepended = this._auth.credentials.user + ' ' + hmacMD5.digest('hex');\n\n        this._responseActions.push(str => {\n            this._actionAUTH_CRAM_MD5_PASS(str, callback);\n        });\n\n        this._sendCommand(\n            Buffer.from(prepended).toString('base64'),\n            // hidden hash for logs\n            Buffer.from(this._auth.credentials.user + ' /* secret */').toString('base64')\n        );\n    }\n\n    /**\n     * Handles the response to CRAM-MD5 authentication, if there's no error,\n     * the user can be considered logged in. Start waiting for a message to send\n     *\n     * @param {String} str Message from the server\n     */\n    _actionAUTH_CRAM_MD5_PASS(str, callback) {\n        if (!str.match(/^235\\s+/)) {\n            return callback(this._formatError('Invalid login sequence while waiting for \"235\"', 'EAUTH', str, 'AUTH CRAM-MD5'));\n        }\n\n        this.logger.info(\n            {\n                tnx: 'smtp',\n                username: this._auth.user,\n                action: 'authenticated',\n                method: this._authMethod\n            },\n            'User %s authenticated',\n            JSON.stringify(this._auth.user)\n        );\n        this.authenticated = true;\n        callback(null, true);\n    }\n\n    /**\n     * Handle the response for AUTH LOGIN command. We are expecting\n     * '334 UGFzc3dvcmQ6' (base64 for 'Password:'). Data to be sent as\n     * response needs to be base64 encoded password.\n     *\n     * @param {String} str Message from the server\n     */\n    _actionAUTH_LOGIN_PASS(str, callback) {\n        if (!/^334[ -]/.test(str)) {\n            // expecting '334 UGFzc3dvcmQ6'\n            return callback(this._formatError('Invalid login sequence while waiting for \"334 UGFzc3dvcmQ6\"', 'EAUTH', str, 'AUTH LOGIN'));\n        }\n\n        this._responseActions.push(str => {\n            this._actionAUTHComplete(str, callback);\n        });\n\n        this._sendCommand(\n            Buffer.from((this._auth.credentials.pass || '').toString(), 'utf-8').toString('base64'),\n            // Hidden pass for logs\n            Buffer.from('/* secret */', 'utf-8').toString('base64')\n        );\n    }\n\n    /**\n     * Handles the response for authentication, if there's no error,\n     * the user can be considered logged in. Start waiting for a message to send\n     *\n     * @param {String} str Message from the server\n     */\n    _actionAUTHComplete(str, isRetry, callback) {\n        if (!callback && typeof isRetry === 'function') {\n            callback = isRetry;\n            isRetry = false;\n        }\n\n        if (str.substr(0, 3) === '334') {\n            this._responseActions.push(str => {\n                if (isRetry || this._authMethod !== 'XOAUTH2') {\n                    this._actionAUTHComplete(str, true, callback);\n                } else {\n                    // fetch a new OAuth2 access token\n                    setImmediate(() => this._handleXOauth2Token(true, callback));\n                }\n            });\n            this._sendCommand('');\n            return;\n        }\n\n        if (str.charAt(0) !== '2') {\n            this.logger.info(\n                {\n                    tnx: 'smtp',\n                    username: this._auth.user,\n                    action: 'authfail',\n                    method: this._authMethod\n                },\n                'User %s failed to authenticate',\n                JSON.stringify(this._auth.user)\n            );\n            return callback(this._formatError('Invalid login', 'EAUTH', str, 'AUTH ' + this._authMethod));\n        }\n\n        this.logger.info(\n            {\n                tnx: 'smtp',\n                username: this._auth.user,\n                action: 'authenticated',\n                method: this._authMethod\n            },\n            'User %s authenticated',\n            JSON.stringify(this._auth.user)\n        );\n        this.authenticated = true;\n        callback(null, true);\n    }\n\n    /**\n     * Handle response for a MAIL FROM: command\n     *\n     * @param {String} str Message from the server\n     */\n    _actionMAIL(str, callback) {\n        let message, curRecipient;\n        if (Number(str.charAt(0)) !== 2) {\n            if (this._usingSmtpUtf8 && /^550 /.test(str) && /[\\x80-\\uFFFF]/.test(this._envelope.from)) {\n                message = 'Internationalized mailbox name not allowed';\n            } else {\n                message = 'Mail command failed';\n            }\n            return callback(this._formatError(message, 'EENVELOPE', str, 'MAIL FROM'));\n        }\n\n        if (!this._envelope.rcptQueue.length) {\n            return callback(this._formatError('Can\\x27t send mail - no recipients defined', 'EENVELOPE', false, 'API'));\n        } else {\n            this._recipientQueue = [];\n\n            if (this._supportedExtensions.includes('PIPELINING')) {\n                while (this._envelope.rcptQueue.length) {\n                    curRecipient = this._envelope.rcptQueue.shift();\n                    this._recipientQueue.push(curRecipient);\n                    this._responseActions.push(str => {\n                        this._actionRCPT(str, callback);\n                    });\n                    this._sendCommand('RCPT TO:<' + curRecipient + '>' + this._getDsnRcptToArgs());\n                }\n            } else {\n                curRecipient = this._envelope.rcptQueue.shift();\n                this._recipientQueue.push(curRecipient);\n                this._responseActions.push(str => {\n                    this._actionRCPT(str, callback);\n                });\n                this._sendCommand('RCPT TO:<' + curRecipient + '>' + this._getDsnRcptToArgs());\n            }\n        }\n    }\n\n    /**\n     * Handle response for a RCPT TO: command\n     *\n     * @param {String} str Message from the server\n     */\n    _actionRCPT(str, callback) {\n        let message,\n            err,\n            curRecipient = this._recipientQueue.shift();\n        if (Number(str.charAt(0)) !== 2) {\n            // this is a soft error\n            if (this._usingSmtpUtf8 && /^553 /.test(str) && /[\\x80-\\uFFFF]/.test(curRecipient)) {\n                message = 'Internationalized mailbox name not allowed';\n            } else {\n                message = 'Recipient command failed';\n            }\n            this._envelope.rejected.push(curRecipient);\n            // store error for the failed recipient\n            err = this._formatError(message, 'EENVELOPE', str, 'RCPT TO');\n            err.recipient = curRecipient;\n            this._envelope.rejectedErrors.push(err);\n        } else {\n            this._envelope.accepted.push(curRecipient);\n        }\n\n        if (!this._envelope.rcptQueue.length && !this._recipientQueue.length) {\n            if (this._envelope.rejected.length < this._envelope.to.length) {\n                this._responseActions.push(str => {\n                    this._actionDATA(str, callback);\n                });\n                this._sendCommand('DATA');\n            } else {\n                err = this._formatError('Can\\x27t send mail - all recipients were rejected', 'EENVELOPE', str, 'RCPT TO');\n                err.rejected = this._envelope.rejected;\n                err.rejectedErrors = this._envelope.rejectedErrors;\n                return callback(err);\n            }\n        } else if (this._envelope.rcptQueue.length) {\n            curRecipient = this._envelope.rcptQueue.shift();\n            this._recipientQueue.push(curRecipient);\n            this._responseActions.push(str => {\n                this._actionRCPT(str, callback);\n            });\n            this._sendCommand('RCPT TO:<' + curRecipient + '>' + this._getDsnRcptToArgs());\n        }\n    }\n\n    /**\n     * Handle response for a DATA command\n     *\n     * @param {String} str Message from the server\n     */\n    _actionDATA(str, callback) {\n        // response should be 354 but according to this issue https://github.com/eleith/emailjs/issues/24\n        // some servers might use 250 instead, so lets check for 2 or 3 as the first digit\n        if (!/^[23]/.test(str)) {\n            return callback(this._formatError('Data command failed', 'EENVELOPE', str, 'DATA'));\n        }\n\n        let response = {\n            accepted: this._envelope.accepted,\n            rejected: this._envelope.rejected\n        };\n\n        if (this._ehloLines && this._ehloLines.length) {\n            response.ehlo = this._ehloLines;\n        }\n\n        if (this._envelope.rejectedErrors.length) {\n            response.rejectedErrors = this._envelope.rejectedErrors;\n        }\n\n        callback(null, response);\n    }\n\n    /**\n     * Handle response for a DATA stream when using SMTP\n     * We expect a single response that defines if the sending succeeded or failed\n     *\n     * @param {String} str Message from the server\n     */\n    _actionSMTPStream(str, callback) {\n        if (Number(str.charAt(0)) !== 2) {\n            // Message failed\n            return callback(this._formatError('Message failed', 'EMESSAGE', str, 'DATA'));\n        } else {\n            // Message sent succesfully\n            return callback(null, str);\n        }\n    }\n\n    /**\n     * Handle response for a DATA stream\n     * We expect a separate response for every recipient. All recipients can either\n     * succeed or fail separately\n     *\n     * @param {String} recipient The recipient this response applies to\n     * @param {Boolean} final Is this the final recipient?\n     * @param {String} str Message from the server\n     */\n    _actionLMTPStream(recipient, final, str, callback) {\n        let err;\n        if (Number(str.charAt(0)) !== 2) {\n            // Message failed\n            err = this._formatError('Message failed for recipient ' + recipient, 'EMESSAGE', str, 'DATA');\n            err.recipient = recipient;\n            this._envelope.rejected.push(recipient);\n            this._envelope.rejectedErrors.push(err);\n            for (let i = 0, len = this._envelope.accepted.length; i < len; i++) {\n                if (this._envelope.accepted[i] === recipient) {\n                    this._envelope.accepted.splice(i, 1);\n                }\n            }\n        }\n        if (final) {\n            return callback(null, str);\n        }\n    }\n\n    _handleXOauth2Token(isRetry, callback) {\n        this._auth.oauth2.getToken(isRetry, (err, accessToken) => {\n            if (err) {\n                this.logger.info(\n                    {\n                        tnx: 'smtp',\n                        username: this._auth.user,\n                        action: 'authfail',\n                        method: this._authMethod\n                    },\n                    'User %s failed to authenticate',\n                    JSON.stringify(this._auth.user)\n                );\n                return callback(this._formatError(err, 'EAUTH', false, 'AUTH XOAUTH2'));\n            }\n            this._responseActions.push(str => {\n                this._actionAUTHComplete(str, isRetry, callback);\n            });\n            this._sendCommand(\n                'AUTH XOAUTH2 ' + this._auth.oauth2.buildXOAuth2Token(accessToken),\n                //  Hidden for logs\n                'AUTH XOAUTH2 ' + this._auth.oauth2.buildXOAuth2Token('/* secret */')\n            );\n        });\n    }\n\n    /**\n     *\n     * @param {string} command\n     * @private\n     */\n    _isDestroyedMessage(command) {\n        if (this._destroyed) {\n            return 'Cannot ' + command + ' - smtp connection is already destroyed.';\n        }\n\n        if (this._socket) {\n            if (this._socket.destroyed) {\n                return 'Cannot ' + command + ' - smtp connection socket is already destroyed.';\n            }\n\n            if (!this._socket.writable) {\n                return 'Cannot ' + command + ' - smtp connection socket is already half-closed.';\n            }\n        }\n    }\n\n    _getHostname() {\n        // defaul hostname is machine hostname or [IP]\n        let defaultHostname;\n        try {\n            defaultHostname = os.hostname() || '';\n        } catch (err) {\n            // fails on windows 7\n            defaultHostname = 'localhost';\n        }\n\n        // ignore if not FQDN\n        if (!defaultHostname || defaultHostname.indexOf('.') < 0) {\n            defaultHostname = '[127.0.0.1]';\n        }\n\n        // IP should be enclosed in []\n        if (defaultHostname.match(/^\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}$/)) {\n            defaultHostname = '[' + defaultHostname + ']';\n        }\n\n        return defaultHostname;\n    }\n}\n\nmodule.exports = SMTPConnection;\n","'use strict';\n\nconst stream = require('stream');\nconst Transform = stream.Transform;\n\n/**\n * Escapes dots in the beginning of lines. Ends the stream with <CR><LF>.<CR><LF>\n * Also makes sure that only <CR><LF> sequences are used for linebreaks\n *\n * @param {Object} options Stream options\n */\nclass DataStream extends Transform {\n    constructor(options) {\n        super(options);\n        // init Transform\n        this.options = options || {};\n        this._curLine = '';\n\n        this.inByteCount = 0;\n        this.outByteCount = 0;\n        this.lastByte = false;\n    }\n\n    /**\n     * Escapes dots\n     */\n    _transform(chunk, encoding, done) {\n        let chunks = [];\n        let chunklen = 0;\n        let i,\n            len,\n            lastPos = 0;\n        let buf;\n\n        if (!chunk || !chunk.length) {\n            return done();\n        }\n\n        if (typeof chunk === 'string') {\n            chunk = Buffer.from(chunk);\n        }\n\n        this.inByteCount += chunk.length;\n\n        for (i = 0, len = chunk.length; i < len; i++) {\n            if (chunk[i] === 0x2e) {\n                // .\n                if ((i && chunk[i - 1] === 0x0a) || (!i && (!this.lastByte || this.lastByte === 0x0a))) {\n                    buf = chunk.slice(lastPos, i + 1);\n                    chunks.push(buf);\n                    chunks.push(Buffer.from('.'));\n                    chunklen += buf.length + 1;\n                    lastPos = i + 1;\n                }\n            } else if (chunk[i] === 0x0a) {\n                // .\n                if ((i && chunk[i - 1] !== 0x0d) || (!i && this.lastByte !== 0x0d)) {\n                    if (i > lastPos) {\n                        buf = chunk.slice(lastPos, i);\n                        chunks.push(buf);\n                        chunklen += buf.length + 2;\n                    } else {\n                        chunklen += 2;\n                    }\n                    chunks.push(Buffer.from('\\r\\n'));\n                    lastPos = i + 1;\n                }\n            }\n        }\n\n        if (chunklen) {\n            // add last piece\n            if (lastPos < chunk.length) {\n                buf = chunk.slice(lastPos);\n                chunks.push(buf);\n                chunklen += buf.length;\n            }\n\n            this.outByteCount += chunklen;\n            this.push(Buffer.concat(chunks, chunklen));\n        } else {\n            this.outByteCount += chunk.length;\n            this.push(chunk);\n        }\n\n        this.lastByte = chunk[chunk.length - 1];\n        done();\n    }\n\n    /**\n     * Finalizes the stream with a dot on a single line\n     */\n    _flush(done) {\n        let buf;\n        if (this.lastByte === 0x0a) {\n            buf = Buffer.from('.\\r\\n');\n        } else if (this.lastByte === 0x0d) {\n            buf = Buffer.from('\\n.\\r\\n');\n        } else {\n            buf = Buffer.from('\\r\\n.\\r\\n');\n        }\n        this.outByteCount += buf.length;\n        this.push(buf);\n        done();\n    }\n}\n\nmodule.exports = DataStream;\n","'use strict';\n\nconst Stream = require('stream').Stream;\nconst nmfetch = require('../fetch');\nconst crypto = require('crypto');\nconst shared = require('../shared');\n\n/**\n * XOAUTH2 access_token generator for Gmail.\n * Create client ID for web applications in Google API console to use it.\n * See Offline Access for receiving the needed refreshToken for an user\n * https://developers.google.com/accounts/docs/OAuth2WebServer#offline\n *\n * Usage for generating access tokens with a custom method using provisionCallback:\n * provisionCallback(user, renew, callback)\n *   * user is the username to get the token for\n *   * renew is a boolean that if true indicates that existing token failed and needs to be renewed\n *   * callback is the callback to run with (error, accessToken [, expires])\n *     * accessToken is a string\n *     * expires is an optional expire time in milliseconds\n * If provisionCallback is used, then Nodemailer does not try to attempt generating the token by itself\n *\n * @constructor\n * @param {Object} options Client information for token generation\n * @param {String} options.user User e-mail address\n * @param {String} options.clientId Client ID value\n * @param {String} options.clientSecret Client secret value\n * @param {String} options.refreshToken Refresh token for an user\n * @param {String} options.accessUrl Endpoint for token generation, defaults to 'https://accounts.google.com/o/oauth2/token'\n * @param {String} options.accessToken An existing valid accessToken\n * @param {String} options.privateKey Private key for JSW\n * @param {Number} options.expires Optional Access Token expire time in ms\n * @param {Number} options.timeout Optional TTL for Access Token in seconds\n * @param {Function} options.provisionCallback Function to run when a new access token is required\n */\nclass XOAuth2 extends Stream {\n    constructor(options, logger) {\n        super();\n\n        this.options = options || {};\n\n        if (options && options.serviceClient) {\n            if (!options.privateKey || !options.user) {\n                setImmediate(() => this.emit('error', new Error('Options \"privateKey\" and \"user\" are required for service account!')));\n                return;\n            }\n\n            let serviceRequestTimeout = Math.min(Math.max(Number(this.options.serviceRequestTimeout) || 0, 0), 3600);\n            this.options.serviceRequestTimeout = serviceRequestTimeout || 5 * 60;\n        }\n\n        this.logger = shared.getLogger(\n            {\n                logger\n            },\n            {\n                component: this.options.component || 'OAuth2'\n            }\n        );\n\n        this.provisionCallback = typeof this.options.provisionCallback === 'function' ? this.options.provisionCallback : false;\n\n        this.options.accessUrl = this.options.accessUrl || 'https://accounts.google.com/o/oauth2/token';\n        this.options.customHeaders = this.options.customHeaders || {};\n        this.options.customParams = this.options.customParams || {};\n\n        this.accessToken = this.options.accessToken || false;\n\n        if (this.options.expires && Number(this.options.expires)) {\n            this.expires = this.options.expires;\n        } else {\n            let timeout = Math.max(Number(this.options.timeout) || 0, 0);\n            this.expires = (timeout && Date.now() + timeout * 1000) || 0;\n        }\n    }\n\n    /**\n     * Returns or generates (if previous has expired) a XOAuth2 token\n     *\n     * @param {Boolean} renew If false then use cached access token (if available)\n     * @param {Function} callback Callback function with error object and token string\n     */\n    getToken(renew, callback) {\n        if (!renew && this.accessToken && (!this.expires || this.expires > Date.now())) {\n            return callback(null, this.accessToken);\n        }\n\n        let generateCallback = (...args) => {\n            if (args[0]) {\n                this.logger.error(\n                    {\n                        err: args[0],\n                        tnx: 'OAUTH2',\n                        user: this.options.user,\n                        action: 'renew'\n                    },\n                    'Failed generating new Access Token for %s',\n                    this.options.user\n                );\n            } else {\n                this.logger.info(\n                    {\n                        tnx: 'OAUTH2',\n                        user: this.options.user,\n                        action: 'renew'\n                    },\n                    'Generated new Access Token for %s',\n                    this.options.user\n                );\n            }\n            callback(...args);\n        };\n\n        if (this.provisionCallback) {\n            this.provisionCallback(this.options.user, !!renew, (err, accessToken, expires) => {\n                if (!err && accessToken) {\n                    this.accessToken = accessToken;\n                    this.expires = expires || 0;\n                }\n                generateCallback(err, accessToken);\n            });\n        } else {\n            this.generateToken(generateCallback);\n        }\n    }\n\n    /**\n     * Updates token values\n     *\n     * @param {String} accessToken New access token\n     * @param {Number} timeout Access token lifetime in seconds\n     *\n     * Emits 'token': { user: User email-address, accessToken: the new accessToken, timeout: TTL in seconds}\n     */\n    updateToken(accessToken, timeout) {\n        this.accessToken = accessToken;\n        timeout = Math.max(Number(timeout) || 0, 0);\n        this.expires = (timeout && Date.now() + timeout * 1000) || 0;\n\n        this.emit('token', {\n            user: this.options.user,\n            accessToken: accessToken || '',\n            expires: this.expires\n        });\n    }\n\n    /**\n     * Generates a new XOAuth2 token with the credentials provided at initialization\n     *\n     * @param {Function} callback Callback function with error object and token string\n     */\n    generateToken(callback) {\n        let urlOptions;\n        let loggedUrlOptions;\n        if (this.options.serviceClient) {\n            // service account - https://developers.google.com/identity/protocols/OAuth2ServiceAccount\n            let iat = Math.floor(Date.now() / 1000); // unix time\n            let tokenData = {\n                iss: this.options.serviceClient,\n                scope: this.options.scope || 'https://mail.google.com/',\n                sub: this.options.user,\n                aud: this.options.accessUrl,\n                iat,\n                exp: iat + this.options.serviceRequestTimeout\n            };\n            let token;\n            try {\n                token = this.jwtSignRS256(tokenData);\n            } catch (err) {\n                return callback(new Error('Can\\x27t generate token. Check your auth options'));\n            }\n\n            urlOptions = {\n                grant_type: 'urn:ietf:params:oauth:grant-type:jwt-bearer',\n                assertion: token\n            };\n\n            loggedUrlOptions = {\n                grant_type: 'urn:ietf:params:oauth:grant-type:jwt-bearer',\n                assertion: tokenData\n            };\n        } else {\n            if (!this.options.refreshToken) {\n                return callback(new Error('Can\\x27t create new access token for user'));\n            }\n\n            // web app - https://developers.google.com/identity/protocols/OAuth2WebServer\n            urlOptions = {\n                client_id: this.options.clientId || '',\n                client_secret: this.options.clientSecret || '',\n                refresh_token: this.options.refreshToken,\n                grant_type: 'refresh_token'\n            };\n\n            loggedUrlOptions = {\n                client_id: this.options.clientId || '',\n                client_secret: (this.options.clientSecret || '').substr(0, 6) + '...',\n                refresh_token: (this.options.refreshToken || '').substr(0, 6) + '...',\n                grant_type: 'refresh_token'\n            };\n        }\n\n        Object.keys(this.options.customParams).forEach(key => {\n            urlOptions[key] = this.options.customParams[key];\n            loggedUrlOptions[key] = this.options.customParams[key];\n        });\n\n        this.logger.debug(\n            {\n                tnx: 'OAUTH2',\n                user: this.options.user,\n                action: 'generate'\n            },\n            'Requesting token using: %s',\n            JSON.stringify(loggedUrlOptions)\n        );\n\n        this.postRequest(this.options.accessUrl, urlOptions, this.options, (error, body) => {\n            let data;\n\n            if (error) {\n                return callback(error);\n            }\n\n            try {\n                data = JSON.parse(body.toString());\n            } catch (E) {\n                return callback(E);\n            }\n\n            if (!data || typeof data !== 'object') {\n                this.logger.debug(\n                    {\n                        tnx: 'OAUTH2',\n                        user: this.options.user,\n                        action: 'post'\n                    },\n                    'Response: %s',\n                    (body || '').toString()\n                );\n                return callback(new Error('Invalid authentication response'));\n            }\n\n            let logData = {};\n            Object.keys(data).forEach(key => {\n                if (key !== 'access_token') {\n                    logData[key] = data[key];\n                } else {\n                    logData[key] = (data[key] || '').toString().substr(0, 6) + '...';\n                }\n            });\n\n            this.logger.debug(\n                {\n                    tnx: 'OAUTH2',\n                    user: this.options.user,\n                    action: 'post'\n                },\n                'Response: %s',\n                JSON.stringify(logData)\n            );\n\n            if (data.error) {\n                // Error Response : https://tools.ietf.org/html/rfc6749#section-5.2\n                let errorMessage = data.error;\n                if (data.error_description) {\n                    errorMessage += ': ' + data.error_description;\n                }\n                if (data.error_uri) {\n                    errorMessage += ' (' + data.error_uri + ')';\n                }\n                return callback(new Error(errorMessage));\n            }\n\n            if (data.access_token) {\n                this.updateToken(data.access_token, data.expires_in);\n                return callback(null, this.accessToken);\n            }\n\n            return callback(new Error('No access token'));\n        });\n    }\n\n    /**\n     * Converts an access_token and user id into a base64 encoded XOAuth2 token\n     *\n     * @param {String} [accessToken] Access token string\n     * @return {String} Base64 encoded token for IMAP or SMTP login\n     */\n    buildXOAuth2Token(accessToken) {\n        let authData = ['user=' + (this.options.user || ''), 'auth=Bearer ' + (accessToken || this.accessToken), '', ''];\n        return Buffer.from(authData.join('\\x01'), 'utf-8').toString('base64');\n    }\n\n    /**\n     * Custom POST request handler.\n     * This is only needed to keep paths short in Windows – usually this module\n     * is a dependency of a dependency and if it tries to require something\n     * like the request module the paths get way too long to handle for Windows.\n     * As we do only a simple POST request we do not actually require complicated\n     * logic support (no redirects, no nothing) anyway.\n     *\n     * @param {String} url Url to POST to\n     * @param {String|Buffer} payload Payload to POST\n     * @param {Function} callback Callback function with (err, buff)\n     */\n    postRequest(url, payload, params, callback) {\n        let returned = false;\n\n        let chunks = [];\n        let chunklen = 0;\n\n        let req = nmfetch(url, {\n            method: 'post',\n            headers: params.customHeaders,\n            body: payload,\n            allowErrorResponse: true\n        });\n\n        req.on('readable', () => {\n            let chunk;\n            while ((chunk = req.read()) !== null) {\n                chunks.push(chunk);\n                chunklen += chunk.length;\n            }\n        });\n\n        req.once('error', err => {\n            if (returned) {\n                return;\n            }\n            returned = true;\n            return callback(err);\n        });\n\n        req.once('end', () => {\n            if (returned) {\n                return;\n            }\n            returned = true;\n            return callback(null, Buffer.concat(chunks, chunklen));\n        });\n    }\n\n    /**\n     * Encodes a buffer or a string into Base64url format\n     *\n     * @param {Buffer|String} data The data to convert\n     * @return {String} The encoded string\n     */\n    toBase64URL(data) {\n        if (typeof data === 'string') {\n            data = Buffer.from(data);\n        }\n\n        return data\n            .toString('base64')\n            .replace(/[=]+/g, '') // remove '='s\n            .replace(/\\+/g, '-') // '+' → '-'\n            .replace(/\\//g, '_'); // '/' → '_'\n    }\n\n    /**\n     * Creates a JSON Web Token signed with RS256 (SHA256 + RSA)\n     *\n     * @param {Object} payload The payload to include in the generated token\n     * @return {String} The generated and signed token\n     */\n    jwtSignRS256(payload) {\n        payload = ['{\"alg\":\"RS256\",\"typ\":\"JWT\"}', JSON.stringify(payload)].map(val => this.toBase64URL(val)).join('.');\n        let signature = crypto.createSign('RSA-SHA256').update(payload).sign(this.options.privateKey);\n        return payload + '.' + this.toBase64URL(signature);\n    }\n}\n\nmodule.exports = XOAuth2;\n","'use strict';\n\nconst services = require('./services.json');\nconst normalized = {};\n\nObject.keys(services).forEach(key => {\n    let service = services[key];\n\n    normalized[normalizeKey(key)] = normalizeService(service);\n\n    [].concat(service.aliases || []).forEach(alias => {\n        normalized[normalizeKey(alias)] = normalizeService(service);\n    });\n\n    [].concat(service.domains || []).forEach(domain => {\n        normalized[normalizeKey(domain)] = normalizeService(service);\n    });\n});\n\nfunction normalizeKey(key) {\n    return key.replace(/[^a-zA-Z0-9.-]/g, '').toLowerCase();\n}\n\nfunction normalizeService(service) {\n    let filter = ['domains', 'aliases'];\n    let response = {};\n\n    Object.keys(service).forEach(key => {\n        if (filter.indexOf(key) < 0) {\n            response[key] = service[key];\n        }\n    });\n\n    return response;\n}\n\n/**\n * Resolves SMTP config for given key. Key can be a name (like 'Gmail'), alias (like 'Google Mail') or\n * an email address (like 'test@googlemail.com').\n *\n * @param {String} key [description]\n * @returns {Object} SMTP config or false if not found\n */\nmodule.exports = function (key) {\n    key = normalizeKey(key.split('@').pop());\n    return normalized[key] || false;\n};\n","'use strict';\n\nconst EventEmitter = require('events');\nconst PoolResource = require('./pool-resource');\nconst SMTPConnection = require('../smtp-connection');\nconst wellKnown = require('../well-known');\nconst shared = require('../shared');\nconst packageData = require('../../package.json');\n\n/**\n * Creates a SMTP pool transport object for Nodemailer\n *\n * @constructor\n * @param {Object} options SMTP Connection options\n */\nclass SMTPPool extends EventEmitter {\n    constructor(options) {\n        super();\n\n        options = options || {};\n        if (typeof options === 'string') {\n            options = {\n                url: options\n            };\n        }\n\n        let urlData;\n        let service = options.service;\n\n        if (typeof options.getSocket === 'function') {\n            this.getSocket = options.getSocket;\n        }\n\n        if (options.url) {\n            urlData = shared.parseConnectionUrl(options.url);\n            service = service || urlData.service;\n        }\n\n        this.options = shared.assign(\n            false, // create new object\n            options, // regular options\n            urlData, // url options\n            service && wellKnown(service) // wellknown options\n        );\n\n        this.options.maxConnections = this.options.maxConnections || 5;\n        this.options.maxMessages = this.options.maxMessages || 100;\n\n        this.logger = shared.getLogger(this.options, {\n            component: this.options.component || 'smtp-pool'\n        });\n\n        // temporary object\n        let connection = new SMTPConnection(this.options);\n\n        this.name = 'SMTP (pool)';\n        this.version = packageData.version + '[client:' + connection.version + ']';\n\n        this._rateLimit = {\n            counter: 0,\n            timeout: null,\n            waiting: [],\n            checkpoint: false,\n            delta: Number(this.options.rateDelta) || 1000,\n            limit: Number(this.options.rateLimit) || 0\n        };\n        this._closed = false;\n        this._queue = [];\n        this._connections = [];\n        this._connectionCounter = 0;\n\n        this.idling = true;\n\n        setImmediate(() => {\n            if (this.idling) {\n                this.emit('idle');\n            }\n        });\n    }\n\n    /**\n     * Placeholder function for creating proxy sockets. This method immediatelly returns\n     * without a socket\n     *\n     * @param {Object} options Connection options\n     * @param {Function} callback Callback function to run with the socket keys\n     */\n    getSocket(options, callback) {\n        // return immediatelly\n        return setImmediate(() => callback(null, false));\n    }\n\n    /**\n     * Queues an e-mail to be sent using the selected settings\n     *\n     * @param {Object} mail Mail object\n     * @param {Function} callback Callback function\n     */\n    send(mail, callback) {\n        if (this._closed) {\n            return false;\n        }\n\n        this._queue.push({\n            mail,\n            requeueAttempts: 0,\n            callback\n        });\n\n        if (this.idling && this._queue.length >= this.options.maxConnections) {\n            this.idling = false;\n        }\n\n        setImmediate(() => this._processMessages());\n\n        return true;\n    }\n\n    /**\n     * Closes all connections in the pool. If there is a message being sent, the connection\n     * is closed later\n     */\n    close() {\n        let connection;\n        let len = this._connections.length;\n        this._closed = true;\n\n        // clear rate limit timer if it exists\n        clearTimeout(this._rateLimit.timeout);\n\n        if (!len && !this._queue.length) {\n            return;\n        }\n\n        // remove all available connections\n        for (let i = len - 1; i >= 0; i--) {\n            if (this._connections[i] && this._connections[i].available) {\n                connection = this._connections[i];\n                connection.close();\n                this.logger.info(\n                    {\n                        tnx: 'connection',\n                        cid: connection.id,\n                        action: 'removed'\n                    },\n                    'Connection #%s removed',\n                    connection.id\n                );\n            }\n        }\n\n        if (len && !this._connections.length) {\n            this.logger.debug(\n                {\n                    tnx: 'connection'\n                },\n                'All connections removed'\n            );\n        }\n\n        if (!this._queue.length) {\n            return;\n        }\n\n        // make sure that entire queue would be cleaned\n        let invokeCallbacks = () => {\n            if (!this._queue.length) {\n                this.logger.debug(\n                    {\n                        tnx: 'connection'\n                    },\n                    'Pending queue entries cleared'\n                );\n                return;\n            }\n            let entry = this._queue.shift();\n            if (entry && typeof entry.callback === 'function') {\n                try {\n                    entry.callback(new Error('Connection pool was closed'));\n                } catch (E) {\n                    this.logger.error(\n                        {\n                            err: E,\n                            tnx: 'callback',\n                            cid: connection.id\n                        },\n                        'Callback error for #%s: %s',\n                        connection.id,\n                        E.message\n                    );\n                }\n            }\n            setImmediate(invokeCallbacks);\n        };\n        setImmediate(invokeCallbacks);\n    }\n\n    /**\n     * Check the queue and available connections. If there is a message to be sent and there is\n     * an available connection, then use this connection to send the mail\n     */\n    _processMessages() {\n        let connection;\n        let i, len;\n\n        // do nothing if already closed\n        if (this._closed) {\n            return;\n        }\n\n        // do nothing if queue is empty\n        if (!this._queue.length) {\n            if (!this.idling) {\n                // no pending jobs\n                this.idling = true;\n                this.emit('idle');\n            }\n            return;\n        }\n\n        // find first available connection\n        for (i = 0, len = this._connections.length; i < len; i++) {\n            if (this._connections[i].available) {\n                connection = this._connections[i];\n                break;\n            }\n        }\n\n        if (!connection && this._connections.length < this.options.maxConnections) {\n            connection = this._createConnection();\n        }\n\n        if (!connection) {\n            // no more free connection slots available\n            this.idling = false;\n            return;\n        }\n\n        // check if there is free space in the processing queue\n        if (!this.idling && this._queue.length < this.options.maxConnections) {\n            this.idling = true;\n            this.emit('idle');\n        }\n\n        let entry = (connection.queueEntry = this._queue.shift());\n        entry.messageId = (connection.queueEntry.mail.message.getHeader('message-id') || '').replace(/[<>\\s]/g, '');\n\n        connection.available = false;\n\n        this.logger.debug(\n            {\n                tnx: 'pool',\n                cid: connection.id,\n                messageId: entry.messageId,\n                action: 'assign'\n            },\n            'Assigned message <%s> to #%s (%s)',\n            entry.messageId,\n            connection.id,\n            connection.messages + 1\n        );\n\n        if (this._rateLimit.limit) {\n            this._rateLimit.counter++;\n            if (!this._rateLimit.checkpoint) {\n                this._rateLimit.checkpoint = Date.now();\n            }\n        }\n\n        connection.send(entry.mail, (err, info) => {\n            // only process callback if current handler is not changed\n            if (entry === connection.queueEntry) {\n                try {\n                    entry.callback(err, info);\n                } catch (E) {\n                    this.logger.error(\n                        {\n                            err: E,\n                            tnx: 'callback',\n                            cid: connection.id\n                        },\n                        'Callback error for #%s: %s',\n                        connection.id,\n                        E.message\n                    );\n                }\n                connection.queueEntry = false;\n            }\n        });\n    }\n\n    /**\n     * Creates a new pool resource\n     */\n    _createConnection() {\n        let connection = new PoolResource(this);\n\n        connection.id = ++this._connectionCounter;\n\n        this.logger.info(\n            {\n                tnx: 'pool',\n                cid: connection.id,\n                action: 'conection'\n            },\n            'Created new pool resource #%s',\n            connection.id\n        );\n\n        // resource comes available\n        connection.on('available', () => {\n            this.logger.debug(\n                {\n                    tnx: 'connection',\n                    cid: connection.id,\n                    action: 'available'\n                },\n                'Connection #%s became available',\n                connection.id\n            );\n\n            if (this._closed) {\n                // if already closed run close() that will remove this connections from connections list\n                this.close();\n            } else {\n                // check if there's anything else to send\n                this._processMessages();\n            }\n        });\n\n        // resource is terminated with an error\n        connection.once('error', err => {\n            if (err.code !== 'EMAXLIMIT') {\n                this.logger.error(\n                    {\n                        err,\n                        tnx: 'pool',\n                        cid: connection.id\n                    },\n                    'Pool Error for #%s: %s',\n                    connection.id,\n                    err.message\n                );\n            } else {\n                this.logger.debug(\n                    {\n                        tnx: 'pool',\n                        cid: connection.id,\n                        action: 'maxlimit'\n                    },\n                    'Max messages limit exchausted for #%s',\n                    connection.id\n                );\n            }\n\n            if (connection.queueEntry) {\n                try {\n                    connection.queueEntry.callback(err);\n                } catch (E) {\n                    this.logger.error(\n                        {\n                            err: E,\n                            tnx: 'callback',\n                            cid: connection.id\n                        },\n                        'Callback error for #%s: %s',\n                        connection.id,\n                        E.message\n                    );\n                }\n                connection.queueEntry = false;\n            }\n\n            // remove the erroneus connection from connections list\n            this._removeConnection(connection);\n\n            this._continueProcessing();\n        });\n\n        connection.once('close', () => {\n            this.logger.info(\n                {\n                    tnx: 'connection',\n                    cid: connection.id,\n                    action: 'closed'\n                },\n                'Connection #%s was closed',\n                connection.id\n            );\n\n            this._removeConnection(connection);\n\n            if (connection.queueEntry) {\n                // If the connection closed when sending, add the message to the queue again\n                // if max number of requeues is not reached yet\n                // Note that we must wait a bit.. because the callback of the 'error' handler might be called\n                // in the next event loop\n                setTimeout(() => {\n                    if (connection.queueEntry) {\n                        if (this._shouldRequeuOnConnectionClose(connection.queueEntry)) {\n                            this._requeueEntryOnConnectionClose(connection);\n                        } else {\n                            this._failDeliveryOnConnectionClose(connection);\n                        }\n                    }\n                    this._continueProcessing();\n                }, 50);\n            } else {\n                this._continueProcessing();\n            }\n        });\n\n        this._connections.push(connection);\n\n        return connection;\n    }\n\n    _shouldRequeuOnConnectionClose(queueEntry) {\n        if (this.options.maxRequeues === undefined || this.options.maxRequeues < 0) {\n            return true;\n        }\n\n        return queueEntry.requeueAttempts < this.options.maxRequeues;\n    }\n\n    _failDeliveryOnConnectionClose(connection) {\n        if (connection.queueEntry && connection.queueEntry.callback) {\n            try {\n                connection.queueEntry.callback(new Error('Reached maximum number of retries after connection was closed'));\n            } catch (E) {\n                this.logger.error(\n                    {\n                        err: E,\n                        tnx: 'callback',\n                        messageId: connection.queueEntry.messageId,\n                        cid: connection.id\n                    },\n                    'Callback error for #%s: %s',\n                    connection.id,\n                    E.message\n                );\n            }\n            connection.queueEntry = false;\n        }\n    }\n\n    _requeueEntryOnConnectionClose(connection) {\n        connection.queueEntry.requeueAttempts = connection.queueEntry.requeueAttempts + 1;\n        this.logger.debug(\n            {\n                tnx: 'pool',\n                cid: connection.id,\n                messageId: connection.queueEntry.messageId,\n                action: 'requeue'\n            },\n            'Re-queued message <%s> for #%s. Attempt: #%s',\n            connection.queueEntry.messageId,\n            connection.id,\n            connection.queueEntry.requeueAttempts\n        );\n        this._queue.unshift(connection.queueEntry);\n        connection.queueEntry = false;\n    }\n\n    /**\n     * Continue to process message if the pool hasn't closed\n     */\n    _continueProcessing() {\n        if (this._closed) {\n            this.close();\n        } else {\n            setTimeout(() => this._processMessages(), 100);\n        }\n    }\n\n    /**\n     * Remove resource from pool\n     *\n     * @param {Object} connection The PoolResource to remove\n     */\n    _removeConnection(connection) {\n        let index = this._connections.indexOf(connection);\n\n        if (index !== -1) {\n            this._connections.splice(index, 1);\n        }\n    }\n\n    /**\n     * Checks if connections have hit current rate limit and if so, queues the availability callback\n     *\n     * @param {Function} callback Callback function to run once rate limiter has been cleared\n     */\n    _checkRateLimit(callback) {\n        if (!this._rateLimit.limit) {\n            return callback();\n        }\n\n        let now = Date.now();\n\n        if (this._rateLimit.counter < this._rateLimit.limit) {\n            return callback();\n        }\n\n        this._rateLimit.waiting.push(callback);\n\n        if (this._rateLimit.checkpoint <= now - this._rateLimit.delta) {\n            return this._clearRateLimit();\n        } else if (!this._rateLimit.timeout) {\n            this._rateLimit.timeout = setTimeout(() => this._clearRateLimit(), this._rateLimit.delta - (now - this._rateLimit.checkpoint));\n            this._rateLimit.checkpoint = now;\n        }\n    }\n\n    /**\n     * Clears current rate limit limitation and runs paused callback\n     */\n    _clearRateLimit() {\n        clearTimeout(this._rateLimit.timeout);\n        this._rateLimit.timeout = null;\n        this._rateLimit.counter = 0;\n        this._rateLimit.checkpoint = false;\n\n        // resume all paused connections\n        while (this._rateLimit.waiting.length) {\n            let cb = this._rateLimit.waiting.shift();\n            setImmediate(cb);\n        }\n    }\n\n    /**\n     * Returns true if there are free slots in the queue\n     */\n    isIdle() {\n        return this.idling;\n    }\n\n    /**\n     * Verifies SMTP configuration\n     *\n     * @param {Function} callback Callback function\n     */\n    verify(callback) {\n        let promise;\n\n        if (!callback) {\n            promise = new Promise((resolve, reject) => {\n                callback = shared.callbackPromise(resolve, reject);\n            });\n        }\n\n        let auth = new PoolResource(this).auth;\n\n        this.getSocket(this.options, (err, socketOptions) => {\n            if (err) {\n                return callback(err);\n            }\n\n            let options = this.options;\n            if (socketOptions && socketOptions.connection) {\n                this.logger.info(\n                    {\n                        tnx: 'proxy',\n                        remoteAddress: socketOptions.connection.remoteAddress,\n                        remotePort: socketOptions.connection.remotePort,\n                        destHost: options.host || '',\n                        destPort: options.port || '',\n                        action: 'connected'\n                    },\n                    'Using proxied socket from %s:%s to %s:%s',\n                    socketOptions.connection.remoteAddress,\n                    socketOptions.connection.remotePort,\n                    options.host || '',\n                    options.port || ''\n                );\n                options = shared.assign(false, options);\n                Object.keys(socketOptions).forEach(key => {\n                    options[key] = socketOptions[key];\n                });\n            }\n\n            let connection = new SMTPConnection(options);\n            let returned = false;\n\n            connection.once('error', err => {\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                connection.close();\n                return callback(err);\n            });\n\n            connection.once('end', () => {\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                return callback(new Error('Connection closed'));\n            });\n\n            let finalize = () => {\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                connection.quit();\n                return callback(null, true);\n            };\n\n            connection.connect(() => {\n                if (returned) {\n                    return;\n                }\n\n                if (auth && (connection.allowsAuth || options.forceAuth)) {\n                    connection.login(auth, err => {\n                        if (returned) {\n                            return;\n                        }\n\n                        if (err) {\n                            returned = true;\n                            connection.close();\n                            return callback(err);\n                        }\n\n                        finalize();\n                    });\n                } else if (!auth && connection.allowsAuth && options.forceAuth) {\n                    let err = new Error('Authentication info was not provided');\n                    err.code = 'NoAuth';\n\n                    returned = true;\n                    connection.close();\n                    return callback(err);\n                } else {\n                    finalize();\n                }\n            });\n        });\n\n        return promise;\n    }\n}\n\n// expose to the world\nmodule.exports = SMTPPool;\n","'use strict';\n\nconst SMTPConnection = require('../smtp-connection');\nconst assign = require('../shared').assign;\nconst XOAuth2 = require('../xoauth2');\nconst EventEmitter = require('events');\n\n/**\n * Creates an element for the pool\n *\n * @constructor\n * @param {Object} options SMTPPool instance\n */\nclass PoolResource extends EventEmitter {\n    constructor(pool) {\n        super();\n\n        this.pool = pool;\n        this.options = pool.options;\n        this.logger = this.pool.logger;\n\n        if (this.options.auth) {\n            switch ((this.options.auth.type || '').toString().toUpperCase()) {\n                case 'OAUTH2': {\n                    let oauth2 = new XOAuth2(this.options.auth, this.logger);\n                    oauth2.provisionCallback = (this.pool.mailer && this.pool.mailer.get('oauth2_provision_cb')) || oauth2.provisionCallback;\n                    this.auth = {\n                        type: 'OAUTH2',\n                        user: this.options.auth.user,\n                        oauth2,\n                        method: 'XOAUTH2'\n                    };\n                    oauth2.on('token', token => this.pool.mailer.emit('token', token));\n                    oauth2.on('error', err => this.emit('error', err));\n                    break;\n                }\n                default:\n                    if (!this.options.auth.user && !this.options.auth.pass) {\n                        break;\n                    }\n                    this.auth = {\n                        type: (this.options.auth.type || '').toString().toUpperCase() || 'LOGIN',\n                        user: this.options.auth.user,\n                        credentials: {\n                            user: this.options.auth.user || '',\n                            pass: this.options.auth.pass,\n                            options: this.options.auth.options\n                        },\n                        method: (this.options.auth.method || '').trim().toUpperCase() || this.options.authMethod || false\n                    };\n            }\n        }\n\n        this._connection = false;\n        this._connected = false;\n\n        this.messages = 0;\n        this.available = true;\n    }\n\n    /**\n     * Initiates a connection to the SMTP server\n     *\n     * @param {Function} callback Callback function to run once the connection is established or failed\n     */\n    connect(callback) {\n        this.pool.getSocket(this.options, (err, socketOptions) => {\n            if (err) {\n                return callback(err);\n            }\n\n            let returned = false;\n            let options = this.options;\n            if (socketOptions && socketOptions.connection) {\n                this.logger.info(\n                    {\n                        tnx: 'proxy',\n                        remoteAddress: socketOptions.connection.remoteAddress,\n                        remotePort: socketOptions.connection.remotePort,\n                        destHost: options.host || '',\n                        destPort: options.port || '',\n                        action: 'connected'\n                    },\n                    'Using proxied socket from %s:%s to %s:%s',\n                    socketOptions.connection.remoteAddress,\n                    socketOptions.connection.remotePort,\n                    options.host || '',\n                    options.port || ''\n                );\n\n                options = assign(false, options);\n                Object.keys(socketOptions).forEach(key => {\n                    options[key] = socketOptions[key];\n                });\n            }\n\n            this.connection = new SMTPConnection(options);\n\n            this.connection.once('error', err => {\n                this.emit('error', err);\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                return callback(err);\n            });\n\n            this.connection.once('end', () => {\n                this.close();\n                if (returned) {\n                    return;\n                }\n                returned = true;\n\n                let timer = setTimeout(() => {\n                    if (returned) {\n                        return;\n                    }\n                    // still have not returned, this means we have an unexpected connection close\n                    let err = new Error('Unexpected socket close');\n                    if (this.connection && this.connection._socket && this.connection._socket.upgrading) {\n                        // starttls connection errors\n                        err.code = 'ETLS';\n                    }\n                    callback(err);\n                }, 1000);\n\n                try {\n                    timer.unref();\n                } catch (E) {\n                    // Ignore. Happens on envs with non-node timer implementation\n                }\n            });\n\n            this.connection.connect(() => {\n                if (returned) {\n                    return;\n                }\n\n                if (this.auth && (this.connection.allowsAuth || options.forceAuth)) {\n                    this.connection.login(this.auth, err => {\n                        if (returned) {\n                            return;\n                        }\n                        returned = true;\n\n                        if (err) {\n                            this.connection.close();\n                            this.emit('error', err);\n                            return callback(err);\n                        }\n\n                        this._connected = true;\n                        callback(null, true);\n                    });\n                } else {\n                    returned = true;\n                    this._connected = true;\n                    return callback(null, true);\n                }\n            });\n        });\n    }\n\n    /**\n     * Sends an e-mail to be sent using the selected settings\n     *\n     * @param {Object} mail Mail object\n     * @param {Function} callback Callback function\n     */\n    send(mail, callback) {\n        if (!this._connected) {\n            return this.connect(err => {\n                if (err) {\n                    return callback(err);\n                }\n                return this.send(mail, callback);\n            });\n        }\n\n        let envelope = mail.message.getEnvelope();\n        let messageId = mail.message.messageId();\n\n        let recipients = [].concat(envelope.to || []);\n        if (recipients.length > 3) {\n            recipients.push('...and ' + recipients.splice(2).length + ' more');\n        }\n        this.logger.info(\n            {\n                tnx: 'send',\n                messageId,\n                cid: this.id\n            },\n            'Sending message %s using #%s to <%s>',\n            messageId,\n            this.id,\n            recipients.join(', ')\n        );\n\n        if (mail.data.dsn) {\n            envelope.dsn = mail.data.dsn;\n        }\n\n        this.connection.send(envelope, mail.message.createReadStream(), (err, info) => {\n            this.messages++;\n\n            if (err) {\n                this.connection.close();\n                this.emit('error', err);\n                return callback(err);\n            }\n\n            info.envelope = {\n                from: envelope.from,\n                to: envelope.to\n            };\n            info.messageId = messageId;\n\n            setImmediate(() => {\n                let err;\n                if (this.messages >= this.options.maxMessages) {\n                    err = new Error('Resource exhausted');\n                    err.code = 'EMAXLIMIT';\n                    this.connection.close();\n                    this.emit('error', err);\n                } else {\n                    this.pool._checkRateLimit(() => {\n                        this.available = true;\n                        this.emit('available');\n                    });\n                }\n            });\n\n            callback(null, info);\n        });\n    }\n\n    /**\n     * Closes the connection\n     */\n    close() {\n        this._connected = false;\n        if (this.auth && this.auth.oauth2) {\n            this.auth.oauth2.removeAllListeners();\n        }\n        if (this.connection) {\n            this.connection.close();\n        }\n        this.emit('close');\n    }\n}\n\nmodule.exports = PoolResource;\n","'use strict';\n\nconst EventEmitter = require('events');\nconst packageData = require('../../package.json');\nconst shared = require('../shared');\nconst LeWindows = require('../mime-node/le-windows');\n\n/**\n * Generates a Transport object for AWS SES\n *\n * Possible options can be the following:\n *\n *  * **sendingRate** optional Number specifying how many messages per second should be delivered to SES\n *  * **maxConnections** optional Number specifying max number of parallel connections to SES\n *\n * @constructor\n * @param {Object} optional config parameter\n */\nclass SESTransport extends EventEmitter {\n    constructor(options) {\n        super();\n        options = options || {};\n\n        this.options = options || {};\n        this.ses = this.options.SES;\n\n        this.name = 'SESTransport';\n        this.version = packageData.version;\n\n        this.logger = shared.getLogger(this.options, {\n            component: this.options.component || 'ses-transport'\n        });\n\n        // parallel sending connections\n        this.maxConnections = Number(this.options.maxConnections) || Infinity;\n        this.connections = 0;\n\n        // max messages per second\n        this.sendingRate = Number(this.options.sendingRate) || Infinity;\n        this.sendingRateTTL = null;\n        this.rateInterval = 1000; // milliseconds\n        this.rateMessages = [];\n\n        this.pending = [];\n\n        this.idling = true;\n\n        setImmediate(() => {\n            if (this.idling) {\n                this.emit('idle');\n            }\n        });\n    }\n\n    /**\n     * Schedules a sending of a message\n     *\n     * @param {Object} emailMessage MailComposer object\n     * @param {Function} callback Callback function to run when the sending is completed\n     */\n    send(mail, callback) {\n        if (this.connections >= this.maxConnections) {\n            this.idling = false;\n            return this.pending.push({\n                mail,\n                callback\n            });\n        }\n\n        if (!this._checkSendingRate()) {\n            this.idling = false;\n            return this.pending.push({\n                mail,\n                callback\n            });\n        }\n\n        this._send(mail, (...args) => {\n            setImmediate(() => callback(...args));\n            this._sent();\n        });\n    }\n\n    _checkRatedQueue() {\n        if (this.connections >= this.maxConnections || !this._checkSendingRate()) {\n            return;\n        }\n\n        if (!this.pending.length) {\n            if (!this.idling) {\n                this.idling = true;\n                this.emit('idle');\n            }\n            return;\n        }\n\n        let next = this.pending.shift();\n        this._send(next.mail, (...args) => {\n            setImmediate(() => next.callback(...args));\n            this._sent();\n        });\n    }\n\n    _checkSendingRate() {\n        clearTimeout(this.sendingRateTTL);\n\n        let now = Date.now();\n        let oldest = false;\n        // delete older messages\n        for (let i = this.rateMessages.length - 1; i >= 0; i--) {\n            if (this.rateMessages[i].ts >= now - this.rateInterval && (!oldest || this.rateMessages[i].ts < oldest)) {\n                oldest = this.rateMessages[i].ts;\n            }\n\n            if (this.rateMessages[i].ts < now - this.rateInterval && !this.rateMessages[i].pending) {\n                this.rateMessages.splice(i, 1);\n            }\n        }\n\n        if (this.rateMessages.length < this.sendingRate) {\n            return true;\n        }\n\n        let delay = Math.max(oldest + 1001, now + 20);\n        this.sendingRateTTL = setTimeout(() => this._checkRatedQueue(), now - delay);\n\n        try {\n            this.sendingRateTTL.unref();\n        } catch (E) {\n            // Ignore. Happens on envs with non-node timer implementation\n        }\n\n        return false;\n    }\n\n    _sent() {\n        this.connections--;\n        this._checkRatedQueue();\n    }\n\n    /**\n     * Returns true if there are free slots in the queue\n     */\n    isIdle() {\n        return this.idling;\n    }\n\n    /**\n     * Compiles a mailcomposer message and forwards it to SES\n     *\n     * @param {Object} emailMessage MailComposer object\n     * @param {Function} callback Callback function to run when the sending is completed\n     */\n    _send(mail, callback) {\n        let statObject = {\n            ts: Date.now(),\n            pending: true\n        };\n        this.connections++;\n        this.rateMessages.push(statObject);\n\n        let envelope = mail.data.envelope || mail.message.getEnvelope();\n        let messageId = mail.message.messageId();\n\n        let recipients = [].concat(envelope.to || []);\n        if (recipients.length > 3) {\n            recipients.push('...and ' + recipients.splice(2).length + ' more');\n        }\n        this.logger.info(\n            {\n                tnx: 'send',\n                messageId\n            },\n            'Sending message %s to <%s>',\n            messageId,\n            recipients.join(', ')\n        );\n\n        let getRawMessage = next => {\n            // do not use Message-ID and Date in DKIM signature\n            if (!mail.data._dkim) {\n                mail.data._dkim = {};\n            }\n            if (mail.data._dkim.skipFields && typeof mail.data._dkim.skipFields === 'string') {\n                mail.data._dkim.skipFields += ':date:message-id';\n            } else {\n                mail.data._dkim.skipFields = 'date:message-id';\n            }\n\n            let sourceStream = mail.message.createReadStream();\n            let stream = sourceStream.pipe(new LeWindows());\n            let chunks = [];\n            let chunklen = 0;\n\n            stream.on('readable', () => {\n                let chunk;\n                while ((chunk = stream.read()) !== null) {\n                    chunks.push(chunk);\n                    chunklen += chunk.length;\n                }\n            });\n\n            sourceStream.once('error', err => stream.emit('error', err));\n\n            stream.once('error', err => {\n                next(err);\n            });\n\n            stream.once('end', () => next(null, Buffer.concat(chunks, chunklen)));\n        };\n\n        setImmediate(() =>\n            getRawMessage((err, raw) => {\n                if (err) {\n                    this.logger.error(\n                        {\n                            err,\n                            tnx: 'send',\n                            messageId\n                        },\n                        'Failed creating message for %s. %s',\n                        messageId,\n                        err.message\n                    );\n                    statObject.pending = false;\n                    return callback(err);\n                }\n\n                let sesMessage = {\n                    RawMessage: {\n                        // required\n                        Data: raw // required\n                    },\n                    Source: envelope.from,\n                    Destinations: envelope.to\n                };\n\n                Object.keys(mail.data.ses || {}).forEach(key => {\n                    sesMessage[key] = mail.data.ses[key];\n                });\n\n                let ses = (this.ses.aws ? this.ses.ses : this.ses) || {};\n                let aws = this.ses.aws || {};\n\n                let getRegion = cb => {\n                    if (ses.config && typeof ses.config.region === 'function') {\n                        // promise\n                        return ses.config\n                            .region()\n                            .then(region => cb(null, region))\n                            .catch(err => cb(err));\n                    }\n                    return cb(null, (ses.config && ses.config.region) || 'us-east-1');\n                };\n\n                getRegion((err, region) => {\n                    if (err || !region) {\n                        region = 'us-east-1';\n                    }\n\n                    let sendPromise;\n                    if (typeof ses.send === 'function' && aws.SendRawEmailCommand) {\n                        // v3 API\n                        sendPromise = ses.send(new aws.SendRawEmailCommand(sesMessage));\n                    } else {\n                        // v2 API\n                        sendPromise = ses.sendRawEmail(sesMessage).promise();\n                    }\n\n                    sendPromise\n                        .then(data => {\n                            if (region === 'us-east-1') {\n                                region = 'email';\n                            }\n\n                            statObject.pending = false;\n                            callback(null, {\n                                envelope: {\n                                    from: envelope.from,\n                                    to: envelope.to\n                                },\n                                messageId: '<' + data.MessageId + (!/@/.test(data.MessageId) ? '@' + region + '.amazonses.com' : '') + '>',\n                                response: data.MessageId,\n                                raw\n                            });\n                        })\n                        .catch(err => {\n                            this.logger.error(\n                                {\n                                    err,\n                                    tnx: 'send'\n                                },\n                                'Send error for %s: %s',\n                                messageId,\n                                err.message\n                            );\n                            statObject.pending = false;\n                            callback(err);\n                        });\n                });\n            })\n        );\n    }\n\n    /**\n     * Verifies SES configuration\n     *\n     * @param {Function} callback Callback function\n     */\n    verify(callback) {\n        let promise;\n        let ses = (this.ses.aws ? this.ses.ses : this.ses) || {};\n        let aws = this.ses.aws || {};\n\n        const sesMessage = {\n            RawMessage: {\n                // required\n                Data: 'From: invalid@invalid\\r\\nTo: invalid@invalid\\r\\n Subject: Invalid\\r\\n\\r\\nInvalid'\n            },\n            Source: 'invalid@invalid',\n            Destinations: ['invalid@invalid']\n        };\n\n        if (!callback) {\n            promise = new Promise((resolve, reject) => {\n                callback = shared.callbackPromise(resolve, reject);\n            });\n        }\n        const cb = err => {\n            if (err && (err.code || err.Code) !== 'InvalidParameterValue') {\n                return callback(err);\n            }\n            return callback(null, true);\n        };\n\n        if (typeof ses.send === 'function' && aws.SendRawEmailCommand) {\n            // v3 API\n            sesMessage.RawMessage.Data = Buffer.from(sesMessage.RawMessage.Data);\n            ses.send(new aws.SendRawEmailCommand(sesMessage), cb);\n        } else {\n            // v2 API\n            ses.sendRawEmail(sesMessage, cb);\n        }\n\n        return promise;\n    }\n}\n\nmodule.exports = SESTransport;\n","'use strict';\n\nconst Mailer = require('./mailer');\nconst shared = require('./shared');\nconst SMTPPool = require('./smtp-pool');\nconst SMTPTransport = require('./smtp-transport');\nconst SendmailTransport = require('./sendmail-transport');\nconst StreamTransport = require('./stream-transport');\nconst JSONTransport = require('./json-transport');\nconst SESTransport = require('./ses-transport');\nconst nmfetch = require('./fetch');\nconst packageData = require('../package.json');\n\nconst ETHEREAL_API = (process.env.ETHEREAL_API || 'https://api.nodemailer.com').replace(/\\/+$/, '');\nconst ETHEREAL_WEB = (process.env.ETHEREAL_WEB || 'https://ethereal.email').replace(/\\/+$/, '');\nconst ETHEREAL_API_KEY = (process.env.ETHEREAL_API_KEY || '').replace(/\\s*/g, '') || null;\nconst ETHEREAL_CACHE = ['true', 'yes', 'y', '1'].includes((process.env.ETHEREAL_CACHE || 'yes').toString().trim().toLowerCase());\n\nlet testAccount = false;\n\nmodule.exports.createTransport = function (transporter, defaults) {\n    let urlConfig;\n    let options;\n    let mailer;\n\n    if (\n        // provided transporter is a configuration object, not transporter plugin\n        (typeof transporter === 'object' && typeof transporter.send !== 'function') ||\n        // provided transporter looks like a connection url\n        (typeof transporter === 'string' && /^(smtps?|direct):/i.test(transporter))\n    ) {\n        if ((urlConfig = typeof transporter === 'string' ? transporter : transporter.url)) {\n            // parse a configuration URL into configuration options\n            options = shared.parseConnectionUrl(urlConfig);\n        } else {\n            options = transporter;\n        }\n\n        if (options.pool) {\n            transporter = new SMTPPool(options);\n        } else if (options.sendmail) {\n            transporter = new SendmailTransport(options);\n        } else if (options.streamTransport) {\n            transporter = new StreamTransport(options);\n        } else if (options.jsonTransport) {\n            transporter = new JSONTransport(options);\n        } else if (options.SES) {\n            transporter = new SESTransport(options);\n        } else {\n            transporter = new SMTPTransport(options);\n        }\n    }\n\n    mailer = new Mailer(transporter, options, defaults);\n\n    return mailer;\n};\n\nmodule.exports.createTestAccount = function (apiUrl, callback) {\n    let promise;\n\n    if (!callback && typeof apiUrl === 'function') {\n        callback = apiUrl;\n        apiUrl = false;\n    }\n\n    if (!callback) {\n        promise = new Promise((resolve, reject) => {\n            callback = shared.callbackPromise(resolve, reject);\n        });\n    }\n\n    if (ETHEREAL_CACHE && testAccount) {\n        setImmediate(() => callback(null, testAccount));\n        return promise;\n    }\n\n    apiUrl = apiUrl || ETHEREAL_API;\n\n    let chunks = [];\n    let chunklen = 0;\n\n    let requestHeaders = {};\n    let requestBody = {\n        requestor: packageData.name,\n        version: packageData.version\n    };\n\n    if (ETHEREAL_API_KEY) {\n        requestHeaders.Authorization = 'Bearer ' + ETHEREAL_API_KEY;\n    }\n\n    let req = nmfetch(apiUrl + '/user', {\n        contentType: 'application/json',\n        method: 'POST',\n        headers: requestHeaders,\n        body: Buffer.from(JSON.stringify(requestBody))\n    });\n\n    req.on('readable', () => {\n        let chunk;\n        while ((chunk = req.read()) !== null) {\n            chunks.push(chunk);\n            chunklen += chunk.length;\n        }\n    });\n\n    req.once('error', err => callback(err));\n\n    req.once('end', () => {\n        let res = Buffer.concat(chunks, chunklen);\n        let data;\n        let err;\n        try {\n            data = JSON.parse(res.toString());\n        } catch (E) {\n            err = E;\n        }\n        if (err) {\n            return callback(err);\n        }\n        if (data.status !== 'success' || data.error) {\n            return callback(new Error(data.error || 'Request failed'));\n        }\n        delete data.status;\n        testAccount = data;\n        callback(null, testAccount);\n    });\n\n    return promise;\n};\n\nmodule.exports.getTestMessageUrl = function (info) {\n    if (!info || !info.response) {\n        return false;\n    }\n\n    let infoProps = new Map();\n    info.response.replace(/\\[([^\\]]+)\\]$/, (m, props) => {\n        props.replace(/\\b([A-Z0-9]+)=([^\\s]+)/g, (m, key, value) => {\n            infoProps.set(key, value);\n        });\n    });\n\n    if (infoProps.has('STATUS') && infoProps.has('MSGID')) {\n        return (testAccount.web || ETHEREAL_WEB) + '/message/' + infoProps.get('MSGID');\n    }\n\n    return false;\n};\n","'use strict';\n\nconst EventEmitter = require('events');\nconst SMTPConnection = require('../smtp-connection');\nconst wellKnown = require('../well-known');\nconst shared = require('../shared');\nconst XOAuth2 = require('../xoauth2');\nconst packageData = require('../../package.json');\n\n/**\n * Creates a SMTP transport object for Nodemailer\n *\n * @constructor\n * @param {Object} options Connection options\n */\nclass SMTPTransport extends EventEmitter {\n    constructor(options) {\n        super();\n\n        options = options || {};\n\n        if (typeof options === 'string') {\n            options = {\n                url: options\n            };\n        }\n\n        let urlData;\n        let service = options.service;\n\n        if (typeof options.getSocket === 'function') {\n            this.getSocket = options.getSocket;\n        }\n\n        if (options.url) {\n            urlData = shared.parseConnectionUrl(options.url);\n            service = service || urlData.service;\n        }\n\n        this.options = shared.assign(\n            false, // create new object\n            options, // regular options\n            urlData, // url options\n            service && wellKnown(service) // wellknown options\n        );\n\n        this.logger = shared.getLogger(this.options, {\n            component: this.options.component || 'smtp-transport'\n        });\n\n        // temporary object\n        let connection = new SMTPConnection(this.options);\n\n        this.name = 'SMTP';\n        this.version = packageData.version + '[client:' + connection.version + ']';\n\n        if (this.options.auth) {\n            this.auth = this.getAuth({});\n        }\n    }\n\n    /**\n     * Placeholder function for creating proxy sockets. This method immediatelly returns\n     * without a socket\n     *\n     * @param {Object} options Connection options\n     * @param {Function} callback Callback function to run with the socket keys\n     */\n    getSocket(options, callback) {\n        // return immediatelly\n        return setImmediate(() => callback(null, false));\n    }\n\n    getAuth(authOpts) {\n        if (!authOpts) {\n            return this.auth;\n        }\n\n        let hasAuth = false;\n        let authData = {};\n\n        if (this.options.auth && typeof this.options.auth === 'object') {\n            Object.keys(this.options.auth).forEach(key => {\n                hasAuth = true;\n                authData[key] = this.options.auth[key];\n            });\n        }\n\n        if (authOpts && typeof authOpts === 'object') {\n            Object.keys(authOpts).forEach(key => {\n                hasAuth = true;\n                authData[key] = authOpts[key];\n            });\n        }\n\n        if (!hasAuth) {\n            return false;\n        }\n\n        switch ((authData.type || '').toString().toUpperCase()) {\n            case 'OAUTH2': {\n                if (!authData.service && !authData.user) {\n                    return false;\n                }\n                let oauth2 = new XOAuth2(authData, this.logger);\n                oauth2.provisionCallback = (this.mailer && this.mailer.get('oauth2_provision_cb')) || oauth2.provisionCallback;\n                oauth2.on('token', token => this.mailer.emit('token', token));\n                oauth2.on('error', err => this.emit('error', err));\n                return {\n                    type: 'OAUTH2',\n                    user: authData.user,\n                    oauth2,\n                    method: 'XOAUTH2'\n                };\n            }\n            default:\n                return {\n                    type: (authData.type || '').toString().toUpperCase() || 'LOGIN',\n                    user: authData.user,\n                    credentials: {\n                        user: authData.user || '',\n                        pass: authData.pass,\n                        options: authData.options\n                    },\n                    method: (authData.method || '').trim().toUpperCase() || this.options.authMethod || false\n                };\n        }\n    }\n\n    /**\n     * Sends an e-mail using the selected settings\n     *\n     * @param {Object} mail Mail object\n     * @param {Function} callback Callback function\n     */\n    send(mail, callback) {\n        this.getSocket(this.options, (err, socketOptions) => {\n            if (err) {\n                return callback(err);\n            }\n\n            let returned = false;\n            let options = this.options;\n            if (socketOptions && socketOptions.connection) {\n                this.logger.info(\n                    {\n                        tnx: 'proxy',\n                        remoteAddress: socketOptions.connection.remoteAddress,\n                        remotePort: socketOptions.connection.remotePort,\n                        destHost: options.host || '',\n                        destPort: options.port || '',\n                        action: 'connected'\n                    },\n                    'Using proxied socket from %s:%s to %s:%s',\n                    socketOptions.connection.remoteAddress,\n                    socketOptions.connection.remotePort,\n                    options.host || '',\n                    options.port || ''\n                );\n\n                // only copy options if we need to modify it\n                options = shared.assign(false, options);\n                Object.keys(socketOptions).forEach(key => {\n                    options[key] = socketOptions[key];\n                });\n            }\n\n            let connection = new SMTPConnection(options);\n\n            connection.once('error', err => {\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                connection.close();\n                return callback(err);\n            });\n\n            connection.once('end', () => {\n                if (returned) {\n                    return;\n                }\n\n                let timer = setTimeout(() => {\n                    if (returned) {\n                        return;\n                    }\n                    returned = true;\n                    // still have not returned, this means we have an unexpected connection close\n                    let err = new Error('Unexpected socket close');\n                    if (connection && connection._socket && connection._socket.upgrading) {\n                        // starttls connection errors\n                        err.code = 'ETLS';\n                    }\n                    callback(err);\n                }, 1000);\n\n                try {\n                    timer.unref();\n                } catch (E) {\n                    // Ignore. Happens on envs with non-node timer implementation\n                }\n            });\n\n            let sendMessage = () => {\n                let envelope = mail.message.getEnvelope();\n                let messageId = mail.message.messageId();\n\n                let recipients = [].concat(envelope.to || []);\n                if (recipients.length > 3) {\n                    recipients.push('...and ' + recipients.splice(2).length + ' more');\n                }\n\n                if (mail.data.dsn) {\n                    envelope.dsn = mail.data.dsn;\n                }\n\n                this.logger.info(\n                    {\n                        tnx: 'send',\n                        messageId\n                    },\n                    'Sending message %s to <%s>',\n                    messageId,\n                    recipients.join(', ')\n                );\n\n                connection.send(envelope, mail.message.createReadStream(), (err, info) => {\n                    returned = true;\n                    connection.close();\n                    if (err) {\n                        this.logger.error(\n                            {\n                                err,\n                                tnx: 'send'\n                            },\n                            'Send error for %s: %s',\n                            messageId,\n                            err.message\n                        );\n                        return callback(err);\n                    }\n                    info.envelope = {\n                        from: envelope.from,\n                        to: envelope.to\n                    };\n                    info.messageId = messageId;\n                    try {\n                        return callback(null, info);\n                    } catch (E) {\n                        this.logger.error(\n                            {\n                                err: E,\n                                tnx: 'callback'\n                            },\n                            'Callback error for %s: %s',\n                            messageId,\n                            E.message\n                        );\n                    }\n                });\n            };\n\n            connection.connect(() => {\n                if (returned) {\n                    return;\n                }\n\n                let auth = this.getAuth(mail.data.auth);\n\n                if (auth && (connection.allowsAuth || options.forceAuth)) {\n                    connection.login(auth, err => {\n                        if (auth && auth !== this.auth && auth.oauth2) {\n                            auth.oauth2.removeAllListeners();\n                        }\n                        if (returned) {\n                            return;\n                        }\n\n                        if (err) {\n                            returned = true;\n                            connection.close();\n                            return callback(err);\n                        }\n\n                        sendMessage();\n                    });\n                } else {\n                    sendMessage();\n                }\n            });\n        });\n    }\n\n    /**\n     * Verifies SMTP configuration\n     *\n     * @param {Function} callback Callback function\n     */\n    verify(callback) {\n        let promise;\n\n        if (!callback) {\n            promise = new Promise((resolve, reject) => {\n                callback = shared.callbackPromise(resolve, reject);\n            });\n        }\n\n        this.getSocket(this.options, (err, socketOptions) => {\n            if (err) {\n                return callback(err);\n            }\n\n            let options = this.options;\n            if (socketOptions && socketOptions.connection) {\n                this.logger.info(\n                    {\n                        tnx: 'proxy',\n                        remoteAddress: socketOptions.connection.remoteAddress,\n                        remotePort: socketOptions.connection.remotePort,\n                        destHost: options.host || '',\n                        destPort: options.port || '',\n                        action: 'connected'\n                    },\n                    'Using proxied socket from %s:%s to %s:%s',\n                    socketOptions.connection.remoteAddress,\n                    socketOptions.connection.remotePort,\n                    options.host || '',\n                    options.port || ''\n                );\n\n                options = shared.assign(false, options);\n                Object.keys(socketOptions).forEach(key => {\n                    options[key] = socketOptions[key];\n                });\n            }\n\n            let connection = new SMTPConnection(options);\n            let returned = false;\n\n            connection.once('error', err => {\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                connection.close();\n                return callback(err);\n            });\n\n            connection.once('end', () => {\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                return callback(new Error('Connection closed'));\n            });\n\n            let finalize = () => {\n                if (returned) {\n                    return;\n                }\n                returned = true;\n                connection.quit();\n                return callback(null, true);\n            };\n\n            connection.connect(() => {\n                if (returned) {\n                    return;\n                }\n\n                let authData = this.getAuth({});\n\n                if (authData && (connection.allowsAuth || options.forceAuth)) {\n                    connection.login(authData, err => {\n                        if (returned) {\n                            return;\n                        }\n\n                        if (err) {\n                            returned = true;\n                            connection.close();\n                            return callback(err);\n                        }\n\n                        finalize();\n                    });\n                } else if (!authData && connection.allowsAuth && options.forceAuth) {\n                    let err = new Error('Authentication info was not provided');\n                    err.code = 'NoAuth';\n\n                    returned = true;\n                    connection.close();\n                    return callback(err);\n                } else {\n                    finalize();\n                }\n            });\n        });\n\n        return promise;\n    }\n\n    /**\n     * Releases resources\n     */\n    close() {\n        if (this.auth && this.auth.oauth2) {\n            this.auth.oauth2.removeAllListeners();\n        }\n        this.emit('close');\n    }\n}\n\n// expose to the world\nmodule.exports = SMTPTransport;\n","'use strict';\n\nconst spawn = require('child_process').spawn;\nconst packageData = require('../../package.json');\nconst shared = require('../shared');\n\n/**\n * Generates a Transport object for Sendmail\n *\n * Possible options can be the following:\n *\n *  * **path** optional path to sendmail binary\n *  * **newline** either 'windows' or 'unix'\n *  * **args** an array of arguments for the sendmail binary\n *\n * @constructor\n * @param {Object} optional config parameter for Sendmail\n */\nclass SendmailTransport {\n    constructor(options) {\n        options = options || {};\n\n        // use a reference to spawn for mocking purposes\n        this._spawn = spawn;\n\n        this.options = options || {};\n\n        this.name = 'Sendmail';\n        this.version = packageData.version;\n\n        this.path = 'sendmail';\n        this.args = false;\n        this.winbreak = false;\n\n        this.logger = shared.getLogger(this.options, {\n            component: this.options.component || 'sendmail'\n        });\n\n        if (options) {\n            if (typeof options === 'string') {\n                this.path = options;\n            } else if (typeof options === 'object') {\n                if (options.path) {\n                    this.path = options.path;\n                }\n                if (Array.isArray(options.args)) {\n                    this.args = options.args;\n                }\n                this.winbreak = ['win', 'windows', 'dos', '\\r\\n'].includes((options.newline || '').toString().toLowerCase());\n            }\n        }\n    }\n\n    /**\n     * <p>Compiles a mailcomposer message and forwards it to handler that sends it.</p>\n     *\n     * @param {Object} emailMessage MailComposer object\n     * @param {Function} callback Callback function to run when the sending is completed\n     */\n    send(mail, done) {\n        // Sendmail strips this header line by itself\n        mail.message.keepBcc = true;\n\n        let envelope = mail.data.envelope || mail.message.getEnvelope();\n        let messageId = mail.message.messageId();\n        let args;\n        let sendmail;\n        let returned;\n\n        const hasInvalidAddresses = []\n            .concat(envelope.from || [])\n            .concat(envelope.to || [])\n            .some(addr => /^-/.test(addr));\n        if (hasInvalidAddresses) {\n            return done(new Error('Can not send mail. Invalid envelope addresses.'));\n        }\n\n        if (this.args) {\n            // force -i to keep single dots\n            args = ['-i'].concat(this.args).concat(envelope.to);\n        } else {\n            args = ['-i'].concat(envelope.from ? ['-f', envelope.from] : []).concat(envelope.to);\n        }\n\n        let callback = err => {\n            if (returned) {\n                // ignore any additional responses, already done\n                return;\n            }\n            returned = true;\n            if (typeof done === 'function') {\n                if (err) {\n                    return done(err);\n                } else {\n                    return done(null, {\n                        envelope: mail.data.envelope || mail.message.getEnvelope(),\n                        messageId,\n                        response: 'Messages queued for delivery'\n                    });\n                }\n            }\n        };\n\n        try {\n            sendmail = this._spawn(this.path, args);\n        } catch (E) {\n            this.logger.error(\n                {\n                    err: E,\n                    tnx: 'spawn',\n                    messageId\n                },\n                'Error occurred while spawning sendmail. %s',\n                E.message\n            );\n            return callback(E);\n        }\n\n        if (sendmail) {\n            sendmail.on('error', err => {\n                this.logger.error(\n                    {\n                        err,\n                        tnx: 'spawn',\n                        messageId\n                    },\n                    'Error occurred when sending message %s. %s',\n                    messageId,\n                    err.message\n                );\n                callback(err);\n            });\n\n            sendmail.once('exit', code => {\n                if (!code) {\n                    return callback();\n                }\n                let err;\n                if (code === 127) {\n                    err = new Error('Sendmail command not found, process exited with code ' + code);\n                } else {\n                    err = new Error('Sendmail exited with code ' + code);\n                }\n\n                this.logger.error(\n                    {\n                        err,\n                        tnx: 'stdin',\n                        messageId\n                    },\n                    'Error sending message %s to sendmail. %s',\n                    messageId,\n                    err.message\n                );\n                callback(err);\n            });\n            sendmail.once('close', callback);\n\n            sendmail.stdin.on('error', err => {\n                this.logger.error(\n                    {\n                        err,\n                        tnx: 'stdin',\n                        messageId\n                    },\n                    'Error occurred when piping message %s to sendmail. %s',\n                    messageId,\n                    err.message\n                );\n                callback(err);\n            });\n\n            let recipients = [].concat(envelope.to || []);\n            if (recipients.length > 3) {\n                recipients.push('...and ' + recipients.splice(2).length + ' more');\n            }\n            this.logger.info(\n                {\n                    tnx: 'send',\n                    messageId\n                },\n                'Sending message %s to <%s>',\n                messageId,\n                recipients.join(', ')\n            );\n\n            let sourceStream = mail.message.createReadStream();\n            sourceStream.once('error', err => {\n                this.logger.error(\n                    {\n                        err,\n                        tnx: 'stdin',\n                        messageId\n                    },\n                    'Error occurred when generating message %s. %s',\n                    messageId,\n                    err.message\n                );\n                sendmail.kill('SIGINT'); // do not deliver the message\n                callback(err);\n            });\n\n            sourceStream.pipe(sendmail.stdin);\n        } else {\n            return callback(new Error('sendmail was not found'));\n        }\n    }\n}\n\nmodule.exports = SendmailTransport;\n","'use strict';\n\nconst packageData = require('../../package.json');\nconst shared = require('../shared');\n\n/**\n * Generates a Transport object for streaming\n *\n * Possible options can be the following:\n *\n *  * **buffer** if true, then returns the message as a Buffer object instead of a stream\n *  * **newline** either 'windows' or 'unix'\n *\n * @constructor\n * @param {Object} optional config parameter\n */\nclass StreamTransport {\n    constructor(options) {\n        options = options || {};\n\n        this.options = options || {};\n\n        this.name = 'StreamTransport';\n        this.version = packageData.version;\n\n        this.logger = shared.getLogger(this.options, {\n            component: this.options.component || 'stream-transport'\n        });\n\n        this.winbreak = ['win', 'windows', 'dos', '\\r\\n'].includes((options.newline || '').toString().toLowerCase());\n    }\n\n    /**\n     * Compiles a mailcomposer message and forwards it to handler that sends it\n     *\n     * @param {Object} emailMessage MailComposer object\n     * @param {Function} callback Callback function to run when the sending is completed\n     */\n    send(mail, done) {\n        // We probably need this in the output\n        mail.message.keepBcc = true;\n\n        let envelope = mail.data.envelope || mail.message.getEnvelope();\n        let messageId = mail.message.messageId();\n\n        let recipients = [].concat(envelope.to || []);\n        if (recipients.length > 3) {\n            recipients.push('...and ' + recipients.splice(2).length + ' more');\n        }\n        this.logger.info(\n            {\n                tnx: 'send',\n                messageId\n            },\n            'Sending message %s to <%s> using %s line breaks',\n            messageId,\n            recipients.join(', '),\n            this.winbreak ? '<CR><LF>' : '<LF>'\n        );\n\n        setImmediate(() => {\n            let stream;\n\n            try {\n                stream = mail.message.createReadStream();\n            } catch (E) {\n                this.logger.error(\n                    {\n                        err: E,\n                        tnx: 'send',\n                        messageId\n                    },\n                    'Creating send stream failed for %s. %s',\n                    messageId,\n                    E.message\n                );\n                return done(E);\n            }\n\n            if (!this.options.buffer) {\n                stream.once('error', err => {\n                    this.logger.error(\n                        {\n                            err,\n                            tnx: 'send',\n                            messageId\n                        },\n                        'Failed creating message for %s. %s',\n                        messageId,\n                        err.message\n                    );\n                });\n                return done(null, {\n                    envelope: mail.data.envelope || mail.message.getEnvelope(),\n                    messageId,\n                    message: stream\n                });\n            }\n\n            let chunks = [];\n            let chunklen = 0;\n            stream.on('readable', () => {\n                let chunk;\n                while ((chunk = stream.read()) !== null) {\n                    chunks.push(chunk);\n                    chunklen += chunk.length;\n                }\n            });\n\n            stream.once('error', err => {\n                this.logger.error(\n                    {\n                        err,\n                        tnx: 'send',\n                        messageId\n                    },\n                    'Failed creating message for %s. %s',\n                    messageId,\n                    err.message\n                );\n                return done(err);\n            });\n\n            stream.on('end', () =>\n                done(null, {\n                    envelope: mail.data.envelope || mail.message.getEnvelope(),\n                    messageId,\n                    message: Buffer.concat(chunks, chunklen)\n                })\n            );\n        });\n    }\n}\n\nmodule.exports = StreamTransport;\n","'use strict';\n\nconst packageData = require('../../package.json');\nconst shared = require('../shared');\n\n/**\n * Generates a Transport object to generate JSON output\n *\n * @constructor\n * @param {Object} optional config parameter\n */\nclass JSONTransport {\n    constructor(options) {\n        options = options || {};\n\n        this.options = options || {};\n\n        this.name = 'JSONTransport';\n        this.version = packageData.version;\n\n        this.logger = shared.getLogger(this.options, {\n            component: this.options.component || 'json-transport'\n        });\n    }\n\n    /**\n     * <p>Compiles a mailcomposer message and forwards it to handler that sends it.</p>\n     *\n     * @param {Object} emailMessage MailComposer object\n     * @param {Function} callback Callback function to run when the sending is completed\n     */\n    send(mail, done) {\n        // Sendmail strips this header line by itself\n        mail.message.keepBcc = true;\n\n        let envelope = mail.data.envelope || mail.message.getEnvelope();\n        let messageId = mail.message.messageId();\n\n        let recipients = [].concat(envelope.to || []);\n        if (recipients.length > 3) {\n            recipients.push('...and ' + recipients.splice(2).length + ' more');\n        }\n        this.logger.info(\n            {\n                tnx: 'send',\n                messageId\n            },\n            'Composing JSON structure of %s to <%s>',\n            messageId,\n            recipients.join(', ')\n        );\n\n        setImmediate(() => {\n            mail.normalize((err, data) => {\n                if (err) {\n                    this.logger.error(\n                        {\n                            err,\n                            tnx: 'send',\n                            messageId\n                        },\n                        'Failed building JSON structure for %s. %s',\n                        messageId,\n                        err.message\n                    );\n                    return done(err);\n                }\n\n                delete data.envelope;\n                delete data.normalizedHeaders;\n\n                return done(null, {\n                    envelope,\n                    messageId,\n                    message: this.options.skipEncoding ? data : JSON.stringify(data)\n                });\n            });\n        });\n    }\n}\n\nmodule.exports = JSONTransport;\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport { EmailConfig, EmailParams } from 'src/core/types';\nimport nodemailer from 'nodemailer';\n\nclass MailController {\n    private environment: Environment;\n    constructor(environment: Environment) {\n        this.environment = environment;\n    }\n\n    private createTransporter(email: EmailConfig) {\n        const { host, port, secure, auth: { user, pass } } = email;\n\n        // const transporter = nodemailer.createTransport(email);\n        const transporter = nodemailer.createTransport({\n            host,\n            port,\n            secure,\n            auth: {\n                user,\n                pass,\n            },\n        });\n\n        return transporter;\n    }\n\n    private mountMail(email: EmailConfig,  mailParams: EmailParams) {\n        const { emailParams: { from, to } } = email;\n        const { message, subject, attachments } = mailParams;\n\n        const attachmentsWithVerifiedFileName = attachments?.map((attachment) => {\n            if (!attachment.filename) {\n                attachment.filename = false;\n            }\n            return attachment;\n        })\n\n        return {\n            from,\n            to,\n            subject,\n            html: message,\n            attachments: attachmentsWithVerifiedFileName,\n        };\n    }\n\n    sendEmail(mailParams: EmailParams) {\n        try {\n            const { email } = this.environment.getConfig();\n\n            if (!email) {\n                throw new Error('Email não configurado. Para utilizar o envio de e-mail certifique-se de passar as configurações corretas para o método \"NFE_LoadEnvironment\".');\n            }\n\n            const transporter = this.createTransporter(email);\n            const mailOptions = this.mountMail(email, mailParams);\n\n            transporter.sendMail(mailOptions, (error: any, info) => {\n                if (error) {\n                    console.log(error);\n                    throw new Error(error);\n                }\n            });\n        } catch (error: any) {\n            throw new Error(`Erro ao enviar e-mail: ${error.message}`);\n        }\n    }\n\n}\n\nexport default MailController;","// can-promise has a crash in some versions of react native that dont have\n// standard global objects\n// https://github.com/soldair/node-qrcode/issues/157\n\nmodule.exports = function () {\n  return typeof Promise === 'function' && Promise.prototype && Promise.prototype.then\n}\n","let toSJISFunction\nconst CODEWORDS_COUNT = [\n  0, // Not used\n  26, 44, 70, 100, 134, 172, 196, 242, 292, 346,\n  404, 466, 532, 581, 655, 733, 815, 901, 991, 1085,\n  1156, 1258, 1364, 1474, 1588, 1706, 1828, 1921, 2051, 2185,\n  2323, 2465, 2611, 2761, 2876, 3034, 3196, 3362, 3532, 3706\n]\n\n/**\n * Returns the QR Code size for the specified version\n *\n * @param  {Number} version QR Code version\n * @return {Number}         size of QR code\n */\nexports.getSymbolSize = function getSymbolSize (version) {\n  if (!version) throw new Error('\"version\" cannot be null or undefined')\n  if (version < 1 || version > 40) throw new Error('\"version\" should be in range from 1 to 40')\n  return version * 4 + 17\n}\n\n/**\n * Returns the total number of codewords used to store data and EC information.\n *\n * @param  {Number} version QR Code version\n * @return {Number}         Data length in bits\n */\nexports.getSymbolTotalCodewords = function getSymbolTotalCodewords (version) {\n  return CODEWORDS_COUNT[version]\n}\n\n/**\n * Encode data with Bose-Chaudhuri-Hocquenghem\n *\n * @param  {Number} data Value to encode\n * @return {Number}      Encoded value\n */\nexports.getBCHDigit = function (data) {\n  let digit = 0\n\n  while (data !== 0) {\n    digit++\n    data >>>= 1\n  }\n\n  return digit\n}\n\nexports.setToSJISFunction = function setToSJISFunction (f) {\n  if (typeof f !== 'function') {\n    throw new Error('\"toSJISFunc\" is not a valid function.')\n  }\n\n  toSJISFunction = f\n}\n\nexports.isKanjiModeEnabled = function () {\n  return typeof toSJISFunction !== 'undefined'\n}\n\nexports.toSJIS = function toSJIS (kanji) {\n  return toSJISFunction(kanji)\n}\n","exports.L = { bit: 1 }\nexports.M = { bit: 0 }\nexports.Q = { bit: 3 }\nexports.H = { bit: 2 }\n\nfunction fromString (string) {\n  if (typeof string !== 'string') {\n    throw new Error('Param is not a string')\n  }\n\n  const lcStr = string.toLowerCase()\n\n  switch (lcStr) {\n    case 'l':\n    case 'low':\n      return exports.L\n\n    case 'm':\n    case 'medium':\n      return exports.M\n\n    case 'q':\n    case 'quartile':\n      return exports.Q\n\n    case 'h':\n    case 'high':\n      return exports.H\n\n    default:\n      throw new Error('Unknown EC Level: ' + string)\n  }\n}\n\nexports.isValid = function isValid (level) {\n  return level && typeof level.bit !== 'undefined' &&\n    level.bit >= 0 && level.bit < 4\n}\n\nexports.from = function from (value, defaultValue) {\n  if (exports.isValid(value)) {\n    return value\n  }\n\n  try {\n    return fromString(value)\n  } catch (e) {\n    return defaultValue\n  }\n}\n","const ECLevel = require('./error-correction-level')\r\n\r\nconst EC_BLOCKS_TABLE = [\r\n// L  M  Q  H\r\n  1, 1, 1, 1,\r\n  1, 1, 1, 1,\r\n  1, 1, 2, 2,\r\n  1, 2, 2, 4,\r\n  1, 2, 4, 4,\r\n  2, 4, 4, 4,\r\n  2, 4, 6, 5,\r\n  2, 4, 6, 6,\r\n  2, 5, 8, 8,\r\n  4, 5, 8, 8,\r\n  4, 5, 8, 11,\r\n  4, 8, 10, 11,\r\n  4, 9, 12, 16,\r\n  4, 9, 16, 16,\r\n  6, 10, 12, 18,\r\n  6, 10, 17, 16,\r\n  6, 11, 16, 19,\r\n  6, 13, 18, 21,\r\n  7, 14, 21, 25,\r\n  8, 16, 20, 25,\r\n  8, 17, 23, 25,\r\n  9, 17, 23, 34,\r\n  9, 18, 25, 30,\r\n  10, 20, 27, 32,\r\n  12, 21, 29, 35,\r\n  12, 23, 34, 37,\r\n  12, 25, 34, 40,\r\n  13, 26, 35, 42,\r\n  14, 28, 38, 45,\r\n  15, 29, 40, 48,\r\n  16, 31, 43, 51,\r\n  17, 33, 45, 54,\r\n  18, 35, 48, 57,\r\n  19, 37, 51, 60,\r\n  19, 38, 53, 63,\r\n  20, 40, 56, 66,\r\n  21, 43, 59, 70,\r\n  22, 45, 62, 74,\r\n  24, 47, 65, 77,\r\n  25, 49, 68, 81\r\n]\r\n\r\nconst EC_CODEWORDS_TABLE = [\r\n// L  M  Q  H\r\n  7, 10, 13, 17,\r\n  10, 16, 22, 28,\r\n  15, 26, 36, 44,\r\n  20, 36, 52, 64,\r\n  26, 48, 72, 88,\r\n  36, 64, 96, 112,\r\n  40, 72, 108, 130,\r\n  48, 88, 132, 156,\r\n  60, 110, 160, 192,\r\n  72, 130, 192, 224,\r\n  80, 150, 224, 264,\r\n  96, 176, 260, 308,\r\n  104, 198, 288, 352,\r\n  120, 216, 320, 384,\r\n  132, 240, 360, 432,\r\n  144, 280, 408, 480,\r\n  168, 308, 448, 532,\r\n  180, 338, 504, 588,\r\n  196, 364, 546, 650,\r\n  224, 416, 600, 700,\r\n  224, 442, 644, 750,\r\n  252, 476, 690, 816,\r\n  270, 504, 750, 900,\r\n  300, 560, 810, 960,\r\n  312, 588, 870, 1050,\r\n  336, 644, 952, 1110,\r\n  360, 700, 1020, 1200,\r\n  390, 728, 1050, 1260,\r\n  420, 784, 1140, 1350,\r\n  450, 812, 1200, 1440,\r\n  480, 868, 1290, 1530,\r\n  510, 924, 1350, 1620,\r\n  540, 980, 1440, 1710,\r\n  570, 1036, 1530, 1800,\r\n  570, 1064, 1590, 1890,\r\n  600, 1120, 1680, 1980,\r\n  630, 1204, 1770, 2100,\r\n  660, 1260, 1860, 2220,\r\n  720, 1316, 1950, 2310,\r\n  750, 1372, 2040, 2430\r\n]\r\n\r\n/**\r\n * Returns the number of error correction block that the QR Code should contain\r\n * for the specified version and error correction level.\r\n *\r\n * @param  {Number} version              QR Code version\r\n * @param  {Number} errorCorrectionLevel Error correction level\r\n * @return {Number}                      Number of error correction blocks\r\n */\r\nexports.getBlocksCount = function getBlocksCount (version, errorCorrectionLevel) {\r\n  switch (errorCorrectionLevel) {\r\n    case ECLevel.L:\r\n      return EC_BLOCKS_TABLE[(version - 1) * 4 + 0]\r\n    case ECLevel.M:\r\n      return EC_BLOCKS_TABLE[(version - 1) * 4 + 1]\r\n    case ECLevel.Q:\r\n      return EC_BLOCKS_TABLE[(version - 1) * 4 + 2]\r\n    case ECLevel.H:\r\n      return EC_BLOCKS_TABLE[(version - 1) * 4 + 3]\r\n    default:\r\n      return undefined\r\n  }\r\n}\r\n\r\n/**\r\n * Returns the number of error correction codewords to use for the specified\r\n * version and error correction level.\r\n *\r\n * @param  {Number} version              QR Code version\r\n * @param  {Number} errorCorrectionLevel Error correction level\r\n * @return {Number}                      Number of error correction codewords\r\n */\r\nexports.getTotalCodewordsCount = function getTotalCodewordsCount (version, errorCorrectionLevel) {\r\n  switch (errorCorrectionLevel) {\r\n    case ECLevel.L:\r\n      return EC_CODEWORDS_TABLE[(version - 1) * 4 + 0]\r\n    case ECLevel.M:\r\n      return EC_CODEWORDS_TABLE[(version - 1) * 4 + 1]\r\n    case ECLevel.Q:\r\n      return EC_CODEWORDS_TABLE[(version - 1) * 4 + 2]\r\n    case ECLevel.H:\r\n      return EC_CODEWORDS_TABLE[(version - 1) * 4 + 3]\r\n    default:\r\n      return undefined\r\n  }\r\n}\r\n","const GF = require('./galois-field')\n\n/**\n * Multiplies two polynomials inside Galois Field\n *\n * @param  {Uint8Array} p1 Polynomial\n * @param  {Uint8Array} p2 Polynomial\n * @return {Uint8Array}    Product of p1 and p2\n */\nexports.mul = function mul (p1, p2) {\n  const coeff = new Uint8Array(p1.length + p2.length - 1)\n\n  for (let i = 0; i < p1.length; i++) {\n    for (let j = 0; j < p2.length; j++) {\n      coeff[i + j] ^= GF.mul(p1[i], p2[j])\n    }\n  }\n\n  return coeff\n}\n\n/**\n * Calculate the remainder of polynomials division\n *\n * @param  {Uint8Array} divident Polynomial\n * @param  {Uint8Array} divisor  Polynomial\n * @return {Uint8Array}          Remainder\n */\nexports.mod = function mod (divident, divisor) {\n  let result = new Uint8Array(divident)\n\n  while ((result.length - divisor.length) >= 0) {\n    const coeff = result[0]\n\n    for (let i = 0; i < divisor.length; i++) {\n      result[i] ^= GF.mul(divisor[i], coeff)\n    }\n\n    // remove all zeros from buffer head\n    let offset = 0\n    while (offset < result.length && result[offset] === 0) offset++\n    result = result.slice(offset)\n  }\n\n  return result\n}\n\n/**\n * Generate an irreducible generator polynomial of specified degree\n * (used by Reed-Solomon encoder)\n *\n * @param  {Number} degree Degree of the generator polynomial\n * @return {Uint8Array}    Buffer containing polynomial coefficients\n */\nexports.generateECPolynomial = function generateECPolynomial (degree) {\n  let poly = new Uint8Array([1])\n  for (let i = 0; i < degree; i++) {\n    poly = exports.mul(poly, new Uint8Array([1, GF.exp(i)]))\n  }\n\n  return poly\n}\n","const EXP_TABLE = new Uint8Array(512)\nconst LOG_TABLE = new Uint8Array(256)\n/**\n * Precompute the log and anti-log tables for faster computation later\n *\n * For each possible value in the galois field 2^8, we will pre-compute\n * the logarithm and anti-logarithm (exponential) of this value\n *\n * ref {@link https://en.wikiversity.org/wiki/Reed%E2%80%93Solomon_codes_for_coders#Introduction_to_mathematical_fields}\n */\n;(function initTables () {\n  let x = 1\n  for (let i = 0; i < 255; i++) {\n    EXP_TABLE[i] = x\n    LOG_TABLE[x] = i\n\n    x <<= 1 // multiply by 2\n\n    // The QR code specification says to use byte-wise modulo 100011101 arithmetic.\n    // This means that when a number is 256 or larger, it should be XORed with 0x11D.\n    if (x & 0x100) { // similar to x >= 256, but a lot faster (because 0x100 == 256)\n      x ^= 0x11D\n    }\n  }\n\n  // Optimization: double the size of the anti-log table so that we don't need to mod 255 to\n  // stay inside the bounds (because we will mainly use this table for the multiplication of\n  // two GF numbers, no more).\n  // @see {@link mul}\n  for (let i = 255; i < 512; i++) {\n    EXP_TABLE[i] = EXP_TABLE[i - 255]\n  }\n}())\n\n/**\n * Returns log value of n inside Galois Field\n *\n * @param  {Number} n\n * @return {Number}\n */\nexports.log = function log (n) {\n  if (n < 1) throw new Error('log(' + n + ')')\n  return LOG_TABLE[n]\n}\n\n/**\n * Returns anti-log value of n inside Galois Field\n *\n * @param  {Number} n\n * @return {Number}\n */\nexports.exp = function exp (n) {\n  return EXP_TABLE[n]\n}\n\n/**\n * Multiplies two number inside Galois Field\n *\n * @param  {Number} x\n * @param  {Number} y\n * @return {Number}\n */\nexports.mul = function mul (x, y) {\n  if (x === 0 || y === 0) return 0\n\n  // should be EXP_TABLE[(LOG_TABLE[x] + LOG_TABLE[y]) % 255] if EXP_TABLE wasn't oversized\n  // @see {@link initTables}\n  return EXP_TABLE[LOG_TABLE[x] + LOG_TABLE[y]]\n}\n","/**\n * Check if QR Code version is valid\n *\n * @param  {Number}  version QR Code version\n * @return {Boolean}         true if valid version, false otherwise\n */\nexports.isValid = function isValid (version) {\n  return !isNaN(version) && version >= 1 && version <= 40\n}\n","const numeric = '[0-9]+'\nconst alphanumeric = '[A-Z $%*+\\\\-./:]+'\nlet kanji = '(?:[u3000-u303F]|[u3040-u309F]|[u30A0-u30FF]|' +\n  '[uFF00-uFFEF]|[u4E00-u9FAF]|[u2605-u2606]|[u2190-u2195]|u203B|' +\n  '[u2010u2015u2018u2019u2025u2026u201Cu201Du2225u2260]|' +\n  '[u0391-u0451]|[u00A7u00A8u00B1u00B4u00D7u00F7])+'\nkanji = kanji.replace(/u/g, '\\\\u')\n\nconst byte = '(?:(?![A-Z0-9 $%*+\\\\-./:]|' + kanji + ')(?:.|[\\r\\n]))+'\n\nexports.KANJI = new RegExp(kanji, 'g')\nexports.BYTE_KANJI = new RegExp('[^A-Z0-9 $%*+\\\\-./:]+', 'g')\nexports.BYTE = new RegExp(byte, 'g')\nexports.NUMERIC = new RegExp(numeric, 'g')\nexports.ALPHANUMERIC = new RegExp(alphanumeric, 'g')\n\nconst TEST_KANJI = new RegExp('^' + kanji + '$')\nconst TEST_NUMERIC = new RegExp('^' + numeric + '$')\nconst TEST_ALPHANUMERIC = new RegExp('^[A-Z0-9 $%*+\\\\-./:]+$')\n\nexports.testKanji = function testKanji (str) {\n  return TEST_KANJI.test(str)\n}\n\nexports.testNumeric = function testNumeric (str) {\n  return TEST_NUMERIC.test(str)\n}\n\nexports.testAlphanumeric = function testAlphanumeric (str) {\n  return TEST_ALPHANUMERIC.test(str)\n}\n","const VersionCheck = require('./version-check')\nconst Regex = require('./regex')\n\n/**\n * Numeric mode encodes data from the decimal digit set (0 - 9)\n * (byte values 30HEX to 39HEX).\n * Normally, 3 data characters are represented by 10 bits.\n *\n * @type {Object}\n */\nexports.NUMERIC = {\n  id: 'Numeric',\n  bit: 1 << 0,\n  ccBits: [10, 12, 14]\n}\n\n/**\n * Alphanumeric mode encodes data from a set of 45 characters,\n * i.e. 10 numeric digits (0 - 9),\n *      26 alphabetic characters (A - Z),\n *   and 9 symbols (SP, $, %, *, +, -, ., /, :).\n * Normally, two input characters are represented by 11 bits.\n *\n * @type {Object}\n */\nexports.ALPHANUMERIC = {\n  id: 'Alphanumeric',\n  bit: 1 << 1,\n  ccBits: [9, 11, 13]\n}\n\n/**\n * In byte mode, data is encoded at 8 bits per character.\n *\n * @type {Object}\n */\nexports.BYTE = {\n  id: 'Byte',\n  bit: 1 << 2,\n  ccBits: [8, 16, 16]\n}\n\n/**\n * The Kanji mode efficiently encodes Kanji characters in accordance with\n * the Shift JIS system based on JIS X 0208.\n * The Shift JIS values are shifted from the JIS X 0208 values.\n * JIS X 0208 gives details of the shift coded representation.\n * Each two-byte character value is compacted to a 13-bit binary codeword.\n *\n * @type {Object}\n */\nexports.KANJI = {\n  id: 'Kanji',\n  bit: 1 << 3,\n  ccBits: [8, 10, 12]\n}\n\n/**\n * Mixed mode will contain a sequences of data in a combination of any of\n * the modes described above\n *\n * @type {Object}\n */\nexports.MIXED = {\n  bit: -1\n}\n\n/**\n * Returns the number of bits needed to store the data length\n * according to QR Code specifications.\n *\n * @param  {Mode}   mode    Data mode\n * @param  {Number} version QR Code version\n * @return {Number}         Number of bits\n */\nexports.getCharCountIndicator = function getCharCountIndicator (mode, version) {\n  if (!mode.ccBits) throw new Error('Invalid mode: ' + mode)\n\n  if (!VersionCheck.isValid(version)) {\n    throw new Error('Invalid version: ' + version)\n  }\n\n  if (version >= 1 && version < 10) return mode.ccBits[0]\n  else if (version < 27) return mode.ccBits[1]\n  return mode.ccBits[2]\n}\n\n/**\n * Returns the most efficient mode to store the specified data\n *\n * @param  {String} dataStr Input data string\n * @return {Mode}           Best mode\n */\nexports.getBestModeForData = function getBestModeForData (dataStr) {\n  if (Regex.testNumeric(dataStr)) return exports.NUMERIC\n  else if (Regex.testAlphanumeric(dataStr)) return exports.ALPHANUMERIC\n  else if (Regex.testKanji(dataStr)) return exports.KANJI\n  else return exports.BYTE\n}\n\n/**\n * Return mode name as string\n *\n * @param {Mode} mode Mode object\n * @returns {String}  Mode name\n */\nexports.toString = function toString (mode) {\n  if (mode && mode.id) return mode.id\n  throw new Error('Invalid mode')\n}\n\n/**\n * Check if input param is a valid mode object\n *\n * @param   {Mode}    mode Mode object\n * @returns {Boolean} True if valid mode, false otherwise\n */\nexports.isValid = function isValid (mode) {\n  return mode && mode.bit && mode.ccBits\n}\n\n/**\n * Get mode object from its name\n *\n * @param   {String} string Mode name\n * @returns {Mode}          Mode object\n */\nfunction fromString (string) {\n  if (typeof string !== 'string') {\n    throw new Error('Param is not a string')\n  }\n\n  const lcStr = string.toLowerCase()\n\n  switch (lcStr) {\n    case 'numeric':\n      return exports.NUMERIC\n    case 'alphanumeric':\n      return exports.ALPHANUMERIC\n    case 'kanji':\n      return exports.KANJI\n    case 'byte':\n      return exports.BYTE\n    default:\n      throw new Error('Unknown mode: ' + string)\n  }\n}\n\n/**\n * Returns mode from a value.\n * If value is not a valid mode, returns defaultValue\n *\n * @param  {Mode|String} value        Encoding mode\n * @param  {Mode}        defaultValue Fallback value\n * @return {Mode}                     Encoding mode\n */\nexports.from = function from (value, defaultValue) {\n  if (exports.isValid(value)) {\n    return value\n  }\n\n  try {\n    return fromString(value)\n  } catch (e) {\n    return defaultValue\n  }\n}\n","const Utils = require('./utils')\nconst ECCode = require('./error-correction-code')\nconst ECLevel = require('./error-correction-level')\nconst Mode = require('./mode')\nconst VersionCheck = require('./version-check')\n\n// Generator polynomial used to encode version information\nconst G18 = (1 << 12) | (1 << 11) | (1 << 10) | (1 << 9) | (1 << 8) | (1 << 5) | (1 << 2) | (1 << 0)\nconst G18_BCH = Utils.getBCHDigit(G18)\n\nfunction getBestVersionForDataLength (mode, length, errorCorrectionLevel) {\n  for (let currentVersion = 1; currentVersion <= 40; currentVersion++) {\n    if (length <= exports.getCapacity(currentVersion, errorCorrectionLevel, mode)) {\n      return currentVersion\n    }\n  }\n\n  return undefined\n}\n\nfunction getReservedBitsCount (mode, version) {\n  // Character count indicator + mode indicator bits\n  return Mode.getCharCountIndicator(mode, version) + 4\n}\n\nfunction getTotalBitsFromDataArray (segments, version) {\n  let totalBits = 0\n\n  segments.forEach(function (data) {\n    const reservedBits = getReservedBitsCount(data.mode, version)\n    totalBits += reservedBits + data.getBitsLength()\n  })\n\n  return totalBits\n}\n\nfunction getBestVersionForMixedData (segments, errorCorrectionLevel) {\n  for (let currentVersion = 1; currentVersion <= 40; currentVersion++) {\n    const length = getTotalBitsFromDataArray(segments, currentVersion)\n    if (length <= exports.getCapacity(currentVersion, errorCorrectionLevel, Mode.MIXED)) {\n      return currentVersion\n    }\n  }\n\n  return undefined\n}\n\n/**\n * Returns version number from a value.\n * If value is not a valid version, returns defaultValue\n *\n * @param  {Number|String} value        QR Code version\n * @param  {Number}        defaultValue Fallback value\n * @return {Number}                     QR Code version number\n */\nexports.from = function from (value, defaultValue) {\n  if (VersionCheck.isValid(value)) {\n    return parseInt(value, 10)\n  }\n\n  return defaultValue\n}\n\n/**\n * Returns how much data can be stored with the specified QR code version\n * and error correction level\n *\n * @param  {Number} version              QR Code version (1-40)\n * @param  {Number} errorCorrectionLevel Error correction level\n * @param  {Mode}   mode                 Data mode\n * @return {Number}                      Quantity of storable data\n */\nexports.getCapacity = function getCapacity (version, errorCorrectionLevel, mode) {\n  if (!VersionCheck.isValid(version)) {\n    throw new Error('Invalid QR Code version')\n  }\n\n  // Use Byte mode as default\n  if (typeof mode === 'undefined') mode = Mode.BYTE\n\n  // Total codewords for this QR code version (Data + Error correction)\n  const totalCodewords = Utils.getSymbolTotalCodewords(version)\n\n  // Total number of error correction codewords\n  const ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel)\n\n  // Total number of data codewords\n  const dataTotalCodewordsBits = (totalCodewords - ecTotalCodewords) * 8\n\n  if (mode === Mode.MIXED) return dataTotalCodewordsBits\n\n  const usableBits = dataTotalCodewordsBits - getReservedBitsCount(mode, version)\n\n  // Return max number of storable codewords\n  switch (mode) {\n    case Mode.NUMERIC:\n      return Math.floor((usableBits / 10) * 3)\n\n    case Mode.ALPHANUMERIC:\n      return Math.floor((usableBits / 11) * 2)\n\n    case Mode.KANJI:\n      return Math.floor(usableBits / 13)\n\n    case Mode.BYTE:\n    default:\n      return Math.floor(usableBits / 8)\n  }\n}\n\n/**\n * Returns the minimum version needed to contain the amount of data\n *\n * @param  {Segment} data                    Segment of data\n * @param  {Number} [errorCorrectionLevel=H] Error correction level\n * @param  {Mode} mode                       Data mode\n * @return {Number}                          QR Code version\n */\nexports.getBestVersionForData = function getBestVersionForData (data, errorCorrectionLevel) {\n  let seg\n\n  const ecl = ECLevel.from(errorCorrectionLevel, ECLevel.M)\n\n  if (Array.isArray(data)) {\n    if (data.length > 1) {\n      return getBestVersionForMixedData(data, ecl)\n    }\n\n    if (data.length === 0) {\n      return 1\n    }\n\n    seg = data[0]\n  } else {\n    seg = data\n  }\n\n  return getBestVersionForDataLength(seg.mode, seg.getLength(), ecl)\n}\n\n/**\n * Returns version information with relative error correction bits\n *\n * The version information is included in QR Code symbols of version 7 or larger.\n * It consists of an 18-bit sequence containing 6 data bits,\n * with 12 error correction bits calculated using the (18, 6) Golay code.\n *\n * @param  {Number} version QR Code version\n * @return {Number}         Encoded version info bits\n */\nexports.getEncodedBits = function getEncodedBits (version) {\n  if (!VersionCheck.isValid(version) || version < 7) {\n    throw new Error('Invalid QR Code version')\n  }\n\n  let d = version << 12\n\n  while (Utils.getBCHDigit(d) - G18_BCH >= 0) {\n    d ^= (G18 << (Utils.getBCHDigit(d) - G18_BCH))\n  }\n\n  return (version << 12) | d\n}\n","'use strict';\n\n/******************************************************************************\n * Created 2008-08-19.\n *\n * Dijkstra path-finding functions. Adapted from the Dijkstar Python project.\n *\n * Copyright (C) 2008\n *   Wyatt Baldwin <self@wyattbaldwin.com>\n *   All rights reserved\n *\n * Licensed under the MIT license.\n *\n *   http://www.opensource.org/licenses/mit-license.php\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 *****************************************************************************/\nvar dijkstra = {\n  single_source_shortest_paths: function(graph, s, d) {\n    // Predecessor map for each node that has been encountered.\n    // node ID => predecessor node ID\n    var predecessors = {};\n\n    // Costs of shortest paths from s to all nodes encountered.\n    // node ID => cost\n    var costs = {};\n    costs[s] = 0;\n\n    // Costs of shortest paths from s to all nodes encountered; differs from\n    // `costs` in that it provides easy access to the node that currently has\n    // the known shortest path from s.\n    // XXX: Do we actually need both `costs` and `open`?\n    var open = dijkstra.PriorityQueue.make();\n    open.push(s, 0);\n\n    var closest,\n        u, v,\n        cost_of_s_to_u,\n        adjacent_nodes,\n        cost_of_e,\n        cost_of_s_to_u_plus_cost_of_e,\n        cost_of_s_to_v,\n        first_visit;\n    while (!open.empty()) {\n      // In the nodes remaining in graph that have a known cost from s,\n      // find the node, u, that currently has the shortest path from s.\n      closest = open.pop();\n      u = closest.value;\n      cost_of_s_to_u = closest.cost;\n\n      // Get nodes adjacent to u...\n      adjacent_nodes = graph[u] || {};\n\n      // ...and explore the edges that connect u to those nodes, updating\n      // the cost of the shortest paths to any or all of those nodes as\n      // necessary. v is the node across the current edge from u.\n      for (v in adjacent_nodes) {\n        if (adjacent_nodes.hasOwnProperty(v)) {\n          // Get the cost of the edge running from u to v.\n          cost_of_e = adjacent_nodes[v];\n\n          // Cost of s to u plus the cost of u to v across e--this is *a*\n          // cost from s to v that may or may not be less than the current\n          // known cost to v.\n          cost_of_s_to_u_plus_cost_of_e = cost_of_s_to_u + cost_of_e;\n\n          // If we haven't visited v yet OR if the current known cost from s to\n          // v is greater than the new cost we just found (cost of s to u plus\n          // cost of u to v across e), update v's cost in the cost list and\n          // update v's predecessor in the predecessor list (it's now u).\n          cost_of_s_to_v = costs[v];\n          first_visit = (typeof costs[v] === 'undefined');\n          if (first_visit || cost_of_s_to_v > cost_of_s_to_u_plus_cost_of_e) {\n            costs[v] = cost_of_s_to_u_plus_cost_of_e;\n            open.push(v, cost_of_s_to_u_plus_cost_of_e);\n            predecessors[v] = u;\n          }\n        }\n      }\n    }\n\n    if (typeof d !== 'undefined' && typeof costs[d] === 'undefined') {\n      var msg = ['Could not find a path from ', s, ' to ', d, '.'].join('');\n      throw new Error(msg);\n    }\n\n    return predecessors;\n  },\n\n  extract_shortest_path_from_predecessor_list: function(predecessors, d) {\n    var nodes = [];\n    var u = d;\n    var predecessor;\n    while (u) {\n      nodes.push(u);\n      predecessor = predecessors[u];\n      u = predecessors[u];\n    }\n    nodes.reverse();\n    return nodes;\n  },\n\n  find_path: function(graph, s, d) {\n    var predecessors = dijkstra.single_source_shortest_paths(graph, s, d);\n    return dijkstra.extract_shortest_path_from_predecessor_list(\n      predecessors, d);\n  },\n\n  /**\n   * A very naive priority queue implementation.\n   */\n  PriorityQueue: {\n    make: function (opts) {\n      var T = dijkstra.PriorityQueue,\n          t = {},\n          key;\n      opts = opts || {};\n      for (key in T) {\n        if (T.hasOwnProperty(key)) {\n          t[key] = T[key];\n        }\n      }\n      t.queue = [];\n      t.sorter = opts.sorter || T.default_sorter;\n      return t;\n    },\n\n    default_sorter: function (a, b) {\n      return a.cost - b.cost;\n    },\n\n    /**\n     * Add a new item to the queue and ensure the highest priority element\n     * is at the front of the queue.\n     */\n    push: function (value, cost) {\n      var item = {value: value, cost: cost};\n      this.queue.push(item);\n      this.queue.sort(this.sorter);\n    },\n\n    /**\n     * Return the highest priority element in the queue.\n     */\n    pop: function () {\n      return this.queue.shift();\n    },\n\n    empty: function () {\n      return this.queue.length === 0;\n    }\n  }\n};\n\n\n// node.js module exports\nif (typeof module !== 'undefined') {\n  module.exports = dijkstra;\n}\n","const Mode = require('./mode')\nconst NumericData = require('./numeric-data')\nconst AlphanumericData = require('./alphanumeric-data')\nconst ByteData = require('./byte-data')\nconst KanjiData = require('./kanji-data')\nconst Regex = require('./regex')\nconst Utils = require('./utils')\nconst dijkstra = require('dijkstrajs')\n\n/**\n * Returns UTF8 byte length\n *\n * @param  {String} str Input string\n * @return {Number}     Number of byte\n */\nfunction getStringByteLength (str) {\n  return unescape(encodeURIComponent(str)).length\n}\n\n/**\n * Get a list of segments of the specified mode\n * from a string\n *\n * @param  {Mode}   mode Segment mode\n * @param  {String} str  String to process\n * @return {Array}       Array of object with segments data\n */\nfunction getSegments (regex, mode, str) {\n  const segments = []\n  let result\n\n  while ((result = regex.exec(str)) !== null) {\n    segments.push({\n      data: result[0],\n      index: result.index,\n      mode: mode,\n      length: result[0].length\n    })\n  }\n\n  return segments\n}\n\n/**\n * Extracts a series of segments with the appropriate\n * modes from a string\n *\n * @param  {String} dataStr Input string\n * @return {Array}          Array of object with segments data\n */\nfunction getSegmentsFromString (dataStr) {\n  const numSegs = getSegments(Regex.NUMERIC, Mode.NUMERIC, dataStr)\n  const alphaNumSegs = getSegments(Regex.ALPHANUMERIC, Mode.ALPHANUMERIC, dataStr)\n  let byteSegs\n  let kanjiSegs\n\n  if (Utils.isKanjiModeEnabled()) {\n    byteSegs = getSegments(Regex.BYTE, Mode.BYTE, dataStr)\n    kanjiSegs = getSegments(Regex.KANJI, Mode.KANJI, dataStr)\n  } else {\n    byteSegs = getSegments(Regex.BYTE_KANJI, Mode.BYTE, dataStr)\n    kanjiSegs = []\n  }\n\n  const segs = numSegs.concat(alphaNumSegs, byteSegs, kanjiSegs)\n\n  return segs\n    .sort(function (s1, s2) {\n      return s1.index - s2.index\n    })\n    .map(function (obj) {\n      return {\n        data: obj.data,\n        mode: obj.mode,\n        length: obj.length\n      }\n    })\n}\n\n/**\n * Returns how many bits are needed to encode a string of\n * specified length with the specified mode\n *\n * @param  {Number} length String length\n * @param  {Mode} mode     Segment mode\n * @return {Number}        Bit length\n */\nfunction getSegmentBitsLength (length, mode) {\n  switch (mode) {\n    case Mode.NUMERIC:\n      return NumericData.getBitsLength(length)\n    case Mode.ALPHANUMERIC:\n      return AlphanumericData.getBitsLength(length)\n    case Mode.KANJI:\n      return KanjiData.getBitsLength(length)\n    case Mode.BYTE:\n      return ByteData.getBitsLength(length)\n  }\n}\n\n/**\n * Merges adjacent segments which have the same mode\n *\n * @param  {Array} segs Array of object with segments data\n * @return {Array}      Array of object with segments data\n */\nfunction mergeSegments (segs) {\n  return segs.reduce(function (acc, curr) {\n    const prevSeg = acc.length - 1 >= 0 ? acc[acc.length - 1] : null\n    if (prevSeg && prevSeg.mode === curr.mode) {\n      acc[acc.length - 1].data += curr.data\n      return acc\n    }\n\n    acc.push(curr)\n    return acc\n  }, [])\n}\n\n/**\n * Generates a list of all possible nodes combination which\n * will be used to build a segments graph.\n *\n * Nodes are divided by groups. Each group will contain a list of all the modes\n * in which is possible to encode the given text.\n *\n * For example the text '12345' can be encoded as Numeric, Alphanumeric or Byte.\n * The group for '12345' will contain then 3 objects, one for each\n * possible encoding mode.\n *\n * Each node represents a possible segment.\n *\n * @param  {Array} segs Array of object with segments data\n * @return {Array}      Array of object with segments data\n */\nfunction buildNodes (segs) {\n  const nodes = []\n  for (let i = 0; i < segs.length; i++) {\n    const seg = segs[i]\n\n    switch (seg.mode) {\n      case Mode.NUMERIC:\n        nodes.push([seg,\n          { data: seg.data, mode: Mode.ALPHANUMERIC, length: seg.length },\n          { data: seg.data, mode: Mode.BYTE, length: seg.length }\n        ])\n        break\n      case Mode.ALPHANUMERIC:\n        nodes.push([seg,\n          { data: seg.data, mode: Mode.BYTE, length: seg.length }\n        ])\n        break\n      case Mode.KANJI:\n        nodes.push([seg,\n          { data: seg.data, mode: Mode.BYTE, length: getStringByteLength(seg.data) }\n        ])\n        break\n      case Mode.BYTE:\n        nodes.push([\n          { data: seg.data, mode: Mode.BYTE, length: getStringByteLength(seg.data) }\n        ])\n    }\n  }\n\n  return nodes\n}\n\n/**\n * Builds a graph from a list of nodes.\n * All segments in each node group will be connected with all the segments of\n * the next group and so on.\n *\n * At each connection will be assigned a weight depending on the\n * segment's byte length.\n *\n * @param  {Array} nodes    Array of object with segments data\n * @param  {Number} version QR Code version\n * @return {Object}         Graph of all possible segments\n */\nfunction buildGraph (nodes, version) {\n  const table = {}\n  const graph = { start: {} }\n  let prevNodeIds = ['start']\n\n  for (let i = 0; i < nodes.length; i++) {\n    const nodeGroup = nodes[i]\n    const currentNodeIds = []\n\n    for (let j = 0; j < nodeGroup.length; j++) {\n      const node = nodeGroup[j]\n      const key = '' + i + j\n\n      currentNodeIds.push(key)\n      table[key] = { node: node, lastCount: 0 }\n      graph[key] = {}\n\n      for (let n = 0; n < prevNodeIds.length; n++) {\n        const prevNodeId = prevNodeIds[n]\n\n        if (table[prevNodeId] && table[prevNodeId].node.mode === node.mode) {\n          graph[prevNodeId][key] =\n            getSegmentBitsLength(table[prevNodeId].lastCount + node.length, node.mode) -\n            getSegmentBitsLength(table[prevNodeId].lastCount, node.mode)\n\n          table[prevNodeId].lastCount += node.length\n        } else {\n          if (table[prevNodeId]) table[prevNodeId].lastCount = node.length\n\n          graph[prevNodeId][key] = getSegmentBitsLength(node.length, node.mode) +\n            4 + Mode.getCharCountIndicator(node.mode, version) // switch cost\n        }\n      }\n    }\n\n    prevNodeIds = currentNodeIds\n  }\n\n  for (let n = 0; n < prevNodeIds.length; n++) {\n    graph[prevNodeIds[n]].end = 0\n  }\n\n  return { map: graph, table: table }\n}\n\n/**\n * Builds a segment from a specified data and mode.\n * If a mode is not specified, the more suitable will be used.\n *\n * @param  {String} data             Input data\n * @param  {Mode | String} modesHint Data mode\n * @return {Segment}                 Segment\n */\nfunction buildSingleSegment (data, modesHint) {\n  let mode\n  const bestMode = Mode.getBestModeForData(data)\n\n  mode = Mode.from(modesHint, bestMode)\n\n  // Make sure data can be encoded\n  if (mode !== Mode.BYTE && mode.bit < bestMode.bit) {\n    throw new Error('\"' + data + '\"' +\n      ' cannot be encoded with mode ' + Mode.toString(mode) +\n      '.\\n Suggested mode is: ' + Mode.toString(bestMode))\n  }\n\n  // Use Mode.BYTE if Kanji support is disabled\n  if (mode === Mode.KANJI && !Utils.isKanjiModeEnabled()) {\n    mode = Mode.BYTE\n  }\n\n  switch (mode) {\n    case Mode.NUMERIC:\n      return new NumericData(data)\n\n    case Mode.ALPHANUMERIC:\n      return new AlphanumericData(data)\n\n    case Mode.KANJI:\n      return new KanjiData(data)\n\n    case Mode.BYTE:\n      return new ByteData(data)\n  }\n}\n\n/**\n * Builds a list of segments from an array.\n * Array can contain Strings or Objects with segment's info.\n *\n * For each item which is a string, will be generated a segment with the given\n * string and the more appropriate encoding mode.\n *\n * For each item which is an object, will be generated a segment with the given\n * data and mode.\n * Objects must contain at least the property \"data\".\n * If property \"mode\" is not present, the more suitable mode will be used.\n *\n * @param  {Array} array Array of objects with segments data\n * @return {Array}       Array of Segments\n */\nexports.fromArray = function fromArray (array) {\n  return array.reduce(function (acc, seg) {\n    if (typeof seg === 'string') {\n      acc.push(buildSingleSegment(seg, null))\n    } else if (seg.data) {\n      acc.push(buildSingleSegment(seg.data, seg.mode))\n    }\n\n    return acc\n  }, [])\n}\n\n/**\n * Builds an optimized sequence of segments from a string,\n * which will produce the shortest possible bitstream.\n *\n * @param  {String} data    Input string\n * @param  {Number} version QR Code version\n * @return {Array}          Array of segments\n */\nexports.fromString = function fromString (data, version) {\n  const segs = getSegmentsFromString(data, Utils.isKanjiModeEnabled())\n\n  const nodes = buildNodes(segs)\n  const graph = buildGraph(nodes, version)\n  const path = dijkstra.find_path(graph.map, 'start', 'end')\n\n  const optimizedSegs = []\n  for (let i = 1; i < path.length - 1; i++) {\n    optimizedSegs.push(graph.table[path[i]].node)\n  }\n\n  return exports.fromArray(mergeSegments(optimizedSegs))\n}\n\n/**\n * Splits a string in various segments with the modes which\n * best represent their content.\n * The produced segments are far from being optimized.\n * The output of this function is only used to estimate a QR Code version\n * which may contain the data.\n *\n * @param  {string} data Input string\n * @return {Array}       Array of segments\n */\nexports.rawSplit = function rawSplit (data) {\n  return exports.fromArray(\n    getSegmentsFromString(data, Utils.isKanjiModeEnabled())\n  )\n}\n","const Mode = require('./mode')\n\nfunction NumericData (data) {\n  this.mode = Mode.NUMERIC\n  this.data = data.toString()\n}\n\nNumericData.getBitsLength = function getBitsLength (length) {\n  return 10 * Math.floor(length / 3) + ((length % 3) ? ((length % 3) * 3 + 1) : 0)\n}\n\nNumericData.prototype.getLength = function getLength () {\n  return this.data.length\n}\n\nNumericData.prototype.getBitsLength = function getBitsLength () {\n  return NumericData.getBitsLength(this.data.length)\n}\n\nNumericData.prototype.write = function write (bitBuffer) {\n  let i, group, value\n\n  // The input data string is divided into groups of three digits,\n  // and each group is converted to its 10-bit binary equivalent.\n  for (i = 0; i + 3 <= this.data.length; i += 3) {\n    group = this.data.substr(i, 3)\n    value = parseInt(group, 10)\n\n    bitBuffer.put(value, 10)\n  }\n\n  // If the number of input digits is not an exact multiple of three,\n  // the final one or two digits are converted to 4 or 7 bits respectively.\n  const remainingNum = this.data.length - i\n  if (remainingNum > 0) {\n    group = this.data.substr(i)\n    value = parseInt(group, 10)\n\n    bitBuffer.put(value, remainingNum * 3 + 1)\n  }\n}\n\nmodule.exports = NumericData\n","const Mode = require('./mode')\n\n/**\n * Array of characters available in alphanumeric mode\n *\n * As per QR Code specification, to each character\n * is assigned a value from 0 to 44 which in this case coincides\n * with the array index\n *\n * @type {Array}\n */\nconst ALPHA_NUM_CHARS = [\n  '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',\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]\n\nfunction AlphanumericData (data) {\n  this.mode = Mode.ALPHANUMERIC\n  this.data = data\n}\n\nAlphanumericData.getBitsLength = function getBitsLength (length) {\n  return 11 * Math.floor(length / 2) + 6 * (length % 2)\n}\n\nAlphanumericData.prototype.getLength = function getLength () {\n  return this.data.length\n}\n\nAlphanumericData.prototype.getBitsLength = function getBitsLength () {\n  return AlphanumericData.getBitsLength(this.data.length)\n}\n\nAlphanumericData.prototype.write = function write (bitBuffer) {\n  let i\n\n  // Input data characters are divided into groups of two characters\n  // and encoded as 11-bit binary codes.\n  for (i = 0; i + 2 <= this.data.length; i += 2) {\n    // The character value of the first character is multiplied by 45\n    let value = ALPHA_NUM_CHARS.indexOf(this.data[i]) * 45\n\n    // The character value of the second digit is added to the product\n    value += ALPHA_NUM_CHARS.indexOf(this.data[i + 1])\n\n    // The sum is then stored as 11-bit binary number\n    bitBuffer.put(value, 11)\n  }\n\n  // If the number of input data characters is not a multiple of two,\n  // the character value of the final character is encoded as a 6-bit binary number.\n  if (this.data.length % 2) {\n    bitBuffer.put(ALPHA_NUM_CHARS.indexOf(this.data[i]), 6)\n  }\n}\n\nmodule.exports = AlphanumericData\n","const Mode = require('./mode')\n\nfunction ByteData (data) {\n  this.mode = Mode.BYTE\n  if (typeof (data) === 'string') {\n    this.data = new TextEncoder().encode(data)\n  } else {\n    this.data = new Uint8Array(data)\n  }\n}\n\nByteData.getBitsLength = function getBitsLength (length) {\n  return length * 8\n}\n\nByteData.prototype.getLength = function getLength () {\n  return this.data.length\n}\n\nByteData.prototype.getBitsLength = function getBitsLength () {\n  return ByteData.getBitsLength(this.data.length)\n}\n\nByteData.prototype.write = function (bitBuffer) {\n  for (let i = 0, l = this.data.length; i < l; i++) {\n    bitBuffer.put(this.data[i], 8)\n  }\n}\n\nmodule.exports = ByteData\n","const Mode = require('./mode')\nconst Utils = require('./utils')\n\nfunction KanjiData (data) {\n  this.mode = Mode.KANJI\n  this.data = data\n}\n\nKanjiData.getBitsLength = function getBitsLength (length) {\n  return length * 13\n}\n\nKanjiData.prototype.getLength = function getLength () {\n  return this.data.length\n}\n\nKanjiData.prototype.getBitsLength = function getBitsLength () {\n  return KanjiData.getBitsLength(this.data.length)\n}\n\nKanjiData.prototype.write = function (bitBuffer) {\n  let i\n\n  // In the Shift JIS system, Kanji characters are represented by a two byte combination.\n  // These byte values are shifted from the JIS X 0208 values.\n  // JIS X 0208 gives details of the shift coded representation.\n  for (i = 0; i < this.data.length; i++) {\n    let value = Utils.toSJIS(this.data[i])\n\n    // For characters with Shift JIS values from 0x8140 to 0x9FFC:\n    if (value >= 0x8140 && value <= 0x9FFC) {\n      // Subtract 0x8140 from Shift JIS value\n      value -= 0x8140\n\n    // For characters with Shift JIS values from 0xE040 to 0xEBBF\n    } else if (value >= 0xE040 && value <= 0xEBBF) {\n      // Subtract 0xC140 from Shift JIS value\n      value -= 0xC140\n    } else {\n      throw new Error(\n        'Invalid SJIS character: ' + this.data[i] + '\\n' +\n        'Make sure your charset is UTF-8')\n    }\n\n    // Multiply most significant byte of result by 0xC0\n    // and add least significant byte to product\n    value = (((value >>> 8) & 0xff) * 0xC0) + (value & 0xff)\n\n    // Convert result to a 13-bit binary string\n    bitBuffer.put(value, 13)\n  }\n}\n\nmodule.exports = KanjiData\n","const Utils = require('./utils')\nconst ECLevel = require('./error-correction-level')\nconst BitBuffer = require('./bit-buffer')\nconst BitMatrix = require('./bit-matrix')\nconst AlignmentPattern = require('./alignment-pattern')\nconst FinderPattern = require('./finder-pattern')\nconst MaskPattern = require('./mask-pattern')\nconst ECCode = require('./error-correction-code')\nconst ReedSolomonEncoder = require('./reed-solomon-encoder')\nconst Version = require('./version')\nconst FormatInfo = require('./format-info')\nconst Mode = require('./mode')\nconst Segments = require('./segments')\n\n/**\n * QRCode for JavaScript\n *\n * modified by Ryan Day for nodejs support\n * Copyright (c) 2011 Ryan Day\n *\n * Licensed under the MIT license:\n *   http://www.opensource.org/licenses/mit-license.php\n *\n//---------------------------------------------------------------------\n// QRCode for JavaScript\n//\n// Copyright (c) 2009 Kazuhiko Arase\n//\n// URL: http://www.d-project.com/\n//\n// Licensed under the MIT license:\n//   http://www.opensource.org/licenses/mit-license.php\n//\n// The word \"QR Code\" is registered trademark of\n// DENSO WAVE INCORPORATED\n//   http://www.denso-wave.com/qrcode/faqpatent-e.html\n//\n//---------------------------------------------------------------------\n*/\n\n/**\n * Add finder patterns bits to matrix\n *\n * @param  {BitMatrix} matrix  Modules matrix\n * @param  {Number}    version QR Code version\n */\nfunction setupFinderPattern (matrix, version) {\n  const size = matrix.size\n  const pos = FinderPattern.getPositions(version)\n\n  for (let i = 0; i < pos.length; i++) {\n    const row = pos[i][0]\n    const col = pos[i][1]\n\n    for (let r = -1; r <= 7; r++) {\n      if (row + r <= -1 || size <= row + r) continue\n\n      for (let c = -1; c <= 7; c++) {\n        if (col + c <= -1 || size <= col + c) continue\n\n        if ((r >= 0 && r <= 6 && (c === 0 || c === 6)) ||\n          (c >= 0 && c <= 6 && (r === 0 || r === 6)) ||\n          (r >= 2 && r <= 4 && c >= 2 && c <= 4)) {\n          matrix.set(row + r, col + c, true, true)\n        } else {\n          matrix.set(row + r, col + c, false, true)\n        }\n      }\n    }\n  }\n}\n\n/**\n * Add timing pattern bits to matrix\n *\n * Note: this function must be called before {@link setupAlignmentPattern}\n *\n * @param  {BitMatrix} matrix Modules matrix\n */\nfunction setupTimingPattern (matrix) {\n  const size = matrix.size\n\n  for (let r = 8; r < size - 8; r++) {\n    const value = r % 2 === 0\n    matrix.set(r, 6, value, true)\n    matrix.set(6, r, value, true)\n  }\n}\n\n/**\n * Add alignment patterns bits to matrix\n *\n * Note: this function must be called after {@link setupTimingPattern}\n *\n * @param  {BitMatrix} matrix  Modules matrix\n * @param  {Number}    version QR Code version\n */\nfunction setupAlignmentPattern (matrix, version) {\n  const pos = AlignmentPattern.getPositions(version)\n\n  for (let i = 0; i < pos.length; i++) {\n    const row = pos[i][0]\n    const col = pos[i][1]\n\n    for (let r = -2; r <= 2; r++) {\n      for (let c = -2; c <= 2; c++) {\n        if (r === -2 || r === 2 || c === -2 || c === 2 ||\n          (r === 0 && c === 0)) {\n          matrix.set(row + r, col + c, true, true)\n        } else {\n          matrix.set(row + r, col + c, false, true)\n        }\n      }\n    }\n  }\n}\n\n/**\n * Add version info bits to matrix\n *\n * @param  {BitMatrix} matrix  Modules matrix\n * @param  {Number}    version QR Code version\n */\nfunction setupVersionInfo (matrix, version) {\n  const size = matrix.size\n  const bits = Version.getEncodedBits(version)\n  let row, col, mod\n\n  for (let i = 0; i < 18; i++) {\n    row = Math.floor(i / 3)\n    col = i % 3 + size - 8 - 3\n    mod = ((bits >> i) & 1) === 1\n\n    matrix.set(row, col, mod, true)\n    matrix.set(col, row, mod, true)\n  }\n}\n\n/**\n * Add format info bits to matrix\n *\n * @param  {BitMatrix} matrix               Modules matrix\n * @param  {ErrorCorrectionLevel}    errorCorrectionLevel Error correction level\n * @param  {Number}    maskPattern          Mask pattern reference value\n */\nfunction setupFormatInfo (matrix, errorCorrectionLevel, maskPattern) {\n  const size = matrix.size\n  const bits = FormatInfo.getEncodedBits(errorCorrectionLevel, maskPattern)\n  let i, mod\n\n  for (i = 0; i < 15; i++) {\n    mod = ((bits >> i) & 1) === 1\n\n    // vertical\n    if (i < 6) {\n      matrix.set(i, 8, mod, true)\n    } else if (i < 8) {\n      matrix.set(i + 1, 8, mod, true)\n    } else {\n      matrix.set(size - 15 + i, 8, mod, true)\n    }\n\n    // horizontal\n    if (i < 8) {\n      matrix.set(8, size - i - 1, mod, true)\n    } else if (i < 9) {\n      matrix.set(8, 15 - i - 1 + 1, mod, true)\n    } else {\n      matrix.set(8, 15 - i - 1, mod, true)\n    }\n  }\n\n  // fixed module\n  matrix.set(size - 8, 8, 1, true)\n}\n\n/**\n * Add encoded data bits to matrix\n *\n * @param  {BitMatrix}  matrix Modules matrix\n * @param  {Uint8Array} data   Data codewords\n */\nfunction setupData (matrix, data) {\n  const size = matrix.size\n  let inc = -1\n  let row = size - 1\n  let bitIndex = 7\n  let byteIndex = 0\n\n  for (let col = size - 1; col > 0; col -= 2) {\n    if (col === 6) col--\n\n    while (true) {\n      for (let c = 0; c < 2; c++) {\n        if (!matrix.isReserved(row, col - c)) {\n          let dark = false\n\n          if (byteIndex < data.length) {\n            dark = (((data[byteIndex] >>> bitIndex) & 1) === 1)\n          }\n\n          matrix.set(row, col - c, dark)\n          bitIndex--\n\n          if (bitIndex === -1) {\n            byteIndex++\n            bitIndex = 7\n          }\n        }\n      }\n\n      row += inc\n\n      if (row < 0 || size <= row) {\n        row -= inc\n        inc = -inc\n        break\n      }\n    }\n  }\n}\n\n/**\n * Create encoded codewords from data input\n *\n * @param  {Number}   version              QR Code version\n * @param  {ErrorCorrectionLevel}   errorCorrectionLevel Error correction level\n * @param  {ByteData} data                 Data input\n * @return {Uint8Array}                    Buffer containing encoded codewords\n */\nfunction createData (version, errorCorrectionLevel, segments) {\n  // Prepare data buffer\n  const buffer = new BitBuffer()\n\n  segments.forEach(function (data) {\n    // prefix data with mode indicator (4 bits)\n    buffer.put(data.mode.bit, 4)\n\n    // Prefix data with character count indicator.\n    // The character count indicator is a string of bits that represents the\n    // number of characters that are being encoded.\n    // The character count indicator must be placed after the mode indicator\n    // and must be a certain number of bits long, depending on the QR version\n    // and data mode\n    // @see {@link Mode.getCharCountIndicator}.\n    buffer.put(data.getLength(), Mode.getCharCountIndicator(data.mode, version))\n\n    // add binary data sequence to buffer\n    data.write(buffer)\n  })\n\n  // Calculate required number of bits\n  const totalCodewords = Utils.getSymbolTotalCodewords(version)\n  const ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel)\n  const dataTotalCodewordsBits = (totalCodewords - ecTotalCodewords) * 8\n\n  // Add a terminator.\n  // If the bit string is shorter than the total number of required bits,\n  // a terminator of up to four 0s must be added to the right side of the string.\n  // If the bit string is more than four bits shorter than the required number of bits,\n  // add four 0s to the end.\n  if (buffer.getLengthInBits() + 4 <= dataTotalCodewordsBits) {\n    buffer.put(0, 4)\n  }\n\n  // If the bit string is fewer than four bits shorter, add only the number of 0s that\n  // are needed to reach the required number of bits.\n\n  // After adding the terminator, if the number of bits in the string is not a multiple of 8,\n  // pad the string on the right with 0s to make the string's length a multiple of 8.\n  while (buffer.getLengthInBits() % 8 !== 0) {\n    buffer.putBit(0)\n  }\n\n  // Add pad bytes if the string is still shorter than the total number of required bits.\n  // Extend the buffer to fill the data capacity of the symbol corresponding to\n  // the Version and Error Correction Level by adding the Pad Codewords 11101100 (0xEC)\n  // and 00010001 (0x11) alternately.\n  const remainingByte = (dataTotalCodewordsBits - buffer.getLengthInBits()) / 8\n  for (let i = 0; i < remainingByte; i++) {\n    buffer.put(i % 2 ? 0x11 : 0xEC, 8)\n  }\n\n  return createCodewords(buffer, version, errorCorrectionLevel)\n}\n\n/**\n * Encode input data with Reed-Solomon and return codewords with\n * relative error correction bits\n *\n * @param  {BitBuffer} bitBuffer            Data to encode\n * @param  {Number}    version              QR Code version\n * @param  {ErrorCorrectionLevel} errorCorrectionLevel Error correction level\n * @return {Uint8Array}                     Buffer containing encoded codewords\n */\nfunction createCodewords (bitBuffer, version, errorCorrectionLevel) {\n  // Total codewords for this QR code version (Data + Error correction)\n  const totalCodewords = Utils.getSymbolTotalCodewords(version)\n\n  // Total number of error correction codewords\n  const ecTotalCodewords = ECCode.getTotalCodewordsCount(version, errorCorrectionLevel)\n\n  // Total number of data codewords\n  const dataTotalCodewords = totalCodewords - ecTotalCodewords\n\n  // Total number of blocks\n  const ecTotalBlocks = ECCode.getBlocksCount(version, errorCorrectionLevel)\n\n  // Calculate how many blocks each group should contain\n  const blocksInGroup2 = totalCodewords % ecTotalBlocks\n  const blocksInGroup1 = ecTotalBlocks - blocksInGroup2\n\n  const totalCodewordsInGroup1 = Math.floor(totalCodewords / ecTotalBlocks)\n\n  const dataCodewordsInGroup1 = Math.floor(dataTotalCodewords / ecTotalBlocks)\n  const dataCodewordsInGroup2 = dataCodewordsInGroup1 + 1\n\n  // Number of EC codewords is the same for both groups\n  const ecCount = totalCodewordsInGroup1 - dataCodewordsInGroup1\n\n  // Initialize a Reed-Solomon encoder with a generator polynomial of degree ecCount\n  const rs = new ReedSolomonEncoder(ecCount)\n\n  let offset = 0\n  const dcData = new Array(ecTotalBlocks)\n  const ecData = new Array(ecTotalBlocks)\n  let maxDataSize = 0\n  const buffer = new Uint8Array(bitBuffer.buffer)\n\n  // Divide the buffer into the required number of blocks\n  for (let b = 0; b < ecTotalBlocks; b++) {\n    const dataSize = b < blocksInGroup1 ? dataCodewordsInGroup1 : dataCodewordsInGroup2\n\n    // extract a block of data from buffer\n    dcData[b] = buffer.slice(offset, offset + dataSize)\n\n    // Calculate EC codewords for this data block\n    ecData[b] = rs.encode(dcData[b])\n\n    offset += dataSize\n    maxDataSize = Math.max(maxDataSize, dataSize)\n  }\n\n  // Create final data\n  // Interleave the data and error correction codewords from each block\n  const data = new Uint8Array(totalCodewords)\n  let index = 0\n  let i, r\n\n  // Add data codewords\n  for (i = 0; i < maxDataSize; i++) {\n    for (r = 0; r < ecTotalBlocks; r++) {\n      if (i < dcData[r].length) {\n        data[index++] = dcData[r][i]\n      }\n    }\n  }\n\n  // Apped EC codewords\n  for (i = 0; i < ecCount; i++) {\n    for (r = 0; r < ecTotalBlocks; r++) {\n      data[index++] = ecData[r][i]\n    }\n  }\n\n  return data\n}\n\n/**\n * Build QR Code symbol\n *\n * @param  {String} data                 Input string\n * @param  {Number} version              QR Code version\n * @param  {ErrorCorretionLevel} errorCorrectionLevel Error level\n * @param  {MaskPattern} maskPattern     Mask pattern\n * @return {Object}                      Object containing symbol data\n */\nfunction createSymbol (data, version, errorCorrectionLevel, maskPattern) {\n  let segments\n\n  if (Array.isArray(data)) {\n    segments = Segments.fromArray(data)\n  } else if (typeof data === 'string') {\n    let estimatedVersion = version\n\n    if (!estimatedVersion) {\n      const rawSegments = Segments.rawSplit(data)\n\n      // Estimate best version that can contain raw splitted segments\n      estimatedVersion = Version.getBestVersionForData(rawSegments, errorCorrectionLevel)\n    }\n\n    // Build optimized segments\n    // If estimated version is undefined, try with the highest version\n    segments = Segments.fromString(data, estimatedVersion || 40)\n  } else {\n    throw new Error('Invalid data')\n  }\n\n  // Get the min version that can contain data\n  const bestVersion = Version.getBestVersionForData(segments, errorCorrectionLevel)\n\n  // If no version is found, data cannot be stored\n  if (!bestVersion) {\n    throw new Error('The amount of data is too big to be stored in a QR Code')\n  }\n\n  // If not specified, use min version as default\n  if (!version) {\n    version = bestVersion\n\n  // Check if the specified version can contain the data\n  } else if (version < bestVersion) {\n    throw new Error('\\n' +\n      'The chosen QR Code version cannot contain this amount of data.\\n' +\n      'Minimum version required to store current data is: ' + bestVersion + '.\\n'\n    )\n  }\n\n  const dataBits = createData(version, errorCorrectionLevel, segments)\n\n  // Allocate matrix buffer\n  const moduleCount = Utils.getSymbolSize(version)\n  const modules = new BitMatrix(moduleCount)\n\n  // Add function modules\n  setupFinderPattern(modules, version)\n  setupTimingPattern(modules)\n  setupAlignmentPattern(modules, version)\n\n  // Add temporary dummy bits for format info just to set them as reserved.\n  // This is needed to prevent these bits from being masked by {@link MaskPattern.applyMask}\n  // since the masking operation must be performed only on the encoding region.\n  // These blocks will be replaced with correct values later in code.\n  setupFormatInfo(modules, errorCorrectionLevel, 0)\n\n  if (version >= 7) {\n    setupVersionInfo(modules, version)\n  }\n\n  // Add data codewords\n  setupData(modules, dataBits)\n\n  if (isNaN(maskPattern)) {\n    // Find best mask pattern\n    maskPattern = MaskPattern.getBestMask(modules,\n      setupFormatInfo.bind(null, modules, errorCorrectionLevel))\n  }\n\n  // Apply mask pattern\n  MaskPattern.applyMask(maskPattern, modules)\n\n  // Replace format info bits with correct values\n  setupFormatInfo(modules, errorCorrectionLevel, maskPattern)\n\n  return {\n    modules: modules,\n    version: version,\n    errorCorrectionLevel: errorCorrectionLevel,\n    maskPattern: maskPattern,\n    segments: segments\n  }\n}\n\n/**\n * QR Code\n *\n * @param {String | Array} data                 Input data\n * @param {Object} options                      Optional configurations\n * @param {Number} options.version              QR Code version\n * @param {String} options.errorCorrectionLevel Error correction level\n * @param {Function} options.toSJISFunc         Helper func to convert utf8 to sjis\n */\nexports.create = function create (data, options) {\n  if (typeof data === 'undefined' || data === '') {\n    throw new Error('No input text')\n  }\n\n  let errorCorrectionLevel = ECLevel.M\n  let version\n  let mask\n\n  if (typeof options !== 'undefined') {\n    // Use higher error correction level as default\n    errorCorrectionLevel = ECLevel.from(options.errorCorrectionLevel, ECLevel.M)\n    version = Version.from(options.version)\n    mask = MaskPattern.from(options.maskPattern)\n\n    if (options.toSJISFunc) {\n      Utils.setToSJISFunction(options.toSJISFunc)\n    }\n  }\n\n  return createSymbol(data, version, errorCorrectionLevel, mask)\n}\n","function BitBuffer () {\n  this.buffer = []\n  this.length = 0\n}\n\nBitBuffer.prototype = {\n\n  get: function (index) {\n    const bufIndex = Math.floor(index / 8)\n    return ((this.buffer[bufIndex] >>> (7 - index % 8)) & 1) === 1\n  },\n\n  put: function (num, length) {\n    for (let i = 0; i < length; i++) {\n      this.putBit(((num >>> (length - i - 1)) & 1) === 1)\n    }\n  },\n\n  getLengthInBits: function () {\n    return this.length\n  },\n\n  putBit: function (bit) {\n    const bufIndex = Math.floor(this.length / 8)\n    if (this.buffer.length <= bufIndex) {\n      this.buffer.push(0)\n    }\n\n    if (bit) {\n      this.buffer[bufIndex] |= (0x80 >>> (this.length % 8))\n    }\n\n    this.length++\n  }\n}\n\nmodule.exports = BitBuffer\n","/**\n * Helper class to handle QR Code symbol modules\n *\n * @param {Number} size Symbol size\n */\nfunction BitMatrix (size) {\n  if (!size || size < 1) {\n    throw new Error('BitMatrix size must be defined and greater than 0')\n  }\n\n  this.size = size\n  this.data = new Uint8Array(size * size)\n  this.reservedBit = new Uint8Array(size * size)\n}\n\n/**\n * Set bit value at specified location\n * If reserved flag is set, this bit will be ignored during masking process\n *\n * @param {Number}  row\n * @param {Number}  col\n * @param {Boolean} value\n * @param {Boolean} reserved\n */\nBitMatrix.prototype.set = function (row, col, value, reserved) {\n  const index = row * this.size + col\n  this.data[index] = value\n  if (reserved) this.reservedBit[index] = true\n}\n\n/**\n * Returns bit value at specified location\n *\n * @param  {Number}  row\n * @param  {Number}  col\n * @return {Boolean}\n */\nBitMatrix.prototype.get = function (row, col) {\n  return this.data[row * this.size + col]\n}\n\n/**\n * Applies xor operator at specified location\n * (used during masking process)\n *\n * @param {Number}  row\n * @param {Number}  col\n * @param {Boolean} value\n */\nBitMatrix.prototype.xor = function (row, col, value) {\n  this.data[row * this.size + col] ^= value\n}\n\n/**\n * Check if bit at specified location is reserved\n *\n * @param {Number}   row\n * @param {Number}   col\n * @return {Boolean}\n */\nBitMatrix.prototype.isReserved = function (row, col) {\n  return this.reservedBit[row * this.size + col]\n}\n\nmodule.exports = BitMatrix\n","/**\n * Alignment pattern are fixed reference pattern in defined positions\n * in a matrix symbology, which enables the decode software to re-synchronise\n * the coordinate mapping of the image modules in the event of moderate amounts\n * of distortion of the image.\n *\n * Alignment patterns are present only in QR Code symbols of version 2 or larger\n * and their number depends on the symbol version.\n */\n\nconst getSymbolSize = require('./utils').getSymbolSize\n\n/**\n * Calculate the row/column coordinates of the center module of each alignment pattern\n * for the specified QR Code version.\n *\n * The alignment patterns are positioned symmetrically on either side of the diagonal\n * running from the top left corner of the symbol to the bottom right corner.\n *\n * Since positions are simmetrical only half of the coordinates are returned.\n * Each item of the array will represent in turn the x and y coordinate.\n * @see {@link getPositions}\n *\n * @param  {Number} version QR Code version\n * @return {Array}          Array of coordinate\n */\nexports.getRowColCoords = function getRowColCoords (version) {\n  if (version === 1) return []\n\n  const posCount = Math.floor(version / 7) + 2\n  const size = getSymbolSize(version)\n  const intervals = size === 145 ? 26 : Math.ceil((size - 13) / (2 * posCount - 2)) * 2\n  const positions = [size - 7] // Last coord is always (size - 7)\n\n  for (let i = 1; i < posCount - 1; i++) {\n    positions[i] = positions[i - 1] - intervals\n  }\n\n  positions.push(6) // First coord is always 6\n\n  return positions.reverse()\n}\n\n/**\n * Returns an array containing the positions of each alignment pattern.\n * Each array's element represent the center point of the pattern as (x, y) coordinates\n *\n * Coordinates are calculated expanding the row/column coordinates returned by {@link getRowColCoords}\n * and filtering out the items that overlaps with finder pattern\n *\n * @example\n * For a Version 7 symbol {@link getRowColCoords} returns values 6, 22 and 38.\n * The alignment patterns, therefore, are to be centered on (row, column)\n * positions (6,22), (22,6), (22,22), (22,38), (38,22), (38,38).\n * Note that the coordinates (6,6), (6,38), (38,6) are occupied by finder patterns\n * and are not therefore used for alignment patterns.\n *\n * let pos = getPositions(7)\n * // [[6,22], [22,6], [22,22], [22,38], [38,22], [38,38]]\n *\n * @param  {Number} version QR Code version\n * @return {Array}          Array of coordinates\n */\nexports.getPositions = function getPositions (version) {\n  const coords = []\n  const pos = exports.getRowColCoords(version)\n  const posLength = pos.length\n\n  for (let i = 0; i < posLength; i++) {\n    for (let j = 0; j < posLength; j++) {\n      // Skip if position is occupied by finder patterns\n      if ((i === 0 && j === 0) || // top-left\n          (i === 0 && j === posLength - 1) || // bottom-left\n          (i === posLength - 1 && j === 0)) { // top-right\n        continue\n      }\n\n      coords.push([pos[i], pos[j]])\n    }\n  }\n\n  return coords\n}\n","const getSymbolSize = require('./utils').getSymbolSize\nconst FINDER_PATTERN_SIZE = 7\n\n/**\n * Returns an array containing the positions of each finder pattern.\n * Each array's element represent the top-left point of the pattern as (x, y) coordinates\n *\n * @param  {Number} version QR Code version\n * @return {Array}          Array of coordinates\n */\nexports.getPositions = function getPositions (version) {\n  const size = getSymbolSize(version)\n\n  return [\n    // top-left\n    [0, 0],\n    // top-right\n    [size - FINDER_PATTERN_SIZE, 0],\n    // bottom-left\n    [0, size - FINDER_PATTERN_SIZE]\n  ]\n}\n","/**\n * Data mask pattern reference\n * @type {Object}\n */\nexports.Patterns = {\n  PATTERN000: 0,\n  PATTERN001: 1,\n  PATTERN010: 2,\n  PATTERN011: 3,\n  PATTERN100: 4,\n  PATTERN101: 5,\n  PATTERN110: 6,\n  PATTERN111: 7\n}\n\n/**\n * Weighted penalty scores for the undesirable features\n * @type {Object}\n */\nconst PenaltyScores = {\n  N1: 3,\n  N2: 3,\n  N3: 40,\n  N4: 10\n}\n\n/**\n * Check if mask pattern value is valid\n *\n * @param  {Number}  mask    Mask pattern\n * @return {Boolean}         true if valid, false otherwise\n */\nexports.isValid = function isValid (mask) {\n  return mask != null && mask !== '' && !isNaN(mask) && mask >= 0 && mask <= 7\n}\n\n/**\n * Returns mask pattern from a value.\n * If value is not valid, returns undefined\n *\n * @param  {Number|String} value        Mask pattern value\n * @return {Number}                     Valid mask pattern or undefined\n */\nexports.from = function from (value) {\n  return exports.isValid(value) ? parseInt(value, 10) : undefined\n}\n\n/**\n* Find adjacent modules in row/column with the same color\n* and assign a penalty value.\n*\n* Points: N1 + i\n* i is the amount by which the number of adjacent modules of the same color exceeds 5\n*/\nexports.getPenaltyN1 = function getPenaltyN1 (data) {\n  const size = data.size\n  let points = 0\n  let sameCountCol = 0\n  let sameCountRow = 0\n  let lastCol = null\n  let lastRow = null\n\n  for (let row = 0; row < size; row++) {\n    sameCountCol = sameCountRow = 0\n    lastCol = lastRow = null\n\n    for (let col = 0; col < size; col++) {\n      let module = data.get(row, col)\n      if (module === lastCol) {\n        sameCountCol++\n      } else {\n        if (sameCountCol >= 5) points += PenaltyScores.N1 + (sameCountCol - 5)\n        lastCol = module\n        sameCountCol = 1\n      }\n\n      module = data.get(col, row)\n      if (module === lastRow) {\n        sameCountRow++\n      } else {\n        if (sameCountRow >= 5) points += PenaltyScores.N1 + (sameCountRow - 5)\n        lastRow = module\n        sameCountRow = 1\n      }\n    }\n\n    if (sameCountCol >= 5) points += PenaltyScores.N1 + (sameCountCol - 5)\n    if (sameCountRow >= 5) points += PenaltyScores.N1 + (sameCountRow - 5)\n  }\n\n  return points\n}\n\n/**\n * Find 2x2 blocks with the same color and assign a penalty value\n *\n * Points: N2 * (m - 1) * (n - 1)\n */\nexports.getPenaltyN2 = function getPenaltyN2 (data) {\n  const size = data.size\n  let points = 0\n\n  for (let row = 0; row < size - 1; row++) {\n    for (let col = 0; col < size - 1; col++) {\n      const last = data.get(row, col) +\n        data.get(row, col + 1) +\n        data.get(row + 1, col) +\n        data.get(row + 1, col + 1)\n\n      if (last === 4 || last === 0) points++\n    }\n  }\n\n  return points * PenaltyScores.N2\n}\n\n/**\n * Find 1:1:3:1:1 ratio (dark:light:dark:light:dark) pattern in row/column,\n * preceded or followed by light area 4 modules wide\n *\n * Points: N3 * number of pattern found\n */\nexports.getPenaltyN3 = function getPenaltyN3 (data) {\n  const size = data.size\n  let points = 0\n  let bitsCol = 0\n  let bitsRow = 0\n\n  for (let row = 0; row < size; row++) {\n    bitsCol = bitsRow = 0\n    for (let col = 0; col < size; col++) {\n      bitsCol = ((bitsCol << 1) & 0x7FF) | data.get(row, col)\n      if (col >= 10 && (bitsCol === 0x5D0 || bitsCol === 0x05D)) points++\n\n      bitsRow = ((bitsRow << 1) & 0x7FF) | data.get(col, row)\n      if (col >= 10 && (bitsRow === 0x5D0 || bitsRow === 0x05D)) points++\n    }\n  }\n\n  return points * PenaltyScores.N3\n}\n\n/**\n * Calculate proportion of dark modules in entire symbol\n *\n * Points: N4 * k\n *\n * k is the rating of the deviation of the proportion of dark modules\n * in the symbol from 50% in steps of 5%\n */\nexports.getPenaltyN4 = function getPenaltyN4 (data) {\n  let darkCount = 0\n  const modulesCount = data.data.length\n\n  for (let i = 0; i < modulesCount; i++) darkCount += data.data[i]\n\n  const k = Math.abs(Math.ceil((darkCount * 100 / modulesCount) / 5) - 10)\n\n  return k * PenaltyScores.N4\n}\n\n/**\n * Return mask value at given position\n *\n * @param  {Number} maskPattern Pattern reference value\n * @param  {Number} i           Row\n * @param  {Number} j           Column\n * @return {Boolean}            Mask value\n */\nfunction getMaskAt (maskPattern, i, j) {\n  switch (maskPattern) {\n    case exports.Patterns.PATTERN000: return (i + j) % 2 === 0\n    case exports.Patterns.PATTERN001: return i % 2 === 0\n    case exports.Patterns.PATTERN010: return j % 3 === 0\n    case exports.Patterns.PATTERN011: return (i + j) % 3 === 0\n    case exports.Patterns.PATTERN100: return (Math.floor(i / 2) + Math.floor(j / 3)) % 2 === 0\n    case exports.Patterns.PATTERN101: return (i * j) % 2 + (i * j) % 3 === 0\n    case exports.Patterns.PATTERN110: return ((i * j) % 2 + (i * j) % 3) % 2 === 0\n    case exports.Patterns.PATTERN111: return ((i * j) % 3 + (i + j) % 2) % 2 === 0\n\n    default: throw new Error('bad maskPattern:' + maskPattern)\n  }\n}\n\n/**\n * Apply a mask pattern to a BitMatrix\n *\n * @param  {Number}    pattern Pattern reference number\n * @param  {BitMatrix} data    BitMatrix data\n */\nexports.applyMask = function applyMask (pattern, data) {\n  const size = data.size\n\n  for (let col = 0; col < size; col++) {\n    for (let row = 0; row < size; row++) {\n      if (data.isReserved(row, col)) continue\n      data.xor(row, col, getMaskAt(pattern, row, col))\n    }\n  }\n}\n\n/**\n * Returns the best mask pattern for data\n *\n * @param  {BitMatrix} data\n * @return {Number} Mask pattern reference number\n */\nexports.getBestMask = function getBestMask (data, setupFormatFunc) {\n  const numPatterns = Object.keys(exports.Patterns).length\n  let bestPattern = 0\n  let lowerPenalty = Infinity\n\n  for (let p = 0; p < numPatterns; p++) {\n    setupFormatFunc(p)\n    exports.applyMask(p, data)\n\n    // Calculate penalty\n    const penalty =\n      exports.getPenaltyN1(data) +\n      exports.getPenaltyN2(data) +\n      exports.getPenaltyN3(data) +\n      exports.getPenaltyN4(data)\n\n    // Undo previously applied mask\n    exports.applyMask(p, data)\n\n    if (penalty < lowerPenalty) {\n      lowerPenalty = penalty\n      bestPattern = p\n    }\n  }\n\n  return bestPattern\n}\n","const Polynomial = require('./polynomial')\n\nfunction ReedSolomonEncoder (degree) {\n  this.genPoly = undefined\n  this.degree = degree\n\n  if (this.degree) this.initialize(this.degree)\n}\n\n/**\n * Initialize the encoder.\n * The input param should correspond to the number of error correction codewords.\n *\n * @param  {Number} degree\n */\nReedSolomonEncoder.prototype.initialize = function initialize (degree) {\n  // create an irreducible generator polynomial\n  this.degree = degree\n  this.genPoly = Polynomial.generateECPolynomial(this.degree)\n}\n\n/**\n * Encodes a chunk of data\n *\n * @param  {Uint8Array} data Buffer containing input data\n * @return {Uint8Array}      Buffer containing encoded data\n */\nReedSolomonEncoder.prototype.encode = function encode (data) {\n  if (!this.genPoly) {\n    throw new Error('Encoder not initialized')\n  }\n\n  // Calculate EC for this data block\n  // extends data size to data+genPoly size\n  const paddedData = new Uint8Array(data.length + this.degree)\n  paddedData.set(data)\n\n  // The error correction codewords are the remainder after dividing the data codewords\n  // by a generator polynomial\n  const remainder = Polynomial.mod(paddedData, this.genPoly)\n\n  // return EC data blocks (last n byte, where n is the degree of genPoly)\n  // If coefficients number in remainder are less than genPoly degree,\n  // pad with 0s to the left to reach the needed number of coefficients\n  const start = this.degree - remainder.length\n  if (start > 0) {\n    const buff = new Uint8Array(this.degree)\n    buff.set(remainder, start)\n\n    return buff\n  }\n\n  return remainder\n}\n\nmodule.exports = ReedSolomonEncoder\n","const Utils = require('./utils')\n\nconst G15 = (1 << 10) | (1 << 8) | (1 << 5) | (1 << 4) | (1 << 2) | (1 << 1) | (1 << 0)\nconst G15_MASK = (1 << 14) | (1 << 12) | (1 << 10) | (1 << 4) | (1 << 1)\nconst G15_BCH = Utils.getBCHDigit(G15)\n\n/**\n * Returns format information with relative error correction bits\n *\n * The format information is a 15-bit sequence containing 5 data bits,\n * with 10 error correction bits calculated using the (15, 5) BCH code.\n *\n * @param  {Number} errorCorrectionLevel Error correction level\n * @param  {Number} mask                 Mask pattern\n * @return {Number}                      Encoded format information bits\n */\nexports.getEncodedBits = function getEncodedBits (errorCorrectionLevel, mask) {\n  const data = ((errorCorrectionLevel.bit << 3) | mask)\n  let d = data << 10\n\n  while (Utils.getBCHDigit(d) - G15_BCH >= 0) {\n    d ^= (G15 << (Utils.getBCHDigit(d) - G15_BCH))\n  }\n\n  // xor final data with mask pattern in order to ensure that\n  // no combination of Error Correction Level and data mask pattern\n  // will result in an all-zero data string\n  return ((data << 10) | d) ^ G15_MASK\n}\n","\"use strict\";\n\nlet util = require(\"util\");\nlet Stream = require(\"stream\");\n\nlet ChunkStream = (module.exports = function () {\n  Stream.call(this);\n\n  this._buffers = [];\n  this._buffered = 0;\n\n  this._reads = [];\n  this._paused = false;\n\n  this._encoding = \"utf8\";\n  this.writable = true;\n});\nutil.inherits(ChunkStream, Stream);\n\nChunkStream.prototype.read = function (length, callback) {\n  this._reads.push({\n    length: Math.abs(length), // if length < 0 then at most this length\n    allowLess: length < 0,\n    func: callback,\n  });\n\n  process.nextTick(\n    function () {\n      this._process();\n\n      // its paused and there is not enought data then ask for more\n      if (this._paused && this._reads && this._reads.length > 0) {\n        this._paused = false;\n\n        this.emit(\"drain\");\n      }\n    }.bind(this)\n  );\n};\n\nChunkStream.prototype.write = function (data, encoding) {\n  if (!this.writable) {\n    this.emit(\"error\", new Error(\"Stream not writable\"));\n    return false;\n  }\n\n  let dataBuffer;\n  if (Buffer.isBuffer(data)) {\n    dataBuffer = data;\n  } else {\n    dataBuffer = Buffer.from(data, encoding || this._encoding);\n  }\n\n  this._buffers.push(dataBuffer);\n  this._buffered += dataBuffer.length;\n\n  this._process();\n\n  // ok if there are no more read requests\n  if (this._reads && this._reads.length === 0) {\n    this._paused = true;\n  }\n\n  return this.writable && !this._paused;\n};\n\nChunkStream.prototype.end = function (data, encoding) {\n  if (data) {\n    this.write(data, encoding);\n  }\n\n  this.writable = false;\n\n  // already destroyed\n  if (!this._buffers) {\n    return;\n  }\n\n  // enqueue or handle end\n  if (this._buffers.length === 0) {\n    this._end();\n  } else {\n    this._buffers.push(null);\n    this._process();\n  }\n};\n\nChunkStream.prototype.destroySoon = ChunkStream.prototype.end;\n\nChunkStream.prototype._end = function () {\n  if (this._reads.length > 0) {\n    this.emit(\"error\", new Error(\"Unexpected end of input\"));\n  }\n\n  this.destroy();\n};\n\nChunkStream.prototype.destroy = function () {\n  if (!this._buffers) {\n    return;\n  }\n\n  this.writable = false;\n  this._reads = null;\n  this._buffers = null;\n\n  this.emit(\"close\");\n};\n\nChunkStream.prototype._processReadAllowingLess = function (read) {\n  // ok there is any data so that we can satisfy this request\n  this._reads.shift(); // == read\n\n  // first we need to peek into first buffer\n  let smallerBuf = this._buffers[0];\n\n  // ok there is more data than we need\n  if (smallerBuf.length > read.length) {\n    this._buffered -= read.length;\n    this._buffers[0] = smallerBuf.slice(read.length);\n\n    read.func.call(this, smallerBuf.slice(0, read.length));\n  } else {\n    // ok this is less than maximum length so use it all\n    this._buffered -= smallerBuf.length;\n    this._buffers.shift(); // == smallerBuf\n\n    read.func.call(this, smallerBuf);\n  }\n};\n\nChunkStream.prototype._processRead = function (read) {\n  this._reads.shift(); // == read\n\n  let pos = 0;\n  let count = 0;\n  let data = Buffer.alloc(read.length);\n\n  // create buffer for all data\n  while (pos < read.length) {\n    let buf = this._buffers[count++];\n    let len = Math.min(buf.length, read.length - pos);\n\n    buf.copy(data, pos, 0, len);\n    pos += len;\n\n    // last buffer wasn't used all so just slice it and leave\n    if (len !== buf.length) {\n      this._buffers[--count] = buf.slice(len);\n    }\n  }\n\n  // remove all used buffers\n  if (count > 0) {\n    this._buffers.splice(0, count);\n  }\n\n  this._buffered -= read.length;\n\n  read.func.call(this, data);\n};\n\nChunkStream.prototype._process = function () {\n  try {\n    // as long as there is any data and read requests\n    while (this._buffered > 0 && this._reads && this._reads.length > 0) {\n      let read = this._reads[0];\n\n      // read any data (but no more than length)\n      if (read.allowLess) {\n        this._processReadAllowingLess(read);\n      } else if (this._buffered >= read.length) {\n        // ok we can meet some expectations\n\n        this._processRead(read);\n      } else {\n        // not enought data to satisfy first request in queue\n        // so we need to wait for more\n        break;\n      }\n    }\n\n    if (this._buffers && !this.writable) {\n      this._end();\n    }\n  } catch (ex) {\n    this.emit(\"error\", ex);\n  }\n};\n","\"use strict\";\n\n// Adam 7\n//   0 1 2 3 4 5 6 7\n// 0 x 6 4 6 x 6 4 6\n// 1 7 7 7 7 7 7 7 7\n// 2 5 6 5 6 5 6 5 6\n// 3 7 7 7 7 7 7 7 7\n// 4 3 6 4 6 3 6 4 6\n// 5 7 7 7 7 7 7 7 7\n// 6 5 6 5 6 5 6 5 6\n// 7 7 7 7 7 7 7 7 7\n\nlet imagePasses = [\n  {\n    // pass 1 - 1px\n    x: [0],\n    y: [0],\n  },\n  {\n    // pass 2 - 1px\n    x: [4],\n    y: [0],\n  },\n  {\n    // pass 3 - 2px\n    x: [0, 4],\n    y: [4],\n  },\n  {\n    // pass 4 - 4px\n    x: [2, 6],\n    y: [0, 4],\n  },\n  {\n    // pass 5 - 8px\n    x: [0, 2, 4, 6],\n    y: [2, 6],\n  },\n  {\n    // pass 6 - 16px\n    x: [1, 3, 5, 7],\n    y: [0, 2, 4, 6],\n  },\n  {\n    // pass 7 - 32px\n    x: [0, 1, 2, 3, 4, 5, 6, 7],\n    y: [1, 3, 5, 7],\n  },\n];\n\nexports.getImagePasses = function (width, height) {\n  let images = [];\n  let xLeftOver = width % 8;\n  let yLeftOver = height % 8;\n  let xRepeats = (width - xLeftOver) / 8;\n  let yRepeats = (height - yLeftOver) / 8;\n  for (let i = 0; i < imagePasses.length; i++) {\n    let pass = imagePasses[i];\n    let passWidth = xRepeats * pass.x.length;\n    let passHeight = yRepeats * pass.y.length;\n    for (let j = 0; j < pass.x.length; j++) {\n      if (pass.x[j] < xLeftOver) {\n        passWidth++;\n      } else {\n        break;\n      }\n    }\n    for (let j = 0; j < pass.y.length; j++) {\n      if (pass.y[j] < yLeftOver) {\n        passHeight++;\n      } else {\n        break;\n      }\n    }\n    if (passWidth > 0 && passHeight > 0) {\n      images.push({ width: passWidth, height: passHeight, index: i });\n    }\n  }\n  return images;\n};\n\nexports.getInterlaceIterator = function (width) {\n  return function (x, y, pass) {\n    let outerXLeftOver = x % imagePasses[pass].x.length;\n    let outerX =\n      ((x - outerXLeftOver) / imagePasses[pass].x.length) * 8 +\n      imagePasses[pass].x[outerXLeftOver];\n    let outerYLeftOver = y % imagePasses[pass].y.length;\n    let outerY =\n      ((y - outerYLeftOver) / imagePasses[pass].y.length) * 8 +\n      imagePasses[pass].y[outerYLeftOver];\n    return outerX * 4 + outerY * width * 4;\n  };\n};\n","\"use strict\";\n\nmodule.exports = function paethPredictor(left, above, upLeft) {\n  let paeth = left + above - upLeft;\n  let pLeft = Math.abs(paeth - left);\n  let pAbove = Math.abs(paeth - above);\n  let pUpLeft = Math.abs(paeth - upLeft);\n\n  if (pLeft <= pAbove && pLeft <= pUpLeft) {\n    return left;\n  }\n  if (pAbove <= pUpLeft) {\n    return above;\n  }\n  return upLeft;\n};\n","\"use strict\";\n\nlet interlaceUtils = require(\"./interlace\");\nlet paethPredictor = require(\"./paeth-predictor\");\n\nfunction getByteWidth(width, bpp, depth) {\n  let byteWidth = width * bpp;\n  if (depth !== 8) {\n    byteWidth = Math.ceil(byteWidth / (8 / depth));\n  }\n  return byteWidth;\n}\n\nlet Filter = (module.exports = function (bitmapInfo, dependencies) {\n  let width = bitmapInfo.width;\n  let height = bitmapInfo.height;\n  let interlace = bitmapInfo.interlace;\n  let bpp = bitmapInfo.bpp;\n  let depth = bitmapInfo.depth;\n\n  this.read = dependencies.read;\n  this.write = dependencies.write;\n  this.complete = dependencies.complete;\n\n  this._imageIndex = 0;\n  this._images = [];\n  if (interlace) {\n    let passes = interlaceUtils.getImagePasses(width, height);\n    for (let i = 0; i < passes.length; i++) {\n      this._images.push({\n        byteWidth: getByteWidth(passes[i].width, bpp, depth),\n        height: passes[i].height,\n        lineIndex: 0,\n      });\n    }\n  } else {\n    this._images.push({\n      byteWidth: getByteWidth(width, bpp, depth),\n      height: height,\n      lineIndex: 0,\n    });\n  }\n\n  // when filtering the line we look at the pixel to the left\n  // the spec also says it is done on a byte level regardless of the number of pixels\n  // so if the depth is byte compatible (8 or 16) we subtract the bpp in order to compare back\n  // a pixel rather than just a different byte part. However if we are sub byte, we ignore.\n  if (depth === 8) {\n    this._xComparison = bpp;\n  } else if (depth === 16) {\n    this._xComparison = bpp * 2;\n  } else {\n    this._xComparison = 1;\n  }\n});\n\nFilter.prototype.start = function () {\n  this.read(\n    this._images[this._imageIndex].byteWidth + 1,\n    this._reverseFilterLine.bind(this)\n  );\n};\n\nFilter.prototype._unFilterType1 = function (\n  rawData,\n  unfilteredLine,\n  byteWidth\n) {\n  let xComparison = this._xComparison;\n  let xBiggerThan = xComparison - 1;\n\n  for (let x = 0; x < byteWidth; x++) {\n    let rawByte = rawData[1 + x];\n    let f1Left = x > xBiggerThan ? unfilteredLine[x - xComparison] : 0;\n    unfilteredLine[x] = rawByte + f1Left;\n  }\n};\n\nFilter.prototype._unFilterType2 = function (\n  rawData,\n  unfilteredLine,\n  byteWidth\n) {\n  let lastLine = this._lastLine;\n\n  for (let x = 0; x < byteWidth; x++) {\n    let rawByte = rawData[1 + x];\n    let f2Up = lastLine ? lastLine[x] : 0;\n    unfilteredLine[x] = rawByte + f2Up;\n  }\n};\n\nFilter.prototype._unFilterType3 = function (\n  rawData,\n  unfilteredLine,\n  byteWidth\n) {\n  let xComparison = this._xComparison;\n  let xBiggerThan = xComparison - 1;\n  let lastLine = this._lastLine;\n\n  for (let x = 0; x < byteWidth; x++) {\n    let rawByte = rawData[1 + x];\n    let f3Up = lastLine ? lastLine[x] : 0;\n    let f3Left = x > xBiggerThan ? unfilteredLine[x - xComparison] : 0;\n    let f3Add = Math.floor((f3Left + f3Up) / 2);\n    unfilteredLine[x] = rawByte + f3Add;\n  }\n};\n\nFilter.prototype._unFilterType4 = function (\n  rawData,\n  unfilteredLine,\n  byteWidth\n) {\n  let xComparison = this._xComparison;\n  let xBiggerThan = xComparison - 1;\n  let lastLine = this._lastLine;\n\n  for (let x = 0; x < byteWidth; x++) {\n    let rawByte = rawData[1 + x];\n    let f4Up = lastLine ? lastLine[x] : 0;\n    let f4Left = x > xBiggerThan ? unfilteredLine[x - xComparison] : 0;\n    let f4UpLeft = x > xBiggerThan && lastLine ? lastLine[x - xComparison] : 0;\n    let f4Add = paethPredictor(f4Left, f4Up, f4UpLeft);\n    unfilteredLine[x] = rawByte + f4Add;\n  }\n};\n\nFilter.prototype._reverseFilterLine = function (rawData) {\n  let filter = rawData[0];\n  let unfilteredLine;\n  let currentImage = this._images[this._imageIndex];\n  let byteWidth = currentImage.byteWidth;\n\n  if (filter === 0) {\n    unfilteredLine = rawData.slice(1, byteWidth + 1);\n  } else {\n    unfilteredLine = Buffer.alloc(byteWidth);\n\n    switch (filter) {\n      case 1:\n        this._unFilterType1(rawData, unfilteredLine, byteWidth);\n        break;\n      case 2:\n        this._unFilterType2(rawData, unfilteredLine, byteWidth);\n        break;\n      case 3:\n        this._unFilterType3(rawData, unfilteredLine, byteWidth);\n        break;\n      case 4:\n        this._unFilterType4(rawData, unfilteredLine, byteWidth);\n        break;\n      default:\n        throw new Error(\"Unrecognised filter type - \" + filter);\n    }\n  }\n\n  this.write(unfilteredLine);\n\n  currentImage.lineIndex++;\n  if (currentImage.lineIndex >= currentImage.height) {\n    this._lastLine = null;\n    this._imageIndex++;\n    currentImage = this._images[this._imageIndex];\n  } else {\n    this._lastLine = unfilteredLine;\n  }\n\n  if (currentImage) {\n    // read, using the byte width that may be from the new current image\n    this.read(currentImage.byteWidth + 1, this._reverseFilterLine.bind(this));\n  } else {\n    this._lastLine = null;\n    this.complete();\n  }\n};\n","\"use strict\";\n\nmodule.exports = {\n  PNG_SIGNATURE: [0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a],\n\n  TYPE_IHDR: 0x49484452,\n  TYPE_IEND: 0x49454e44,\n  TYPE_IDAT: 0x49444154,\n  TYPE_PLTE: 0x504c5445,\n  TYPE_tRNS: 0x74524e53, // eslint-disable-line camelcase\n  TYPE_gAMA: 0x67414d41, // eslint-disable-line camelcase\n\n  // color-type bits\n  COLORTYPE_GRAYSCALE: 0,\n  COLORTYPE_PALETTE: 1,\n  COLORTYPE_COLOR: 2,\n  COLORTYPE_ALPHA: 4, // e.g. grayscale and alpha\n\n  // color-type combinations\n  COLORTYPE_PALETTE_COLOR: 3,\n  COLORTYPE_COLOR_ALPHA: 6,\n\n  COLORTYPE_TO_BPP_MAP: {\n    0: 1,\n    2: 3,\n    3: 1,\n    4: 2,\n    6: 4,\n  },\n\n  GAMMA_DIVISION: 100000,\n};\n","\"use strict\";\n\nlet crcTable = [];\n\n(function () {\n  for (let i = 0; i < 256; i++) {\n    let currentCrc = i;\n    for (let j = 0; j < 8; j++) {\n      if (currentCrc & 1) {\n        currentCrc = 0xedb88320 ^ (currentCrc >>> 1);\n      } else {\n        currentCrc = currentCrc >>> 1;\n      }\n    }\n    crcTable[i] = currentCrc;\n  }\n})();\n\nlet CrcCalculator = (module.exports = function () {\n  this._crc = -1;\n});\n\nCrcCalculator.prototype.write = function (data) {\n  for (let i = 0; i < data.length; i++) {\n    this._crc = crcTable[(this._crc ^ data[i]) & 0xff] ^ (this._crc >>> 8);\n  }\n  return true;\n};\n\nCrcCalculator.prototype.crc32 = function () {\n  return this._crc ^ -1;\n};\n\nCrcCalculator.crc32 = function (buf) {\n  let crc = -1;\n  for (let i = 0; i < buf.length; i++) {\n    crc = crcTable[(crc ^ buf[i]) & 0xff] ^ (crc >>> 8);\n  }\n  return crc ^ -1;\n};\n","\"use strict\";\n\nlet constants = require(\"./constants\");\nlet CrcCalculator = require(\"./crc\");\n\nlet Parser = (module.exports = function (options, dependencies) {\n  this._options = options;\n  options.checkCRC = options.checkCRC !== false;\n\n  this._hasIHDR = false;\n  this._hasIEND = false;\n  this._emittedHeadersFinished = false;\n\n  // input flags/metadata\n  this._palette = [];\n  this._colorType = 0;\n\n  this._chunks = {};\n  this._chunks[constants.TYPE_IHDR] = this._handleIHDR.bind(this);\n  this._chunks[constants.TYPE_IEND] = this._handleIEND.bind(this);\n  this._chunks[constants.TYPE_IDAT] = this._handleIDAT.bind(this);\n  this._chunks[constants.TYPE_PLTE] = this._handlePLTE.bind(this);\n  this._chunks[constants.TYPE_tRNS] = this._handleTRNS.bind(this);\n  this._chunks[constants.TYPE_gAMA] = this._handleGAMA.bind(this);\n\n  this.read = dependencies.read;\n  this.error = dependencies.error;\n  this.metadata = dependencies.metadata;\n  this.gamma = dependencies.gamma;\n  this.transColor = dependencies.transColor;\n  this.palette = dependencies.palette;\n  this.parsed = dependencies.parsed;\n  this.inflateData = dependencies.inflateData;\n  this.finished = dependencies.finished;\n  this.simpleTransparency = dependencies.simpleTransparency;\n  this.headersFinished = dependencies.headersFinished || function () {};\n});\n\nParser.prototype.start = function () {\n  this.read(constants.PNG_SIGNATURE.length, this._parseSignature.bind(this));\n};\n\nParser.prototype._parseSignature = function (data) {\n  let signature = constants.PNG_SIGNATURE;\n\n  for (let i = 0; i < signature.length; i++) {\n    if (data[i] !== signature[i]) {\n      this.error(new Error(\"Invalid file signature\"));\n      return;\n    }\n  }\n  this.read(8, this._parseChunkBegin.bind(this));\n};\n\nParser.prototype._parseChunkBegin = function (data) {\n  // chunk content length\n  let length = data.readUInt32BE(0);\n\n  // chunk type\n  let type = data.readUInt32BE(4);\n  let name = \"\";\n  for (let i = 4; i < 8; i++) {\n    name += String.fromCharCode(data[i]);\n  }\n\n  //console.log('chunk ', name, length);\n\n  // chunk flags\n  let ancillary = Boolean(data[4] & 0x20); // or critical\n  //    priv = Boolean(data[5] & 0x20), // or public\n  //    safeToCopy = Boolean(data[7] & 0x20); // or unsafe\n\n  if (!this._hasIHDR && type !== constants.TYPE_IHDR) {\n    this.error(new Error(\"Expected IHDR on beggining\"));\n    return;\n  }\n\n  this._crc = new CrcCalculator();\n  this._crc.write(Buffer.from(name));\n\n  if (this._chunks[type]) {\n    return this._chunks[type](length);\n  }\n\n  if (!ancillary) {\n    this.error(new Error(\"Unsupported critical chunk type \" + name));\n    return;\n  }\n\n  this.read(length + 4, this._skipChunk.bind(this));\n};\n\nParser.prototype._skipChunk = function (/*data*/) {\n  this.read(8, this._parseChunkBegin.bind(this));\n};\n\nParser.prototype._handleChunkEnd = function () {\n  this.read(4, this._parseChunkEnd.bind(this));\n};\n\nParser.prototype._parseChunkEnd = function (data) {\n  let fileCrc = data.readInt32BE(0);\n  let calcCrc = this._crc.crc32();\n\n  // check CRC\n  if (this._options.checkCRC && calcCrc !== fileCrc) {\n    this.error(new Error(\"Crc error - \" + fileCrc + \" - \" + calcCrc));\n    return;\n  }\n\n  if (!this._hasIEND) {\n    this.read(8, this._parseChunkBegin.bind(this));\n  }\n};\n\nParser.prototype._handleIHDR = function (length) {\n  this.read(length, this._parseIHDR.bind(this));\n};\nParser.prototype._parseIHDR = function (data) {\n  this._crc.write(data);\n\n  let width = data.readUInt32BE(0);\n  let height = data.readUInt32BE(4);\n  let depth = data[8];\n  let colorType = data[9]; // bits: 1 palette, 2 color, 4 alpha\n  let compr = data[10];\n  let filter = data[11];\n  let interlace = data[12];\n\n  // console.log('    width', width, 'height', height,\n  //     'depth', depth, 'colorType', colorType,\n  //     'compr', compr, 'filter', filter, 'interlace', interlace\n  // );\n\n  if (\n    depth !== 8 &&\n    depth !== 4 &&\n    depth !== 2 &&\n    depth !== 1 &&\n    depth !== 16\n  ) {\n    this.error(new Error(\"Unsupported bit depth \" + depth));\n    return;\n  }\n  if (!(colorType in constants.COLORTYPE_TO_BPP_MAP)) {\n    this.error(new Error(\"Unsupported color type\"));\n    return;\n  }\n  if (compr !== 0) {\n    this.error(new Error(\"Unsupported compression method\"));\n    return;\n  }\n  if (filter !== 0) {\n    this.error(new Error(\"Unsupported filter method\"));\n    return;\n  }\n  if (interlace !== 0 && interlace !== 1) {\n    this.error(new Error(\"Unsupported interlace method\"));\n    return;\n  }\n\n  this._colorType = colorType;\n\n  let bpp = constants.COLORTYPE_TO_BPP_MAP[this._colorType];\n\n  this._hasIHDR = true;\n\n  this.metadata({\n    width: width,\n    height: height,\n    depth: depth,\n    interlace: Boolean(interlace),\n    palette: Boolean(colorType & constants.COLORTYPE_PALETTE),\n    color: Boolean(colorType & constants.COLORTYPE_COLOR),\n    alpha: Boolean(colorType & constants.COLORTYPE_ALPHA),\n    bpp: bpp,\n    colorType: colorType,\n  });\n\n  this._handleChunkEnd();\n};\n\nParser.prototype._handlePLTE = function (length) {\n  this.read(length, this._parsePLTE.bind(this));\n};\nParser.prototype._parsePLTE = function (data) {\n  this._crc.write(data);\n\n  let entries = Math.floor(data.length / 3);\n  // console.log('Palette:', entries);\n\n  for (let i = 0; i < entries; i++) {\n    this._palette.push([data[i * 3], data[i * 3 + 1], data[i * 3 + 2], 0xff]);\n  }\n\n  this.palette(this._palette);\n\n  this._handleChunkEnd();\n};\n\nParser.prototype._handleTRNS = function (length) {\n  this.simpleTransparency();\n  this.read(length, this._parseTRNS.bind(this));\n};\nParser.prototype._parseTRNS = function (data) {\n  this._crc.write(data);\n\n  // palette\n  if (this._colorType === constants.COLORTYPE_PALETTE_COLOR) {\n    if (this._palette.length === 0) {\n      this.error(new Error(\"Transparency chunk must be after palette\"));\n      return;\n    }\n    if (data.length > this._palette.length) {\n      this.error(new Error(\"More transparent colors than palette size\"));\n      return;\n    }\n    for (let i = 0; i < data.length; i++) {\n      this._palette[i][3] = data[i];\n    }\n    this.palette(this._palette);\n  }\n\n  // for colorType 0 (grayscale) and 2 (rgb)\n  // there might be one gray/color defined as transparent\n  if (this._colorType === constants.COLORTYPE_GRAYSCALE) {\n    // grey, 2 bytes\n    this.transColor([data.readUInt16BE(0)]);\n  }\n  if (this._colorType === constants.COLORTYPE_COLOR) {\n    this.transColor([\n      data.readUInt16BE(0),\n      data.readUInt16BE(2),\n      data.readUInt16BE(4),\n    ]);\n  }\n\n  this._handleChunkEnd();\n};\n\nParser.prototype._handleGAMA = function (length) {\n  this.read(length, this._parseGAMA.bind(this));\n};\nParser.prototype._parseGAMA = function (data) {\n  this._crc.write(data);\n  this.gamma(data.readUInt32BE(0) / constants.GAMMA_DIVISION);\n\n  this._handleChunkEnd();\n};\n\nParser.prototype._handleIDAT = function (length) {\n  if (!this._emittedHeadersFinished) {\n    this._emittedHeadersFinished = true;\n    this.headersFinished();\n  }\n  this.read(-length, this._parseIDAT.bind(this, length));\n};\nParser.prototype._parseIDAT = function (length, data) {\n  this._crc.write(data);\n\n  if (\n    this._colorType === constants.COLORTYPE_PALETTE_COLOR &&\n    this._palette.length === 0\n  ) {\n    throw new Error(\"Expected palette not found\");\n  }\n\n  this.inflateData(data);\n  let leftOverLength = length - data.length;\n\n  if (leftOverLength > 0) {\n    this._handleIDAT(leftOverLength);\n  } else {\n    this._handleChunkEnd();\n  }\n};\n\nParser.prototype._handleIEND = function (length) {\n  this.read(length, this._parseIEND.bind(this));\n};\nParser.prototype._parseIEND = function (data) {\n  this._crc.write(data);\n\n  this._hasIEND = true;\n  this._handleChunkEnd();\n\n  if (this.finished) {\n    this.finished();\n  }\n};\n","\"use strict\";\n\nlet interlaceUtils = require(\"./interlace\");\n\nlet pixelBppMapper = [\n  // 0 - dummy entry\n  function () {},\n\n  // 1 - L\n  // 0: 0, 1: 0, 2: 0, 3: 0xff\n  function (pxData, data, pxPos, rawPos) {\n    if (rawPos === data.length) {\n      throw new Error(\"Ran out of data\");\n    }\n\n    let pixel = data[rawPos];\n    pxData[pxPos] = pixel;\n    pxData[pxPos + 1] = pixel;\n    pxData[pxPos + 2] = pixel;\n    pxData[pxPos + 3] = 0xff;\n  },\n\n  // 2 - LA\n  // 0: 0, 1: 0, 2: 0, 3: 1\n  function (pxData, data, pxPos, rawPos) {\n    if (rawPos + 1 >= data.length) {\n      throw new Error(\"Ran out of data\");\n    }\n\n    let pixel = data[rawPos];\n    pxData[pxPos] = pixel;\n    pxData[pxPos + 1] = pixel;\n    pxData[pxPos + 2] = pixel;\n    pxData[pxPos + 3] = data[rawPos + 1];\n  },\n\n  // 3 - RGB\n  // 0: 0, 1: 1, 2: 2, 3: 0xff\n  function (pxData, data, pxPos, rawPos) {\n    if (rawPos + 2 >= data.length) {\n      throw new Error(\"Ran out of data\");\n    }\n\n    pxData[pxPos] = data[rawPos];\n    pxData[pxPos + 1] = data[rawPos + 1];\n    pxData[pxPos + 2] = data[rawPos + 2];\n    pxData[pxPos + 3] = 0xff;\n  },\n\n  // 4 - RGBA\n  // 0: 0, 1: 1, 2: 2, 3: 3\n  function (pxData, data, pxPos, rawPos) {\n    if (rawPos + 3 >= data.length) {\n      throw new Error(\"Ran out of data\");\n    }\n\n    pxData[pxPos] = data[rawPos];\n    pxData[pxPos + 1] = data[rawPos + 1];\n    pxData[pxPos + 2] = data[rawPos + 2];\n    pxData[pxPos + 3] = data[rawPos + 3];\n  },\n];\n\nlet pixelBppCustomMapper = [\n  // 0 - dummy entry\n  function () {},\n\n  // 1 - L\n  // 0: 0, 1: 0, 2: 0, 3: 0xff\n  function (pxData, pixelData, pxPos, maxBit) {\n    let pixel = pixelData[0];\n    pxData[pxPos] = pixel;\n    pxData[pxPos + 1] = pixel;\n    pxData[pxPos + 2] = pixel;\n    pxData[pxPos + 3] = maxBit;\n  },\n\n  // 2 - LA\n  // 0: 0, 1: 0, 2: 0, 3: 1\n  function (pxData, pixelData, pxPos) {\n    let pixel = pixelData[0];\n    pxData[pxPos] = pixel;\n    pxData[pxPos + 1] = pixel;\n    pxData[pxPos + 2] = pixel;\n    pxData[pxPos + 3] = pixelData[1];\n  },\n\n  // 3 - RGB\n  // 0: 0, 1: 1, 2: 2, 3: 0xff\n  function (pxData, pixelData, pxPos, maxBit) {\n    pxData[pxPos] = pixelData[0];\n    pxData[pxPos + 1] = pixelData[1];\n    pxData[pxPos + 2] = pixelData[2];\n    pxData[pxPos + 3] = maxBit;\n  },\n\n  // 4 - RGBA\n  // 0: 0, 1: 1, 2: 2, 3: 3\n  function (pxData, pixelData, pxPos) {\n    pxData[pxPos] = pixelData[0];\n    pxData[pxPos + 1] = pixelData[1];\n    pxData[pxPos + 2] = pixelData[2];\n    pxData[pxPos + 3] = pixelData[3];\n  },\n];\n\nfunction bitRetriever(data, depth) {\n  let leftOver = [];\n  let i = 0;\n\n  function split() {\n    if (i === data.length) {\n      throw new Error(\"Ran out of data\");\n    }\n    let byte = data[i];\n    i++;\n    let byte8, byte7, byte6, byte5, byte4, byte3, byte2, byte1;\n    switch (depth) {\n      default:\n        throw new Error(\"unrecognised depth\");\n      case 16:\n        byte2 = data[i];\n        i++;\n        leftOver.push((byte << 8) + byte2);\n        break;\n      case 4:\n        byte2 = byte & 0x0f;\n        byte1 = byte >> 4;\n        leftOver.push(byte1, byte2);\n        break;\n      case 2:\n        byte4 = byte & 3;\n        byte3 = (byte >> 2) & 3;\n        byte2 = (byte >> 4) & 3;\n        byte1 = (byte >> 6) & 3;\n        leftOver.push(byte1, byte2, byte3, byte4);\n        break;\n      case 1:\n        byte8 = byte & 1;\n        byte7 = (byte >> 1) & 1;\n        byte6 = (byte >> 2) & 1;\n        byte5 = (byte >> 3) & 1;\n        byte4 = (byte >> 4) & 1;\n        byte3 = (byte >> 5) & 1;\n        byte2 = (byte >> 6) & 1;\n        byte1 = (byte >> 7) & 1;\n        leftOver.push(byte1, byte2, byte3, byte4, byte5, byte6, byte7, byte8);\n        break;\n    }\n  }\n\n  return {\n    get: function (count) {\n      while (leftOver.length < count) {\n        split();\n      }\n      let returner = leftOver.slice(0, count);\n      leftOver = leftOver.slice(count);\n      return returner;\n    },\n    resetAfterLine: function () {\n      leftOver.length = 0;\n    },\n    end: function () {\n      if (i !== data.length) {\n        throw new Error(\"extra data found\");\n      }\n    },\n  };\n}\n\nfunction mapImage8Bit(image, pxData, getPxPos, bpp, data, rawPos) {\n  // eslint-disable-line max-params\n  let imageWidth = image.width;\n  let imageHeight = image.height;\n  let imagePass = image.index;\n  for (let y = 0; y < imageHeight; y++) {\n    for (let x = 0; x < imageWidth; x++) {\n      let pxPos = getPxPos(x, y, imagePass);\n      pixelBppMapper[bpp](pxData, data, pxPos, rawPos);\n      rawPos += bpp; //eslint-disable-line no-param-reassign\n    }\n  }\n  return rawPos;\n}\n\nfunction mapImageCustomBit(image, pxData, getPxPos, bpp, bits, maxBit) {\n  // eslint-disable-line max-params\n  let imageWidth = image.width;\n  let imageHeight = image.height;\n  let imagePass = image.index;\n  for (let y = 0; y < imageHeight; y++) {\n    for (let x = 0; x < imageWidth; x++) {\n      let pixelData = bits.get(bpp);\n      let pxPos = getPxPos(x, y, imagePass);\n      pixelBppCustomMapper[bpp](pxData, pixelData, pxPos, maxBit);\n    }\n    bits.resetAfterLine();\n  }\n}\n\nexports.dataToBitMap = function (data, bitmapInfo) {\n  let width = bitmapInfo.width;\n  let height = bitmapInfo.height;\n  let depth = bitmapInfo.depth;\n  let bpp = bitmapInfo.bpp;\n  let interlace = bitmapInfo.interlace;\n  let bits;\n\n  if (depth !== 8) {\n    bits = bitRetriever(data, depth);\n  }\n  let pxData;\n  if (depth <= 8) {\n    pxData = Buffer.alloc(width * height * 4);\n  } else {\n    pxData = new Uint16Array(width * height * 4);\n  }\n  let maxBit = Math.pow(2, depth) - 1;\n  let rawPos = 0;\n  let images;\n  let getPxPos;\n\n  if (interlace) {\n    images = interlaceUtils.getImagePasses(width, height);\n    getPxPos = interlaceUtils.getInterlaceIterator(width, height);\n  } else {\n    let nonInterlacedPxPos = 0;\n    getPxPos = function () {\n      let returner = nonInterlacedPxPos;\n      nonInterlacedPxPos += 4;\n      return returner;\n    };\n    images = [{ width: width, height: height }];\n  }\n\n  for (let imageIndex = 0; imageIndex < images.length; imageIndex++) {\n    if (depth === 8) {\n      rawPos = mapImage8Bit(\n        images[imageIndex],\n        pxData,\n        getPxPos,\n        bpp,\n        data,\n        rawPos\n      );\n    } else {\n      mapImageCustomBit(\n        images[imageIndex],\n        pxData,\n        getPxPos,\n        bpp,\n        bits,\n        maxBit\n      );\n    }\n  }\n  if (depth === 8) {\n    if (rawPos !== data.length) {\n      throw new Error(\"extra data found\");\n    }\n  } else {\n    bits.end();\n  }\n\n  return pxData;\n};\n","\"use strict\";\n\nfunction dePalette(indata, outdata, width, height, palette) {\n  let pxPos = 0;\n  // use values from palette\n  for (let y = 0; y < height; y++) {\n    for (let x = 0; x < width; x++) {\n      let color = palette[indata[pxPos]];\n\n      if (!color) {\n        throw new Error(\"index \" + indata[pxPos] + \" not in palette\");\n      }\n\n      for (let i = 0; i < 4; i++) {\n        outdata[pxPos + i] = color[i];\n      }\n      pxPos += 4;\n    }\n  }\n}\n\nfunction replaceTransparentColor(indata, outdata, width, height, transColor) {\n  let pxPos = 0;\n  for (let y = 0; y < height; y++) {\n    for (let x = 0; x < width; x++) {\n      let makeTrans = false;\n\n      if (transColor.length === 1) {\n        if (transColor[0] === indata[pxPos]) {\n          makeTrans = true;\n        }\n      } else if (\n        transColor[0] === indata[pxPos] &&\n        transColor[1] === indata[pxPos + 1] &&\n        transColor[2] === indata[pxPos + 2]\n      ) {\n        makeTrans = true;\n      }\n      if (makeTrans) {\n        for (let i = 0; i < 4; i++) {\n          outdata[pxPos + i] = 0;\n        }\n      }\n      pxPos += 4;\n    }\n  }\n}\n\nfunction scaleDepth(indata, outdata, width, height, depth) {\n  let maxOutSample = 255;\n  let maxInSample = Math.pow(2, depth) - 1;\n  let pxPos = 0;\n\n  for (let y = 0; y < height; y++) {\n    for (let x = 0; x < width; x++) {\n      for (let i = 0; i < 4; i++) {\n        outdata[pxPos + i] = Math.floor(\n          (indata[pxPos + i] * maxOutSample) / maxInSample + 0.5\n        );\n      }\n      pxPos += 4;\n    }\n  }\n}\n\nmodule.exports = function (indata, imageData) {\n  let depth = imageData.depth;\n  let width = imageData.width;\n  let height = imageData.height;\n  let colorType = imageData.colorType;\n  let transColor = imageData.transColor;\n  let palette = imageData.palette;\n\n  let outdata = indata; // only different for 16 bits\n\n  if (colorType === 3) {\n    // paletted\n    dePalette(indata, outdata, width, height, palette);\n  } else {\n    if (transColor) {\n      replaceTransparentColor(indata, outdata, width, height, transColor);\n    }\n    // if it needs scaling\n    if (depth !== 8) {\n      // if we need to change the buffer size\n      if (depth === 16) {\n        outdata = Buffer.alloc(width * height * 4);\n      }\n      scaleDepth(indata, outdata, width, height, depth);\n    }\n  }\n  return outdata;\n};\n","\"use strict\";\n\nlet util = require(\"util\");\nlet zlib = require(\"zlib\");\nlet ChunkStream = require(\"./chunkstream\");\nlet FilterAsync = require(\"./filter-parse-async\");\nlet Parser = require(\"./parser\");\nlet bitmapper = require(\"./bitmapper\");\nlet formatNormaliser = require(\"./format-normaliser\");\n\nlet ParserAsync = (module.exports = function (options) {\n  ChunkStream.call(this);\n\n  this._parser = new Parser(options, {\n    read: this.read.bind(this),\n    error: this._handleError.bind(this),\n    metadata: this._handleMetaData.bind(this),\n    gamma: this.emit.bind(this, \"gamma\"),\n    palette: this._handlePalette.bind(this),\n    transColor: this._handleTransColor.bind(this),\n    finished: this._finished.bind(this),\n    inflateData: this._inflateData.bind(this),\n    simpleTransparency: this._simpleTransparency.bind(this),\n    headersFinished: this._headersFinished.bind(this),\n  });\n  this._options = options;\n  this.writable = true;\n\n  this._parser.start();\n});\nutil.inherits(ParserAsync, ChunkStream);\n\nParserAsync.prototype._handleError = function (err) {\n  this.emit(\"error\", err);\n\n  this.writable = false;\n\n  this.destroy();\n\n  if (this._inflate && this._inflate.destroy) {\n    this._inflate.destroy();\n  }\n\n  if (this._filter) {\n    this._filter.destroy();\n    // For backward compatibility with Node 7 and below.\n    // Suppress errors due to _inflate calling write() even after\n    // it's destroy()'ed.\n    this._filter.on(\"error\", function () {});\n  }\n\n  this.errord = true;\n};\n\nParserAsync.prototype._inflateData = function (data) {\n  if (!this._inflate) {\n    if (this._bitmapInfo.interlace) {\n      this._inflate = zlib.createInflate();\n\n      this._inflate.on(\"error\", this.emit.bind(this, \"error\"));\n      this._filter.on(\"complete\", this._complete.bind(this));\n\n      this._inflate.pipe(this._filter);\n    } else {\n      let rowSize =\n        ((this._bitmapInfo.width *\n          this._bitmapInfo.bpp *\n          this._bitmapInfo.depth +\n          7) >>\n          3) +\n        1;\n      let imageSize = rowSize * this._bitmapInfo.height;\n      let chunkSize = Math.max(imageSize, zlib.Z_MIN_CHUNK);\n\n      this._inflate = zlib.createInflate({ chunkSize: chunkSize });\n      let leftToInflate = imageSize;\n\n      let emitError = this.emit.bind(this, \"error\");\n      this._inflate.on(\"error\", function (err) {\n        if (!leftToInflate) {\n          return;\n        }\n\n        emitError(err);\n      });\n      this._filter.on(\"complete\", this._complete.bind(this));\n\n      let filterWrite = this._filter.write.bind(this._filter);\n      this._inflate.on(\"data\", function (chunk) {\n        if (!leftToInflate) {\n          return;\n        }\n\n        if (chunk.length > leftToInflate) {\n          chunk = chunk.slice(0, leftToInflate);\n        }\n\n        leftToInflate -= chunk.length;\n\n        filterWrite(chunk);\n      });\n\n      this._inflate.on(\"end\", this._filter.end.bind(this._filter));\n    }\n  }\n  this._inflate.write(data);\n};\n\nParserAsync.prototype._handleMetaData = function (metaData) {\n  this._metaData = metaData;\n  this._bitmapInfo = Object.create(metaData);\n\n  this._filter = new FilterAsync(this._bitmapInfo);\n};\n\nParserAsync.prototype._handleTransColor = function (transColor) {\n  this._bitmapInfo.transColor = transColor;\n};\n\nParserAsync.prototype._handlePalette = function (palette) {\n  this._bitmapInfo.palette = palette;\n};\n\nParserAsync.prototype._simpleTransparency = function () {\n  this._metaData.alpha = true;\n};\n\nParserAsync.prototype._headersFinished = function () {\n  // Up until this point, we don't know if we have a tRNS chunk (alpha)\n  // so we can't emit metadata any earlier\n  this.emit(\"metadata\", this._metaData);\n};\n\nParserAsync.prototype._finished = function () {\n  if (this.errord) {\n    return;\n  }\n\n  if (!this._inflate) {\n    this.emit(\"error\", \"No Inflate block\");\n  } else {\n    // no more data to inflate\n    this._inflate.end();\n  }\n};\n\nParserAsync.prototype._complete = function (filteredData) {\n  if (this.errord) {\n    return;\n  }\n\n  let normalisedBitmapData;\n\n  try {\n    let bitmapData = bitmapper.dataToBitMap(filteredData, this._bitmapInfo);\n\n    normalisedBitmapData = formatNormaliser(bitmapData, this._bitmapInfo);\n    bitmapData = null;\n  } catch (ex) {\n    this._handleError(ex);\n    return;\n  }\n\n  this.emit(\"parsed\", normalisedBitmapData);\n};\n","\"use strict\";\n\nlet util = require(\"util\");\nlet ChunkStream = require(\"./chunkstream\");\nlet Filter = require(\"./filter-parse\");\n\nlet FilterAsync = (module.exports = function (bitmapInfo) {\n  ChunkStream.call(this);\n\n  let buffers = [];\n  let that = this;\n  this._filter = new Filter(bitmapInfo, {\n    read: this.read.bind(this),\n    write: function (buffer) {\n      buffers.push(buffer);\n    },\n    complete: function () {\n      that.emit(\"complete\", Buffer.concat(buffers));\n    },\n  });\n\n  this._filter.start();\n});\nutil.inherits(FilterAsync, ChunkStream);\n","\"use strict\";\n\nlet constants = require(\"./constants\");\nlet CrcStream = require(\"./crc\");\nlet bitPacker = require(\"./bitpacker\");\nlet filter = require(\"./filter-pack\");\nlet zlib = require(\"zlib\");\n\nlet Packer = (module.exports = function (options) {\n  this._options = options;\n\n  options.deflateChunkSize = options.deflateChunkSize || 32 * 1024;\n  options.deflateLevel =\n    options.deflateLevel != null ? options.deflateLevel : 9;\n  options.deflateStrategy =\n    options.deflateStrategy != null ? options.deflateStrategy : 3;\n  options.inputHasAlpha =\n    options.inputHasAlpha != null ? options.inputHasAlpha : true;\n  options.deflateFactory = options.deflateFactory || zlib.createDeflate;\n  options.bitDepth = options.bitDepth || 8;\n  // This is outputColorType\n  options.colorType =\n    typeof options.colorType === \"number\"\n      ? options.colorType\n      : constants.COLORTYPE_COLOR_ALPHA;\n  options.inputColorType =\n    typeof options.inputColorType === \"number\"\n      ? options.inputColorType\n      : constants.COLORTYPE_COLOR_ALPHA;\n\n  if (\n    [\n      constants.COLORTYPE_GRAYSCALE,\n      constants.COLORTYPE_COLOR,\n      constants.COLORTYPE_COLOR_ALPHA,\n      constants.COLORTYPE_ALPHA,\n    ].indexOf(options.colorType) === -1\n  ) {\n    throw new Error(\n      \"option color type:\" + options.colorType + \" is not supported at present\"\n    );\n  }\n  if (\n    [\n      constants.COLORTYPE_GRAYSCALE,\n      constants.COLORTYPE_COLOR,\n      constants.COLORTYPE_COLOR_ALPHA,\n      constants.COLORTYPE_ALPHA,\n    ].indexOf(options.inputColorType) === -1\n  ) {\n    throw new Error(\n      \"option input color type:\" +\n        options.inputColorType +\n        \" is not supported at present\"\n    );\n  }\n  if (options.bitDepth !== 8 && options.bitDepth !== 16) {\n    throw new Error(\n      \"option bit depth:\" + options.bitDepth + \" is not supported at present\"\n    );\n  }\n});\n\nPacker.prototype.getDeflateOptions = function () {\n  return {\n    chunkSize: this._options.deflateChunkSize,\n    level: this._options.deflateLevel,\n    strategy: this._options.deflateStrategy,\n  };\n};\n\nPacker.prototype.createDeflate = function () {\n  return this._options.deflateFactory(this.getDeflateOptions());\n};\n\nPacker.prototype.filterData = function (data, width, height) {\n  // convert to correct format for filtering (e.g. right bpp and bit depth)\n  let packedData = bitPacker(data, width, height, this._options);\n\n  // filter pixel data\n  let bpp = constants.COLORTYPE_TO_BPP_MAP[this._options.colorType];\n  let filteredData = filter(packedData, width, height, this._options, bpp);\n  return filteredData;\n};\n\nPacker.prototype._packChunk = function (type, data) {\n  let len = data ? data.length : 0;\n  let buf = Buffer.alloc(len + 12);\n\n  buf.writeUInt32BE(len, 0);\n  buf.writeUInt32BE(type, 4);\n\n  if (data) {\n    data.copy(buf, 8);\n  }\n\n  buf.writeInt32BE(\n    CrcStream.crc32(buf.slice(4, buf.length - 4)),\n    buf.length - 4\n  );\n  return buf;\n};\n\nPacker.prototype.packGAMA = function (gamma) {\n  let buf = Buffer.alloc(4);\n  buf.writeUInt32BE(Math.floor(gamma * constants.GAMMA_DIVISION), 0);\n  return this._packChunk(constants.TYPE_gAMA, buf);\n};\n\nPacker.prototype.packIHDR = function (width, height) {\n  let buf = Buffer.alloc(13);\n  buf.writeUInt32BE(width, 0);\n  buf.writeUInt32BE(height, 4);\n  buf[8] = this._options.bitDepth; // Bit depth\n  buf[9] = this._options.colorType; // colorType\n  buf[10] = 0; // compression\n  buf[11] = 0; // filter\n  buf[12] = 0; // interlace\n\n  return this._packChunk(constants.TYPE_IHDR, buf);\n};\n\nPacker.prototype.packIDAT = function (data) {\n  return this._packChunk(constants.TYPE_IDAT, data);\n};\n\nPacker.prototype.packIEND = function () {\n  return this._packChunk(constants.TYPE_IEND, null);\n};\n","\"use strict\";\n\nlet constants = require(\"./constants\");\n\nmodule.exports = function (dataIn, width, height, options) {\n  let outHasAlpha =\n    [constants.COLORTYPE_COLOR_ALPHA, constants.COLORTYPE_ALPHA].indexOf(\n      options.colorType\n    ) !== -1;\n  if (options.colorType === options.inputColorType) {\n    let bigEndian = (function () {\n      let buffer = new ArrayBuffer(2);\n      new DataView(buffer).setInt16(0, 256, true /* littleEndian */);\n      // Int16Array uses the platform's endianness.\n      return new Int16Array(buffer)[0] !== 256;\n    })();\n    // If no need to convert to grayscale and alpha is present/absent in both, take a fast route\n    if (options.bitDepth === 8 || (options.bitDepth === 16 && bigEndian)) {\n      return dataIn;\n    }\n  }\n\n  // map to a UInt16 array if data is 16bit, fix endianness below\n  let data = options.bitDepth !== 16 ? dataIn : new Uint16Array(dataIn.buffer);\n\n  let maxValue = 255;\n  let inBpp = constants.COLORTYPE_TO_BPP_MAP[options.inputColorType];\n  if (inBpp === 4 && !options.inputHasAlpha) {\n    inBpp = 3;\n  }\n  let outBpp = constants.COLORTYPE_TO_BPP_MAP[options.colorType];\n  if (options.bitDepth === 16) {\n    maxValue = 65535;\n    outBpp *= 2;\n  }\n  let outData = Buffer.alloc(width * height * outBpp);\n\n  let inIndex = 0;\n  let outIndex = 0;\n\n  let bgColor = options.bgColor || {};\n  if (bgColor.red === undefined) {\n    bgColor.red = maxValue;\n  }\n  if (bgColor.green === undefined) {\n    bgColor.green = maxValue;\n  }\n  if (bgColor.blue === undefined) {\n    bgColor.blue = maxValue;\n  }\n\n  function getRGBA() {\n    let red;\n    let green;\n    let blue;\n    let alpha = maxValue;\n    switch (options.inputColorType) {\n      case constants.COLORTYPE_COLOR_ALPHA:\n        alpha = data[inIndex + 3];\n        red = data[inIndex];\n        green = data[inIndex + 1];\n        blue = data[inIndex + 2];\n        break;\n      case constants.COLORTYPE_COLOR:\n        red = data[inIndex];\n        green = data[inIndex + 1];\n        blue = data[inIndex + 2];\n        break;\n      case constants.COLORTYPE_ALPHA:\n        alpha = data[inIndex + 1];\n        red = data[inIndex];\n        green = red;\n        blue = red;\n        break;\n      case constants.COLORTYPE_GRAYSCALE:\n        red = data[inIndex];\n        green = red;\n        blue = red;\n        break;\n      default:\n        throw new Error(\n          \"input color type:\" +\n            options.inputColorType +\n            \" is not supported at present\"\n        );\n    }\n\n    if (options.inputHasAlpha) {\n      if (!outHasAlpha) {\n        alpha /= maxValue;\n        red = Math.min(\n          Math.max(Math.round((1 - alpha) * bgColor.red + alpha * red), 0),\n          maxValue\n        );\n        green = Math.min(\n          Math.max(Math.round((1 - alpha) * bgColor.green + alpha * green), 0),\n          maxValue\n        );\n        blue = Math.min(\n          Math.max(Math.round((1 - alpha) * bgColor.blue + alpha * blue), 0),\n          maxValue\n        );\n      }\n    }\n    return { red: red, green: green, blue: blue, alpha: alpha };\n  }\n\n  for (let y = 0; y < height; y++) {\n    for (let x = 0; x < width; x++) {\n      let rgba = getRGBA(data, inIndex);\n\n      switch (options.colorType) {\n        case constants.COLORTYPE_COLOR_ALPHA:\n        case constants.COLORTYPE_COLOR:\n          if (options.bitDepth === 8) {\n            outData[outIndex] = rgba.red;\n            outData[outIndex + 1] = rgba.green;\n            outData[outIndex + 2] = rgba.blue;\n            if (outHasAlpha) {\n              outData[outIndex + 3] = rgba.alpha;\n            }\n          } else {\n            outData.writeUInt16BE(rgba.red, outIndex);\n            outData.writeUInt16BE(rgba.green, outIndex + 2);\n            outData.writeUInt16BE(rgba.blue, outIndex + 4);\n            if (outHasAlpha) {\n              outData.writeUInt16BE(rgba.alpha, outIndex + 6);\n            }\n          }\n          break;\n        case constants.COLORTYPE_ALPHA:\n        case constants.COLORTYPE_GRAYSCALE: {\n          // Convert to grayscale and alpha\n          let grayscale = (rgba.red + rgba.green + rgba.blue) / 3;\n          if (options.bitDepth === 8) {\n            outData[outIndex] = grayscale;\n            if (outHasAlpha) {\n              outData[outIndex + 1] = rgba.alpha;\n            }\n          } else {\n            outData.writeUInt16BE(grayscale, outIndex);\n            if (outHasAlpha) {\n              outData.writeUInt16BE(rgba.alpha, outIndex + 2);\n            }\n          }\n          break;\n        }\n        default:\n          throw new Error(\"unrecognised color Type \" + options.colorType);\n      }\n\n      inIndex += inBpp;\n      outIndex += outBpp;\n    }\n  }\n\n  return outData;\n};\n","\"use strict\";\n\nlet paethPredictor = require(\"./paeth-predictor\");\n\nfunction filterNone(pxData, pxPos, byteWidth, rawData, rawPos) {\n  for (let x = 0; x < byteWidth; x++) {\n    rawData[rawPos + x] = pxData[pxPos + x];\n  }\n}\n\nfunction filterSumNone(pxData, pxPos, byteWidth) {\n  let sum = 0;\n  let length = pxPos + byteWidth;\n\n  for (let i = pxPos; i < length; i++) {\n    sum += Math.abs(pxData[i]);\n  }\n  return sum;\n}\n\nfunction filterSub(pxData, pxPos, byteWidth, rawData, rawPos, bpp) {\n  for (let x = 0; x < byteWidth; x++) {\n    let left = x >= bpp ? pxData[pxPos + x - bpp] : 0;\n    let val = pxData[pxPos + x] - left;\n\n    rawData[rawPos + x] = val;\n  }\n}\n\nfunction filterSumSub(pxData, pxPos, byteWidth, bpp) {\n  let sum = 0;\n  for (let x = 0; x < byteWidth; x++) {\n    let left = x >= bpp ? pxData[pxPos + x - bpp] : 0;\n    let val = pxData[pxPos + x] - left;\n\n    sum += Math.abs(val);\n  }\n\n  return sum;\n}\n\nfunction filterUp(pxData, pxPos, byteWidth, rawData, rawPos) {\n  for (let x = 0; x < byteWidth; x++) {\n    let up = pxPos > 0 ? pxData[pxPos + x - byteWidth] : 0;\n    let val = pxData[pxPos + x] - up;\n\n    rawData[rawPos + x] = val;\n  }\n}\n\nfunction filterSumUp(pxData, pxPos, byteWidth) {\n  let sum = 0;\n  let length = pxPos + byteWidth;\n  for (let x = pxPos; x < length; x++) {\n    let up = pxPos > 0 ? pxData[x - byteWidth] : 0;\n    let val = pxData[x] - up;\n\n    sum += Math.abs(val);\n  }\n\n  return sum;\n}\n\nfunction filterAvg(pxData, pxPos, byteWidth, rawData, rawPos, bpp) {\n  for (let x = 0; x < byteWidth; x++) {\n    let left = x >= bpp ? pxData[pxPos + x - bpp] : 0;\n    let up = pxPos > 0 ? pxData[pxPos + x - byteWidth] : 0;\n    let val = pxData[pxPos + x] - ((left + up) >> 1);\n\n    rawData[rawPos + x] = val;\n  }\n}\n\nfunction filterSumAvg(pxData, pxPos, byteWidth, bpp) {\n  let sum = 0;\n  for (let x = 0; x < byteWidth; x++) {\n    let left = x >= bpp ? pxData[pxPos + x - bpp] : 0;\n    let up = pxPos > 0 ? pxData[pxPos + x - byteWidth] : 0;\n    let val = pxData[pxPos + x] - ((left + up) >> 1);\n\n    sum += Math.abs(val);\n  }\n\n  return sum;\n}\n\nfunction filterPaeth(pxData, pxPos, byteWidth, rawData, rawPos, bpp) {\n  for (let x = 0; x < byteWidth; x++) {\n    let left = x >= bpp ? pxData[pxPos + x - bpp] : 0;\n    let up = pxPos > 0 ? pxData[pxPos + x - byteWidth] : 0;\n    let upleft =\n      pxPos > 0 && x >= bpp ? pxData[pxPos + x - (byteWidth + bpp)] : 0;\n    let val = pxData[pxPos + x] - paethPredictor(left, up, upleft);\n\n    rawData[rawPos + x] = val;\n  }\n}\n\nfunction filterSumPaeth(pxData, pxPos, byteWidth, bpp) {\n  let sum = 0;\n  for (let x = 0; x < byteWidth; x++) {\n    let left = x >= bpp ? pxData[pxPos + x - bpp] : 0;\n    let up = pxPos > 0 ? pxData[pxPos + x - byteWidth] : 0;\n    let upleft =\n      pxPos > 0 && x >= bpp ? pxData[pxPos + x - (byteWidth + bpp)] : 0;\n    let val = pxData[pxPos + x] - paethPredictor(left, up, upleft);\n\n    sum += Math.abs(val);\n  }\n\n  return sum;\n}\n\nlet filters = {\n  0: filterNone,\n  1: filterSub,\n  2: filterUp,\n  3: filterAvg,\n  4: filterPaeth,\n};\n\nlet filterSums = {\n  0: filterSumNone,\n  1: filterSumSub,\n  2: filterSumUp,\n  3: filterSumAvg,\n  4: filterSumPaeth,\n};\n\nmodule.exports = function (pxData, width, height, options, bpp) {\n  let filterTypes;\n  if (!(\"filterType\" in options) || options.filterType === -1) {\n    filterTypes = [0, 1, 2, 3, 4];\n  } else if (typeof options.filterType === \"number\") {\n    filterTypes = [options.filterType];\n  } else {\n    throw new Error(\"unrecognised filter types\");\n  }\n\n  if (options.bitDepth === 16) {\n    bpp *= 2;\n  }\n  let byteWidth = width * bpp;\n  let rawPos = 0;\n  let pxPos = 0;\n  let rawData = Buffer.alloc((byteWidth + 1) * height);\n\n  let sel = filterTypes[0];\n\n  for (let y = 0; y < height; y++) {\n    if (filterTypes.length > 1) {\n      // find best filter for this line (with lowest sum of values)\n      let min = Infinity;\n\n      for (let i = 0; i < filterTypes.length; i++) {\n        let sum = filterSums[filterTypes[i]](pxData, pxPos, byteWidth, bpp);\n        if (sum < min) {\n          sel = filterTypes[i];\n          min = sum;\n        }\n      }\n    }\n\n    rawData[rawPos] = sel;\n    rawPos++;\n    filters[sel](pxData, pxPos, byteWidth, rawData, rawPos, bpp);\n    rawPos += byteWidth;\n    pxPos += byteWidth;\n  }\n  return rawData;\n};\n","\"use strict\";\n\nlet assert = require(\"assert\").ok;\nlet zlib = require(\"zlib\");\nlet util = require(\"util\");\n\nlet kMaxLength = require(\"buffer\").kMaxLength;\n\nfunction Inflate(opts) {\n  if (!(this instanceof Inflate)) {\n    return new Inflate(opts);\n  }\n\n  if (opts && opts.chunkSize < zlib.Z_MIN_CHUNK) {\n    opts.chunkSize = zlib.Z_MIN_CHUNK;\n  }\n\n  zlib.Inflate.call(this, opts);\n\n  // Node 8 --> 9 compatibility check\n  this._offset = this._offset === undefined ? this._outOffset : this._offset;\n  this._buffer = this._buffer || this._outBuffer;\n\n  if (opts && opts.maxLength != null) {\n    this._maxLength = opts.maxLength;\n  }\n}\n\nfunction createInflate(opts) {\n  return new Inflate(opts);\n}\n\nfunction _close(engine, callback) {\n  if (callback) {\n    process.nextTick(callback);\n  }\n\n  // Caller may invoke .close after a zlib error (which will null _handle).\n  if (!engine._handle) {\n    return;\n  }\n\n  engine._handle.close();\n  engine._handle = null;\n}\n\nInflate.prototype._processChunk = function (chunk, flushFlag, asyncCb) {\n  if (typeof asyncCb === \"function\") {\n    return zlib.Inflate._processChunk.call(this, chunk, flushFlag, asyncCb);\n  }\n\n  let self = this;\n\n  let availInBefore = chunk && chunk.length;\n  let availOutBefore = this._chunkSize - this._offset;\n  let leftToInflate = this._maxLength;\n  let inOff = 0;\n\n  let buffers = [];\n  let nread = 0;\n\n  let error;\n  this.on(\"error\", function (err) {\n    error = err;\n  });\n\n  function handleChunk(availInAfter, availOutAfter) {\n    if (self._hadError) {\n      return;\n    }\n\n    let have = availOutBefore - availOutAfter;\n    assert(have >= 0, \"have should not go down\");\n\n    if (have > 0) {\n      let out = self._buffer.slice(self._offset, self._offset + have);\n      self._offset += have;\n\n      if (out.length > leftToInflate) {\n        out = out.slice(0, leftToInflate);\n      }\n\n      buffers.push(out);\n      nread += out.length;\n      leftToInflate -= out.length;\n\n      if (leftToInflate === 0) {\n        return false;\n      }\n    }\n\n    if (availOutAfter === 0 || self._offset >= self._chunkSize) {\n      availOutBefore = self._chunkSize;\n      self._offset = 0;\n      self._buffer = Buffer.allocUnsafe(self._chunkSize);\n    }\n\n    if (availOutAfter === 0) {\n      inOff += availInBefore - availInAfter;\n      availInBefore = availInAfter;\n\n      return true;\n    }\n\n    return false;\n  }\n\n  assert(this._handle, \"zlib binding closed\");\n  let res;\n  do {\n    res = this._handle.writeSync(\n      flushFlag,\n      chunk, // in\n      inOff, // in_off\n      availInBefore, // in_len\n      this._buffer, // out\n      this._offset, //out_off\n      availOutBefore\n    ); // out_len\n    // Node 8 --> 9 compatibility check\n    res = res || this._writeState;\n  } while (!this._hadError && handleChunk(res[0], res[1]));\n\n  if (this._hadError) {\n    throw error;\n  }\n\n  if (nread >= kMaxLength) {\n    _close(this);\n    throw new RangeError(\n      \"Cannot create final Buffer. It would be larger than 0x\" +\n        kMaxLength.toString(16) +\n        \" bytes\"\n    );\n  }\n\n  let buf = Buffer.concat(buffers, nread);\n  _close(this);\n\n  return buf;\n};\n\nutil.inherits(Inflate, zlib.Inflate);\n\nfunction zlibBufferSync(engine, buffer) {\n  if (typeof buffer === \"string\") {\n    buffer = Buffer.from(buffer);\n  }\n  if (!(buffer instanceof Buffer)) {\n    throw new TypeError(\"Not a string or buffer\");\n  }\n\n  let flushFlag = engine._finishFlushFlag;\n  if (flushFlag == null) {\n    flushFlag = zlib.Z_FINISH;\n  }\n\n  return engine._processChunk(buffer, flushFlag);\n}\n\nfunction inflateSync(buffer, opts) {\n  return zlibBufferSync(new Inflate(opts), buffer);\n}\n\nmodule.exports = exports = inflateSync;\nexports.Inflate = Inflate;\nexports.createInflate = createInflate;\nexports.inflateSync = inflateSync;\n","\"use strict\";\n\nlet SyncReader = (module.exports = function (buffer) {\n  this._buffer = buffer;\n  this._reads = [];\n});\n\nSyncReader.prototype.read = function (length, callback) {\n  this._reads.push({\n    length: Math.abs(length), // if length < 0 then at most this length\n    allowLess: length < 0,\n    func: callback,\n  });\n};\n\nSyncReader.prototype.process = function () {\n  // as long as there is any data and read requests\n  while (this._reads.length > 0 && this._buffer.length) {\n    let read = this._reads[0];\n\n    if (\n      this._buffer.length &&\n      (this._buffer.length >= read.length || read.allowLess)\n    ) {\n      // ok there is any data so that we can satisfy this request\n      this._reads.shift(); // == read\n\n      let buf = this._buffer;\n\n      this._buffer = buf.slice(read.length);\n\n      read.func.call(this, buf.slice(0, read.length));\n    } else {\n      break;\n    }\n  }\n\n  if (this._reads.length > 0) {\n    return new Error(\"There are some read requests waitng on finished stream\");\n  }\n\n  if (this._buffer.length > 0) {\n    return new Error(\"unrecognised content at end of stream\");\n  }\n};\n","\"use strict\";\n\nlet hasSyncZlib = true;\nlet zlib = require(\"zlib\");\nlet inflateSync = require(\"./sync-inflate\");\nif (!zlib.deflateSync) {\n  hasSyncZlib = false;\n}\nlet SyncReader = require(\"./sync-reader\");\nlet FilterSync = require(\"./filter-parse-sync\");\nlet Parser = require(\"./parser\");\nlet bitmapper = require(\"./bitmapper\");\nlet formatNormaliser = require(\"./format-normaliser\");\n\nmodule.exports = function (buffer, options) {\n  if (!hasSyncZlib) {\n    throw new Error(\n      \"To use the sync capability of this library in old node versions, please pin pngjs to v2.3.0\"\n    );\n  }\n\n  let err;\n  function handleError(_err_) {\n    err = _err_;\n  }\n\n  let metaData;\n  function handleMetaData(_metaData_) {\n    metaData = _metaData_;\n  }\n\n  function handleTransColor(transColor) {\n    metaData.transColor = transColor;\n  }\n\n  function handlePalette(palette) {\n    metaData.palette = palette;\n  }\n\n  function handleSimpleTransparency() {\n    metaData.alpha = true;\n  }\n\n  let gamma;\n  function handleGamma(_gamma_) {\n    gamma = _gamma_;\n  }\n\n  let inflateDataList = [];\n  function handleInflateData(inflatedData) {\n    inflateDataList.push(inflatedData);\n  }\n\n  let reader = new SyncReader(buffer);\n\n  let parser = new Parser(options, {\n    read: reader.read.bind(reader),\n    error: handleError,\n    metadata: handleMetaData,\n    gamma: handleGamma,\n    palette: handlePalette,\n    transColor: handleTransColor,\n    inflateData: handleInflateData,\n    simpleTransparency: handleSimpleTransparency,\n  });\n\n  parser.start();\n  reader.process();\n\n  if (err) {\n    throw err;\n  }\n\n  //join together the inflate datas\n  let inflateData = Buffer.concat(inflateDataList);\n  inflateDataList.length = 0;\n\n  let inflatedData;\n  if (metaData.interlace) {\n    inflatedData = zlib.inflateSync(inflateData);\n  } else {\n    let rowSize =\n      ((metaData.width * metaData.bpp * metaData.depth + 7) >> 3) + 1;\n    let imageSize = rowSize * metaData.height;\n    inflatedData = inflateSync(inflateData, {\n      chunkSize: imageSize,\n      maxLength: imageSize,\n    });\n  }\n  inflateData = null;\n\n  if (!inflatedData || !inflatedData.length) {\n    throw new Error(\"bad png - invalid inflate data response\");\n  }\n\n  let unfilteredData = FilterSync.process(inflatedData, metaData);\n  inflateData = null;\n\n  let bitmapData = bitmapper.dataToBitMap(unfilteredData, metaData);\n  unfilteredData = null;\n\n  let normalisedBitmapData = formatNormaliser(bitmapData, metaData);\n\n  metaData.data = normalisedBitmapData;\n  metaData.gamma = gamma || 0;\n\n  return metaData;\n};\n","\"use strict\";\n\nlet SyncReader = require(\"./sync-reader\");\nlet Filter = require(\"./filter-parse\");\n\nexports.process = function (inBuffer, bitmapInfo) {\n  let outBuffers = [];\n  let reader = new SyncReader(inBuffer);\n  let filter = new Filter(bitmapInfo, {\n    read: reader.read.bind(reader),\n    write: function (bufferPart) {\n      outBuffers.push(bufferPart);\n    },\n    complete: function () {},\n  });\n\n  filter.start();\n  reader.process();\n\n  return Buffer.concat(outBuffers);\n};\n","\"use strict\";\n\nlet parse = require(\"./parser-sync\");\nlet pack = require(\"./packer-sync\");\n\nexports.read = function (buffer, options) {\n  return parse(buffer, options || {});\n};\n\nexports.write = function (png, options) {\n  return pack(png, options);\n};\n","\"use strict\";\n\nlet hasSyncZlib = true;\nlet zlib = require(\"zlib\");\nif (!zlib.deflateSync) {\n  hasSyncZlib = false;\n}\nlet constants = require(\"./constants\");\nlet Packer = require(\"./packer\");\n\nmodule.exports = function (metaData, opt) {\n  if (!hasSyncZlib) {\n    throw new Error(\n      \"To use the sync capability of this library in old node versions, please pin pngjs to v2.3.0\"\n    );\n  }\n\n  let options = opt || {};\n\n  let packer = new Packer(options);\n\n  let chunks = [];\n\n  // Signature\n  chunks.push(Buffer.from(constants.PNG_SIGNATURE));\n\n  // Header\n  chunks.push(packer.packIHDR(metaData.width, metaData.height));\n\n  if (metaData.gamma) {\n    chunks.push(packer.packGAMA(metaData.gamma));\n  }\n\n  let filteredData = packer.filterData(\n    metaData.data,\n    metaData.width,\n    metaData.height\n  );\n\n  // compress it\n  let compressedData = zlib.deflateSync(\n    filteredData,\n    packer.getDeflateOptions()\n  );\n  filteredData = null;\n\n  if (!compressedData || !compressedData.length) {\n    throw new Error(\"bad png - invalid compressed data response\");\n  }\n  chunks.push(packer.packIDAT(compressedData));\n\n  // End\n  chunks.push(packer.packIEND());\n\n  return Buffer.concat(chunks);\n};\n","\"use strict\";\n\nlet util = require(\"util\");\nlet Stream = require(\"stream\");\nlet Parser = require(\"./parser-async\");\nlet Packer = require(\"./packer-async\");\nlet PNGSync = require(\"./png-sync\");\n\nlet PNG = (exports.PNG = function (options) {\n  Stream.call(this);\n\n  options = options || {}; // eslint-disable-line no-param-reassign\n\n  // coerce pixel dimensions to integers (also coerces undefined -> 0):\n  this.width = options.width | 0;\n  this.height = options.height | 0;\n\n  this.data =\n    this.width > 0 && this.height > 0\n      ? Buffer.alloc(4 * this.width * this.height)\n      : null;\n\n  if (options.fill && this.data) {\n    this.data.fill(0);\n  }\n\n  this.gamma = 0;\n  this.readable = this.writable = true;\n\n  this._parser = new Parser(options);\n\n  this._parser.on(\"error\", this.emit.bind(this, \"error\"));\n  this._parser.on(\"close\", this._handleClose.bind(this));\n  this._parser.on(\"metadata\", this._metadata.bind(this));\n  this._parser.on(\"gamma\", this._gamma.bind(this));\n  this._parser.on(\n    \"parsed\",\n    function (data) {\n      this.data = data;\n      this.emit(\"parsed\", data);\n    }.bind(this)\n  );\n\n  this._packer = new Packer(options);\n  this._packer.on(\"data\", this.emit.bind(this, \"data\"));\n  this._packer.on(\"end\", this.emit.bind(this, \"end\"));\n  this._parser.on(\"close\", this._handleClose.bind(this));\n  this._packer.on(\"error\", this.emit.bind(this, \"error\"));\n});\nutil.inherits(PNG, Stream);\n\nPNG.sync = PNGSync;\n\nPNG.prototype.pack = function () {\n  if (!this.data || !this.data.length) {\n    this.emit(\"error\", \"No data provided\");\n    return this;\n  }\n\n  process.nextTick(\n    function () {\n      this._packer.pack(this.data, this.width, this.height, this.gamma);\n    }.bind(this)\n  );\n\n  return this;\n};\n\nPNG.prototype.parse = function (data, callback) {\n  if (callback) {\n    let onParsed, onError;\n\n    onParsed = function (parsedData) {\n      this.removeListener(\"error\", onError);\n\n      this.data = parsedData;\n      callback(null, this);\n    }.bind(this);\n\n    onError = function (err) {\n      this.removeListener(\"parsed\", onParsed);\n\n      callback(err, null);\n    }.bind(this);\n\n    this.once(\"parsed\", onParsed);\n    this.once(\"error\", onError);\n  }\n\n  this.end(data);\n  return this;\n};\n\nPNG.prototype.write = function (data) {\n  this._parser.write(data);\n  return true;\n};\n\nPNG.prototype.end = function (data) {\n  this._parser.end(data);\n};\n\nPNG.prototype._metadata = function (metadata) {\n  this.width = metadata.width;\n  this.height = metadata.height;\n\n  this.emit(\"metadata\", metadata);\n};\n\nPNG.prototype._gamma = function (gamma) {\n  this.gamma = gamma;\n};\n\nPNG.prototype._handleClose = function () {\n  if (!this._parser.writable && !this._packer.readable) {\n    this.emit(\"close\");\n  }\n};\n\nPNG.bitblt = function (src, dst, srcX, srcY, width, height, deltaX, deltaY) {\n  // eslint-disable-line max-params\n  // coerce pixel dimensions to integers (also coerces undefined -> 0):\n  /* eslint-disable no-param-reassign */\n  srcX |= 0;\n  srcY |= 0;\n  width |= 0;\n  height |= 0;\n  deltaX |= 0;\n  deltaY |= 0;\n  /* eslint-enable no-param-reassign */\n\n  if (\n    srcX > src.width ||\n    srcY > src.height ||\n    srcX + width > src.width ||\n    srcY + height > src.height\n  ) {\n    throw new Error(\"bitblt reading outside image\");\n  }\n\n  if (\n    deltaX > dst.width ||\n    deltaY > dst.height ||\n    deltaX + width > dst.width ||\n    deltaY + height > dst.height\n  ) {\n    throw new Error(\"bitblt writing outside image\");\n  }\n\n  for (let y = 0; y < height; y++) {\n    src.data.copy(\n      dst.data,\n      ((deltaY + y) * dst.width + deltaX) << 2,\n      ((srcY + y) * src.width + srcX) << 2,\n      ((srcY + y) * src.width + srcX + width) << 2\n    );\n  }\n};\n\nPNG.prototype.bitblt = function (\n  dst,\n  srcX,\n  srcY,\n  width,\n  height,\n  deltaX,\n  deltaY\n) {\n  // eslint-disable-line max-params\n\n  PNG.bitblt(this, dst, srcX, srcY, width, height, deltaX, deltaY);\n  return this;\n};\n\nPNG.adjustGamma = function (src) {\n  if (src.gamma) {\n    for (let y = 0; y < src.height; y++) {\n      for (let x = 0; x < src.width; x++) {\n        let idx = (src.width * y + x) << 2;\n\n        for (let i = 0; i < 3; i++) {\n          let sample = src.data[idx + i] / 255;\n          sample = Math.pow(sample, 1 / 2.2 / src.gamma);\n          src.data[idx + i] = Math.round(sample * 255);\n        }\n      }\n    }\n    src.gamma = 0;\n  }\n};\n\nPNG.prototype.adjustGamma = function () {\n  PNG.adjustGamma(this);\n};\n","\"use strict\";\n\nlet util = require(\"util\");\nlet Stream = require(\"stream\");\nlet constants = require(\"./constants\");\nlet Packer = require(\"./packer\");\n\nlet PackerAsync = (module.exports = function (opt) {\n  Stream.call(this);\n\n  let options = opt || {};\n\n  this._packer = new Packer(options);\n  this._deflate = this._packer.createDeflate();\n\n  this.readable = true;\n});\nutil.inherits(PackerAsync, Stream);\n\nPackerAsync.prototype.pack = function (data, width, height, gamma) {\n  // Signature\n  this.emit(\"data\", Buffer.from(constants.PNG_SIGNATURE));\n  this.emit(\"data\", this._packer.packIHDR(width, height));\n\n  if (gamma) {\n    this.emit(\"data\", this._packer.packGAMA(gamma));\n  }\n\n  let filteredData = this._packer.filterData(data, width, height);\n\n  // compress it\n  this._deflate.on(\"error\", this.emit.bind(this, \"error\"));\n\n  this._deflate.on(\n    \"data\",\n    function (compressedData) {\n      this.emit(\"data\", this._packer.packIDAT(compressedData));\n    }.bind(this)\n  );\n\n  this._deflate.on(\n    \"end\",\n    function () {\n      this.emit(\"data\", this._packer.packIEND());\n      this.emit(\"end\");\n    }.bind(this)\n  );\n\n  this._deflate.end(filteredData);\n};\n","function hex2rgba (hex) {\n  if (typeof hex === 'number') {\n    hex = hex.toString()\n  }\n\n  if (typeof hex !== 'string') {\n    throw new Error('Color should be defined as hex string')\n  }\n\n  let hexCode = hex.slice().replace('#', '').split('')\n  if (hexCode.length < 3 || hexCode.length === 5 || hexCode.length > 8) {\n    throw new Error('Invalid hex color: ' + hex)\n  }\n\n  // Convert from short to long form (fff -> ffffff)\n  if (hexCode.length === 3 || hexCode.length === 4) {\n    hexCode = Array.prototype.concat.apply([], hexCode.map(function (c) {\n      return [c, c]\n    }))\n  }\n\n  // Add default alpha value\n  if (hexCode.length === 6) hexCode.push('F', 'F')\n\n  const hexValue = parseInt(hexCode.join(''), 16)\n\n  return {\n    r: (hexValue >> 24) & 255,\n    g: (hexValue >> 16) & 255,\n    b: (hexValue >> 8) & 255,\n    a: hexValue & 255,\n    hex: '#' + hexCode.slice(0, 6).join('')\n  }\n}\n\nexports.getOptions = function getOptions (options) {\n  if (!options) options = {}\n  if (!options.color) options.color = {}\n\n  const margin = typeof options.margin === 'undefined' ||\n    options.margin === null ||\n    options.margin < 0\n    ? 4\n    : options.margin\n\n  const width = options.width && options.width >= 21 ? options.width : undefined\n  const scale = options.scale || 4\n\n  return {\n    width: width,\n    scale: width ? 4 : scale,\n    margin: margin,\n    color: {\n      dark: hex2rgba(options.color.dark || '#000000ff'),\n      light: hex2rgba(options.color.light || '#ffffffff')\n    },\n    type: options.type,\n    rendererOpts: options.rendererOpts || {}\n  }\n}\n\nexports.getScale = function getScale (qrSize, opts) {\n  return opts.width && opts.width >= qrSize + opts.margin * 2\n    ? opts.width / (qrSize + opts.margin * 2)\n    : opts.scale\n}\n\nexports.getImageWidth = function getImageWidth (qrSize, opts) {\n  const scale = exports.getScale(qrSize, opts)\n  return Math.floor((qrSize + opts.margin * 2) * scale)\n}\n\nexports.qrToImageData = function qrToImageData (imgData, qr, opts) {\n  const size = qr.modules.size\n  const data = qr.modules.data\n  const scale = exports.getScale(size, opts)\n  const symbolSize = Math.floor((size + opts.margin * 2) * scale)\n  const scaledMargin = opts.margin * scale\n  const palette = [opts.color.light, opts.color.dark]\n\n  for (let i = 0; i < symbolSize; i++) {\n    for (let j = 0; j < symbolSize; j++) {\n      let posDst = (i * symbolSize + j) * 4\n      let pxColor = opts.color.light\n\n      if (i >= scaledMargin && j >= scaledMargin &&\n        i < symbolSize - scaledMargin && j < symbolSize - scaledMargin) {\n        const iSrc = Math.floor((i - scaledMargin) / scale)\n        const jSrc = Math.floor((j - scaledMargin) / scale)\n        pxColor = palette[data[iSrc * size + jSrc] ? 1 : 0]\n      }\n\n      imgData[posDst++] = pxColor.r\n      imgData[posDst++] = pxColor.g\n      imgData[posDst++] = pxColor.b\n      imgData[posDst] = pxColor.a\n    }\n  }\n}\n","const big = require('./terminal/terminal')\nconst small = require('./terminal/terminal-small')\n\nexports.render = function (qrData, options, cb) {\n  if (options && options.small) {\n    return small.render(qrData, options, cb)\n  }\n  return big.render(qrData, options, cb)\n}\n","// let Utils = require('./utils')\n\nexports.render = function (qrData, options, cb) {\n  const size = qrData.modules.size\n  const data = qrData.modules.data\n\n  // let opts = Utils.getOptions(options)\n\n  // use same scheme as https://github.com/gtanner/qrcode-terminal because it actually works! =)\n  const black = '\\x1b[40m  \\x1b[0m'\n  const white = '\\x1b[47m  \\x1b[0m'\n\n  let output = ''\n  const hMargin = Array(size + 3).join(white)\n  const vMargin = Array(2).join(white)\n\n  output += hMargin + '\\n'\n  for (let i = 0; i < size; ++i) {\n    output += white\n    for (let j = 0; j < size; j++) {\n      // let topModule = data[i * size + j]\n      // let bottomModule = data[(i + 1) * size + j]\n\n      output += data[i * size + j] ? black : white// getBlockChar(topModule, bottomModule)\n    }\n    // output += white+'\\n'\n    output += vMargin + '\\n'\n  }\n\n  output += hMargin + '\\n'\n\n  if (typeof cb === 'function') {\n    cb(null, output)\n  }\n\n  return output\n}\n/*\nexports.renderToFile = function renderToFile (path, qrData, options, cb) {\n  if (typeof cb === 'undefined') {\n    cb = options\n    options = undefined\n  }\n\n  let fs = require('fs')\n  let utf8 = exports.render(qrData, options)\n  fs.writeFile(path, utf8, cb)\n}\n*/\n","const backgroundWhite = '\\x1b[47m'\nconst backgroundBlack = '\\x1b[40m'\nconst foregroundWhite = '\\x1b[37m'\nconst foregroundBlack = '\\x1b[30m'\nconst reset = '\\x1b[0m'\nconst lineSetupNormal = backgroundWhite + foregroundBlack // setup colors\nconst lineSetupInverse = backgroundBlack + foregroundWhite // setup colors\n\nconst createPalette = function (lineSetup, foregroundWhite, foregroundBlack) {\n  return {\n    // 1 ... white, 2 ... black, 0 ... transparent (default)\n\n    '00': reset + ' ' + lineSetup,\n    '01': reset + foregroundWhite + '▄' + lineSetup,\n    '02': reset + foregroundBlack + '▄' + lineSetup,\n    10: reset + foregroundWhite + '▀' + lineSetup,\n    11: ' ',\n    12: '▄',\n    20: reset + foregroundBlack + '▀' + lineSetup,\n    21: '▀',\n    22: '█'\n  }\n}\n\n/**\n * Returns code for QR pixel\n * @param {boolean[][]} modules\n * @param {number} size\n * @param {number} x\n * @param {number} y\n * @return {'0' | '1' | '2'}\n */\nconst mkCodePixel = function (modules, size, x, y) {\n  const sizePlus = size + 1\n  if ((x >= sizePlus) || (y >= sizePlus) || (y < -1) || (x < -1)) return '0'\n  if ((x >= size) || (y >= size) || (y < 0) || (x < 0)) return '1'\n  const idx = (y * size) + x\n  return modules[idx] ? '2' : '1'\n}\n\n/**\n * Returns code for four QR pixels. Suitable as key in palette.\n * @param {boolean[][]} modules\n * @param {number} size\n * @param {number} x\n * @param {number} y\n * @return {keyof palette}\n */\nconst mkCode = function (modules, size, x, y) {\n  return (\n    mkCodePixel(modules, size, x, y) +\n    mkCodePixel(modules, size, x, y + 1)\n  )\n}\n\nexports.render = function (qrData, options, cb) {\n  const size = qrData.modules.size\n  const data = qrData.modules.data\n\n  const inverse = !!(options && options.inverse)\n  const lineSetup = options && options.inverse ? lineSetupInverse : lineSetupNormal\n  const white = inverse ? foregroundBlack : foregroundWhite\n  const black = inverse ? foregroundWhite : foregroundBlack\n\n  const palette = createPalette(lineSetup, white, black)\n  const newLine = reset + '\\n' + lineSetup\n\n  let output = lineSetup // setup colors\n\n  for (let y = -1; y < size + 1; y += 2) {\n    for (let x = -1; x < size; x++) {\n      output += palette[mkCode(data, size, x, y)]\n    }\n\n    output += palette[mkCode(data, size, size, y)] + newLine\n  }\n\n  output += reset\n\n  if (typeof cb === 'function') {\n    cb(null, output)\n  }\n\n  return output\n}\n","const Utils = require('./utils')\n\nfunction getColorAttrib (color, attrib) {\n  const alpha = color.a / 255\n  const str = attrib + '=\"' + color.hex + '\"'\n\n  return alpha < 1\n    ? str + ' ' + attrib + '-opacity=\"' + alpha.toFixed(2).slice(1) + '\"'\n    : str\n}\n\nfunction svgCmd (cmd, x, y) {\n  let str = cmd + x\n  if (typeof y !== 'undefined') str += ' ' + y\n\n  return str\n}\n\nfunction qrToPath (data, size, margin) {\n  let path = ''\n  let moveBy = 0\n  let newRow = false\n  let lineLength = 0\n\n  for (let i = 0; i < data.length; i++) {\n    const col = Math.floor(i % size)\n    const row = Math.floor(i / size)\n\n    if (!col && !newRow) newRow = true\n\n    if (data[i]) {\n      lineLength++\n\n      if (!(i > 0 && col > 0 && data[i - 1])) {\n        path += newRow\n          ? svgCmd('M', col + margin, 0.5 + row + margin)\n          : svgCmd('m', moveBy, 0)\n\n        moveBy = 0\n        newRow = false\n      }\n\n      if (!(col + 1 < size && data[i + 1])) {\n        path += svgCmd('h', lineLength)\n        lineLength = 0\n      }\n    } else {\n      moveBy++\n    }\n  }\n\n  return path\n}\n\nexports.render = function render (qrData, options, cb) {\n  const opts = Utils.getOptions(options)\n  const size = qrData.modules.size\n  const data = qrData.modules.data\n  const qrcodesize = size + opts.margin * 2\n\n  const bg = !opts.color.light.a\n    ? ''\n    : '<path ' + getColorAttrib(opts.color.light, 'fill') +\n      ' d=\"M0 0h' + qrcodesize + 'v' + qrcodesize + 'H0z\"/>'\n\n  const path =\n    '<path ' + getColorAttrib(opts.color.dark, 'stroke') +\n    ' d=\"' + qrToPath(data, size, opts.margin) + '\"/>'\n\n  const viewBox = 'viewBox=\"' + '0 0 ' + qrcodesize + ' ' + qrcodesize + '\"'\n\n  const width = !opts.width ? '' : 'width=\"' + opts.width + '\" height=\"' + opts.width + '\" '\n\n  const svgTag = '<svg xmlns=\"http://www.w3.org/2000/svg\" ' + width + viewBox + ' shape-rendering=\"crispEdges\">' + bg + path + '</svg>\\n'\n\n  if (typeof cb === 'function') {\n    cb(null, svgTag)\n  }\n\n  return svgTag\n}\n","const Utils = require('./utils')\n\nfunction clearCanvas (ctx, canvas, size) {\n  ctx.clearRect(0, 0, canvas.width, canvas.height)\n\n  if (!canvas.style) canvas.style = {}\n  canvas.height = size\n  canvas.width = size\n  canvas.style.height = size + 'px'\n  canvas.style.width = size + 'px'\n}\n\nfunction getCanvasElement () {\n  try {\n    return document.createElement('canvas')\n  } catch (e) {\n    throw new Error('You need to specify a canvas element')\n  }\n}\n\nexports.render = function render (qrData, canvas, options) {\n  let opts = options\n  let canvasEl = canvas\n\n  if (typeof opts === 'undefined' && (!canvas || !canvas.getContext)) {\n    opts = canvas\n    canvas = undefined\n  }\n\n  if (!canvas) {\n    canvasEl = getCanvasElement()\n  }\n\n  opts = Utils.getOptions(opts)\n  const size = Utils.getImageWidth(qrData.modules.size, opts)\n\n  const ctx = canvasEl.getContext('2d')\n  const image = ctx.createImageData(size, size)\n  Utils.qrToImageData(image.data, qrData, opts)\n\n  clearCanvas(ctx, canvasEl, size)\n  ctx.putImageData(image, 0, 0)\n\n  return canvasEl\n}\n\nexports.renderToDataURL = function renderToDataURL (qrData, canvas, options) {\n  let opts = options\n\n  if (typeof opts === 'undefined' && (!canvas || !canvas.getContext)) {\n    opts = canvas\n    canvas = undefined\n  }\n\n  if (!opts) opts = {}\n\n  const canvasEl = exports.render(qrData, canvas, opts)\n\n  const type = opts.type || 'image/png'\n  const rendererOpts = opts.rendererOpts || {}\n\n  return canvasEl.toDataURL(type, rendererOpts.quality)\n}\n","const canPromise = require('./can-promise')\nconst QRCode = require('./core/qrcode')\nconst PngRenderer = require('./renderer/png')\nconst Utf8Renderer = require('./renderer/utf8')\nconst TerminalRenderer = require('./renderer/terminal')\nconst SvgRenderer = require('./renderer/svg')\n\nfunction checkParams (text, opts, cb) {\n  if (typeof text === 'undefined') {\n    throw new Error('String required as first argument')\n  }\n\n  if (typeof cb === 'undefined') {\n    cb = opts\n    opts = {}\n  }\n\n  if (typeof cb !== 'function') {\n    if (!canPromise()) {\n      throw new Error('Callback required as last argument')\n    } else {\n      opts = cb || {}\n      cb = null\n    }\n  }\n\n  return {\n    opts: opts,\n    cb: cb\n  }\n}\n\nfunction getTypeFromFilename (path) {\n  return path.slice((path.lastIndexOf('.') - 1 >>> 0) + 2).toLowerCase()\n}\n\nfunction getRendererFromType (type) {\n  switch (type) {\n    case 'svg':\n      return SvgRenderer\n\n    case 'txt':\n    case 'utf8':\n      return Utf8Renderer\n\n    case 'png':\n    case 'image/png':\n    default:\n      return PngRenderer\n  }\n}\n\nfunction getStringRendererFromType (type) {\n  switch (type) {\n    case 'svg':\n      return SvgRenderer\n\n    case 'terminal':\n      return TerminalRenderer\n\n    case 'utf8':\n    default:\n      return Utf8Renderer\n  }\n}\n\nfunction render (renderFunc, text, params) {\n  if (!params.cb) {\n    return new Promise(function (resolve, reject) {\n      try {\n        const data = QRCode.create(text, params.opts)\n        return renderFunc(data, params.opts, function (err, data) {\n          return err ? reject(err) : resolve(data)\n        })\n      } catch (e) {\n        reject(e)\n      }\n    })\n  }\n\n  try {\n    const data = QRCode.create(text, params.opts)\n    return renderFunc(data, params.opts, params.cb)\n  } catch (e) {\n    params.cb(e)\n  }\n}\n\nexports.create = QRCode.create\n\nexports.toCanvas = require('./browser').toCanvas\n\nexports.toString = function toString (text, opts, cb) {\n  const params = checkParams(text, opts, cb)\n  const type = params.opts ? params.opts.type : undefined\n  const renderer = getStringRendererFromType(type)\n  return render(renderer.render, text, params)\n}\n\nexports.toDataURL = function toDataURL (text, opts, cb) {\n  const params = checkParams(text, opts, cb)\n  const renderer = getRendererFromType(params.opts.type)\n  return render(renderer.renderToDataURL, text, params)\n}\n\nexports.toBuffer = function toBuffer (text, opts, cb) {\n  const params = checkParams(text, opts, cb)\n  const renderer = getRendererFromType(params.opts.type)\n  return render(renderer.renderToBuffer, text, params)\n}\n\nexports.toFile = function toFile (path, text, opts, cb) {\n  if (typeof path !== 'string' || !(typeof text === 'string' || typeof text === 'object')) {\n    throw new Error('Invalid argument')\n  }\n\n  if ((arguments.length < 3) && !canPromise()) {\n    throw new Error('Too few arguments provided')\n  }\n\n  const params = checkParams(text, opts, cb)\n  const type = params.opts.type || getTypeFromFilename(path)\n  const renderer = getRendererFromType(type)\n  const renderToFile = renderer.renderToFile.bind(null, path)\n\n  return render(renderToFile, text, params)\n}\n\nexports.toFileStream = function toFileStream (stream, text, opts) {\n  if (arguments.length < 2) {\n    throw new Error('Too few arguments provided')\n  }\n\n  const params = checkParams(text, opts, stream.emit.bind(stream, 'error'))\n  const renderer = getRendererFromType('png') // Only png support for now\n  const renderToFileStream = renderer.renderToFileStream.bind(null, stream)\n  render(renderToFileStream, text, params)\n}\n","const fs = require('fs')\nconst PNG = require('pngjs').PNG\nconst Utils = require('./utils')\n\nexports.render = function render (qrData, options) {\n  const opts = Utils.getOptions(options)\n  const pngOpts = opts.rendererOpts\n  const size = Utils.getImageWidth(qrData.modules.size, opts)\n\n  pngOpts.width = size\n  pngOpts.height = size\n\n  const pngImage = new PNG(pngOpts)\n  Utils.qrToImageData(pngImage.data, qrData, opts)\n\n  return pngImage\n}\n\nexports.renderToDataURL = function renderToDataURL (qrData, options, cb) {\n  if (typeof cb === 'undefined') {\n    cb = options\n    options = undefined\n  }\n\n  exports.renderToBuffer(qrData, options, function (err, output) {\n    if (err) cb(err)\n    let url = 'data:image/png;base64,'\n    url += output.toString('base64')\n    cb(null, url)\n  })\n}\n\nexports.renderToBuffer = function renderToBuffer (qrData, options, cb) {\n  if (typeof cb === 'undefined') {\n    cb = options\n    options = undefined\n  }\n\n  const png = exports.render(qrData, options)\n  const buffer = []\n\n  png.on('error', cb)\n\n  png.on('data', function (data) {\n    buffer.push(data)\n  })\n\n  png.on('end', function () {\n    cb(null, Buffer.concat(buffer))\n  })\n\n  png.pack()\n}\n\nexports.renderToFile = function renderToFile (path, qrData, options, cb) {\n  if (typeof cb === 'undefined') {\n    cb = options\n    options = undefined\n  }\n\n  let called = false\n  const done = (...args) => {\n    if (called) return\n    called = true\n    cb.apply(null, args)\n  }\n  const stream = fs.createWriteStream(path)\n\n  stream.on('error', done)\n  stream.on('close', done)\n\n  exports.renderToFileStream(stream, qrData, options)\n}\n\nexports.renderToFileStream = function renderToFileStream (stream, qrData, options) {\n  const png = exports.render(qrData, options)\n  png.pack().pipe(stream)\n}\n","const Utils = require('./utils')\n\nconst BLOCK_CHAR = {\n  WW: ' ',\n  WB: '▄',\n  BB: '█',\n  BW: '▀'\n}\n\nconst INVERTED_BLOCK_CHAR = {\n  BB: ' ',\n  BW: '▄',\n  WW: '█',\n  WB: '▀'\n}\n\nfunction getBlockChar (top, bottom, blocks) {\n  if (top && bottom) return blocks.BB\n  if (top && !bottom) return blocks.BW\n  if (!top && bottom) return blocks.WB\n  return blocks.WW\n}\n\nexports.render = function (qrData, options, cb) {\n  const opts = Utils.getOptions(options)\n  let blocks = BLOCK_CHAR\n  if (opts.color.dark.hex === '#ffffff' || opts.color.light.hex === '#000000') {\n    blocks = INVERTED_BLOCK_CHAR\n  }\n\n  const size = qrData.modules.size\n  const data = qrData.modules.data\n\n  let output = ''\n  let hMargin = Array(size + (opts.margin * 2) + 1).join(blocks.WW)\n  hMargin = Array((opts.margin / 2) + 1).join(hMargin + '\\n')\n\n  const vMargin = Array(opts.margin + 1).join(blocks.WW)\n\n  output += hMargin\n  for (let i = 0; i < size; i += 2) {\n    output += vMargin\n    for (let j = 0; j < size; j++) {\n      const topModule = data[i * size + j]\n      const bottomModule = data[(i + 1) * size + j]\n\n      output += getBlockChar(topModule, bottomModule, blocks)\n    }\n\n    output += vMargin + '\\n'\n  }\n\n  output += hMargin.slice(0, -1)\n\n  if (typeof cb === 'function') {\n    cb(null, output)\n  }\n\n  return output\n}\n\nexports.renderToFile = function renderToFile (path, qrData, options, cb) {\n  if (typeof cb === 'undefined') {\n    cb = options\n    options = undefined\n  }\n\n  const fs = require('fs')\n  const utf8 = exports.render(qrData, options)\n  fs.writeFile(path, utf8, cb)\n}\n","const svgTagRenderer = require('./svg-tag')\n\nexports.render = svgTagRenderer.render\n\nexports.renderToFile = function renderToFile (path, qrData, options, cb) {\n  if (typeof cb === 'undefined') {\n    cb = options\n    options = undefined\n  }\n\n  const fs = require('fs')\n  const svgTag = exports.render(qrData, options)\n\n  const xmlStr = '<?xml version=\"1.0\" encoding=\"utf-8\"?>' +\n    '<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\" \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">' +\n    svgTag\n\n  fs.writeFile(path, xmlStr, cb)\n}\n","\nconst canPromise = require('./can-promise')\n\nconst QRCode = require('./core/qrcode')\nconst CanvasRenderer = require('./renderer/canvas')\nconst SvgRenderer = require('./renderer/svg-tag.js')\n\nfunction renderCanvas (renderFunc, canvas, text, opts, cb) {\n  const args = [].slice.call(arguments, 1)\n  const argsNum = args.length\n  const isLastArgCb = typeof args[argsNum - 1] === 'function'\n\n  if (!isLastArgCb && !canPromise()) {\n    throw new Error('Callback required as last argument')\n  }\n\n  if (isLastArgCb) {\n    if (argsNum < 2) {\n      throw new Error('Too few arguments provided')\n    }\n\n    if (argsNum === 2) {\n      cb = text\n      text = canvas\n      canvas = opts = undefined\n    } else if (argsNum === 3) {\n      if (canvas.getContext && typeof cb === 'undefined') {\n        cb = opts\n        opts = undefined\n      } else {\n        cb = opts\n        opts = text\n        text = canvas\n        canvas = undefined\n      }\n    }\n  } else {\n    if (argsNum < 1) {\n      throw new Error('Too few arguments provided')\n    }\n\n    if (argsNum === 1) {\n      text = canvas\n      canvas = opts = undefined\n    } else if (argsNum === 2 && !canvas.getContext) {\n      opts = text\n      text = canvas\n      canvas = undefined\n    }\n\n    return new Promise(function (resolve, reject) {\n      try {\n        const data = QRCode.create(text, opts)\n        resolve(renderFunc(data, canvas, opts))\n      } catch (e) {\n        reject(e)\n      }\n    })\n  }\n\n  try {\n    const data = QRCode.create(text, opts)\n    cb(null, renderFunc(data, canvas, opts))\n  } catch (e) {\n    cb(e)\n  }\n}\n\nexports.create = QRCode.create\nexports.toCanvas = renderCanvas.bind(null, CanvasRenderer.render)\nexports.toDataURL = renderCanvas.bind(null, CanvasRenderer.renderToDataURL)\n\n// only svg for now.\nexports.toString = renderCanvas.bind(null, function (data, _, opts) {\n  return SvgRenderer.render(data, opts)\n})\n","/*\n*copyright Ryan Day 2012\n*\n* Licensed under the MIT license:\n*   http://www.opensource.org/licenses/mit-license.php\n*\n* this is the main server side application file for node-qrcode.\n* these exports use serverside canvas api methods for file IO and buffers\n*\n*/\n\nmodule.exports = require('./server')\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\n\nclass ValidaCPFCNPJ {\n    constructor() { }\n\n    /**\n     * Valida o CPF ou CNPJ.\n     * @param cpfCnpj CPF ou CNPJ à validar.\n     * @returns Retorna um objeto com o tipo do documento e um boolean se é um documento válido ou não\n     */\n    public validarCpfCnpj(cpfCnpj: string): { documentoValido: boolean, tipoDoDocumento: 'CPF' | 'CNPJ' | 'Desconhecido' } {\n        const isCpf = cpfCnpj.length === 11;\n        const isCnpj = cpfCnpj.length === 14;\n\n        if (!isCpf && !isCnpj) {\n            return { documentoValido: false, tipoDoDocumento: 'Desconhecido' };\n        }\n\n        const cleanCpfCnpj = cpfCnpj.replace(/\\D/g, '');\n\n        if (isCpf) {\n            // CPF\n            if (cleanCpfCnpj === \"00000000000\") {\n                return { documentoValido: false, tipoDoDocumento: 'CPF' };\n            }\n\n            if (!this.documentoValidoateCpf(cleanCpfCnpj)) {\n                return { documentoValido: false, tipoDoDocumento: 'CPF' };\n            }\n\n            return { documentoValido: true, tipoDoDocumento: 'CPF' };\n        } else {\n            // CNPJ\n            if (!this.documentoValidoateCnpj(cleanCpfCnpj)) {\n                return { documentoValido: false, tipoDoDocumento: 'CNPJ' };\n            }\n\n            return { documentoValido: true, tipoDoDocumento: 'CNPJ' };\n        }\n    }\n\n    /**\n     * Validoa o CPF\n     * @param cpf \n     * @returns Retorna se o CPF é valido ou não\n     */\n    private documentoValidoateCpf(cpf: string): boolean {\n        let sum = 0;\n        let remainder;\n\n        for (let i = 1; i <= 9; i++) {\n            sum += parseInt(cpf.substring(i - 1, i)) * (11 - i);\n        }\n\n        remainder = (sum * 10) % 11;\n\n        if ((remainder === 10) || (remainder === 11)) {\n            remainder = 0;\n        }\n\n        if (remainder !== parseInt(cpf.substring(9, 10))) {\n            return false;\n        }\n\n        sum = 0;\n\n        for (let i = 1; i <= 10; i++) {\n            sum += parseInt(cpf.substring(i - 1, i)) * (12 - i);\n        }\n\n        remainder = (sum * 10) % 11;\n\n        if ((remainder === 10) || (remainder === 11)) {\n            remainder = 0;\n        }\n\n        if (remainder !== parseInt(cpf.substring(10, 11))) {\n            return false;\n        }\n\n        return true;\n    }\n\n    /**\n     * Validoa o CNPJ\n     * @param CNPJ \n     * @returns Retorna se o CNPJ é valido ou não\n     */\n    private documentoValidoateCnpj(cnpj: string): boolean {\n        let size = cnpj.length - 2;\n        let numbers = cnpj.substring(0, size);\n        const digits = cnpj.substring(size);\n        let sum = 0;\n        let pos = size - 7;\n\n        for (let i = size; i >= 1; i--) {\n            sum += parseInt(numbers.charAt(size - i)) * pos--;\n            if (pos < 2) {\n                pos = 9;\n            }\n        }\n\n        let result = sum % 11 < 2 ? 0 : 11 - sum % 11;\n\n        if (result != parseInt(digits.charAt(0))) {\n            return false;\n        }\n\n        size = size + 1;\n        numbers = cnpj.substring(0, size);\n        sum = 0;\n        pos = size - 7;\n\n        for (let i = size; i >= 1; i--) {\n            sum += parseInt(numbers.charAt(size - i)) * pos--;\n            if (pos < 2) {\n                pos = 9;\n            }\n        }\n\n        result = sum % 11 < 2 ? 0 : 11 - sum % 11;\n\n        if (result != parseInt(digits.charAt(1))) {\n            return false;\n        }\n\n        return true;\n    }\n\n    /**\n     * Adiciona máscara ao CPF/CNPJ.\n     * @param cpfCnpj CPF ou CNPJ à adicionar máscara.\n     * @returns Retorna o documento com máscara.\n     */\n    public mascaraCnpjCpf(cpfcnpj: string) {\n        cpfcnpj = cpfcnpj.replace(/\\D/g, '');\n        if (cpfcnpj.length === 11) { // CPF\n            return cpfcnpj.replace(/(\\d{3})(\\d{3})(\\d{3})(\\d{2})/, '$1.$2.$3-$4');\n        } else if (cpfcnpj.length === 14) { // CNPJ\n            return cpfcnpj.replace(/(\\d{2})(\\d{3})(\\d{3})(\\d{4})(\\d{2})/, '$1.$2.$3/$4-$5');\n        } else {\n            return cpfcnpj;\n        }\n    }\n}\n\nexport default ValidaCPFCNPJ;\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\n  \nexport const getDesTipoPag = (tPag: string) => {\n    const sefazPagamento: { [key: string]: string } = {\n        '01': 'Dinheiro',\n        '02': 'Cheque',\n        '03': 'Cartão de Crédito',\n        '04': 'Cartão de Débito',\n        '05': 'Cartão da Loja (Private Label), Crediário Digital, Outros Crediários',\n        '10': 'Vale Alimentação',\n        '11': 'Vale Refeição',\n        '12': 'Vale Presente',\n        '13': 'Vale Combustível',\n        '14': 'Duplicata Mercantil',\n        '15': 'Boleto Bancário',\n        '16': 'Depósito Bancário',\n        '17': 'Pagamento Instantâneo (PIX) - Dinâmico',\n        '18': 'Transferência bancária, Carteira Digital',\n        '19': 'Programa de fidelidade, Cashback, Crédito Virtual',\n        '20': 'Pagamento Instantâneo (PIX) - Estático',\n        '21': 'Crédito em Loja',\n        '22': 'Pagamento Eletrônico não Informado - falha de hardware do sistema emissor',\n        '90': 'Sem Pagamento',\n        '99': 'Outros'\n      };\n    \n      return sefazPagamento[tPag] || 'Outros';\n  }","/**\n    * @description      : \n    * @author           : Marco Aurélio Silva Lima\n    * @group            : \n    * @created          : \n    * \n    * MODIFICATION LOG\n    * - Version         : 1.0.0\n    * - Date            : 17/11/2024\n    * - Author          : Cassio Seffrin\n    * - Modification    : \n**/\n/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport bwipjs from 'bwip-js';\nimport path from 'path';\nimport fs from 'fs';\nimport { DetProd, NFEGerarDanfeProps, Ide, Dest, Emit, Total, Transp, InfAdic, ProtNFe, Pag, InfNFeSupl } from 'src/core/types';\nimport { format, parseISO } from 'date-fns';\nimport PDFDocument from 'pdfkit';\nimport QRCode from 'qrcode';\nimport { fileURLToPath } from 'url';\nimport ValidaCPFCNPJ from '@Core/utils/ValidaCPFCNPJ';\nimport { getDesTipoPag } from '@Core/utils/getDesTipoPag';\n\nconst baseDir = path.dirname(fileURLToPath(import.meta.url))\nconst fontDir = process.env.NODE_ENV === 'production' ? '../resources/fonts/ARIAL.TTF' : '../../../../resources/fonts/ARIAL.TTF';\nconst fontDirBold = process.env.NODE_ENV === 'production' ? '../resources/fonts/ARIALBD.TTF' : '../../../../resources/fonts/ARIALBD.TTF';\n\nclass NFCEGerarDanfe {\n    data: NFEGerarDanfeProps['data'];\n    chave: string;\n    enviada: boolean;\n    outputPath: string\n    qrcodePath: string;\n    documento: ValidaCPFCNPJ;\n    protNFe: ProtNFe | undefined;\n    det: DetProd | DetProd[];\n    ide: Ide;\n    dest: Dest | undefined;\n    emit: Emit;\n    total: Total;\n    transp: Transp;\n    pag: Pag;\n    infAdic: InfAdic | undefined;\n    infNFeSupl: InfNFeSupl | undefined\n    exibirMarcaDaguaDanfe?: boolean;\n    fontSize: number;\n    larguraPadrao: number;\n    documentWidth: number;\n    itemHeight: number;\n    doc: InstanceType<typeof PDFDocument>;\n\n    constructor(props: NFEGerarDanfeProps) {\n        const { data, chave, outputPath, pageWidth } = props;\n\n        this.data = data;\n        this.chave = chave.trim();\n        this.outputPath = outputPath;\n        this.enviada = false; // Valor padrão\n        this.qrcodePath = outputPath; // Caminho padrão\n        this.documento = new ValidaCPFCNPJ(); // Inicialização correta\n        this.protNFe = data.protNFe;\n\n        const nfeData = Array.isArray(data.NFe) ? data.NFe[0] : data.NFe;\n        const { det, ide, emit, dest, total, transp, pag, infAdic } = nfeData.infNFe;\n        const infNFeSupl = nfeData.infNFeSupl;\n\n        this.det = det;\n        this.ide = ide;\n        this.emit = emit;\n        this.total = total;\n        this.transp = transp;\n        this.pag = pag;\n        this.infAdic = infAdic;\n        this.infNFeSupl = infNFeSupl;\n        if (dest) this.dest = dest;\n\n        if (this.protNFe?.infProt.nProt) {\n            this.enviada = true;\n        }\n\n        function calculateHeight(itemsLength: number, itemHeight: number) {\n            const headerHeight = 34.22975675056; // Altura do cabeçalho\n            const footerHeight = 170; // Altura do rodapé -> 34.22975675056\n\n            // Altura total é a soma das alturas dos itens + cabeçalho + rodapé\n            return headerHeight + footerHeight + (itemsLength * itemHeight) + 5;\n        }\n\n        function calculateFontSize(width: number) {\n            // Aqui você pode ajustar a fórmula para atender às suas necessidades\n            return Math.min(width) * 0.02646;\n        }\n\n        this.larguraPadrao = 226.772;\n        this.documentWidth = pageWidth || 226.772; // 158.74\n        // const pageHeight = 300;\n        let itensLength = 1;\n        if (this.det instanceof Array) {\n            itensLength = this.det.length;\n        }\n\n        const fontSize = calculateFontSize(this.documentWidth);\n        this.fontSize = fontSize;\n\n        this.itemHeight = fontSize * 1.116;\n        const pageHeight = calculateHeight(itensLength, this.itemHeight);\n\n        const fontPath = path.resolve(baseDir, fontDir);\n        const fontPathBold = path.resolve(baseDir, fontDirBold);\n\n        this.doc = new PDFDocument({\n            margins: { top: 5.67, right: 5.67, bottom: 5.67, left: 5.67 },\n            size: [this.documentWidth, pageHeight],\n            bufferPages: true,\n            layout: 'portrait',\n        });\n        this.doc.registerFont('Arial', fontPath)\n        this.doc.registerFont('Arial-bold', fontPathBold)\n    }\n\n    saveQRCode = async (text: string) => {\n        const filePath = path.resolve(baseDir, this.qrcodePath);\n\n        try {\n            await QRCode.toFile(`${filePath}/qrcode.png`, text, {\n                color: {\n                    dark: '#000000', // Cor do código\n                    light: '#FFFFFF', // Cor de fundo\n                },\n                width: 300, // Largura da imagem\n            });\n        } catch (error: any) {\n            console.error('Erro ao gerar o QR code:', error);\n            console.error(error.stack);\n        }\n    };\n\n    getQRCodeBuffer = async (text: string) => {\n        try {\n            const buffer = await QRCode.toBuffer(text, {\n                color: {\n                    dark: '#000000', // Cor do código\n                    light: '#FFFFFF', // Cor de fundo\n                },\n                width: 300, // Largura da imagem\n            });\n            return buffer;\n        } catch (error: any) {\n            console.error('Erro ao gerar o QR code:', error);\n            console.error(error.stack);\n            throw new Error(`Erro ao gerar o QR code: ${error.message}`);\n        }\n    };\n\n    createDir(path: string) {\n        if (!fs.existsSync(path)) {\n            fs.mkdirSync(path, { recursive: true });\n        }\n    }\n\n    async generateBarcode(data: string) {\n        try {\n            const png = await bwipjs.toBuffer({\n                bcid: 'code128',       // Tipo de código de barras\n                text: data,            // Dado a ser codificado\n                scaleX: 4,             // Fator de escala\n                height: 14,            // Altura da barra\n                includetext: false,    // Incluir texto\n            });\n            const barcode = png.toString('base64');\n            const buffer: any = Buffer.from(barcode, 'base64')\n            const barcodeDir = this.qrcodePath;\n            const barcodeFilePath = path.join(barcodeDir, 'barcode.png');\n            // this.createDir(barcodeDir);\n            fs.writeFileSync(barcodeFilePath, buffer);\n        } catch (err) {\n            console.error('Erro ao gerar código de barras:', err);\n            return null;\n        }\n    }\n\n    centeredPos(texto: string) {\n        const larguraPagina = this.doc.page.width;\n        const larguraTexto = this.doc.fontSize(this.fontSize).widthOfString(texto);\n        const posicaoX = (larguraPagina - larguraTexto) / 2;\n        return posicaoX;\n    }\n\n    ajustarPosicao(posicaoOriginal: number, novaLargura: number) {\n        return posicaoOriginal * (novaLargura / this.larguraPadrao);\n    }\n\n    calculaPosicao(text: string) {\n        const { right, left } = this.doc.page.margins;\n        const [pageWidth] = this.doc.page.size;\n\n        const textWidth = this.doc.widthOfString(text);\n        return Number(pageWidth) - textWidth - right - left;\n    }\n\n    drawHeader(isFirstPage: boolean) {\n        this._buildHeader();\n    }\n\n    drawFooter(qrCodeBuffer: Buffer) {\n        this._buildFooter(qrCodeBuffer);\n    }\n\n    _buildHeader() {\n        const CNPJCPF = this.emit.CNPJCPF?.toString()\n        const CNPJ = this.emit.CNPJ?.toString()\n        const CPF = this.emit.CPF?.toString()\n        const documento = this.documento.mascaraCnpjCpf(CNPJCPF || CNPJ || CPF || '')\n\n        const identificationJoined = `${this.emit.enderEmit.xLgr}, ${this.emit.enderEmit.nro}, ${this.emit.enderEmit.xBairro}, ${this.emit.enderEmit.UF}`\n\n        /** IDENTIFICACAO EMITENTE */\n        const _buildIdentificacaoEmit = () => {\n            const centeredPosEmit = this.centeredPos(`CNPJ: ${documento} ${this.emit.xNome}`)\n            const centeredPosEnd = this.centeredPos(identificationJoined)\n            const centeredPosText = this.centeredPos('Documento Auxiliar da Nota Fiscal de Consumidor Eletrônica')\n\n            this.doc.font('Arial').fontSize(this.fontSize).text(`CNPJ: ${documento} `, centeredPosEmit, 2, {\n                lineBreak: false,\n            })\n                .font('Arial-bold').text(this.emit.xNome)\n                .fontSize(this.fontSize)\n                .font('Arial')\n                .text(identificationJoined, centeredPosEnd)\n                .text('Documento Auxiliar da Nota Fiscal de Consumidor Eletrônica', centeredPosText)\n        }\n\n        _buildIdentificacaoEmit();\n    }\n\n    _buildProdutos() {\n        const { right, left, top } = this.doc.page.margins;\n        const tableWidth = this.documentWidth - left - right;\n        const startX = left;\n        const tableTop = this.doc.y + top;\n        const columnRatios = {\n            codigo: 0.15,\n            descricao: 0.40,\n            qtdeUn: 0.15,\n            unit: 0.15,\n            total: 0.15\n        };\n        const columnSpacing = 0;\n        const columnWidths = {\n            codigo: tableWidth * columnRatios.codigo,\n            descricao: tableWidth * columnRatios.descricao,\n            qtdeUn: tableWidth * columnRatios.qtdeUn,\n            unit: tableWidth * columnRatios.unit,\n            total: tableWidth * columnRatios.total\n        };\n        const header = (top: number) => {\n            let x = startX;\n            this.doc.font('Arial-bold').fontSize(this.fontSize).text('Código', x, top, { width: columnWidths.codigo });\n            x += columnWidths.codigo + columnSpacing;\n            this.doc.text('Descrição', x, top, { width: columnWidths.descricao });\n            x += columnWidths.descricao + columnSpacing;\n            this.doc.text('Qtde', x, top, { width: columnWidths.qtdeUn, align: 'right' });\n            x += columnWidths.qtdeUn + columnSpacing;\n            this.doc.text('Unit', x, top, { width: columnWidths.unit, align: 'right' });\n            x += columnWidths.unit + columnSpacing;\n            this.doc.text('Total', x, top, { width: columnWidths.total, align: 'right' });\n        };\n        const row = (top: number, item: DetProd) => {\n            const quant = parseFloat(String(item.prod.qCom || item.prod.qTrib)).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 3 });\n            const valUnit = parseFloat(String(item.prod.vUnCom || item.prod.vUnTrib || '0')).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 2 });\n            const valLiq = parseFloat(String(item.prod.vProd || '0')).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 2 });\n            let x = startX;\n            this.doc.font('Arial').fontSize(this.fontSize).text(item.prod.cProd, x, top, { width: columnWidths.codigo });\n            x += columnWidths.codigo + columnSpacing;\n            this.doc.text(item.prod.xProd.slice(0, 24), x, top, { width: columnWidths.descricao });\n            x += columnWidths.descricao + columnSpacing;\n            this.doc.text(`${quant} ${item.prod.uCom}`, x, top, { width: columnWidths.qtdeUn, align: 'right' });\n            x += columnWidths.qtdeUn + columnSpacing;\n            this.doc.text(valUnit, x, top, { width: columnWidths.unit, align: 'right' });\n            x += columnWidths.unit + columnSpacing;\n            this.doc.text(valLiq, x, top, { width: columnWidths.total, align: 'right' });\n        };\n        header(tableTop);\n        let y = tableTop + this.itemHeight;\n        if (this.det instanceof Array) {\n            this.det.forEach((prod) => {\n                row(y, prod);\n                y += this.itemHeight;\n            });\n        } else {\n            row(y, this.det);\n        }\n    }\n    _buildTotais() {\n\n        let tableTop = this.doc.y + 5;\n\n        const quantidadeTotalDeItens = Array.isArray(this.det) ? this.det.length : 1;\n\n        let valTotal = 0;\n        let acrescimo = 0;\n        let desconto = 0;\n\n        if (Array.isArray(this.det)) {\n            // Calcula o valor total dos produtos\n            valTotal = this.det.reduce((sum, item) => sum + parseFloat(item.prod.vProd), 0);\n\n            // Calcula o total dos acréscimos\n            acrescimo = this.det.reduce((sum, item) =>\n                sum + (parseFloat(item.prod.vFrete || '0') + parseFloat(item.prod.vSeg || '0') + parseFloat(item.prod.vOutro || '0')), 0\n            );\n\n            // Calcula o total dos descontos\n            desconto = this.det.reduce((sum, item) => sum + parseFloat(item.prod.vDesc || '0'), 0);\n        } else {\n            // Calcula o valor total do produto, os acréscimos, e desconto caso não seja um array\n            valTotal = parseFloat(this.det.prod.vProd);\n            acrescimo = parseFloat(this.det.prod.vFrete || '0') + parseFloat(this.det.prod.vSeg || '0') + parseFloat(this.det.prod.vOutro || '0');\n            desconto = parseFloat(this.det.prod.vDesc || '0')\n        }\n        const valorTotal = valTotal.toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 3 })\n        const acrescimoTotal = acrescimo.toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 3 })\n        const descontoTotal = desconto.toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 3 })\n\n        this.doc.text('Qtd. total de itens', 2, tableTop);\n        this.doc.text(String(quantidadeTotalDeItens), this.calculaPosicao(String(quantidadeTotalDeItens)), tableTop, {\n            align: 'right',\n        });\n        tableTop += this.itemHeight;\n\n        this.doc.text('Valor total R$', 2, tableTop);\n        this.doc.text(valorTotal, this.calculaPosicao(valorTotal), tableTop, {\n            align: 'right',\n        });\n\n        tableTop += this.itemHeight;\n\n        if (desconto > 0) {\n            this.doc.text('Desconto R$', 2, tableTop);\n            this.doc.text(descontoTotal, this.calculaPosicao(descontoTotal), tableTop, {\n                align: 'right',\n            });\n            tableTop += this.itemHeight;\n        }\n        if (acrescimo > 0) {\n            this.doc.text('Acréscimo R$', 2, tableTop);\n            this.doc.text(acrescimoTotal, this.calculaPosicao(acrescimoTotal), tableTop, {\n                align: 'right',\n            });\n            tableTop += this.itemHeight;\n        }\n\n        if (desconto > 0 || acrescimo > 0) {\n            const totalPagar = parseFloat(String(valTotal + acrescimo - desconto)).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 3 });\n\n            this.doc.font('Arial-bold').text('Valor a Pagar R$', 2, tableTop);\n            this.doc.text(totalPagar, this.calculaPosicao(totalPagar), tableTop, {\n                align: 'right',\n            });\n        }\n\n        tableTop += this.itemHeight + 2;\n\n        this.doc.font('Arial').text('FORMA PAGAMENTO', 2, tableTop);\n\n        // Tipos\n\n        let topTiposPag = tableTop;\n        if (Array.isArray(this.pag.detPag)) {\n            for (let pagto of this.pag.detPag) {\n                if (!pagto.xPag) pagto.xPag = getDesTipoPag(pagto.tPag);\n                this.doc.text(pagto.xPag || 'Não informado', 2, topTiposPag + this.itemHeight);\n                topTiposPag += this.itemHeight;\n            }\n        } else {\n            if (!this.pag.detPag.xPag) this.pag.detPag.xPag = getDesTipoPag(this.pag.detPag.tPag);\n            this.doc.text(this.pag.detPag.xPag || 'Não informado', 2, topTiposPag + this.itemHeight);\n        }\n\n        this.doc.text('VALOR PAGO R$', this.calculaPosicao('VALOR PAGO R$'), tableTop, {\n            align: 'right',\n        });\n\n        // Valores\n        let topValPags = tableTop;\n        if (Array.isArray(this.pag.detPag)) {\n            for (let pagto of this.pag.detPag) {\n                const val = parseFloat(pagto.vPag).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 3 })\n                this.doc.text(val, this.calculaPosicao(val), topValPags + this.itemHeight, {\n                    align: 'right',\n                });\n                topValPags += this.itemHeight;\n            }\n        } else {\n            const val = parseFloat(this.pag.detPag.vPag).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 3 })\n            this.doc.text(val, this.calculaPosicao(val), topValPags + this.itemHeight, {\n                align: 'right',\n            });\n        }\n\n        tableTop = topValPags;\n        tableTop += 2 * this.itemHeight;\n\n        let valTroco = 0;\n        if (Array.isArray(this.pag.detPag)) {\n            valTroco = this.pag.detPag.reduce((sum, item) => sum + parseFloat(item.vTroco || '0'), 0);\n        } else {\n            valTroco = parseFloat(this.pag.detPag.vTroco || '0');\n        }\n\n        const troco = valTroco.toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 3 })\n\n        this.doc.text('Troco R$', 2, tableTop);\n        this.doc.text(troco, this.calculaPosicao(troco), tableTop, {\n            align: 'right',\n        });\n\n    }\n\n    _buildFooter(qrCodeBuffer: Buffer) {\n        let tableTop = this.doc.y + 5;\n\n        this.doc.font('Arial-bold').text('Consulte pela Chave de Acesso em', 0, tableTop, {\n            align: 'center'\n        });\n        tableTop += this.itemHeight;\n\n        this.doc.font('Arial').text(this.infNFeSupl?.urlChave || '', 0, tableTop, {\n            align: 'center'\n        });\n        tableTop += this.itemHeight;\n\n        this.doc.text(this.protNFe?.infProt.chNFe || '', 0, tableTop, {\n            align: 'center'\n        });\n\n        tableTop += this.itemHeight;\n        // const filePath = path.resolve(baseDir, this.qrcodePath);\n        // this.doc.image(`${filePath}/qrcode.png`, 2, tableTop, { width: 70.87, height: 70.87 });\n        this.doc.image(qrCodeBuffer, 2, tableTop, { width: 70.87, height: 70.87 });\n\n\n        tableTop += 4;\n        let topBeforeQrCode = tableTop;\n\n        const CNPJCPF = this.documento.mascaraCnpjCpf(\n            this.dest?.CNPJCPF || this.dest?.CNPJ || this.dest?.CPF || this.dest?.idEstrangeiro || ''\n        );\n        const xNome = this.dest?.xNome ?? 'Sem cliente identificado';\n        const xLgr = this.dest?.enderDest?.xLgr ?? '';\n        const nro = this.dest?.enderDest?.nro ?? '';\n        const xBairro = this.dest?.enderDest?.xBairro ?? null;\n        const xMun = this.dest?.enderDest?.xMun ?? '';\n        const UF = this.dest?.enderDest?.UF ?? '';\n        const enderecoPartes = [\n            xLgr && `${xLgr}`,\n            nro && `${nro}`,\n            xBairro && `bairro: ${xBairro}`,\n            xMun && `${xMun}`,\n            UF && `${UF}`\n        ].filter(Boolean);\n        const enderecoStr = enderecoPartes.join(', ');\n        if (CNPJCPF && CNPJCPF !== '') {\n            this.doc.font('Arial-bold').text(`CONSUMIDOR - DOC ${CNPJCPF}`, 75, tableTop, {\n                align: 'left',\n                lineGap: 1,\n                continued: true,\n            }).font('Arial')\n                .text(` - ${xNome} -`, {\n                    lineGap: 1,\n                    continued: true,\n                })\n                .text(enderecoStr); \n            tableTop = this.doc.y + 4;\n        } else {\n            this.doc.text('CONSUMIDOR NÃO IDENTIFICADO', 75, tableTop, {\n                align: 'left',\n            });\n            tableTop = this.doc.y + 4;\n        }\n\n        const data = parseISO(this.ide.dhEmi);\n        const dtaEmi = format(data, 'dd/MM/yyyy HH:mm:ss');\n\n        let dtaAut = format(new Date(), 'dd/MM/yyyy HH:mm:ss');\n        if (this.protNFe?.infProt.dhRecbto) {\n            const dataAut = parseISO(this.protNFe?.infProt.dhRecbto);\n            dtaAut = format(dataAut, 'dd/MM/yyyy HH:mm:ss');\n        }\n\n        this.doc.font('Arial-bold').text(`NCF-e nº ${this.ide.nNF} Série ${this.ide.serie} ${dtaEmi}`, 75, tableTop, {\n            align: 'left',\n            lineGap: 1,\n        })\n            .text('Protocolo de autorização: ', {\n                continued: true,\n                lineGap: 1,\n            })\n            .font('Arial')\n            .text(this.protNFe?.infProt.nProt || '123')\n            .font('Arial-bold')\n            .text('Data de autorização ', {\n                continued: true,\n                lineGap: 1,\n            })\n            .font('Arial')\n            .text(dtaAut);\n\n        tableTop = this.doc.y + 20;\n        topBeforeQrCode += 70.87\n        this.doc.text(`Tributos Totais Incidentes (Lei Federal 12.741/2012): R$ ${parseFloat(this.total.ICMSTot.vTotTrib || '0').toFixed(2)}`, 0, topBeforeQrCode, {\n            align: 'center'\n        });\n    }\n\n    async generatePDF(exibirMarcaDaguaDanfe?: boolean) {\n        try {\n            this.exibirMarcaDaguaDanfe = exibirMarcaDaguaDanfe || true;\n\n            // await this.saveQRCode(this.infNFeSupl?.qrCode  || '')\n            const qrCodeBuffer = await this.getQRCodeBuffer(this.infNFeSupl?.qrCode || '');\n\n            this.doc.pipe(fs.createWriteStream(this.outputPath));\n\n            this.drawHeader(true);\n\n            this._buildProdutos();\n\n            this._buildTotais();\n\n            this.drawFooter(qrCodeBuffer);\n\n            this.doc.end();\n\n            return {\n                message: `  DANFE Gerada em '${this.outputPath}'`,\n                success: true,\n            };\n        } catch (error: any) {\n            throw new Error(`Erro ao gerar DANFE: ${error.message}`);\n        }\n    }\n}\n\nexport default NFCEGerarDanfe;\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport bwipjs from 'bwip-js';\nimport path from 'path';\nimport fs from 'fs';\nimport { ICMS, IPI, DetProd, NFEGerarDanfeProps, Ide, Dest, Emit, Total, Transp, InfAdic, Vol, ProtNFe } from 'src/core/types';\nimport { format } from 'date-fns';\nimport PDFDocument from 'pdfkit';\nimport { fileURLToPath } from 'url';\nimport ValidaCPFCNPJ from '@Core/utils/ValidaCPFCNPJ';\n\nconst baseDir = path.dirname(fileURLToPath(import.meta.url))\nconst barcodePath = process.env.NODE_ENV === 'production' ? '../tmp' : '../../../../../tmp'\n\nclass NFEGerarDanfe {\n    data: NFEGerarDanfeProps['data'];\n    chave: string;\n    enviada: boolean;\n    outputPath: string\n    barcodePath: string;\n    documento: ValidaCPFCNPJ;\n    protNFe: ProtNFe | undefined;\n    det: DetProd | DetProd[];\n    ide: Ide;\n    dest: Dest | undefined;\n    emit: Emit;\n    total: Total;\n    transp: Transp;\n    infAdic: InfAdic | undefined;\n    exibirMarcaDaguaDanfe?: boolean;\n    doc: InstanceType<typeof PDFDocument>;\n\n    constructor(props: NFEGerarDanfeProps) {\n        const { data, chave, outputPath } = props;\n\n        this.data = data;\n        this.chave = chave.trim();\n        this.outputPath = outputPath;\n        this.enviada = false; // Valor padrão\n        this.barcodePath = barcodePath;\n        this.documento = new ValidaCPFCNPJ(); // Inicialização correta\n        this.protNFe = data.protNFe;\n\n        const nfeData = Array.isArray(data.NFe) ? data.NFe[0] : data.NFe;\n        const { det, ide, emit, dest, total, transp, infAdic } = nfeData.infNFe;\n\n        this.det = det;\n        this.ide = ide;\n        this.emit = emit;\n        this.total = total;\n        this.transp = transp;\n        this.infAdic = infAdic;\n        if (dest) this.dest = dest;\n\n        if (this.protNFe?.infProt.nProt) {\n            this.enviada = true;\n        }\n\n        // Área útil ignorando margem à direita (22.68) e esquerda (5.67) = 566.93\n        this.doc = new PDFDocument({\n            margins: { top: 22, right: 22.68, bottom: 12, left: 5.67 },\n            size: 'a4', // 595.28 * 841.89\n            bufferPages: true,\n            layout: 'portrait',\n            font: 'Times-Roman',\n        });\n    }\n\n    createDir(path: string) {\n        if (!fs.existsSync(path)) {\n            fs.mkdirSync(path, { recursive: true });\n        }\n    }\n\n    async generateBarcode(data: string) {\n        try {\n            const png = await bwipjs.toBuffer({\n                bcid: 'code128',       // Tipo de código de barras\n                text: data,            // Dado a ser codificado\n                scaleX: 4,             // Fator de escala\n                height: 14,            // Altura da barra\n                includetext: false,    // Incluir texto\n            });\n\n            const barcode = png.toString('base64');\n            const barcodeDir = this.barcodePath;\n            const filePath = path.resolve(baseDir, this.barcodePath);\n            const buffer: any = Buffer.from(barcode, 'base64');\n            this.createDir(barcodeDir);\n            fs.writeFileSync(`${filePath}/barcode.png`, buffer);\n        } catch (err) {\n            console.error('Erro ao gerar código de barras:', err);\n            return null;\n        }\n    }\n\n    setLineStyle(lineWidth: number, strokeColor: string) {\n        this.doc.lineWidth(lineWidth).strokeColor(strokeColor).fill('black');\n    }\n\n    drawHeader(isFirstPage: boolean) {\n        if (isFirstPage) {\n            this._buildGuia();\n            this._buildSeparator();\n            this._buildHeader(52);\n        } else {\n            this._buildHeader(0);\n        }\n        // this.doc.moveDown();\n    }\n\n    drawFooter() {\n        this._buildFooter();\n    }\n\n    _buildGuia() {\n        const { top, left } = this.doc.page.margins;\n        this.setLineStyle(0.75, '#1c1c1c');\n\n        /** TOP LEFT */\n        this.doc.rect(left, top, 470, 21).stroke();\n        this.doc.fontSize(5).text(`RECEBEMOS DE ${this.emit.xNome} OS PRODUTOS / SERVIÇOS CONSTANTES DA NOTA FISCAL INDICADO AO LADO`, 10, 26, {\n            characterSpacing: 0.5\n        });\n        this.doc.fontSize(6).text(`EMISSÃO: ${format(new Date(this.ide.dhEmi), 'dd-MM-yyyy')} -  DEST. / REM.: ${this.dest?.xNome || ''}  -  VALOR TOTAL: R$ ${parseFloat(String(this.total.ICMSTot.vNF)).toFixed(2)}`, 10, 33.5, {\n            characterSpacing: 0.5\n        });\n        /** RIGHT */\n        this.doc.rect(left + 470, top, 96.93, 42).stroke();\n        this.doc.fontSize(11).text(`NF-e`, 480, 27, {\n            characterSpacing: 1.5,\n            align: 'center'\n        });\n        this.doc.fontSize(8.8).font('Times-Bold').text(`Nº ${String(this.ide.nNF).padStart(2, '0')}`, 480, 40.5, {\n            characterSpacing: 1.5,\n            align: 'center',\n        });\n        this.doc.fontSize(8.5).font('Times-Roman').text(`SÉRIE ${this.ide.serie.padStart(3, '0')}`, 480, 53, {\n            characterSpacing: 1.5,\n            align: 'center',\n        });\n        /** BOTTON LEFT */\n        this.doc.rect(left, top + 21, 75, 21).stroke();\n        this.doc.fontSize(5).text(`DATA DE RECEBIMENTO`, 10, 46.5, {\n            characterSpacing: 0.5,\n        });\n        /** BOTTON RIGHT */\n        this.doc.rect(left + 75, top + 21, 395, 21).stroke();\n        this.doc.fontSize(5).text(`IDENTIFICAÇÃO E ASSINATURA DO RECEBEDOR`, 75 + 10, 46.5, {\n            characterSpacing: 0.5\n        });\n    }\n\n    _buildSeparator() {\n        const { left, right } = this.doc.page.margins;\n        const pageWidth = 595.28; // Largura da página A4 em pontos\n\n        // Calcule a largura da linha, considerando as margens esquerda e direita\n        const lineWidth = pageWidth - left - right;\n\n        // Desenhe a linha\n        this.doc.moveTo(left, 69) // Início da linha\n            .lineTo(left + lineWidth, 69) // Fim da linha\n            .lineWidth(1) // Espessura da linha\n            .dash(1.5, { space: 1.5 }) // Estilo pontilhado\n            .strokeColor('black') // Cor da linha\n            .stroke(); // Desenhar a linha\n\n        this.doc.undash();\n    }\n\n    _buildHeader(pos: number) {\n        const { top, left } = this.doc.page.margins;\n        const page = this.doc.bufferedPageRange();\n        const CNPJCPF = this.emit.CNPJCPF?.toString() \n        const CNPJ = this.emit.CNPJ?.toString() \n        const CPF = this.emit.CPF?.toString()\n        const documento = this.documento.mascaraCnpjCpf(CNPJCPF || CNPJ || CPF || '')\n        this.setLineStyle(0.75, '#1c1c1c');\n\n        const topIdentificacao_1 = top + pos;\n        const identificationJoined = `\\nCEP: ${this.emit.enderEmit.CEP} - ${this.emit.enderEmit.xBairro} - ${this.emit.enderEmit.UF}\\nTEL: ${this.emit.enderEmit.fone} - FAX: ${this.emit.enderEmit.fone}`\n\n        /** IDENTIFICACAO EMITENTE */\n        const _buildIdentificacaoEmit = () => {\n            this.doc.rect(left, topIdentificacao_1, 197.5, 98).stroke();\n            this.doc.fontSize(5).text(`IDENTIFICAÇÃO DO EMITENTE`, 10, topIdentificacao_1 + 3.5, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).font('Times-Bold').text(this.emit.xNome, 35, topIdentificacao_1 + 14, {\n                characterSpacing: 1,\n                width: 170,\n                lineBreak: true,\n                lineGap: 4\n            });\n            this.doc.fontSize(7).font('Times-Roman').text(`${this.emit.enderEmit.xLgr}, ${this.emit.enderEmit.nro} ${this.emit.xFant ? `- ${this.emit.xFant}` : ''}`, 10, topIdentificacao_1 + 44, {\n                characterSpacing: 1,\n                width: 181,\n                lineBreak: true,\n                lineGap: 2,\n                continued: true\n            }).text(identificationJoined);\n        }\n\n        /** IDENTIFICACAO NFe */\n        const _buildIdentificacaoDanfe = () => {\n            this.doc.rect(left + 197.5, topIdentificacao_1, 112.7, 98).stroke();\n            this.doc.fontSize(12).font('Times-Bold').text(`DANFE`, 203, topIdentificacao_1 + 8, {\n                characterSpacing: 1.5,\n                width: 112.7,\n                align: 'center'\n            });\n            this.doc.fontSize(6).text(`DOCUMENTO AUXILIAR DA NOTA FISCAL ELETRÔNICA`, 215, topIdentificacao_1 + 20, {\n                characterSpacing: 0.5,\n                width: 95,\n                align: 'left',\n                lineGap: 2,\n            });\n            this.doc.fontSize(8).font('Times-Roman').text(`0 - ENTRADA`, 217, topIdentificacao_1 + 40, {\n                characterSpacing: 0.5,\n                align: 'left',\n            });\n            this.doc.fontSize(8).text(`1 - SAÍDA`, 217, topIdentificacao_1 + 50, {\n                characterSpacing: 0.5,\n                align: 'left',\n            });\n            this.doc.rect(left + 275, topIdentificacao_1 + 38, 18, 18).stroke();\n            this.doc.fontSize(14).font('Times-Bold').text(String(this.ide.tpNF), left + 280, topIdentificacao_1 + 42.5);\n            this.doc.fontSize(8.8).text(`Nº ${String(this.ide.nNF).padStart(2, '0')}`, 208, topIdentificacao_1 + 65, {\n                characterSpacing: 1,\n            });\n            this.doc.fontSize(10).font('Times-Roman').text(`fl. ${page.start + 1}/${page.count}`, 240, topIdentificacao_1 + 65, {\n                characterSpacing: 1.5,\n                width: 112.7,\n                align: 'center'\n            });\n            this.doc.fontSize(8.8).text(`SÉRIE ${this.ide.serie.padStart(3, '0')}`, 208, topIdentificacao_1 + 78, {\n                characterSpacing: 1.5,\n                width: 112.7,\n                align: 'center'\n            });\n        }\n\n        /** IDENTIFICACAO NFe */\n        const _buildIdentificacaoNFe = () => {\n            this.doc.rect(left + 310.2, topIdentificacao_1, 256.73, 35).stroke();\n            const filePath = path.resolve(baseDir, this.barcodePath);\n            this.doc.image(`${filePath}/barcode.png`, left + 323.5, topIdentificacao_1 + 3, { width: 230, height: 30 });\n            if (Number(this.ide.tpAmb) !== 2 && !this.enviada) {\n                this.doc.fontSize(14).font('Times-Bold').fillColor('red').text('NF-E NÃO ENVIADA PARA SEFAZ', left + 316, topIdentificacao_1 + 12, {\n                    characterSpacing: 1,\n                    width: 256.73,\n                });\n            }\n            this.setLineStyle(0.75, '#1c1c1c')\n            this.doc.rect(left + 310.2, topIdentificacao_1 + 35, 256.73, 23).stroke();\n            this.doc.fontSize(5).font('Times-Roman').text(`CHAVE DE ACESSO`, left + 314, topIdentificacao_1 + 38, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(6).text(this.chave, left + 310.2, topIdentificacao_1 + 47, {\n                characterSpacing: 1,\n                width: 256.73,\n                align: 'center'\n            });\n\n            this.doc.rect(left + 310.2, topIdentificacao_1 + 58, 256.73, 40).stroke();\n            if (Number(this.ide.tpAmb) === 2 || this.enviada) {\n                this.doc.fontSize(6.5).text('Consulta de autenticidade no portal nacional da NF-e', left + 310.2, topIdentificacao_1 + 65, {\n                    characterSpacing: 0.5,\n                    width: 256.73,\n                    align: 'center'\n                });\n                this.doc.fontSize(6.5).text('www.nfe.fazenda.gov.br/portal', left + 310.2, topIdentificacao_1 + 75, {\n                    characterSpacing: 0.5,\n                    width: 256.73,\n                    align: 'center'\n                });\n                this.doc.fontSize(6.5).text('ou no site da Sefaz Autorizadora', left + 310.2, topIdentificacao_1 + 85, {\n                    characterSpacing: 0.5,\n                    width: 256.73,\n                    align: 'center'\n                });\n            }\n\n            this.doc.rect(left, topIdentificacao_1 + 98, 310.2, 23).stroke();\n            this.doc.fontSize(5).text('NATUREZA DE OPERAÇÃO', left + 4, topIdentificacao_1 + 102, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.ide.natOp, left + 4, topIdentificacao_1 + 112, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 310.2, topIdentificacao_1 + 98, 256.73, 23).stroke();\n            if (Number(this.ide.tpAmb) === 2 || this.enviada) {\n                let dhRecbto = '';\n                if (this.protNFe?.infProt.dhRecbto) {\n                    dhRecbto = format(new Date(this.protNFe?.infProt.dhRecbto), 'dd/MM/yyyy HH:mm:ss')\n                }\n                const xProtNfe = `${String(this.protNFe?.infProt.nProt || '')} ${dhRecbto}`;\n                this.doc.fontSize(5).text('PROTOCOLO DE AUTORIZAÇÃO DE USO', left + 314.2, topIdentificacao_1 + 102, {\n                    characterSpacing: 0.5,\n                });\n                this.doc.fontSize(8).text(xProtNfe, left + 314.2, topIdentificacao_1 + 112, {\n                    characterSpacing: 1,\n                });\n            }\n        }\n\n        /** IDENTIFICACAO PESSOA */\n        const _buildIdentificacaoPessoa = () => {\n            this.doc.rect(left, topIdentificacao_1 + 121, 189.5, 23).stroke();\n            this.doc.fontSize(5).text('INSCRIÇÃO ESTADUAL', left + 4, topIdentificacao_1 + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.emit.IE, left + 5, topIdentificacao_1 + 135, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 189.5, topIdentificacao_1 + 121, 187.93, 23).stroke();\n            this.doc.fontSize(5).text('INSCRIÇÃO ESTADUAL DO SUBST. TRIB.', left + 193.5, topIdentificacao_1 + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(String(this.emit.IEST || ''), left + 194.5, topIdentificacao_1 + 135, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 377.43, topIdentificacao_1 + 121, 189.5, 23).stroke();\n            this.doc.fontSize(5).text('CNPJ / CPF', left + 381.43, topIdentificacao_1 + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(documento, left + 386.43, topIdentificacao_1 + 135, {\n                characterSpacing: 1,\n            });\n        }\n\n        _buildIdentificacaoEmit();\n        _buildIdentificacaoDanfe();\n        _buildIdentificacaoNFe();\n        _buildIdentificacaoPessoa();\n    }\n\n    _buildDestinatario() {\n        const { top, left } = this.doc.page.margins;\n        const docDest = this.documento.mascaraCnpjCpf(this.dest?.CNPJCPF || this.dest?.CNPJ || this.dest?.CPF || '')\n        this.setLineStyle(0.75, '#1c1c1c');\n        const topDestinatario = top + 90;\n\n        const _buildDestPessoa = () => {\n            this.doc.rect(left, topDestinatario + 120, 398, 23).stroke();\n            let xNome = 'NF-E EMITIDA EM AMBIENTE DE HOMOLOGACAO - SEM VALOR FISCAL';\n            if (Number(this.ide.tpAmb) !== 2) {\n                xNome = String(this.dest?.xNome || '');\n            }\n            this.doc.fontSize(5).font('Times-Roman').text('NOME / RAZÃO SOCIAL', left + 4, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(xNome, left + 5, topDestinatario + 135, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 398, topDestinatario + 120, 94, 23).stroke();\n            this.doc.fontSize(5).text('CNPJ / CPF', left + 402, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(docDest, left + 403, topDestinatario + 135, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 492, topDestinatario + 120, 74.3, 23).stroke();\n            this.doc.fontSize(5).text('DATA DA EMISSÃO', left + 496, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(format(new Date(this.ide.dhEmi), 'dd-MM-yyyy'), left + 497, topDestinatario + 135, {\n                characterSpacing: 1,\n            });\n        }\n        const _buildDestLogradouro = () => {\n            this.doc.rect(left, topDestinatario + 143, 320, 23).stroke();\n            this.doc.fontSize(5).text('ENDEREÇO', left + 4, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(`${this.dest?.enderDest?.xLgr  || ''}, ${this.dest?.enderDest?.nro  || ''}`, left + 5, topDestinatario + 158, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 320, topDestinatario + 143, 118.5, 23).stroke();\n            this.doc.fontSize(5).text('BAIRRO / DISTRITO', left + 324, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(String(this.dest?.enderDest?.xBairro  || ''), left + 326, topDestinatario + 158, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 438.5, topDestinatario + 143, 53.5, 23).stroke();\n            this.doc.fontSize(5).text('CEP', left + 442.5, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(String(this.dest?.enderDest?.CEP  || ''), left + 443.5, topDestinatario + 158, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 492, topDestinatario + 143, 74.3, 23).stroke();\n            this.doc.fontSize(5).text('DATA SAÍDA / ENTRADA', left + 496, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(format(new Date(), 'dd-MM-yyyy'), left + 497, topDestinatario + 158, {\n                characterSpacing: 1,\n            });\n        }\n        const _buildDestEndereco = () => {\n            this.doc.rect(left, topDestinatario + 166, 246.5, 23).stroke();\n            this.doc.fontSize(5).text('MUNICÍPIO', left + 4, topDestinatario + 171, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(String(this.dest?.enderDest?.xMun || ''), left + 5, topDestinatario + 181, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 246.5, topDestinatario + 166, 113, 23).stroke();\n            this.doc.fontSize(5).text('FONE / FAX', left + 250.5, topDestinatario + 171, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.dest?.enderDest?.fone  || '', left + 250.5, topDestinatario + 181, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 359.5, topDestinatario + 166, 40, 23).stroke();\n            this.doc.fontSize(5).text('UF', left + 363.5, topDestinatario + 171, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(String(this.dest?.enderDest?.UF || ''), left + 363.5, topDestinatario + 181, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 399.5, topDestinatario + 166, 92.5, 23).stroke();\n            this.doc.fontSize(5).text('INSCRIÇÃO ESTADUAL', left + 403.5, topDestinatario + 171, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(String(this.dest?.indIEDest || ''), left + 403.5, topDestinatario + 181, {\n                characterSpacing: 1,\n            });\n\n            this.doc.rect(left + 492, topDestinatario + 166, 74.3, 23).stroke();\n            this.doc.fontSize(5).text('HORA DA SAÍDA', left + 496, topDestinatario + 171, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(format(new Date(), 'HH:mm'), left + 497, topDestinatario + 181, {\n                characterSpacing: 1,\n            });\n        }\n\n        this.doc.fontSize(6).font('Times-Bold').text('DESTINATÁRIO / REMETENTE', left, topDestinatario + 114, {\n            characterSpacing: 0.5,\n        });\n        _buildDestPessoa();\n        _buildDestLogradouro();\n        _buildDestEndereco();\n\n    }\n\n    _builCalculoImposto() {\n        const { top, left } = this.doc.page.margins;\n        this.setLineStyle(0.75, '#1c1c1c');\n        const topDestinatario = top + 173;\n\n        const _buildCalcImposto = () => {\n            /** LINHA 1 */\n            this.doc.rect(left, topDestinatario + 120, 86, 23).stroke();\n            this.doc.fontSize(5).font('Times-Roman').text('BASE DE CÁLCULO DO ICMS', left + 4, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vBC)).toFixed(2), left - 8, topDestinatario + 135, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n            this.doc.rect(left + 86, topDestinatario + 120, 79, 23).stroke();\n            this.doc.fontSize(5).text('VALOR DO ICMS', left + 90, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vICMS)).toFixed(2), left + 86 - 16, topDestinatario + 135, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n            this.doc.rect(left + 165, topDestinatario + 120, 79, 23).stroke();\n            this.doc.fontSize(5).text('BASE CÁLC. ICMS SUBST', left + 169, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vBCST)).toFixed(2), left + 165 - 16, topDestinatario + 135, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n            this.doc.rect(left + 244, topDestinatario + 120, 79, 23).stroke();\n            this.doc.fontSize(5).text('VALOR DO ICMS SUBST.', left + 248, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vST)).toFixed(2), left + 244 - 16, topDestinatario + 135, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n            this.doc.rect(left + 323, topDestinatario + 120, 91, 23).stroke();\n            this.doc.fontSize(5).text('VALOR APROX. DOS TRIBUTOS', left + 327, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(this.total.ICMSTot.vTotTrib || '0').toFixed(2), left + 323 - 6, topDestinatario + 135, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n            this.doc.rect(left + 414, topDestinatario + 120, 152.93, 23).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.fontSize(5).text('VALOR TOTAL DOS PRODUTOS', left + 418, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vProd)).toFixed(2), left + 480 - 8, topDestinatario + 135, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n\n            /** LINHA 2 */\n            this.doc.rect(left, topDestinatario + 143, 86, 23).stroke();\n            this.doc.fontSize(5).text('VALOR DO FRETE', left + 4, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vFrete)).toFixed(2), left - 8, topDestinatario + 158, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n\n            this.doc.rect(left + 86, topDestinatario + 143, 79, 23).stroke();\n            this.doc.fontSize(5).text('VALOR DO SEGURO', left + 90, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vSeg)).toFixed(2), left + 86 - 16, topDestinatario + 158, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n            this.doc.rect(left + 165, topDestinatario + 143, 79, 23).stroke();\n            this.doc.fontSize(5).text('DESCONTO', left + 169, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vDesc)).toFixed(2), left + 165 - 16, topDestinatario + 158, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n            this.doc.rect(left + 244, topDestinatario + 143, 79, 23).stroke();\n            this.doc.fontSize(5).text('OUTRAS DESP. ACESS.', left + 248, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vOutro)).toFixed(2), left + 244 - 16, topDestinatario + 158, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n            this.doc.rect(left + 323, topDestinatario + 143, 91, 23).stroke();\n            this.doc.fontSize(5).text('VALOR DO IPI', left + 327, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vIPI)).toFixed(2), left + 323 - 6, topDestinatario + 158, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n            this.doc.rect(left + 414, topDestinatario + 143, 152.93, 23).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.fontSize(5).text('VALOR TOTAL DA NOTA', left + 418, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(parseFloat(String(this.total.ICMSTot.vNF)).toFixed(2), left + 480 - 8, topDestinatario + 158, {\n                characterSpacing: 1,\n                align: 'right',\n                width: 86\n            });\n        }\n\n        this.doc.fontSize(6).font('Times-Bold').text('CÁLCULO DO IMPOSTO', left, topDestinatario + 114, {\n            characterSpacing: 0.5,\n        });\n        _buildCalcImposto();\n\n    }\n\n    _builTransporte() {\n        const { top, left } = this.doc.page.margins;\n        this.setLineStyle(0.75, '#1c1c1c');\n        const topDestinatario = top + 233;\n\n        const getModFrete = () => {\n            // * 0=Contratação do Frete por conta do Remetente (CIF)\n            // * 1=Contratação do Frete por conta do Destinatário (FOB)\n            // * 2=Contratação do Frete por conta de Terceiros\n            // * 3=Transporte Próprio por conta do Remetente\n            // * 4=Transporte Próprio por conta do Destinatário\n            // * 9=Sem Ocorrência de Transporte. (Atualizado na NT 2016/002)\n            const modFrete = parseInt(String(this.transp.modFrete));\n            switch (modFrete) {\n                case 0:\n                    return `${modFrete} - REMETENTE`;\n                case 1:\n                    return `${modFrete} - DESTINATÁRIO`;\n                case 2:\n                    return `${modFrete} - TERCEIROS`;\n                case 3:\n                    return `${modFrete} - REMETENTE`;\n                case 4:\n                    return `${modFrete} - DESTINATÁRIO`;\n                case 9:\n                    return '';\n                default:\n                    return '';\n            }\n        }\n\n        const _buildVolumeTransporte = () => {\n            if (this.transp.vol) {\n                /** Posição da primeira linha */\n                let topTrnasport = topDestinatario + 166;\n                let topTrnasportTitle = topDestinatario + 171;\n                let topTrnasportValue = topDestinatario + 181;\n\n                const createVolume = (vol: Vol) => {\n                    this.doc.rect(left, topTrnasport, 68.5, 23).stroke();\n                    this.doc.fontSize(5).text('QUANTIDADE', left + 4, topTrnasportTitle, {\n                        characterSpacing: 0.5,\n                    });\n                    this.doc.fontSize(8).text(String(vol?.qVol || ''), left - 8, topTrnasportValue, {\n                        characterSpacing: 1,\n                        align: 'right',\n                        width: 68.5\n                    });\n                    this.doc.rect(left + 68.5, topTrnasport, 100.5, 23).stroke();\n                    this.doc.fontSize(5).text('ESPÉCIE', left + 72.5, topTrnasportTitle, {\n                        characterSpacing: 0.5,\n                    });\n                    this.doc.fontSize(8).text(String(vol?.esp || ''), left + 73.5, topTrnasportValue, {\n                        characterSpacing: 1,\n                    });\n                    this.doc.rect(left + 169, topTrnasport, 100.5, 23).stroke();\n                    this.doc.fontSize(5).text('MARCA', left + 173, topTrnasportTitle, {\n                        characterSpacing: 0.5,\n                    });\n                    this.doc.fontSize(8).text(String(vol?.marca || ''), left + 174, topTrnasportValue, {\n                        characterSpacing: 1,\n                    });\n                    this.doc.rect(left + 269.5, topTrnasport, 100.5, 23).stroke();\n                    this.doc.fontSize(5).text('NUMERAÇÃO', left + 273.5, topTrnasportTitle, {\n                        characterSpacing: 0.5,\n                    });\n                    this.doc.fontSize(8).text(String(vol?.nVol || ''), left + 274.5, topTrnasportValue, {\n                        characterSpacing: 1,\n                    });\n                    this.doc.rect(left + 370, topTrnasport, 102.6, 23).stroke();\n                    this.doc.fontSize(5).text('PESO BRUTO', left + 374, topTrnasportTitle, {\n                        characterSpacing: 0.5,\n                    });\n                    this.doc.fontSize(8).text(String(vol?.nVol || ''), left + 375, topTrnasportValue, {\n                        characterSpacing: 1,\n                    });\n                    //96,43\n                    this.doc.rect(left + 472.5, topTrnasport, 94.43, 23).stroke();\n                    this.doc.fontSize(5).text('PESO LÍQUIDO', left + 474.5, topTrnasportTitle, {\n                        characterSpacing: 0.5,\n                    });\n                    this.doc.fontSize(8).text(String(vol?.nVol || ''), left + 475.5, topTrnasportValue, {\n                        characterSpacing: 1,\n                    });\n                    /** Define posição da nova linha */\n                    topTrnasport = topTrnasport + 23;\n                    topTrnasportTitle = topTrnasportTitle + 23;\n                    topTrnasportValue = topTrnasportValue + 23;\n                }\n\n                if (this.transp.vol instanceof Array) {\n                    for (let vol of this.transp.vol) {\n                        createVolume(vol);\n                    }\n                } else {\n                    createVolume(this.transp.vol);\n                }\n\n            }\n\n        }\n\n        const _buildCalcImposto = () => {\n            const documento = this.documento.mascaraCnpjCpf(this.transp.transporta?.CNPJCPF || this.transp.transporta?.CNPJ || this.transp.transporta?.CPF || '');\n            /** LINHA 1 */\n            this.doc.rect(left, topDestinatario + 120, 248.5, 23).stroke();\n            this.doc.fontSize(5).font('Times-Roman').text('RAZÃO SOCIAL', left + 4, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.transp.transporta?.xNome || '', left + 5, topDestinatario + 135, {\n                characterSpacing: 1,\n                width: 246\n            });\n            this.doc.rect(left + 248.5, topDestinatario + 120, 90, 23).stroke();\n            this.doc.fontSize(5).text('FRETE POR CONTA', left + 252.5, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(getModFrete(), left + 253.5, topDestinatario + 135, {\n                characterSpacing: 1,\n            });\n            this.doc.rect(left + 338.5, topDestinatario + 120, 50, 23).stroke();\n            this.doc.fontSize(5).text('CÓDIGO ANTT', left + 342.5, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.transp?.veicTransp?.RNTC || '', left + 343.5, topDestinatario + 135, {\n                characterSpacing: 1,\n            });\n            this.doc.rect(left + 388.5, topDestinatario + 120, 62, 23).stroke();\n            this.doc.fontSize(5).text('PLACA DO VEÍCULO', left + 391.5, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.transp?.veicTransp?.placa || '', left + 393.5, topDestinatario + 135, {\n                characterSpacing: 1,\n            });\n            this.doc.rect(left + 450.5, topDestinatario + 120, 22, 23).stroke();\n            this.doc.fontSize(5).text('UF', left + 454.5, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.transp?.transporta?.UF || '', left + 455.5, topDestinatario + 135, {\n                characterSpacing: 1,\n            });\n            this.doc.rect(left + 472.5, topDestinatario + 120, 94.43, 23).stroke();\n            this.doc.fontSize(5).text('CNPJ / CPF', left + 476.5, topDestinatario + 125, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(documento, left + 477.5, topDestinatario + 135, {\n                characterSpacing: 1,\n            });\n\n            /** LINHA 2 */\n            this.doc.rect(left, topDestinatario + 143, 338.5, 23).stroke();\n            this.doc.fontSize(5).text('ENDEREÇO', left + 4, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.transp.transporta?.xEnder || '', left + 4, topDestinatario + 158, {\n                characterSpacing: 1,\n            });\n            this.doc.rect(left + 338.5, topDestinatario + 143, 112, 23).stroke();\n            this.doc.fontSize(5).text('MUNICÍPIO', left + 342.5, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.transp.transporta?.xMun || '', left + 343.5, topDestinatario + 158, {\n                characterSpacing: 1,\n            });\n            this.doc.rect(left + 450.5, topDestinatario + 143, 22, 23).stroke();\n            this.doc.fontSize(5).text('UF', left + 454.5, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.transp?.transporta?.UF || '', left + 455.5, topDestinatario + 158, {\n                characterSpacing: 1,\n            });\n            this.doc.rect(left + 472.5, topDestinatario + 143, 94.43, 23).stroke();\n            this.doc.fontSize(5).text('INSCRIÇÃO ESTADUAL', left + 476.5, topDestinatario + 148, {\n                characterSpacing: 0.5,\n            });\n            this.doc.fontSize(8).text(this.transp?.transporta?.IE || '', left + 476.5, topDestinatario + 158, {\n                characterSpacing: 1,\n            });\n        }\n\n        this.doc.fontSize(6).font('Times-Bold').text('TRANSPORTADOR / VOLUMES TRANSPORTADOS', left, topDestinatario + 114, {\n            characterSpacing: 0.5,\n        });\n        _buildCalcImposto();\n        _buildVolumeTransporte();\n\n    }\n\n    _buildProdutos() {\n        const { top, left } = this.doc.page.margins;\n        this.setLineStyle(0.75, '#1c1c1c');\n\n        this.doc.fontSize(6).font('Times-Bold').fillColor('black').text('DADOS DO PRODUTO / SERVIÇOS', left, 452, {\n            characterSpacing: 0.5,\n        });\n\n        const tableTop = 458;\n        const defaultItemHeight = 15;\n        let y = tableTop;\n        let currentPage = 0;\n\n        const header = (top: number) => {\n            this.doc.rect(left, top, 40, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.font('Times-Roman').fontSize(5.7).text('CÓDIGO DO PROD. / SERV', left, top + 2.8, {\n                width: 40,\n                align: 'center',\n            });\n            this.doc.rect(left + 40, top, 138, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('DESCRIÇÃO DO PRODUTO / SERVIÇO', left + 40, top + 5.9, {\n                width: 138,\n                align: 'center'\n            });\n            this.doc.rect(left + 178, top, 30, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('NCM / SH', left + 178, top + 5.9, {\n                width: 30,\n                align: 'center'\n            });\n            this.doc.rect(left + 208, top, 17, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('CST', left + 208, top + 5.9, {\n                width: 17,\n                align: 'center'\n            });\n            this.doc.rect(left + 225, top, 28, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('CFOP', left + 225, top + 5.9, {\n                width: 28,\n                align: 'center'\n            });\n            this.doc.rect(left + 253, top, 23, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('UNID.', left + 253, top + 5.9, {\n                width: 23,\n                align: 'center'\n            });\n            this.doc.rect(left + 276, top, 25, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('QUANT.', left + 276, top + 5.9, {\n                width: 25,\n                align: 'center'\n            });\n            this.doc.rect(left + 301, top, 37.23, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('VALOR UNITÁRIO', left + 301, top + 2.9, {\n                width: 37.23,\n                align: 'center'\n            });\n            this.doc.rect(left + 338.23, top, 39.23, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('VALOR DESCONTO', left + 338.23, top + 2.9, {\n                width: 39.23,\n                align: 'center'\n            });\n            this.doc.rect(left + 377.46, top, 33.23, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('VALOR LIQUIDO', left + 377.46, top + 2.9, {\n                width: 33.23,\n                align: 'center'\n            });\n            this.doc.rect(left + 410.69, top, 38, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('BASE CÁLC. ICMS', left + 413.8, top + 2.9, {\n                width: 32,\n                align: 'center'\n            });\n            this.doc.rect(left + 448.69, top, 35, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('VALOR I.C.M.S.', left + 448.69, top + 2.9, {\n                width: 35,\n                align: 'center'\n            });\n            this.doc.rect(left + 483.69, top, 38, defaultItemHeight).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('VALOR I.P.I.', left + 490.69, top + 2.9, {\n                width: 25,\n                align: 'center'\n            });\n            this.doc.rect(left + 521.69, top, 45.2, 7.5).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('ALÍQUOTAS', left + 521.69, top + 2, {\n                width: 45,\n                align: 'center'\n            });\n            this.doc.rect(left + 521.69, top + 7.5, 22.5, 7.5).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('ICMS', left + 521.69, top + 9.5, {\n                width: 22.5,\n                align: 'center'\n            });\n            this.doc.rect(left + 544.19, top + 7.5, 22.75, 7.5).fillAndStroke('#DDDDDD', '#1c1c1c');\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.text('IPI', left + 544.19, top + 9.5, {\n                width: 22.5,\n                align: 'center'\n            });\n        };\n\n        const row = (top: number, item: DetProd) => {\n            function getCST(ICMS: ICMS): string {\n                const chavesICMS: (keyof ICMS)[] = Object.keys(ICMS) as (keyof ICMS)[];\n\n                const listaIcmsSemCST = [\n                    'ICMSSN101',\n                    'ICMSSN102',\n                    'ICMSSN201',\n                    'ICMSSN202',\n                    'ICMSSN500',\n                    'ICMSSN900'\n                ];\n\n                const icmsSemCST = listaIcmsSemCST.includes(chavesICMS[0]);\n\n                let CST = '';\n                if (chavesICMS.length > 0) {\n                    const tipoICMS = chavesICMS[0];\n                    if (!icmsSemCST) {\n                        CST = (ICMS[tipoICMS] as any).CST;\n                    }\n                }\n                return CST;\n            }\n            function getValoresItem(ICMS: ICMS): {\n                vBC: string,\n                vICMS: string,\n                pICMS: string\n            } {\n                const chavesICMS: (keyof ICMS)[] = Object.keys(ICMS) as (keyof ICMS)[];\n\n                const listaIcmsSemvBC = [\n                    'ICMS02',\n                    'ICMS15',\n                    'ICMS30',\n                    'ICMS40',\n                    'ICMS53',\n                    'ICMS60',\n                    'ICMS61',\n                    'ICMSST',\n                    'ICMSSN101',\n                    'ICMSSN102',\n                    'ICMSSN201',\n                    'ICMSSN202',\n                    'ICMSSN500'\n                ];\n                const icmsSemvBC = listaIcmsSemvBC.includes(chavesICMS[0]);\n\n                let vBC = '0,00';\n                let vICMS = '0,00';\n                let pICMS = '0,00';\n                if (chavesICMS.length > 0) {\n                    const tipoICMS = chavesICMS[0];\n                    if (!icmsSemvBC) {\n                        vBC = (ICMS[tipoICMS] as any).vBC;\n                        vICMS = (ICMS[tipoICMS] as any).vICMS\n                        pICMS = (ICMS[tipoICMS] as any).pICMS\n                        return {\n                            vBC: parseFloat(vBC).toFixed(2),\n                            vICMS: parseFloat(vBC).toFixed(2),\n                            pICMS: parseFloat(pICMS).toFixed(2)\n                        };\n                    }\n                }\n                return { vBC, vICMS, pICMS };\n            }\n            function getValoresIPI(IPI: IPI | undefined): { vIPI: string, pIPI: string } {\n                if (!IPI) {\n                    return {\n                        vIPI: '0,00',\n                        pIPI: '0,00'\n                    }\n                }\n\n                let vIPI = parseFloat(String(IPI.IPITrib.vIPI)).toFixed(2);\n                let pIPI = parseFloat(String(IPI.IPITrib.pIPI)).toFixed(2);\n                return { vIPI, pIPI }\n            }\n            const CST = getCST(item.imposto.ICMS);\n            const { vIPI, pIPI } = getValoresIPI(item.imposto.IPI);\n            const { vBC, vICMS, pICMS } = getValoresItem(item.imposto.ICMS);\n\n            const text = item.infAdProd ? `${item.prod.xProd || ''}\\n${item.infAdProd}` : item.prod.xProd || '';\n            const textHeight = this.doc.heightOfString(text, {\n                width: 138,\n                align: 'center'\n            });\n\n            const itemHeight = Math.max(defaultItemHeight, textHeight + 10); // 10 is padding\n\n            this.setLineStyle(0.75, '#1c1c1c');\n            this.doc.rect(left, top, 40, itemHeight).stroke();\n            this.doc.font('Times-Roman').fontSize(6).text(item.prod.cProd || '', left + 2, top + 3, {\n                width: 40,\n            });\n\n            this.doc.rect(left + 40, top, 138, itemHeight).stroke();\n            this.doc.text(text, left + 43, top + 4, {\n                width: 137,\n            });\n\n            this.doc.rect(left + 178, top, 30, itemHeight).stroke();\n            this.doc.text(String(item.prod.NCM) || '', left + 178, top + 5.9, {\n                width: 30,\n                align: 'center'\n            });\n\n            this.doc.rect(left + 208, top, 17, itemHeight).stroke();\n            this.doc.text(CST, left + 208, top + 5.9, {\n                width: 17,\n                align: 'center'\n            });\n\n            this.doc.rect(left + 225, top, 28, itemHeight).stroke();\n            this.doc.text(String(item.prod.CFOP || ''), left + 225, top + 5.9, {\n                width: 28,\n                align: 'center'\n            });\n\n            this.doc.rect(left + 253, top, 23, itemHeight).stroke();\n            this.doc.text(item.prod.uCom || item.prod.uTrib || '', left + 256, top + 5.9, {\n                width: 23,\n            });\n\n            const quant = parseFloat(String(item.prod.qCom || item.prod.qTrib)).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 3 });\n            this.doc.rect(left + 276, top, 25, itemHeight).stroke();\n            this.doc.text(String(quant || ''), left + 274.5, top + 5.9, {\n                width: 25,\n                align: 'right'\n            });\n\n            const valUnit = parseFloat(String(item.prod.vUnCom || item.prod.vUnTrib || '0')).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 2 });\n            this.doc.rect(left + 301, top, 37.23, itemHeight).stroke();\n            this.doc.text(valUnit, left + 299.5, top + 5.9, {\n                width: 37.23,\n                align: 'right'\n            });\n\n            const valDesc = parseFloat(String(item.prod.vDesc || '0')).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 2 });\n            this.doc.rect(left + 338.23, top, 39.23, itemHeight).stroke();\n            this.doc.text(valDesc, left + 336.73, top + 5.9, {\n                width: 39.23,\n                align: 'right'\n            });\n\n            const valLiq = parseFloat(String(item.prod.vProd || '0')).toLocaleString('pt-BR', { minimumFractionDigits: 2, maximumFractionDigits: 2 });\n            this.doc.rect(left + 377.46, top, 33.23, itemHeight).stroke();\n            this.doc.text(valLiq, left + 375.96, top + 5.9, {\n                width: 33.23,\n                align: 'right'\n            });\n\n            this.doc.rect(left + 410.69, top, 38, itemHeight).stroke();\n            this.doc.text(vBC, left + 409.19, top + 5.9, {\n                width: 38,\n                align: 'right'\n            });\n\n            this.doc.rect(left + 448.69, top, 35, itemHeight).stroke();\n            this.doc.text(vICMS, left + 447.19, top + 5.9, {\n                width: 35,\n                align: 'right'\n            });\n\n            this.doc.rect(left + 483.69, top, 38, itemHeight).stroke();\n            this.doc.text(vIPI, left + 482.19, top + 5.9, {\n                width: 38,\n                align: 'right'\n            });\n\n            this.doc.rect(left + 521.69, top, 22.5, itemHeight).stroke();\n            this.doc.text(pICMS, left + 520.19, top + 5.9, {\n                width: 22.5,\n                align: 'right'\n            });\n\n            this.doc.rect(left + 544.19, top, 22.75, itemHeight).stroke();\n            this.doc.text(pIPI, left + 542.69, top + 5.9, {\n                width: 22.5,\n                align: 'right'\n            });\n\n            return itemHeight;\n        };\n\n        header(458);\n\n        const createTable = (prod: DetProd) => {\n            if (y + defaultItemHeight > this.doc.page.height - 160) {\n                this.doc.addPage();\n                currentPage++;\n                if (currentPage > 0) {\n                    y = 185;\n                    this.doc.fontSize(6).font('Times-Bold').fillColor('black').text('DADOS DO PRODUTO / SERVIÇOS', left, 175, {\n                        characterSpacing: 0.5,\n                    });\n                    header(185);\n                }\n            }\n            const itemHeight = row(y + 15, prod);\n            y += itemHeight;\n        }\n\n        // Adicionando itens da tabela\n        if (this.det instanceof Array) {\n            for (let i = 0; i < this.det.length; i++) {\n                const prod = this.det[i];\n                createTable(prod);\n            }\n        } else {\n            createTable(this.det);\n        }\n    }\n\n    _buildFooter() {\n        const { left } = this.doc.page.margins;\n\n        this.setLineStyle(0.75, '#1c1c1c');\n        const topDestinatario = 820.45 - 88.5;\n\n        this.doc.fontSize(6).font('Times-Bold').text('DADOS ADICIONAIS', left, topDestinatario - 5, {\n            characterSpacing: 0.5,\n        });\n        this.doc.rect(left, topDestinatario, 408, 95).stroke();\n        this.doc.fontSize(5).font('Times-Roman').text('INFORMAÇÕES COMPLEMENTARES', 10, topDestinatario + 4.5, {\n            characterSpacing: 0.5\n        });\n        this.doc.fontSize(8).text(this.infAdic?.infCpl || '', 13, topDestinatario + 13, {\n            characterSpacing: 1,\n            width: 400,\n        });\n        this.doc.rect(left + 408, topDestinatario, 158.93, 95).stroke();\n        this.doc.fontSize(5).text('RESERVADO AO FISCO', 408 + 10, topDestinatario + 4.5, {\n            characterSpacing: 0.5\n        });\n        this.doc.fontSize(8).text(String(this.infAdic?.infAdFisco || ''), 13, topDestinatario + 13, {\n            characterSpacing: 1,\n            width: 400,\n        });\n\n        if (this.exibirMarcaDaguaDanfe) {\n            const topPosition = Number(Number(this.ide.tpAmb)) !== 2 ? topDestinatario + 38 : topDestinatario + 58;\n            const leftPosition = Number(Number(this.ide.tpAmb)) !== 2 ? left + 150 : left + 100;\n            this.doc.fontSize(26).font('Times-Bold').fillColor('#c7c7c7').text('NFeWizard-io', leftPosition, topPosition, {\n                characterSpacing: 0.5,\n            });\n        }\n\n        if (Number(Number(this.ide.tpAmb)) === 2) {\n            this.doc.fontSize(14).font('Times-Bold').fillColor('grey').text('AMBIENTE DE HOMOLOGAÇÃO - NF-E SEM VALOR FISCAL', left + 100, topDestinatario + 45, {\n                characterSpacing: 1\n            });\n        }\n        // .rotate(45, { origin: [0, 0] })\n    }\n\n    async generatePDF(exibirMarcaDaguaDanfe?: boolean) {\n        try {\n            this.exibirMarcaDaguaDanfe = exibirMarcaDaguaDanfe || true;\n            const chave = this.chave;\n\n            await this.generateBarcode(chave);\n\n            this.doc.pipe(fs.createWriteStream(this.outputPath));\n\n            this.drawHeader(true);\n\n            this._buildDestinatario();\n            this._builCalculoImposto();\n            this._builTransporte();\n\n            this.doc.on('pageAdded', () => {\n                this.drawHeader(false);\n            });\n            this.drawFooter();\n            this.doc.on('pageAdded', () => {\n                this.drawFooter();\n            });\n\n            this._buildProdutos();\n            this.doc.end();\n\n            return {\n                message: `  DANFE Gerada em '${this.outputPath}'`,\n                success: true,\n            };\n        } catch (error: any) {\n            throw new Error(`Erro ao gerar DANFE: ${error.message}`);\n        }\n    }\n}\n\nexport default NFEGerarDanfe;\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFCEAutorizacaoServiceImpl } from '@Interfaces';\n\nclass NFCEAutorizacao {\n    nfceAutorizacaoService: NFCEAutorizacaoServiceImpl;\n    constructor(nfceAutorizacaoService: NFCEAutorizacaoServiceImpl) {\n        this.nfceAutorizacaoService = nfceAutorizacaoService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfceAutorizacaoService.Exec(data);\n    }\n\n}\n\n\nexport default NFCEAutorizacao;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFEDistribuicaoDFeServiceImpl } from '@Interfaces';\n\nclass NFERecepcaoEvento implements NFEDistribuicaoDFeServiceImpl {\n    nfeDistribuicaoDFeService: NFEDistribuicaoDFeServiceImpl;\n    constructor(nfeDistribuicaoDFeService: NFEDistribuicaoDFeServiceImpl) {\n        this.nfeDistribuicaoDFeService = nfeDistribuicaoDFeService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeDistribuicaoDFeService.Exec(data);\n    }\n}\n\nexport default NFERecepcaoEvento;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFEDistribuicaoDFeServiceImpl } from '@Interfaces';\n\nclass NFEDistribuicaoDFePorChave implements NFEDistribuicaoDFeServiceImpl {\n    nfeDistribuicaoDFePorChaveService: NFEDistribuicaoDFeServiceImpl;\n    constructor(nfeDistribuicaoDFePorChaveService: NFEDistribuicaoDFeServiceImpl) {\n        this.nfeDistribuicaoDFePorChaveService = nfeDistribuicaoDFePorChaveService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeDistribuicaoDFePorChaveService.Exec(data);\n    }\n}\nexport default NFEDistribuicaoDFePorChave;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFEDistribuicaoDFeServiceImpl } from '@Interfaces';\n\nclass NFEDistribuicaoDFePorNSU implements NFEDistribuicaoDFeServiceImpl {\n    nfeDistribuicaoDFePorNSUService: NFEDistribuicaoDFeServiceImpl;\n    constructor(nfeDistribuicaoDFePorNSUService: NFEDistribuicaoDFeServiceImpl) {\n        this.nfeDistribuicaoDFePorNSUService = nfeDistribuicaoDFePorNSUService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeDistribuicaoDFePorNSUService.Exec(data);\n    }\n}\n\nexport default NFEDistribuicaoDFePorNSU;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFEDistribuicaoDFeServiceImpl } from '@Interfaces';\n\nclass NFEDistribuicaoDFePorUltNSU implements NFEDistribuicaoDFeServiceImpl {\n    nfeDistribuicaoDFePorUltNSUService: NFEDistribuicaoDFeServiceImpl;\n    constructor(nfeDistribuicaoDFePorUltNSUService: NFEDistribuicaoDFeServiceImpl) {\n        this.nfeDistribuicaoDFePorUltNSUService = nfeDistribuicaoDFePorUltNSUService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeDistribuicaoDFePorUltNSUService.Exec(data);\n    }\n}\nexport default NFEDistribuicaoDFePorUltNSU;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFEInutilizacaoServiceImpl } from '@Interfaces';\n\nclass NFEInutilizacao implements NFEInutilizacaoServiceImpl{\n    nfeInutilizacaoService: NFEInutilizacaoServiceImpl;\n    constructor(nfeInutilizacaoService: NFEInutilizacaoServiceImpl) {\n        this.nfeInutilizacaoService = nfeInutilizacaoService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeInutilizacaoService.Exec(data);\n    }\n\n}\nexport default NFEInutilizacao;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFERecepcaoEventoServiceImpl } from '@Interfaces/NFERecepcaoEventoServiceImpl.js';\n\n\nclass NFECartaDeCorrecao implements NFERecepcaoEventoServiceImpl {\n    nfeCartaDeCorrecaoServiceService: NFERecepcaoEventoServiceImpl;\n    constructor(nfeCartaDeCorrecaoServiceService: NFERecepcaoEventoServiceImpl) {\n        this.nfeCartaDeCorrecaoServiceService = nfeCartaDeCorrecaoServiceService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeCartaDeCorrecaoServiceService.Exec(data);\n    }\n}\n\nexport default NFECartaDeCorrecao;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFERecepcaoEventoServiceImpl } from '@Interfaces';\n\nclass NFEDesconhecimentoDaOperacao implements NFERecepcaoEventoServiceImpl {\n    nfeDesconhecimentoDaOperacaoServiceService: NFERecepcaoEventoServiceImpl;\n    constructor(nfeDesconhecimentoDaOperacaoServiceService: NFERecepcaoEventoServiceImpl) {\n        this.nfeDesconhecimentoDaOperacaoServiceService = nfeDesconhecimentoDaOperacaoServiceService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeDesconhecimentoDaOperacaoServiceService.Exec(data);\n    }\n}\n\nexport default NFEDesconhecimentoDaOperacao;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFERetornoAutorizacaoServiceImpl } from '@Interfaces';\nimport { ProtNFe } from '@Types/NFEAutorizacao';\n\nclass NFERetornoAutorizacao implements NFERetornoAutorizacaoServiceImpl {\n    nfeStatusServicoService: NFERetornoAutorizacaoServiceImpl;\n    constructor(nfeStatusServicoService: NFERetornoAutorizacaoServiceImpl) {\n        this.nfeStatusServicoService = nfeStatusServicoService;\n    }\n\n    async getXmlRetorno(data: {\n        tipoEmissao: number;\n        nRec?: string;\n        protNFe?: ProtNFe[];\n        xmlNFe: string[];\n    }): Promise<{\n        success: boolean;\n        message: any;\n        data: string[];\n    }> {\n        return await this.nfeStatusServicoService.getXmlRetorno(data);\n    }\n\n}\n\nexport default NFERetornoAutorizacao;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { COFINS, ICMS, PIS, dadosCOFINS, dadosICMS, dadosPIS } from 'src/core/types';\n\nfunction filterFieldsByType<T extends object>(source: any, requiredFields: (keyof T)[]): Partial<T> {\n    const result: Partial<T> = {};\n    for (const key of requiredFields) {\n        if (key in source) {\n            if (source[key] !== '')\n                result[key] = source[key];\n        }\n    }\n    return result;\n}\n\nconst COFINSMap: { [key: string]: keyof COFINS } = {\n    '01': 'COFINSAliq',\n    '02': 'COFINSAliq',\n    '03': 'COFINSQtde',\n    '04': 'COFINSNT',\n    '05': 'COFINSNT',\n    '06': 'COFINSNT',\n    '07': 'COFINSNT',\n    '08': 'COFINSNT',\n    '09': 'COFINSNT',\n    '49': 'COFINSOutr',\n    '50': 'COFINSOutr',\n    '51': 'COFINSOutr',\n    '52': 'COFINSOutr',\n    '53': 'COFINSOutr',\n    '54': 'COFINSOutr',\n    '55': 'COFINSOutr',\n    '56': 'COFINSOutr',\n    '60': 'COFINSOutr',\n    '61': 'COFINSOutr',\n    '62': 'COFINSOutr',\n    '63': 'COFINSOutr',\n    '64': 'COFINSOutr',\n    '65': 'COFINSOutr',\n    '66': 'COFINSOutr',\n    '67': 'COFINSOutr',\n    '70': 'COFINSOutr',\n    '71': 'COFINSOutr',\n    '72': 'COFINSOutr',\n    '73': 'COFINSOutr',\n    '74': 'COFINSOutr',\n    '75': 'COFINSOutr',\n    '98': 'COFINSOutr',\n    '99': 'COFINSOutr',\n};\n\nconst PISMap: { [key: string]: keyof PIS } = {\n    '01': 'PISAliq',\n    '02': 'PISAliq',\n    '03': 'PISQtde',\n    '04': 'PISNT',\n    '05': 'PISNT',\n    '06': 'PISNT',\n    '07': 'PISNT',\n    '08': 'PISNT',\n    '09': 'PISNT',\n    '49': 'PISOutr',\n    '50': 'PISOutr',\n    '51': 'PISOutr',\n    '52': 'PISOutr',\n    '53': 'PISOutr',\n    '54': 'PISOutr',\n    '55': 'PISOutr',\n    '56': 'PISOutr',\n    '60': 'PISOutr',\n    '61': 'PISOutr',\n    '62': 'PISOutr',\n    '63': 'PISOutr',\n    '64': 'PISOutr',\n    '65': 'PISOutr',\n    '66': 'PISOutr',\n    '67': 'PISOutr',\n    '70': 'PISOutr',\n    '71': 'PISOutr',\n    '72': 'PISOutr',\n    '73': 'PISOutr',\n    '74': 'PISOutr',\n    '75': 'PISOutr',\n    '98': 'PISOutr',\n    '99': 'PISOutr',\n};\n\nconst ICMSMap: { [key: string]: keyof ICMS } = {\n    '00': 'ICMS00',\n    '02': 'ICMS02',\n    '10': 'ICMS10',\n    '20': 'ICMS20',\n    '30': 'ICMS30',\n    '40': 'ICMS40',\n    '41': 'ICMS40',\n    '50': 'ICMS40',\n    '51': 'ICMS51',\n    '60': 'ICMS60',\n    '70': 'ICMS70',\n    '90': 'ICMS90',\n    '101': 'ICMSSN101',\n    '102': 'ICMSSN102',\n    '103': 'ICMSSN102',\n    '201': 'ICMSSN201',\n    '202': 'ICMSSN202',\n    '203': 'ICMSSN202',\n    '500': 'ICMSSN500',\n    '900': 'ICMSSN900',\n};\n\nexport const mountCOFINS = (cofins: dadosCOFINS) => {\n    const { CST } = cofins;\n    const cst_cofins = CST;\n\n    let cofinsKey = COFINSMap[CST]\n    if (!cofinsKey) {\n        console.warn(`Código de situação tributária do COFINS ${cst_cofins} não é reconhecido. Alterado para padrão 'COFINSAliq'.`);\n        cofinsKey = 'COFINSAliq';\n    }\n\n    // const cofins = {\n    //     CST: cst_cofins,\n    //     vBC: 0, // No ERP  - nf_item.val_base_cofins   \n    //     pCOFINS: 0, // No ERP - nf_item.per_cofins\n    //     vCOFINS: 0, // No ERP - nf_item.val_cofins\n    //     qBCProd: 0, // No ERP -- Fixo Vazio\n    //     vAliqProd: 0, // No ERP -- Fixo Vazio\n    // }\n\n    const requiredFields = {\n        COFINSAliq: ['CST', 'vBC', 'pCOFINS', 'vCOFINS'],\n        COFINSQtde: ['CST', 'qBCProd', 'vAliqProd', 'vCOFINS'],\n        COFINSNT: ['CST'],\n        COFINSOutr: ['CST', 'vBC', 'pCOFINS', 'qBCProd', 'vAliqProd', 'vCOFINS'],\n    };\n\n    if (cofinsKey in requiredFields) {\n        const required = requiredFields[cofinsKey as keyof typeof requiredFields];\n\n        const cofinsProperties = filterFieldsByType(cofins, required);\n\n        const cofinsObject: COFINS = { [cofinsKey]: cofinsProperties } as COFINS;\n\n        return cofinsObject;\n    }\n\n    console.warn(`Chave COFINS '${cofinsKey}' não reconhecida.`);\n    return {} as COFINS;\n}\n\nexport const mountPIS = (pis: dadosPIS): PIS => {\n    const { CST } = pis;\n    const cst_pis = CST;\n\n    let pisKey = PISMap[cst_pis]\n    if (!pisKey) {\n        console.warn(`Código de situação tributária do PIS ${cst_pis} não é reconhecido. Alterado para padrão 'PISAliq'.`);\n        pisKey = 'PISAliq';\n    }\n\n    const requiredFields = {\n        PISAliq: ['CST', 'vBC', 'pPIS', 'vPIS'],\n        PISQtde: ['CST', 'qBCProd', 'vAliqProd', 'vPIS'],\n        PISNT: ['CST'],\n        PISOutr: ['CST', 'vBC', 'pPIS', 'qBCProd', 'vAliqProd', 'vPIS'],\n    };\n\n    if (pisKey in requiredFields) {\n        const required = requiredFields[pisKey as keyof typeof requiredFields];\n\n        const pisProperties = filterFieldsByType(pis, required);\n\n        const pisObject: PIS = { [pisKey]: pisProperties } as PIS;\n\n        return pisObject;\n    }\n\n    console.warn(`Chave PIS '${pisKey}' não reconhecida.`);\n    return {} as PIS;\n}\n\nexport const mountICMS = (icms: dadosICMS): ICMS => {\n    const { CST, CSOSN } = icms;\n\n    let cod_sit = CST;\n\n    if (CST?.trim()?.length > 0) {\n        cod_sit = CST.length > 2 ? CST.substring(1, 3) : CST;\n    } else if (CSOSN) {\n        cod_sit = String(CSOSN);\n    }\n    \n\n    let icmsKey = ICMSMap[cod_sit];\n    if (!icmsKey) {\n        console.warn(`Código de situação tributária ${cod_sit} não é reconhecido. Alterado para padrão 'ICMS00'.`);\n        icmsKey = 'ICMS00';\n    }\n\n    const requiredFields = {\n        ICMS00: ['orig', 'CST', 'modBC', 'vBC', 'pICMS', 'vICMS', 'pFCP', 'vFCP'],\n        ICMS02: ['orig', 'CST', 'qBCMono', 'adRemICMS', 'vICMSMono'],\n        ICMS10: ['orig', 'CST', 'modBC', 'vBC', 'pICMS', 'vICMS', 'vBCFCP', 'pFCP', 'modBCST', 'pMVAST', 'pRedBCST', 'vBCST', 'pICMSST', 'vICMSST', 'vICMSSTDeson', 'motDesICMSST'],\n        ICMS15: ['orig', 'CST', 'qBCMono', 'adRemICMS', 'vICMSMono', 'qBCMonoReten', 'adRemICMSReten', 'vICMSMonoReten', 'pRedAdRem', 'motRedAdRem'],\n        ICMS20: ['orig', 'CST', 'modBC', 'pRedBC', 'vBC', 'pICMS', 'vICMS', 'vBCFCP', 'pFCP', 'vICMSDeson', 'motDesICMS', 'indDeduzDeson'],\n        ICMS30: ['orig', 'CST', 'modBCST', 'pMVAST', 'pRedBCST', 'vBCST', 'pICMSST', 'vICMSST', 'vBCFCPST', 'pFCPST', 'vFCPST', 'vICMSDeson', 'motDesICMS', 'indDeduzDeson'],\n        ICMS40: ['orig', 'CST', 'vICMSDeson', 'motDesICMS', 'indDeduzDeson'],\n        ICMS41: ['orig', 'CST', 'vICMSDeson', 'motDesICMS', 'indDeduzDeson'],\n        ICMS50: ['orig', 'CST', 'vICMSDeson', 'motDesICMS', 'indDeduzDeson'],\n        ICMS51: ['orig', 'CST', 'modBC', 'pRedBC', 'vBC', 'pICMS', 'vICMS', 'vICMSOp', 'pDif', 'vICMSDif'],\n        ICMS53: ['orig', 'CST', 'qBCMono', 'adRemICMS', 'vICMSMonoOp', 'pDif', 'vICMSMonoDif', 'vICMSMono', 'qBCMonoDif', 'adRemICMSDif'],\n        ICMS60: ['orig', 'CST', 'vBCSTRet', 'pST', 'vICMSSubstituto', 'vICMSSTRet', 'vBCFCPSTRet', 'pFCPSTRet', 'vFCPSTRet', 'pRedBCEfet', 'vBCEfet', 'pICMSEfet', 'vICMSEfet'],\n        ICMS61: ['orig', 'CST', 'qBCMonoRet', 'adRemICMSRet', 'vICMSMonoRet'],\n        ICMS70: ['orig', 'CST', 'modBC', 'pRedBC', 'vBC', 'pICMS', 'vICMS', 'vBCST', 'pICMSST', 'vICMSST', 'vICMSDeson', 'motDesICMS', 'indDeduzDeson', 'modBCST', 'pMVAST', 'pRedBCST'],\n\n        ICMS90: ['orig', 'CST', 'modBC', 'vBC', 'pRedBC', 'pICMS', 'vICMS', 'vBCFCP', 'pFCP', 'vFCP', 'modBCST', 'pMVAST', 'pRedBCST', 'vBCST', 'pICMSST', 'vICMSST', 'vBCFCPST', 'pFCPST', 'vFCPST', 'vICMSDeson', 'motDesICMS', 'indDeduzDeson'],\n\n        ICMSPart: ['orig', 'CST', 'modBC', 'vBC', 'pRedBC', 'pICMS', 'vICMS', 'modBCST', 'pMVAST', 'pRedBCST', 'vBCST', 'pICMSST', 'vICMSST', 'pBCOp', 'UFST', 'vBCFCPST', 'pFCPST', 'vFCPST'],\n        ICMSST: ['orig', 'CST', 'vBCSTRet', 'pST', 'vICMSSubstituto', 'vICMSSTRet', 'vBCFCPSTRet', 'pFCPSTRet', 'vFCPSTRet', 'vBCSTDest', 'vICMSSTDest'],\n        ICMSSN101: ['orig', 'CSOSN', 'pCredSN', 'vCredICMSSN'],\n        ICMSSN102: ['orig', 'CSOSN'],\n        ICMSSN201: ['orig', 'CSOSN', 'modBCST', 'pMVAST', 'pRedBCST', 'vBCST', 'pICMSST', 'vICMSST', 'pFCPST', 'vFCPST'],\n        ICMSSN202: ['orig', 'CSOSN', 'modBCST', 'pMVAST', 'pRedBCST', 'vBCST', 'pICMSST', 'vICMSST', 'vFCPST', 'vBCFCPST', 'pFCPST'],\n        ICMSSN500: ['orig', 'CSOSN', 'vBCSTRet', 'pST', 'vICMSSubstituto', 'vICMSSTRet', 'vBCFCPSTRet', 'pFCPSTRet', 'vFCPSTRet', 'pRedBCEfet', 'vBCEfet', 'pICMSEfet', 'vICMSEfet'],\n        ICMSSN900: ['orig', 'CSOSN', 'modBC', 'vBC', 'pRedBC', 'pICMS', 'vICMS', 'modBCST', 'pMVAST', 'pRedBCST', 'vBCST', 'pICMSST', 'vICMSST', 'vBCFCPST', 'pFCPST', 'vFCPST', 'pCredSN', 'vCredICMSSN'],\n    };\n\n    if (icmsKey in requiredFields) {\n        // Obtém os campos obrigatórios para o tipo ICMS\n        const required = requiredFields[icmsKey as keyof typeof requiredFields];\n\n        // Filtra as propriedades do item de acordo com os campos obrigatórios do tipo ICMS\n        const icmsProperties = filterFieldsByType(icms, required);\n        // Monta o objeto ICMS usando a chave dinâmica e as propriedades filtradas\n        const icmsObject: ICMS = { [icmsKey]: icmsProperties } as ICMS;\n\n        return icmsObject;\n    }\n\n    console.warn(`Chave ICMS '${icmsKey}' não reconhecida.`);\n    return {} as ICMS;\n\n}\n\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport BaseNFE from '@Modules/dfe/base/BaseNFe.js';\nimport { ProtNFe } from '@Types';\nimport { AxiosInstance } from 'axios';\nimport { GerarConsultaImpl, NFERetornoAutorizacaoServiceImpl, SaveFilesImpl } from '@Interfaces';\n\nclass NFERetornoAutorizacaoService extends BaseNFE implements NFERetornoAutorizacaoServiceImpl {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, 'NFERetAutorizacao', axios, saveFiles, gerarConsulta);\n    }\n\n    protected gerarXml(data: string): string {\n        try {\n            const { nfe: { ambiente } } = this.environment.getConfig();\n\n            const xmlObject = {\n                $: {\n                    xmlns: 'http://www.portalfiscal.inf.br/nfe',\n                    versao: \"4.00\",\n                },\n                tpAmb: ambiente,\n                nRec: data\n            }\n            return this.xmlBuilder.gerarXml(xmlObject, 'consReciNFe')\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    /**\n     * Busca o retorno da Autorização pelo número do recibo (nRec)\n     * \n     * @param {string} nRec - Número do recibo retornado pela SEFAZ ao emitir uma NFe em modo assíncrono.\n     * @param {any} xmlNFe - Array contendo as NFe do lote enviado à SEFAZ.\n     * @returns {Promise<string>} XML completo da NFe (já com protocolo de autorização).\n     */\n    async getRetornoRecibo(nRec: string, xmlNFe: string[]): Promise<{\n        success: boolean;\n        message: any;\n        data: string[];\n    }> {\n        try {\n            /**\n             * Gera o XML para consulta de acordo com o número do recibo da emissão (nRec)\n             */\n            const xmlConsulta = this.gerarXml(nRec);\n\n            const { xmlFormated, agent, webServiceUrl, action } = await this.gerarConsulta.gerarConsulta(xmlConsulta, this.metodo);\n\n            // Salva XML de Consulta\n            this.utility.salvaConsulta(xmlConsulta, xmlFormated, this.metodo);\n\n            // Efetua requisição para o webservice NFEStatusServico\n            const xmlRetorno = await this.axios.post(webServiceUrl, xmlFormated, {\n                headers: {\n                    'Content-Type': this.setContentType(),\n                    'SOAPAction': action,\n                },\n                httpsAgent: agent\n            });\n\n            const responseInJson = this.utility.verificaRejeicao(xmlRetorno.data, this.metodo);\n            \n            // Salva XML de Retorno\n            this.utility.salvaRetorno(xmlRetorno.data, responseInJson, this.metodo);\n\n            const { protNFe } = this.utility.getProtNFe(xmlRetorno.data);\n\n            if (!protNFe) {\n                throw new Error(`Não foi possível encontrar a tag 'protNFe'. Talvez a NFe ainda não tenha sido processada.`)\n            }\n            return this.getXmlRetornoAutorizacao(protNFe, xmlNFe);\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    /**\n     * Agrega o protNFe ao restante da NFe gerada na emissão.\n     * \n     * @param {string} protNFe - Tag protNFe do XML em formato JSON.\n     * @param {any} xmlNFe - Array contendo as NFe do lote enviado à SEFAZ.\n     * @returns {} XML completo da NFe (já com protocolo de autorização).\n     */\n    private getXmlRetornoAutorizacao(protNFe: ProtNFe[], xmlNFe: string[]): {\n        success: boolean;\n        message: any;\n        data: string[];\n    } {\n        try {\n            /**\n             * Cria o Obj base da NFe já processada (nfeProc)\n             */\n            const XMLs = []\n            for (let i = 0; i < protNFe.length; i++) {\n                const baseXML = {\n                    $: {\n                        versao: \"4.00\",\n                        xmlns: 'http://www.portalfiscal.inf.br/nfe'\n                    },\n                    _: '[XML]'\n                }\n                let xml = this.xmlBuilder.gerarXml(baseXML, 'nfeProc')\n                /**\n                 * Converte a tag protNFe do formato JSON para XML e armazena na string protTag.\n                 * Adiciona a tag protNFe (armazenada na string protTag) ao array contendo os dados das NFe.\n                 */\n                // Expressão regular para capturar o valor do atributo Id\n                const formatedProtNFe: any = protNFe;\n                const xmlCompleto = xmlNFe.find((item) => item.indexOf(formatedProtNFe[i].infProt[0].chNFe[0]) !== -1);\n \n                if (xmlCompleto) {\n                    const protTag = this.xmlBuilder.gerarXml(protNFe[i], 'protNFe')\n                    const xmlFinal = [xmlCompleto]\n                    xmlFinal.push(protTag)\n\n                    /**\n                     * Substitui o \"[XML]\" com as tags NFe e a tag protNFe\n                     */\n                    xml = xml.replace('[XML]', xmlFinal.join(''));\n                    xml = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>${xml}`;\n\n                    XMLs.push(xml)\n                }\n            }\n            return {\n                success: true,\n                message: 'xMotivo',\n                data: XMLs\n            }\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n\n    }\n\n    /**\n     * Retorna o XML completo da Autorização (já com o protocolo de autorização)\n     * \n     * @param {number} tipoEmissao - Informa se o tipo emissão foi síncrona ou assíncrona (0- Não / 1 - Sim).\n     * @param {string | undefined} nRec - Número do recibo retornado pela SEFAZ ao emitir uma NFe em modo assíncrono.\n     * @param {ProtNFe | undefined} protNFe - Tag protNFe do XML em formato JSON.\n     * @param {string[]} xmlNFe - Array contendo as NFe do lote enviado à SEFAZ.\n     * @returns {Promise<string>} XML completo da NFe (já com protocolo de autorização).\n     */\n    async getXmlRetorno({\n        tipoEmissao,\n        nRec,\n        protNFe,\n        xmlNFe\n    }: {\n        tipoEmissao: number,\n        nRec?: string,\n        protNFe?: ProtNFe[],\n        xmlNFe: string[]\n    }): Promise<{\n        success: boolean;\n        message: any;\n        data: string[];\n    }> {\n        try {\n\n            /**\n             * Trata retorno Síncrono\n             */\n            if (tipoEmissao === 1 && protNFe) {\n                return this.getXmlRetornoAutorizacao(protNFe, xmlNFe);\n            }\n\n            /**\n             * Trata retorno Assíncrono\n             */\n            if (tipoEmissao === 0 && nRec) {\n                return this.getRetornoRecibo(nRec, xmlNFe);\n            }\n\n            throw new Error('Não foi possível buscar o retorno da autorização.');\n\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n}\n\nexport default NFERetornoAutorizacaoService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { AxiosInstance, AxiosResponse } from 'axios';\nimport NFERetornoAutorizacao from '../../operations/NFERetornoAutorizacao/NFERetornoAutorizacao.js';\nimport XmlParser from '../../../../../core/utils/XmlParser.js';\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport ValidaCPFCNPJ from '../../../../../core/utils/ValidaCPFCNPJ.js';\nimport { GenericObject, LayoutNFe, NFe, ProtNFe } from '@Types';\nimport BaseNFE from '@Modules/dfe/base/BaseNFe.js';\nimport { format } from 'date-fns';\nimport { mountCOFINS, mountICMS, mountPIS } from '@Utils/NFEImposto.js';\nimport { GerarConsultaImpl, NFEAutorizacaoServiceImpl, SaveFilesImpl } from '@Interfaces';\nimport NFERetornoAutorizacaoService from '../NFERetornoAutorizacao/NFERetornoAutorizacaoService.js';\nimport { logger } from '@Core/exceptions/logger.js';\n\nclass NFEAutorizacaoService extends BaseNFE implements NFEAutorizacaoServiceImpl {\n    xmlNFe: string[];\n\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, 'NFEAutorizacao', axios, saveFiles, gerarConsulta);\n        this.xmlNFe = [];\n    }\n\n    protected gerarXml(data: NFe): string {\n        return this.gerarXmlNFeAutorizacao(data);\n    }\n\n    protected salvaArquivos(xmlConsulta: string, responseInJson: GenericObject, xmlRetorno: AxiosResponse<any, any>, options?: Record<string, any>): GenericObject {\n\n        // Recupera configuração do ambiente para verificar se os arquivos gerados serão gravados em disco\n        const config = this.environment.getConfig();\n        let dateAndTimeInFileName = config.dfe.incluirTimestampNoNomeDosArquivos;\n\n        const createFileName = (prefix: string | undefined, includeMethodName?: boolean) => {\n            const dtaTime = dateAndTimeInFileName ? `-${format(new Date(), 'dd-MM-yyyy-HHmm')}` : '';\n\n            const baseFileName = includeMethodName ? `${this.metodo}` : '';\n            const prefixPart = prefix ? includeMethodName ? `-${prefix}` : `${prefix}` : '';\n            const nfePart = responseInJson.chNFe ? `-${responseInJson.chNFe}` : '';\n            const dateTimePart = dtaTime;\n\n            return `${baseFileName}${prefixPart}${nfePart}${dateTimePart}`;\n        }\n\n        const salvarArquivo = (data: any, prefix: string | undefined, path: string | undefined, fileType: 'xml' | 'json', includeMethodName?: boolean) => {\n            const fileName = createFileName(prefix, includeMethodName);\n            const method = fileType === 'xml' ? 'salvaXML' : 'salvaJSON';\n\n            this.utility[method]({\n                data: data,\n                fileName,\n                metodo: this.metodo,\n                path,\n            });\n        };\n\n        let chNFe = ''\n        let xmlAutorizacaoInJson: GenericObject = {} as GenericObject;\n        let xMotivoPorXml: GenericObject[] = [];\n        let xmlsInJson: GenericObject[] = [];\n        if (options) {\n            const { xmlAutorizacao } = options;\n\n            const json = new XmlParser();\n\n            for (let i = 0; i < xmlAutorizacao.length; i++) {\n                xmlAutorizacaoInJson = json.convertXmlToJson(xmlAutorizacao[i], 'NFEAutorizacaoFinal');\n                xmlsInJson.push(xmlAutorizacaoInJson);\n\n                const chNFe = xmlAutorizacaoInJson.protNFe.infProt.chNFe;\n                const xMotivo = xmlAutorizacaoInJson.protNFe.infProt.xMotivo;\n                const cStat = xmlAutorizacaoInJson.protNFe.infProt.cStat;\n                xMotivoPorXml.push({\n                    chNFe,\n                    xMotivo,\n                    cStat,\n                })\n\n                if (config.dfe.armazenarXMLAutorizacao) {\n                    salvarArquivo(xmlAutorizacao[i], chNFe, config.dfe.pathXMLAutorizacao, 'xml', false);\n                    salvarArquivo(xmlAutorizacaoInJson, chNFe, config.dfe.pathXMLAutorizacao, 'json', false);\n                }\n            }\n\n            return {\n                success: true,\n                xMotivo: xMotivoPorXml,\n                response: xmlsInJson,\n            }\n        }\n        return {\n            success: true,\n            xMotivo: xMotivoPorXml,\n            response: xmlsInJson,\n        }\n    }\n\n    private async trataRetorno(xmlRetorno: string, indSinc: number, responseInJson: GenericObject) {\n        try {\n            /**\n             * Captura o valor nRec e protNFe\n             */\n            const { nRec, protNFe } = this.utility.getProtNFe(xmlRetorno);\n\n            /**\n             * 0 - assíncrona\n             * 1 - síncrona\n             */\n            let tipoEmissao = 0;\n            if (indSinc === 1 && protNFe) {\n                tipoEmissao = 1;\n            }\n\n            const nfeRetornoAutService = new NFERetornoAutorizacaoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeRetornoAut = new NFERetornoAutorizacao(nfeRetornoAutService);\n\n            await new Promise(resolve => setTimeout(resolve, Number(responseInJson.infRec.tMed) * 1000));\n\n            const retorno = await nfeRetornoAut.getXmlRetorno({\n                tipoEmissao,\n                nRec,\n                protNFe,\n                xmlNFe: this.xmlNFe\n            });\n\n            return retorno;\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    /**\n     * Método utilitário para criação do XML a partir de um Objeto\n     */\n\n\n    private anoMesEmissao(dhEmi: string) {\n        // Lógica para obter o ano e mês de emissão (AAMM)\n        const dataAtual = new Date(dhEmi);\n        const ano = dataAtual.getFullYear().toString().slice(-2);\n        const mes = (dataAtual.getMonth() + 1).toString().padStart(2, '0');\n\n        return ano + mes;\n    }\n\n    private gerarCodigoNumerico() {\n        // Lógica para gerar um código numérico aleatório de 8 dígitos\n        return Math.floor(Math.random() * 100000000).toString().padStart(8, '0');\n    }\n\n    private calcularModulo11(sequencia: string) {\n        const pesos = [4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2];\n\n        let somatoria = 0;\n\n        for (let i = 0; i < sequencia.length; i++) {\n            somatoria += parseInt(sequencia.charAt(i)) * pesos[i];\n        }\n\n        const restoDivisao = somatoria % 11;\n        const digitoVerificador = restoDivisao === 0 || restoDivisao === 1 ? 0 : 11 - restoDivisao;\n\n        return digitoVerificador;\n    }\n\n    private calcularDigitoVerificador(data: LayoutNFe) {\n        const {\n            infNFe: {\n                ide: { cUF, mod, serie, nNF, tpEmis, cNF, dhEmi },\n                emit: { CNPJCPF }\n            }\n        } = data;\n\n        const anoMes = this.anoMesEmissao(dhEmi);\n\n        // Montando a sequência para o cálculo do dígito verificador\n        const sequencia = `${cUF}${anoMes}${CNPJCPF}${mod}${String(serie).padStart(3, '0')}${String(nNF).padStart(9, '0')}${tpEmis}${cNF}`;\n\n        // Calculando o dígito verificador\n        const dv = this.calcularModulo11(sequencia);\n\n        // Montando a chave de acesso\n        const chaveAcesso = `NFe${sequencia}` + dv;\n        this.chaveNfe = `${sequencia}${dv}`;\n\n        return {\n            chaveAcesso,\n            dv\n        };\n    }\n\n    private validaDocumento(doc: string, campo: string) {\n        // Valida se CPF ou CNPJ\n        const nfeAutorizacaoHandler = new ValidaCPFCNPJ();\n        const { documentoValido, tipoDoDocumento } = nfeAutorizacaoHandler.validarCpfCnpj(doc);\n\n        if (!documentoValido || tipoDoDocumento === 'Desconhecido') {\n            const message = tipoDoDocumento === 'Desconhecido'\n                ? `Documento do ${campo} ausente ou inválido`\n                : `${tipoDoDocumento} do ${campo} é inválido`\n            throw new Error(message);\n        }\n\n        return tipoDoDocumento;\n    }\n\n    private gerarXmlNFeAutorizacao(data: NFe) {\n        const createXML = (NFe: LayoutNFe) => {\n            // Verificando se existe mais de um produto\n            if (NFe?.infNFe?.det instanceof Array) {\n                // Adicionando indice ao item\n                const formatedItens = NFe.infNFe.det.map((det, index) => {\n                    if (det.imposto.ICMS.dadosICMS) {\n                        const icms = mountICMS(det.imposto.ICMS.dadosICMS);\n                        det.imposto.ICMS = icms;\n                    }\n                    if (det.imposto.PIS.dadosPIS) {\n                        const pis = mountPIS(det.imposto.PIS.dadosPIS);\n                        det.imposto.PIS = pis;\n                    }\n                    if (det.imposto.COFINS.dadosCOFINS) {\n                        const cofins = mountCOFINS(det.imposto.COFINS.dadosCOFINS);\n                        det.imposto.COFINS = cofins\n                    }\n                    return {\n                        $: {\n                            nItem: index + 1,\n                        },\n                        ...det,\n                    };\n                });\n                NFe.infNFe.det = formatedItens;\n            }\n\n            // Cria chave da nota e grava digito verificador\n            const { chaveAcesso, dv } = this.calcularDigitoVerificador(NFe);\n\n            NFe.infNFe.ide.cDV = dv;\n            NFe.infNFe.ide.verProc = NFe.infNFe.ide.verProc || '1.0.0.0';\n\n            // Valida Documento do emitente\n            NFe.infNFe.emit = Object.assign({ [this.validaDocumento(String(NFe.infNFe.emit.CNPJCPF), 'emitente')]: NFe.infNFe.emit.CNPJCPF }, NFe.infNFe.emit)\n            delete NFe.infNFe.emit.CNPJCPF;\n            // Valida Documento do destinatário\n            if (NFe.infNFe.dest) {\n                NFe.infNFe.dest = Object.assign({ [this.validaDocumento(String(NFe.infNFe.dest?.CNPJCPF || ''), 'destinatário')]: NFe.infNFe.dest?.CNPJCPF || '' }, NFe.infNFe.dest)\n                delete NFe.infNFe.dest.CNPJCPF;\n            }\n            // Valida Documento do transportador\n            if (NFe.infNFe.transp.transporta) {\n                NFe.infNFe.transp.transporta = Object.assign({ [this.validaDocumento(String(NFe.infNFe.transp.transporta?.CNPJCPF), 'transportador')]: NFe.infNFe.transp.transporta?.CNPJCPF }, NFe.infNFe.transp.transporta)\n                delete NFe.infNFe.transp.transporta?.CNPJCPF;\n            }\n\n            // Valida Documento do produtor rural\n            if (NFe.infNFe?.NFref instanceof Array) {\n                const NFrefArray = NFe.infNFe.NFref;\n                if (NFrefArray && NFrefArray.length > 0) {\n                    NFe.infNFe.NFref = NFrefArray.map(NFref => {\n                        if (NFref.refNFP) {\n                            NFref.refNFP = Object.assign(\n                                { [this.validaDocumento(String(NFref.refNFP.CNPJCPF), 'produtor rural')]: NFref.refNFP.CNPJCPF },\n                                NFref.refNFP\n                            );\n                            delete NFref.refNFP.CNPJCPF;\n                        }\n                        return NFref;\n                    });\n                }\n            } else {\n                if (NFe.infNFe.NFref && NFe.infNFe.NFref.refNFP) {\n                    NFe.infNFe.NFref.refNFP = Object.assign(\n                        { [this.validaDocumento(String(NFe.infNFe.NFref.refNFP.CNPJCPF), 'produtor rural')]: NFe.infNFe.NFref.refNFP.CNPJCPF },\n                        NFe.infNFe.NFref.refNFP\n                    )\n                }\n            }\n\n            // Caso Seja hambiente de homologação\n            if (NFe.infNFe.dest) {\n                if (NFe.infNFe.ide.tpAmb === 2) {\n                    NFe.infNFe.dest.xNome = 'NF-E EMITIDA EM AMBIENTE DE HOMOLOGACAO - SEM VALOR FISCAL';\n                }\n            }\n\n            const xmlObject = {\n                $: {\n                    xmlns: 'http://www.portalfiscal.inf.br/nfe'\n                },\n                infNFe: {\n                    $: {\n                        versao: \"4.00\",\n                        Id: chaveAcesso,\n                    },\n                    ...NFe.infNFe\n                }\n            }\n\n            const eventoXML = this.xmlBuilder.gerarXml(xmlObject, 'NFe')\n            const xmlAssinado = this.xmlBuilder.assinarXML(eventoXML, 'infNFe')\n            this.xmlNFe.push(xmlAssinado);\n        }\n\n        if (data.NFe instanceof Array) {\n            for (let i = 0; i < data.NFe.length; i++) {\n                const NFe = data.NFe[i];\n                createXML(NFe);\n            }\n        } else {\n            createXML(data.NFe);\n        }\n\n        // Base do XML\n        const baseXML = {\n            $: {\n                versao: \"4.00\",\n                xmlns: 'http://www.portalfiscal.inf.br/nfe'\n            },\n            idLote: data.idLote,\n            indSinc: data.indSinc,\n            _: '[XML]'\n        }\n\n        // Gera base do XML\n        const xml = this.xmlBuilder.gerarXml(baseXML, 'enviNFe')\n\n        return xml.replace('[XML]', this.xmlNFe.join(''));\n    }\n\n    public async Exec(data: NFe): Promise<{\n        success: boolean;\n        xMotivo: GenericObject;\n        xmls: {\n            NFe: LayoutNFe;\n            protNFe: ProtNFe\n        }[];\n    }> {\n        let xmlConsulta: string = '';\n        let xmlConsultaSoap: string = '';\n        let webServiceUrlTmp: string = '';\n        let responseInJson: GenericObject | undefined = undefined;\n        let xmlRetorno: AxiosResponse<any, any> = {} as AxiosResponse<any, any>;\n        const ContentType = this.setContentType();\n        try {\n            // Gerando XML para consulta de Status do Serviço\n            xmlConsulta = this.gerarXmlNFeAutorizacao(data);\n\n            const { xmlFormated, agent, webServiceUrl, action } = await this.gerarConsulta.gerarConsulta(xmlConsulta, this.metodo);\n\n            xmlConsultaSoap = xmlFormated;\n            webServiceUrlTmp = webServiceUrl;\n\n            // Efetua requisição para o webservice NFEStatusServico\n            xmlRetorno = await this.axios.post(webServiceUrl, xmlFormated, {\n                headers: {\n                    'Content-Type': ContentType,\n                    'SOAPAction': action,\n                },\n                httpsAgent: agent\n            });\n            /**\n             * Verifica se houve rejeição no processamento do lote\n             */\n            responseInJson = this.utility.verificaRejeicao(xmlRetorno.data, this.metodo);\n\n            const retorno = await this.trataRetorno(xmlRetorno.data, data.indSinc, responseInJson);\n\n            const xmlFinal = this.salvaArquivos(xmlConsulta, responseInJson, xmlRetorno.data,\n                {\n                    xmlAutorizacao: retorno.data,\n                    xMotivo: retorno.message\n                })\n\n            return {\n                success: true,\n                xMotivo: xmlFinal.xMotivo,\n                xmls: xmlFinal.response,\n            }\n\n        } catch (error: any) {\n            // const logConfig = this.environment.config.lib?.log;\n\n            // if (logConfig) {\n            //     const { armazenarLogs } = logConfig;\n            //     if (armazenarLogs) {\n            //         logger.error({\n            //             message: error.message,\n            //             webServiceUrl: webServiceUrlTmp,\n            //             contentType: ContentType,\n            //             xmlSent: xmlConsultaSoap,\n            //             xmlResponse: error.response?.data || 'Sem resposta',\n            //         });\n            //     }\n            // }\n            throw new Error(error.message)\n        } finally {\n            // Salva XML de Consulta\n            this.utility.salvaConsulta(xmlConsulta, xmlConsultaSoap, this.metodo);\n\n            // Salva XML de Retorno\n            this.utility.salvaRetorno(xmlRetorno.data, responseInJson, this.metodo);\n        }\n    }\n}\n\nexport default NFEAutorizacaoService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder';\nimport BaseNFE from '@Modules/dfe/base/BaseNFe.js';\nimport { AxiosInstance } from 'axios';\nimport { GerarConsultaImpl, SaveFilesImpl, NFEconsultaProtocoloServiceImpl } from '@Interfaces';\n\nclass NFEconsultaProtocoloService extends BaseNFE implements NFEconsultaProtocoloServiceImpl{\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, 'NFEConsultaProtocolo', axios, saveFiles, gerarConsulta);\n    }\n\n    protected gerarXml(chave: string): string {\n        try {\n            const { nfe: { ambiente, versaoDF } } = this.environment.getConfig();\n\n            const xmlObject = {\n                $: {\n                    versao: versaoDF,\n                    xmlns: 'http://www.portalfiscal.inf.br/nfe'\n                },\n                tpAmb: ambiente,\n                xServ: 'CONSULTAR',\n                chNFe: chave,\n            }\n\n            return this.xmlBuilder.gerarXml(xmlObject, 'consSitNFe')\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n}\n\nexport default NFEconsultaProtocoloService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFEStatusServicoServiceImpl } from '@Interfaces';\n\nclass NFEStatusServico implements NFEStatusServicoServiceImpl{\n    nfeStatusServicoService: NFEStatusServicoServiceImpl;\n    constructor(nfeStatusServicoService: NFEStatusServicoServiceImpl) {\n        this.nfeStatusServicoService = nfeStatusServicoService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeStatusServicoService.Exec(data);\n    }\n\n}\n\nexport default NFEStatusServico;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFERecepcaoEventoServiceImpl } from '@Interfaces';\n\nclass NFERecepcaoEvento implements NFERecepcaoEventoServiceImpl {\n    nfeRecepcaoEventoService: NFERecepcaoEventoServiceImpl;\n    constructor(nfeRecepcaoEventoService: NFERecepcaoEventoServiceImpl) {\n        this.nfeRecepcaoEventoService = nfeRecepcaoEventoService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeRecepcaoEventoService.Exec(data);\n    }\n}\n\nexport default NFERecepcaoEvento;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { AxiosInstance } from 'axios';\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { EventoNFe, GenericObject, TipoEvento } from '@Types';\nimport BaseNFE from '@Modules/dfe/base/BaseNFe.js';\nimport { GerarConsultaImpl, NFERecepcaoEventoServiceImpl, SaveFilesImpl } from '@Interfaces';\nimport { logger } from '@Core/exceptions/logger';\n\nclass NFERecepcaoEventoService extends BaseNFE implements NFERecepcaoEventoServiceImpl {\n    tpEvento: string;\n    modelo?: string;\n    xmlEventosNacionais: string[];\n    xmlEventosRegionais: string[];\n    xMotivoPorEvento: any[];\n\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, 'RecepcaoEvento', axios, saveFiles, gerarConsulta);\n        this.tpEvento = '';\n        this.modelo = 'NFe';\n        this.xmlEventosNacionais = [];\n        this.xmlEventosRegionais = [];\n        this.xMotivoPorEvento = [];\n        console.log('constructor recepcao evento service');\n    }\n\n    /**\n     * Método para gerar o Id do evento\n     */\n    private getID(evento: TipoEvento) {\n\n        const { tpEvento, chNFe, nSeqEvento } = evento;\n\n        // Validação do tipo do evento (tpEvento)\n        if (typeof tpEvento !== 'string' || !/^\\d{6}$/.test(tpEvento)) {\n            throw new Error('tpEvento deve ser uma string com 6 dígitos.');\n        }\n\n        // Validação da chave da NF-e (chNFe)\n        if (typeof chNFe !== 'string' || !/^\\d{44}$/.test(chNFe)) {\n            throw new Error('chNFe deve ser uma string com 44 dígitos.');\n        }\n\n        // Validação do número sequencial do evento (nSeqEvento)\n        if (!Number.isInteger(nSeqEvento) || nSeqEvento < 1 || nSeqEvento > 99) {\n            throw new Error('nSeqEvento deve ser um número entre 1 e 99.');\n        }\n\n        // Preenchendo o número sequencial do evento com zeros à esquerda\n        const nSeqEventoPadded = nSeqEvento.toString().padStart(2, '0');\n\n        // Construção do ID\n        const id = `ID${tpEvento}${chNFe}${nSeqEventoPadded}`;\n\n        // Verificação do comprimento do ID\n        if (id.length !== 54) {\n            throw new Error('O ID construído não tem 54 caracteres.');\n        }\n\n        return id; // Retorna o ID validado\n    }\n\n    /**\n     * Verifica se o evento será disparado para o ambiente nacional ou para o estado pré-definido\n     */\n    private isAmbienteNacional(tpEvento: string) {\n        switch (tpEvento) {\n            case '210210':\n                return true;\n            case '210200':\n                return true;\n            case '210220':\n                return true;\n            case '210240':\n                return true;\n            case '110140':\n                return true;\n            case '110110':\n                return false;\n            default:\n                return false;\n        }\n    }\n\n    /**\n     * Retorna o nome do Evento\n     */\n    private getTipoEventoName(tpEvento: string) {\n        switch (tpEvento) {\n            case '210210':\n                return 'Ciência da Operação';\n            case '210200':\n                return 'Confirmação da Operaçã';\n            case '210220':\n                return 'Desconhecimento da Operação';\n            case '210240':\n                return 'Operação não Realizada';\n            case '110110':\n                return 'Carta de Correção';\n            case '110111':\n                return 'Cancelamento';\n            case '110140':\n                return 'EPEC';\n            default:\n                return 'Desconhecido';\n        }\n    }\n\n    private separaEventosPorAmbiente(evento: TipoEvento[]) {\n        const nacional = evento.filter(event => ['210210', '210200', '210220', '210240', '110140'].includes(event.tpEvento));\n        const regional = evento.filter(event => !['210210', '210200', '210220', '210240', '110140'].includes(event.tpEvento));\n\n        return { nacional, regional };\n    }\n\n    /**\n     * Criação do XML\n     */\n    private gerarXmlRecepcaoEvento(evento: TipoEvento[], idLote: number, ambienteNacional: boolean) {\n\n        const { nfe: { ambiente, versaoDF }, dfe: { UF } } = this.environment.getConfig();\n\n        for (let i = 0; i < evento.length; i++) {\n            const eventoProps = evento[i];\n\n            const {\n                tpAmb,\n                cOrgao,\n                tpEvento,\n                chNFe,\n                nSeqEvento,\n                CNPJ,\n                CPF,\n                detEvento,\n                dhEvento,\n                verEvento\n            } = eventoProps;\n\n            const idEvento = this.getID(eventoProps);\n            // const ambienteNacional = this.isAmbienteNacional(tpEvento);\n            const orgao = ambienteNacional ? 91 : cOrgao;\n\n            this.tpEvento = tpEvento;\n\n            //  XML parte 1\n            const eventoObject = {\n                $: {\n                    versao: \"1.00\",\n                    xmlns: 'http://www.portalfiscal.inf.br/nfe'\n                },\n                infEvento: {\n                    $: {\n                        Id: idEvento,\n                    },\n                    cOrgao: orgao,\n                    tpAmb: ambiente,\n                    ...(CNPJ ? { CNPJ } : { CPF }),\n                    chNFe: chNFe,\n                    dhEvento: dhEvento,\n                    tpEvento: tpEvento,\n                    nSeqEvento: nSeqEvento,\n                    verEvento: verEvento,\n                    detEvento: {\n                        $: {\n                            versao: \"1.00\",\n                        },\n                        ...detEvento,\n                    },\n                }\n            }\n\n            // Gera primeira parte do XML\n            const eventoXML = this.xmlBuilder.gerarXml(eventoObject, 'evento')\n            const xmlAssinado = this.xmlBuilder.assinarXML(eventoXML, 'infEvento');\n            if (ambienteNacional) {\n                this.xmlEventosNacionais.push(xmlAssinado);\n            } else {\n                this.xmlEventosRegionais.push(xmlAssinado);\n            }\n        }\n\n        // XML parte 2\n        const envEvento = {\n            $: {\n                versao: \"1.00\",\n                xmlns: 'http://www.portalfiscal.inf.br/nfe'\n            },\n            idLote,\n            _: '[XML]'\n        }\n\n        // Gera Segunda parte do XML\n        const xml = this.xmlBuilder.gerarXml(envEvento, 'envEvento')\n        if (ambienteNacional) {\n            return xml.replace('[XML]', this.xmlEventosNacionais.join(''));\n        }\n        return xml.replace('[XML]', this.xmlEventosRegionais.join(''));\n    }\n\n    private trataRetorno(responseInJson: GenericObject) {\n        const retornoEventos = this.utility.findInObj(responseInJson, 'retEvento')\n\n        if (retornoEventos instanceof Array) {\n            for (let i = 0; i < retornoEventos.length; i++) {\n                const chNFe = retornoEventos[i].infEvento.chNFe;\n                const xMotivo = retornoEventos[i].infEvento.xMotivo;\n                const cStat = retornoEventos[i].infEvento.cStat;\n                const tipoEvento = this.getTipoEventoName(retornoEventos[i].infEvento.tpEvento);\n                this.xMotivoPorEvento.push({\n                    chNFe,\n                    xMotivo,\n                    cStat,\n                    tipoEvento\n                })\n            }\n            return this.xMotivoPorEvento;\n        }\n        const chNFe = retornoEventos.infEvento.chNFe;\n        const xMotivo = retornoEventos.infEvento.xMotivo;\n        const cStat = retornoEventos.infEvento.cStat;\n        const tipoEvento = this.getTipoEventoName(retornoEventos.infEvento.tpEvento);\n        this.xMotivoPorEvento.push({\n            chNFe,\n            xMotivo,\n            cStat,\n            tipoEvento\n        })\n\n        return this.xMotivoPorEvento;\n    }\n\n    protected async enviaEvento(evento: TipoEvento[], idLote: number, tipoAmbiente: number) {\n        let xmlConsulta: string = '';\n        let xmlConsultaSoap: string = '';\n        let webServiceUrlTmp: string = '';\n        const ContentType = this.setContentType();\n        const ambienteNacional = tipoAmbiente === 0 ? true : false;\n        try {\n            // Gerando XML para consulta de Status do Serviço\n            xmlConsulta = this.gerarXmlRecepcaoEvento(evento, idLote, ambienteNacional);\n\n            const { xmlFormated, agent, webServiceUrl, action } = await this.gerarConsulta.gerarConsulta(xmlConsulta, this.metodo, ambienteNacional || this.isAmbienteNacional(this.tpEvento), '', this.modelo);\n\n            xmlConsultaSoap = xmlFormated;\n            webServiceUrlTmp = webServiceUrl;\n            // Efetua requisição para o webservice NFEStatusServico\n            const xmlRetorno = await this.axios.post(webServiceUrl, xmlFormated, {\n                headers: {\n                    'Content-Type': ContentType,\n                    'SOAPAction': action,\n                },\n                httpsAgent: agent\n            });\n\n            return xmlRetorno.data\n        } catch (error: any) {\n            // const logConfig = this.environment.config.lib?.log;\n\n            // if (logConfig) {\n            //     const { armazenarLogs } = logConfig;\n            //     if (armazenarLogs) {\n            //         logger.error({\n            //             message: error.message,\n            //             webServiceUrl: webServiceUrlTmp,\n            //             contentType: ContentType,\n            //             xmlSent: xmlConsultaSoap,\n            //             xmlResponse: error.response?.data || 'Sem resposta',\n            //         });\n            //     }\n            // }\n            throw new Error(error.message)\n        } finally {\n            // Salva XML de Consulta\n            const fileName = ambienteNacional ? 'RecepcaoEvento[Nacional]-consulta' : 'RecepcaoEvento[Regional]-consulta'\n            this.utility.salvaConsulta(xmlConsulta, xmlConsultaSoap, this.metodo, fileName);\n        }\n    }\n\n    async Exec(data: EventoNFe) {\n        try {\n            const { evento, idLote, modelo } = data;\n            const { nacional, regional } = this.separaEventosPorAmbiente(evento);\n\n            if (modelo === '65') this.modelo = 'NFCe';\n\n            // Enviar eventos ambiente nacional e regional separadamente\n            let responseNacionalInJson, responseRegionalInJson = null\n            let finalResponseInJson = []\n\n            if (nacional.length > 0) {\n                const retornoNacional = await this.enviaEvento(nacional, idLote, 0);\n\n                responseNacionalInJson = this.utility.verificaRejeicao(retornoNacional, this.metodo);\n\n                this.utility.salvaRetorno(retornoNacional, responseNacionalInJson, this.metodo, 'RecepcaoEvento[Nacional]-retorno');\n\n                this.trataRetorno(responseNacionalInJson);\n                finalResponseInJson.push(responseNacionalInJson)\n            }\n\n            if (regional.length > 0) {\n                const retornoRegional = await this.enviaEvento(regional, idLote, 1);\n\n                responseRegionalInJson = this.utility.verificaRejeicao(retornoRegional, this.metodo);\n\n                this.utility.salvaRetorno(retornoRegional, responseRegionalInJson, this.metodo, 'RecepcaoEvento[Regional]-retorno');\n\n                this.trataRetorno(responseRegionalInJson);\n                finalResponseInJson.push(responseRegionalInJson)\n            }\n\n            return {\n                success: true,\n                xMotivos: this.xMotivoPorEvento,\n                response: finalResponseInJson,\n            };\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n}\n\nexport default NFERecepcaoEventoService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { AxiosInstance } from 'axios';\nimport NFERecepcaoEventoService from './NFERecepcaoEventoService';\nimport { GerarConsultaImpl,SaveFilesImpl } from '@Interfaces';\n\nclass NFECancelamentoService extends NFERecepcaoEventoService {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, axios, saveFiles, gerarConsulta);\n    }\n}\n\nexport default NFECancelamentoService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { AxiosInstance } from 'axios';\nimport NFERecepcaoEventoService from './NFERecepcaoEventoService.js';\nimport { GerarConsultaImpl, SaveFilesImpl } from '@Interfaces';\n\nclass NFECartaDeCorrecaoService extends NFERecepcaoEventoService {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, axios, saveFiles, gerarConsulta);\n    }\n\n}\n\nexport default NFECartaDeCorrecaoService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { AxiosInstance } from 'axios';\nimport NFERecepcaoEventoService from './NFERecepcaoEventoService';\nimport { GerarConsultaImpl, SaveFilesImpl } from '@Interfaces';\n\nclass NFECienciaDaOperacaoService extends NFERecepcaoEventoService {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, axios, saveFiles, gerarConsulta);\n    }\n}\n\nexport default NFECienciaDaOperacaoService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { AxiosInstance } from 'axios';\nimport NFERecepcaoEventoService from './NFERecepcaoEventoService';\nimport { SaveFilesImpl, GerarConsultaImpl } from '@Interfaces';\n\nclass NFEDesconhecimentoDaOperacaoService extends NFERecepcaoEventoService {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, axios, saveFiles, gerarConsulta);\n    }\n}\n\nexport default NFEDesconhecimentoDaOperacaoService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { AxiosInstance } from 'axios';\nimport { GerarConsultaImpl, SaveFilesImpl } from '@Interfaces';\nimport NFERecepcaoEventoService from './NFERecepcaoEventoService';\n\nclass NFEEpecService extends NFERecepcaoEventoService {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, axios, saveFiles, gerarConsulta);\n    }\n}\n\nexport default NFEEpecService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { AxiosInstance } from 'axios';\nimport NFERecepcaoEventoService from './NFERecepcaoEventoService';\nimport { SaveFilesImpl, GerarConsultaImpl } from '@Interfaces';\n\nclass NFEOperacaoNaoRealizadaService extends NFERecepcaoEventoService {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, axios, saveFiles, gerarConsulta);\n    }\n}\n\nexport default NFEOperacaoNaoRealizadaService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFEAutorizacaoServiceImpl } from '@Interfaces/NFEAutorizacaoServiceImpl.js';\n\nclass NFEAutorizacao {\n    nfeAutorizacaoService: NFEAutorizacaoServiceImpl;\n    constructor(nfeAutorizacaoService: NFEAutorizacaoServiceImpl) {\n        this.nfeAutorizacaoService = nfeAutorizacaoService;\n    }\n\n    async Exec(data?: any): Promise<any> {\n        return await this.nfeAutorizacaoService.Exec(data);\n    }\n\n}\n\nexport default NFEAutorizacao;","\n/*! pako 2.1.0 https://github.com/nodeca/pako @license (MIT AND Zlib) */\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$1               = 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$1             = 2;\n\n/*============================================================================*/\n\n\nfunction zero$1(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$1    = 3;\nconst MAX_MATCH$1    = 258;\n/* The minimum and maximum match lengths */\n\n// From deflate.h\n/* ===========================================================================\n * Internal compression state.\n */\n\nconst LENGTH_CODES$1  = 29;\n/* number of length codes, not counting the special END_BLOCK code */\n\nconst LITERALS$1      = 256;\n/* number of literal bytes 0..255 */\n\nconst L_CODES$1       = LITERALS$1 + 1 + LENGTH_CODES$1;\n/* number of Literal or Length codes, including the END_BLOCK code */\n\nconst D_CODES$1       = 30;\n/* number of distance codes */\n\nconst BL_CODES$1      = 19;\n/* number of codes used to transfer the bit lengths */\n\nconst HEAP_SIZE$1     = 2 * L_CODES$1 + 1;\n/* maximum heap size */\n\nconst MAX_BITS$1      = 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$1 + 2) * 2);\nzero$1(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$1 * 2);\nzero$1(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$1(_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$1 - MIN_MATCH$1 + 1);\nzero$1(_length_code);\n/* length code for each normalized match length (0 == MIN_MATCH) */\n\nconst base_length   = new Array(LENGTH_CODES$1);\nzero$1(base_length);\n/* First normalized length for each code (0 = MIN_MATCH) */\n\nconst base_dist     = new Array(D_CODES$1);\nzero$1(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$1; 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$1; 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 + 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$1; 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<<MAX_BITS)-1,\n  //        \"inconsistent bit counts\");\n  //Tracev((stderr,\"\\ngen_codes: max_code %d \", max_code));\n\n  for (n = 0;  n <= max_code; n++) {\n    let len = tree[n * 2 + 1]/*.Len*/;\n    if (len === 0) { continue; }\n    /* Now reverse the bits */\n    tree[n * 2]/*.Code*/ = bi_reverse(next_code[len]++, len);\n\n    //Tracecv(tree != static_ltree, (stderr,\"\\nn %3d %c l %2d c %4x (%x) \",\n    //     n, (isgraph(n) ? n : ' '), len, tree[n].Code, next_code[len]-1));\n  }\n};\n\n\n/* ===========================================================================\n * Initialize the various 'constant' tables.\n */\nconst tr_static_init = () => {\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 + 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 - 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$1; 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$1; 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 + 1, bl_count);\n\n  /* The static distance tree is trivial: */\n  for (n = 0; n < D_CODES$1; 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 + 1, L_CODES$1, MAX_BITS$1);\n  static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0,          D_CODES$1, MAX_BITS$1);\n  static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0,         BL_CODES$1, 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$1;  n++) { s.dyn_ltree[n * 2]/*.Freq*/ = 0; }\n  for (n = 0; n < D_CODES$1;  n++) { s.dyn_dtree[n * 2]/*.Freq*/ = 0; }\n  for (n = 0; n < BL_CODES$1; 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 + 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$1;\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 - 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$1; 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$1 = (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$1 = (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$1 = (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$1 = (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$1) {\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$1(s, buf, stored_len, last);\n\n  } else if (s.strategy === Z_FIXED$1 || 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$1 = (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 + 1) * 2]/*.Freq*/++;\n    s.dyn_dtree[d_code(dist) * 2]/*.Freq*/++;\n  }\n\n  return (s.sym_next === s.sym_end);\n};\n\nvar _tr_init_1  = _tr_init$1;\nvar _tr_stored_block_1 = _tr_stored_block$1;\nvar _tr_flush_block_1  = _tr_flush_block$1;\nvar _tr_tally_1 = _tr_tally$1;\nvar _tr_align_1 = _tr_align$1;\n\nvar trees = {\n\t_tr_init: _tr_init_1,\n\t_tr_stored_block: _tr_stored_block_1,\n\t_tr_flush_block: _tr_flush_block_1,\n\t_tr_tally: _tr_tally_1,\n\t_tr_align: _tr_align_1\n};\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\nvar adler32_1 = adler32;\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\nvar crc32_1 = crc32;\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\nvar messages = {\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\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\nvar constants$2 = {\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\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 } = trees;\n\n\n\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n  Z_NO_FLUSH: Z_NO_FLUSH$2, Z_PARTIAL_FLUSH, Z_FULL_FLUSH: Z_FULL_FLUSH$1, Z_FINISH: Z_FINISH$3, Z_BLOCK: Z_BLOCK$1,\n  Z_OK: Z_OK$3, Z_STREAM_END: Z_STREAM_END$3, Z_STREAM_ERROR: Z_STREAM_ERROR$2, Z_DATA_ERROR: Z_DATA_ERROR$2, Z_BUF_ERROR: Z_BUF_ERROR$1,\n  Z_DEFAULT_COMPRESSION: Z_DEFAULT_COMPRESSION$1,\n  Z_FILTERED, Z_HUFFMAN_ONLY, Z_RLE, Z_FIXED, Z_DEFAULT_STRATEGY: Z_DEFAULT_STRATEGY$1,\n  Z_UNKNOWN,\n  Z_DEFLATED: Z_DEFLATED$2\n} = constants$2;\n\n/*============================================================================*/\n\n\nconst MAX_MEM_LEVEL = 9;\n/* Maximum value for memLevel in deflateInit2 */\nconst MAX_WBITS$1 = 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 = messages[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_1(strm.adler, buf, len, start);\n  }\n\n  else if (strm.state.wrap === 2) {\n    strm.adler = crc32_1(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$3) ||\n                        flush === Z_NO_FLUSH$2 ||\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$3 && 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$2 && flush !== Z_FINISH$3 &&\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$3) && flush !== Z_NO_FLUSH$2 &&\n     s.strm.avail_in === 0 && left <= have)) {\n    len = left > have ? have : left;\n    last = flush === Z_FINISH$3 && 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$2) {\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$3) {\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$2) {\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$3) {\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$2) {\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$3) {\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$2) {\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$3) {\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$2; /* 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$2);\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$3;\n};\n\n\nconst deflateReset = (strm) => {\n\n  const ret = deflateResetKeep(strm);\n  if (ret === Z_OK$3) {\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$2;\n  }\n  strm.state.gzhead = head;\n  return Z_OK$3;\n};\n\n\nconst deflateInit2 = (strm, level, method, windowBits, memLevel, strategy) => {\n\n  if (!strm) { // === Z_NULL\n    return Z_STREAM_ERROR$2;\n  }\n  let wrap = 1;\n\n  if (level === Z_DEFAULT_COMPRESSION$1) {\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$2 ||\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$2);\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$2, MAX_WBITS$1, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY$1);\n};\n\n\n/* ========================================================================= */\nconst deflate$2 = (strm, flush) => {\n\n  if (deflateStateCheck(strm) || flush > Z_BLOCK$1 || flush < 0) {\n    return strm ? err(strm, Z_STREAM_ERROR$2) : Z_STREAM_ERROR$2;\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$3)) {\n    return err(strm, (strm.avail_out === 0) ? Z_BUF_ERROR$1 : Z_STREAM_ERROR$2);\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$3;\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$3) {\n    return err(strm, Z_BUF_ERROR$1);\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$1);\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$2 + ((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$3;\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$3;\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_1(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_1(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$3;\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_1(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_1(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$3;\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_1(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_1(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$3;\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_1(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$3;\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$3;\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$2 && 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$3;\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$1) { /* 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$1) {\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$3;\n      }\n    }\n  }\n\n  if (flush !== Z_FINISH$3) { return Z_OK$3; }\n  if (s.wrap <= 0) { return Z_STREAM_END$3; }\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$3 : Z_STREAM_END$3;\n};\n\n\nconst deflateEnd = (strm) => {\n\n  if (deflateStateCheck(strm)) {\n    return Z_STREAM_ERROR$2;\n  }\n\n  const status = strm.state.status;\n\n  strm.state = null;\n\n  return status === BUSY_STATE ? err(strm, Z_DATA_ERROR$2) : Z_OK$3;\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$2;\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$2;\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_1(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$3;\n};\n\n\nvar deflateInit_1 = deflateInit;\nvar deflateInit2_1 = deflateInit2;\nvar deflateReset_1 = deflateReset;\nvar deflateResetKeep_1 = deflateResetKeep;\nvar deflateSetHeader_1 = deflateSetHeader;\nvar deflate_2$1 = deflate$2;\nvar deflateEnd_1 = deflateEnd;\nvar deflateSetDictionary_1 = deflateSetDictionary;\nvar 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\nvar deflate_1$2 = {\n\tdeflateInit: deflateInit_1,\n\tdeflateInit2: deflateInit2_1,\n\tdeflateReset: deflateReset_1,\n\tdeflateResetKeep: deflateResetKeep_1,\n\tdeflateSetHeader: deflateSetHeader_1,\n\tdeflate: deflate_2$1,\n\tdeflateEnd: deflateEnd_1,\n\tdeflateSetDictionary: deflateSetDictionary_1,\n\tdeflateInfo: deflateInfo\n};\n\nconst _has = (obj, key) => {\n  return Object.prototype.hasOwnProperty.call(obj, key);\n};\n\nvar 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.\nvar 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\nvar common = {\n\tassign: assign,\n\tflattenChunks: flattenChunks\n};\n\n// String encode/decode helpers\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)\nvar 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\nvar 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);\nvar 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\nvar strings = {\n\tstring2buf: string2buf,\n\tbuf2string: buf2string,\n\tutf8border: utf8border\n};\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\nvar zstream = ZStream;\n\nconst toString$1 = Object.prototype.toString;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n  Z_NO_FLUSH: Z_NO_FLUSH$1, Z_SYNC_FLUSH, Z_FULL_FLUSH, Z_FINISH: Z_FINISH$2,\n  Z_OK: Z_OK$2, Z_STREAM_END: Z_STREAM_END$2,\n  Z_DEFAULT_COMPRESSION,\n  Z_DEFAULT_STRATEGY,\n  Z_DEFLATED: Z_DEFLATED$1\n} = constants$2;\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$1(options) {\n  this.options = common.assign({\n    level: Z_DEFAULT_COMPRESSION,\n    method: Z_DEFLATED$1,\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 = deflate_1$2.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$2) {\n    throw new Error(messages[status]);\n  }\n\n  if (opt.header) {\n    deflate_1$2.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$1.call(opt.dictionary) === '[object ArrayBuffer]') {\n      dict = new Uint8Array(opt.dictionary);\n    } else {\n      dict = opt.dictionary;\n    }\n\n    status = deflate_1$2.deflateSetDictionary(this.strm, dict);\n\n    if (status !== Z_OK$2) {\n      throw new Error(messages[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$1.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$2 : Z_NO_FLUSH$1;\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$1.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 = deflate_1$2.deflate(strm, _flush_mode);\n\n    // Ended => flush and finish\n    if (status === Z_STREAM_END$2) {\n      if (strm.next_out > 0) {\n        this.onData(strm.output.subarray(0, strm.next_out));\n      }\n      status = deflate_1$2.deflateEnd(this.strm);\n      this.onEnd(status);\n      this.ended = true;\n      return status === Z_OK$2;\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$1.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$1.prototype.onEnd = function (status) {\n  // On success - join\n  if (status === Z_OK$2) {\n    this.result = common.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$1(input, options) {\n  const deflator = new Deflate$1(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 || messages[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$1(input, options) {\n  options = options || {};\n  options.raw = true;\n  return deflate$1(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$1(input, options) {\n  options = options || {};\n  options.gzip = true;\n  return deflate$1(input, options);\n}\n\n\nvar Deflate_1$1 = Deflate$1;\nvar deflate_2 = deflate$1;\nvar deflateRaw_1$1 = deflateRaw$1;\nvar gzip_1$1 = gzip$1;\nvar constants$1 = constants$2;\n\nvar deflate_1$1 = {\n\tDeflate: Deflate_1$1,\n\tdeflate: deflate_2,\n\tdeflateRaw: deflateRaw_1$1,\n\tgzip: gzip_1$1,\n\tconstants: constants$1\n};\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$1 = 16209;       /* got a data error -- remain here until reset */\nconst TYPE$1 = 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 */\nvar inffast = 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$1;\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$1;\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$1;\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$1;\n        break top;\n      }\n      else {\n        strm.msg = 'invalid literal/length code';\n        state.mode = BAD$1;\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\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$1 = 852;\nconst ENOUGH_DISTS$1 = 592;\n//const ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nconst CODES$1 = 0;\nconst LENS$1 = 1;\nconst DISTS$1 = 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$1 || 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$1) {\n    base = extra = work;    /* dummy value--not used */\n    match = 20;\n\n  } else if (type === LENS$1) {\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$1 && used > ENOUGH_LENS$1) ||\n    (type === DISTS$1 && used > ENOUGH_DISTS$1)) {\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$1 && used > ENOUGH_LENS$1) ||\n        (type === DISTS$1 && used > ENOUGH_DISTS$1)) {\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\nvar inftrees = inflate_table;\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\n\n\n\n\nconst CODES = 0;\nconst LENS = 1;\nconst DISTS = 2;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n  Z_FINISH: Z_FINISH$1, Z_BLOCK, Z_TREES,\n  Z_OK: Z_OK$1, Z_STREAM_END: Z_STREAM_END$1, Z_NEED_DICT: Z_NEED_DICT$1, Z_STREAM_ERROR: Z_STREAM_ERROR$1, Z_DATA_ERROR: Z_DATA_ERROR$1, Z_MEM_ERROR: Z_MEM_ERROR$1, Z_BUF_ERROR,\n  Z_DEFLATED\n} = constants$2;\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$1; }\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$1;\n};\n\n\nconst inflateReset = (strm) => {\n\n  if (inflateStateCheck(strm)) { return Z_STREAM_ERROR$1; }\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$1; }\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$1;\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$1; }\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$1) {\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    inftrees(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    inftrees(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$2 = (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$1;\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$1;\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_1(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_1(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_1(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_1(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_1(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_1(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_1(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_1(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$1;\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 = inftrees(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 = inftrees(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 = inftrees(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          inffast(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_1(state.check, output, _out, put - _out) : adler32_1(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$1;\n        break inf_leave;\n      case BAD:\n        ret = Z_DATA_ERROR$1;\n        break inf_leave;\n      case MEM:\n        return Z_MEM_ERROR$1;\n      case SYNC:\n        /* falls through */\n      default:\n        return Z_STREAM_ERROR$1;\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$1))) {\n    if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) ;\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_1(state.check, output, _out, strm.next_out - _out) : adler32_1(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$1) && ret === Z_OK$1) {\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$1;\n  }\n\n  let state = strm.state;\n  if (state.window) {\n    state.window = null;\n  }\n  strm.state = null;\n  return Z_OK$1;\n};\n\n\nconst inflateGetHeader = (strm, head) => {\n\n  /* check state */\n  if (inflateStateCheck(strm)) { return Z_STREAM_ERROR$1; }\n  const state = strm.state;\n  if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR$1; }\n\n  /* save header structure */\n  state.head = head;\n  head.done = false;\n  return Z_OK$1;\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$1; }\n  state = strm.state;\n\n  if (state.wrap !== 0 && state.mode !== DICT) {\n    return Z_STREAM_ERROR$1;\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_1(dictid, dictionary, dictLength, 0);\n    if (dictid !== state.check) {\n      return Z_DATA_ERROR$1;\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$1;\n  }\n  state.havedict = 1;\n  // Tracev((stderr, \"inflate:   dictionary set\\n\"));\n  return Z_OK$1;\n};\n\n\nvar inflateReset_1 = inflateReset;\nvar inflateReset2_1 = inflateReset2;\nvar inflateResetKeep_1 = inflateResetKeep;\nvar inflateInit_1 = inflateInit;\nvar inflateInit2_1 = inflateInit2;\nvar inflate_2$1 = inflate$2;\nvar inflateEnd_1 = inflateEnd;\nvar inflateGetHeader_1 = inflateGetHeader;\nvar inflateSetDictionary_1 = inflateSetDictionary;\nvar 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\nvar inflate_1$2 = {\n\tinflateReset: inflateReset_1,\n\tinflateReset2: inflateReset2_1,\n\tinflateResetKeep: inflateResetKeep_1,\n\tinflateInit: inflateInit_1,\n\tinflateInit2: inflateInit2_1,\n\tinflate: inflate_2$1,\n\tinflateEnd: inflateEnd_1,\n\tinflateGetHeader: inflateGetHeader_1,\n\tinflateSetDictionary: inflateSetDictionary_1,\n\tinflateInfo: inflateInfo\n};\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\nvar gzheader = 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} = constants$2;\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$1(options) {\n  this.options = common.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  = inflate_1$2.inflateInit2(\n    this.strm,\n    opt.windowBits\n  );\n\n  if (status !== Z_OK) {\n    throw new Error(messages[status]);\n  }\n\n  this.header = new gzheader();\n\n  inflate_1$2.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 = inflate_1$2.inflateSetDictionary(this.strm, opt.dictionary);\n      if (status !== Z_OK) {\n        throw new Error(messages[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$1.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 = inflate_1$2.inflate(strm, _flush_mode);\n\n    if (status === Z_NEED_DICT && dictionary) {\n      status = inflate_1$2.inflateSetDictionary(strm, dictionary);\n\n      if (status === Z_OK) {\n        status = inflate_1$2.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      inflate_1$2.inflateReset(strm);\n      status = inflate_1$2.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 = inflate_1$2.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$1.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$1.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 = common.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$1(input, options) {\n  const inflator = new Inflate$1(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 || messages[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$1(input, options) {\n  options = options || {};\n  options.raw = true;\n  return inflate$1(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\nvar Inflate_1$1 = Inflate$1;\nvar inflate_2 = inflate$1;\nvar inflateRaw_1$1 = inflateRaw$1;\nvar ungzip$1 = inflate$1;\nvar constants = constants$2;\n\nvar inflate_1$1 = {\n\tInflate: Inflate_1$1,\n\tinflate: inflate_2,\n\tinflateRaw: inflateRaw_1$1,\n\tungzip: ungzip$1,\n\tconstants: constants\n};\n\nconst { Deflate, deflate, deflateRaw, gzip } = deflate_1$1;\n\nconst { Inflate, inflate, inflateRaw, ungzip } = inflate_1$1;\n\n\n\nvar Deflate_1 = Deflate;\nvar deflate_1 = deflate;\nvar deflateRaw_1 = deflateRaw;\nvar gzip_1 = gzip;\nvar Inflate_1 = Inflate;\nvar inflate_1 = inflate;\nvar inflateRaw_1 = inflateRaw;\nvar ungzip_1 = ungzip;\nvar constants_1 = constants$2;\n\nvar pako = {\n\tDeflate: Deflate_1,\n\tdeflate: deflate_1,\n\tdeflateRaw: deflateRaw_1,\n\tgzip: gzip_1,\n\tInflate: Inflate_1,\n\tinflate: inflate_1,\n\tinflateRaw: inflateRaw_1,\n\tungzip: ungzip_1,\n\tconstants: constants_1\n};\n\nexport { Deflate_1 as Deflate, Inflate_1 as Inflate, constants_1 as constants, pako as default, deflate_1 as deflate, deflateRaw_1 as deflateRaw, gzip_1 as gzip, inflate_1 as inflate, inflateRaw_1 as inflateRaw, ungzip_1 as ungzip };\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport pako from 'pako';\nimport xml2js from 'xml2js';\nimport XmlParser from '@Utils/XmlParser.js';\nimport Utility from '@Utils/Utility.js';\nimport { GenericObject } from '@Types';\nimport Environment from '@Modules/environment/Environment.js';\nimport { AxiosResponse } from 'axios';\n\nclass DistribuicaoHandler {\n    environment: Environment;\n    utility: Utility;\n    metodo: string;\n    constructor(environment: Environment, utility: Utility, metodo: string) {\n        this.utility = utility;\n        this.environment = environment;\n        this.metodo = metodo;\n    }\n\n    /**\n     * Métodos para tratativas do DistribuicaoDFe\n     */\n\n    protected salvaArquivos(XMLDistribuicaoInJson: GenericObject, XMLDistribuicao: string, chNFe: string): void {\n        const { pathXMLDistribuicao, baixarXMLDistribuicao, armazenarRetornoEmJSON } = this.environment.config.dfe\n\n        if (baixarXMLDistribuicao) {\n            this.utility.salvaXML({\n                data: XMLDistribuicao,\n                fileName: chNFe,\n                metodo: this.metodo,\n                path: pathXMLDistribuicao,\n            });\n\n            if (armazenarRetornoEmJSON) {\n                this.utility.salvaJSON({\n                    data: XMLDistribuicaoInJson,\n                    fileName: chNFe,\n                    metodo: this.metodo,\n                    path: pathXMLDistribuicao,\n                });\n            }\n        }\n    }\n\n    deCompressDFeXML(loteDistDFeInt: AxiosResponse<any, any>, metodo: string, xmlConsulta: string) {\n        try {\n            const json = new XmlParser()\n            const files: string[] = [];\n            xml2js.parseString(loteDistDFeInt, (err, result) => {\n                if (err) {\n                    throw new Error(`Erro ao descomprimir o XML: ${err}`);\n                }\n\n                const docZips = this.utility.findInObj(result, 'docZip');\n                docZips.forEach((docZip: any) => {\n                    const xmlString = this.decodeDocZip(docZip);\n                    const cleanedXml = this.removeSignatureTag(xmlString);\n\n                    const parsedResult = this.parseXml(cleanedXml);\n                    if (!parsedResult) return;\n\n                    let chNFe = this.getChNFe(parsedResult);\n                    let tipo = this.getTipo(parsedResult);\n                    const nsu = docZip['$'].NSU;\n\n                    if (parsedResult['procEventoNFe']) {\n                        const tpEvento = this.utility.findInObj(parsedResult, 'tpEvento');\n                        chNFe = `${chNFe}-event-${tpEvento}`;\n                        tipo = 'event';\n                    }\n\n                    const xmlDistribuicaoInJson = json.convertXmlToJson(cleanedXml, `${metodo}_${tipo}`, nsu);\n                    this.handleResponse(xmlDistribuicaoInJson, cleanedXml, chNFe);\n                    files.push(chNFe);\n                });\n            });\n            return files;\n        } catch (error: any) {\n            throw new Error(error.message);\n        }\n    }\n\n    decodeDocZip(docZip: any) {\n        const base64String = docZip['_'];\n        let binaryString = atob(base64String);\n        let bytes = new Uint8Array(binaryString.length);\n        for (let i = 0; i < binaryString.length; i++) {\n            bytes[i] = binaryString.charCodeAt(i);\n        }\n        let decompressedData = pako.inflate(bytes);\n        return new TextDecoder(\"utf-8\").decode(decompressedData);\n    }\n\n    removeSignatureTag(xmlString: string) {\n        return xmlString.replace(/<Signature.*?<\\/Signature>/gs, '');\n    }\n\n    parseXml(xmlString: string) {\n        let parsedResult;\n        xml2js.parseString(xmlString, (err, result) => {\n            if (err) {\n                console.error('Erro ao parsear o XML decomprimido:', err);\n                parsedResult = null;\n            } else {\n                parsedResult = result;\n            }\n        });\n        return parsedResult;\n    }\n\n    getChNFe(parsedResult: GenericObject) {\n        return this.utility.findInObj(parsedResult, 'chNFe');\n    }\n\n    getTipo(parsedResult: GenericObject) {\n        if (this.utility.findInObj(parsedResult, 'resNFe')) {\n            return 'res';\n        } else if (parsedResult['procEventoNFe']) {\n            return 'event';\n        }\n        return 'proc';\n    }\n\n    handleResponse(XMLDistribuicaoInJson: GenericObject, XMLDistribuicao: string, chNFe: string) {\n        \n        this.salvaArquivos(XMLDistribuicaoInJson, XMLDistribuicao, chNFe)\n        \n        // Gera erro em caso de Rejeição\n        const xMotivo = this.utility.findInObj(XMLDistribuicaoInJson, 'xMotivo')\n        if (xMotivo && (xMotivo.includes('Rejeição') || xMotivo.includes('Rejeicao'))) {\n            throw new Error(XMLDistribuicaoInJson.xMotivo)\n        }\n    }\n\n}\n\nexport default DistribuicaoHandler;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { AxiosInstance, AxiosResponse } from 'axios';\nimport DistribuicaoHandler from './util/DistribuicaoHandler.js';\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { ConsultaNFe, GenericObject } from '@Types';\nimport BaseNFE from '@Modules/dfe/base/BaseNFe.js';\nimport { GerarConsultaImpl, SaveFilesImpl } from '@Interfaces';\nimport { logger } from '@Core/exceptions/logger.js';\n\nclass NFEDistribuicaoDFeService extends BaseNFE {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, 'NFeDistribuicaoDFe', axios, saveFiles, gerarConsulta);\n    }\n\n    protected gerarXml(data: ConsultaNFe): string {\n        return this.gerarXmlNFeDistribuicaoDFe(data);\n    }\n\n\n    gerarXmlNFeDistribuicaoDFe(data: ConsultaNFe) {\n        const { nfe: { ambiente } } = this.environment.getConfig();\n\n        //  XML\n        const xmlObject = {\n            $: {\n                versao: \"1.01\",\n                xmlns: 'http://www.portalfiscal.inf.br/nfe'\n            },\n            tpAmb: ambiente,\n            ...data,\n        }\n\n        return this.xmlBuilder.gerarXml(xmlObject, 'distDFeInt')\n    }\n\n\n    async Exec(data: ConsultaNFe) {\n        let xmlConsulta: string = '';\n        let xmlConsultaSoap: string = '';\n        let webServiceUrlTmp: string = '';\n        let responseInJson: GenericObject | undefined = undefined;\n        let xmlRetorno: AxiosResponse<any, any> = {} as AxiosResponse<any, any>;\n        const ContentType = this.setContentType();\n        try {\n            // Gerando XML para consulta de Status do Serviço\n            xmlConsulta = this.gerarXmlNFeDistribuicaoDFe(data);\n\n\n            const { xmlFormated, agent, webServiceUrl, action } = await this.gerarConsulta.gerarConsulta(xmlConsulta, this.metodo, true, '1.01', 'NFe', true, 'nfeDistDFeInteresse');\n\n            xmlConsultaSoap = xmlFormated;\n            webServiceUrlTmp = webServiceUrl;\n\n            // Efetua requisição para o webservice NFEStatusServico\n            xmlRetorno = await this.axios.post(webServiceUrl, xmlFormated, {\n                headers: {\n                    'Content-Type': ContentType,\n                    'SOAPAction': action,\n                },\n                httpsAgent: agent\n            });\n\n            // Verifica se houve rejeição\n            responseInJson = this.utility.verificaRejeicao(xmlRetorno.data, this.metodo);\n\n            /**\n             * Descompacta XML\n             * Converte XML para Json\n             * Salva XML\n             * Gera erro em caso de rejeição\n             */\n            const handlerDistribuicao = new DistribuicaoHandler(this.environment, this.utility, this.metodo);\n            const filesList = handlerDistribuicao.deCompressDFeXML(xmlRetorno.data, this.metodo, xmlConsulta);\n            const xMotivo = this.utility.findInObj(responseInJson, 'xMotivo');\n\n            return {\n                data: responseInJson,\n                xMotivo,\n                filesList,\n            }\n        } catch (error: any) {\n            // const logConfig = this.environment.config.lib?.log;\n\n            // if (logConfig) {\n            //     const { armazenarLogs } = logConfig;\n            //     if (armazenarLogs) {\n            //         logger.error({\n            //             message: error.message,\n            //             webServiceUrl: webServiceUrlTmp,\n            //             contentType: ContentType,\n            //             xmlSent: xmlConsultaSoap,\n            //             xmlResponse: error.response?.data || 'Sem resposta',\n            //         });\n            //     }\n            // }\n            throw new Error(error.message)\n        } finally {\n            // Salva XML de Consulta\n            this.utility.salvaConsulta(xmlConsulta, xmlConsultaSoap, this.metodo);\n\n            // Salva XML de Retorno\n            this.utility.salvaRetorno(xmlRetorno.data, responseInJson, this.metodo);\n        }\n    }\n\n}\n\nexport default NFEDistribuicaoDFeService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { AxiosInstance } from 'axios';\n\nimport { GerarConsultaImpl, SaveFilesImpl } from '@Interfaces';\nimport NFEDistribuicaoDFeService from './NFEDistribuicaoDFeService.js';\n\nclass NFEDistribuicaoDFePorUltNSUService extends NFEDistribuicaoDFeService {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, axios, saveFiles, gerarConsulta);\n    }\n}\n\nexport default NFEDistribuicaoDFePorUltNSUService;\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { AxiosInstance } from 'axios';\n\nimport { GerarConsultaImpl, SaveFilesImpl } from '@Interfaces';\nimport NFEDistribuicaoDFeService from './NFEDistribuicaoDFeService.js';\n\nclass NFEDistribuicaoDFePorNSUService extends NFEDistribuicaoDFeService {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, axios, saveFiles, gerarConsulta);\n    }\n}\n\nexport default NFEDistribuicaoDFePorNSUService;\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { AxiosInstance } from 'axios';\nimport { GerarConsultaImpl, SaveFilesImpl } from '@Interfaces';\nimport NFEDistribuicaoDFeService from './NFEDistribuicaoDFeService.js';\n\nclass NFEDistribuicaoDFePorChaveService extends NFEDistribuicaoDFeService {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, axios, saveFiles, gerarConsulta);\n    }\n}\n\nexport default NFEDistribuicaoDFePorChaveService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport { InutilizacaoData } from '@Types';\nimport BaseNFE from '@Modules/dfe/base/BaseNFe.js';\nimport { AxiosInstance } from 'axios';\nimport { GerarConsultaImpl, NFEInutilizacaoServiceImpl, SaveFilesImpl } from '@Interfaces';\n\nclass NFEInutilizacaoService extends BaseNFE implements NFEInutilizacaoServiceImpl {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, 'NFEInutilizacao', axios, saveFiles, gerarConsulta);\n    }\n\n    protected gerarXml(chave: InutilizacaoData): string {\n        return this.gerarXmlNFeInutilizacao(chave);\n    }\n\n    /**\n     * Método para criação do ID de Inutilização\n     */\n    private criarId(codigoUF: number, ano: string, cnpj: string, modelo: string, serie: string, numeroInicial: string, numeroFinal: string) {\n        const id = `ID${codigoUF}${ano}${cnpj}${modelo}${serie}${numeroInicial}${numeroFinal}`;\n\n        return id;\n    }\n\n    /**\n     * Método utilitário para criação do XML a partir de um Objeto\n     */\n    gerarXmlNFeInutilizacao(data: InutilizacaoData) {\n        const { nfe: { ambiente } } = this.environment.getConfig();\n\n        const {\n            cUF,\n            ano,\n            CNPJ,\n            mod,\n            serie,\n            nNFIni,\n            nNFFin,\n            xJust\n        } = data;\n\n        const anoFormatado = ano.toString().slice(-2);\n        const serieFormatada = serie.padStart(3, '0')\n        const numNFIniFormatado = nNFIni.padStart(9, '0')\n        const numNFFinFormatado = nNFFin.padStart(9, '0')\n\n        const id = this.criarId(cUF, anoFormatado, CNPJ, mod, serieFormatada, numNFIniFormatado, numNFFinFormatado);\n        const xServ = 'INUTILIZAR';\n\n        if ([55, 65].indexOf(Number(mod)) === -1) {\n            throw new Error(`Modelo do documento para inutilização deve ser 55 ou 65. Modelo informado: ${mod}`);\n        }\n\n        const xmlObject = {\n            $: {\n                versao: \"4.00\",\n                xmlns: 'http://www.portalfiscal.inf.br/nfe'\n            },\n            infInut: {\n                $: {\n                    Id: `${id}`,\n                },\n                tpAmb: ambiente,\n                xServ,\n                cUF,\n                ano,\n                CNPJ,\n                mod,\n                serie,\n                nNFIni,\n                nNFFin,\n                xJust,\n            }\n        }\n\n        // Gerar XML\n        const xml = this.xmlBuilder.gerarXml(xmlObject, 'inutNFe')\n\n        // Assinar XML\n        return this.xmlBuilder.assinarXML(xml, 'infInut');\n    }\n\n}\n\nexport default NFEInutilizacaoService;","(function() {\n  var base64map\n      = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/',\n\n  crypt = {\n    // Bit-wise rotation left\n    rotl: function(n, b) {\n      return (n << b) | (n >>> (32 - b));\n    },\n\n    // Bit-wise rotation right\n    rotr: function(n, b) {\n      return (n << (32 - b)) | (n >>> b);\n    },\n\n    // Swap big-endian to little-endian and vice versa\n    endian: function(n) {\n      // If number given, swap endian\n      if (n.constructor == Number) {\n        return crypt.rotl(n, 8) & 0x00FF00FF | crypt.rotl(n, 24) & 0xFF00FF00;\n      }\n\n      // Else, assume array and swap all items\n      for (var i = 0; i < n.length; i++)\n        n[i] = crypt.endian(n[i]);\n      return n;\n    },\n\n    // Generate an array of any length of random bytes\n    randomBytes: function(n) {\n      for (var bytes = []; n > 0; n--)\n        bytes.push(Math.floor(Math.random() * 256));\n      return bytes;\n    },\n\n    // Convert a byte array to big-endian 32-bit words\n    bytesToWords: function(bytes) {\n      for (var words = [], i = 0, b = 0; i < bytes.length; i++, b += 8)\n        words[b >>> 5] |= bytes[i] << (24 - b % 32);\n      return words;\n    },\n\n    // Convert big-endian 32-bit words to a byte array\n    wordsToBytes: function(words) {\n      for (var bytes = [], b = 0; b < words.length * 32; b += 8)\n        bytes.push((words[b >>> 5] >>> (24 - b % 32)) & 0xFF);\n      return bytes;\n    },\n\n    // Convert a byte array to a hex string\n    bytesToHex: function(bytes) {\n      for (var hex = [], i = 0; i < bytes.length; i++) {\n        hex.push((bytes[i] >>> 4).toString(16));\n        hex.push((bytes[i] & 0xF).toString(16));\n      }\n      return hex.join('');\n    },\n\n    // Convert a hex string to a byte array\n    hexToBytes: function(hex) {\n      for (var bytes = [], c = 0; c < hex.length; c += 2)\n        bytes.push(parseInt(hex.substr(c, 2), 16));\n      return bytes;\n    },\n\n    // Convert a byte array to a base-64 string\n    bytesToBase64: function(bytes) {\n      for (var base64 = [], i = 0; i < bytes.length; i += 3) {\n        var triplet = (bytes[i] << 16) | (bytes[i + 1] << 8) | bytes[i + 2];\n        for (var j = 0; j < 4; j++)\n          if (i * 8 + j * 6 <= bytes.length * 8)\n            base64.push(base64map.charAt((triplet >>> 6 * (3 - j)) & 0x3F));\n          else\n            base64.push('=');\n      }\n      return base64.join('');\n    },\n\n    // Convert a base-64 string to a byte array\n    base64ToBytes: function(base64) {\n      // Remove non-base-64 characters\n      base64 = base64.replace(/[^A-Z0-9+\\/]/ig, '');\n\n      for (var bytes = [], i = 0, imod4 = 0; i < base64.length;\n          imod4 = ++i % 4) {\n        if (imod4 == 0) continue;\n        bytes.push(((base64map.indexOf(base64.charAt(i - 1))\n            & (Math.pow(2, -2 * imod4 + 8) - 1)) << (imod4 * 2))\n            | (base64map.indexOf(base64.charAt(i)) >>> (6 - imod4 * 2)));\n      }\n      return bytes;\n    }\n  };\n\n  module.exports = crypt;\n})();\n","var charenc = {\n  // UTF-8 encoding\n  utf8: {\n    // Convert a string to a byte array\n    stringToBytes: function(str) {\n      return charenc.bin.stringToBytes(unescape(encodeURIComponent(str)));\n    },\n\n    // Convert a byte array to a string\n    bytesToString: function(bytes) {\n      return decodeURIComponent(escape(charenc.bin.bytesToString(bytes)));\n    }\n  },\n\n  // Binary encoding\n  bin: {\n    // Convert a string to a byte array\n    stringToBytes: function(str) {\n      for (var bytes = [], i = 0; i < str.length; i++)\n        bytes.push(str.charCodeAt(i) & 0xFF);\n      return bytes;\n    },\n\n    // Convert a byte array to a string\n    bytesToString: function(bytes) {\n      for (var str = [], i = 0; i < bytes.length; i++)\n        str.push(String.fromCharCode(bytes[i]));\n      return str.join('');\n    }\n  }\n};\n\nmodule.exports = charenc;\n","(function() {\n  var crypt = require('crypt'),\n      utf8 = require('charenc').utf8,\n      bin = require('charenc').bin,\n\n  // The core\n  sha1 = function (message) {\n    // Convert to byte array\n    if (message.constructor == String)\n      message = utf8.stringToBytes(message);\n    else if (typeof Buffer !== 'undefined' && typeof Buffer.isBuffer == 'function' && Buffer.isBuffer(message))\n      message = Array.prototype.slice.call(message, 0);\n    else if (!Array.isArray(message))\n      message = message.toString();\n\n    // otherwise assume byte array\n\n    var m  = crypt.bytesToWords(message),\n        l  = message.length * 8,\n        w  = [],\n        H0 =  1732584193,\n        H1 = -271733879,\n        H2 = -1732584194,\n        H3 =  271733878,\n        H4 = -1009589776;\n\n    // Padding\n    m[l >> 5] |= 0x80 << (24 - l % 32);\n    m[((l + 64 >>> 9) << 4) + 15] = l;\n\n    for (var i = 0; i < m.length; i += 16) {\n      var a = H0,\n          b = H1,\n          c = H2,\n          d = H3,\n          e = H4;\n\n      for (var j = 0; j < 80; j++) {\n\n        if (j < 16)\n          w[j] = m[i + j];\n        else {\n          var n = w[j - 3] ^ w[j - 8] ^ w[j - 14] ^ w[j - 16];\n          w[j] = (n << 1) | (n >>> 31);\n        }\n\n        var t = ((H0 << 5) | (H0 >>> 27)) + H4 + (w[j] >>> 0) + (\n                j < 20 ? (H1 & H2 | ~H1 & H3) + 1518500249 :\n                j < 40 ? (H1 ^ H2 ^ H3) + 1859775393 :\n                j < 60 ? (H1 & H2 | H1 & H3 | H2 & H3) - 1894007588 :\n                         (H1 ^ H2 ^ H3) - 899497514);\n\n        H4 = H3;\n        H3 = H2;\n        H2 = (H1 << 30) | (H1 >>> 2);\n        H1 = H0;\n        H0 = t;\n      }\n\n      H0 += a;\n      H1 += b;\n      H2 += c;\n      H3 += d;\n      H4 += e;\n    }\n\n    return [H0, H1, H2, H3, H4];\n  },\n\n  // Public API\n  api = function (message, options) {\n    var digestbytes = crypt.wordsToBytes(sha1(message));\n    return options && options.asBytes ? digestbytes :\n        options && options.asString ? bin.bytesToString(digestbytes) :\n        crypt.bytesToHex(digestbytes);\n  };\n\n  api._blocksize = 16;\n  api._digestsize = 20;\n\n  module.exports = api;\n})();\n","import Utility from '../../../../../../core/utils/Utility.js';\nimport { createHash } from 'crypto';\nimport sha1 from 'sha1';\n\n// Função para gerar o hash SHA-1 em formato hexadecimal\nfunction generateSHA1Hash(input: string): string {\n    return createHash('sha1').update(input).digest('hex');\n}\n\nfunction calcularDigestValueHex(digVal: string): string {\n    return Buffer.from(digVal).toString('hex');\n}\n\n// Função para gerar a URL do QR Code para emissão ONLINE\nexport function generateQRCodeURLOnline(\n    chaveAcesso: string,\n    versaoQRCode: string,\n    tipoAmbiente: number,\n    identificadorCSC: number,\n    csc: string,\n    utility: Utility\n): string {\n    const urlQRCodeNFCe = utility.getUrlNFCe('URL-QRCode', false, '');\n    chaveAcesso = chaveAcesso.replace('NFe', '');\n\n    // Passo 1: Concatenar parâmetros\n    const baseString = `${chaveAcesso}|${versaoQRCode}|${tipoAmbiente}|${identificadorCSC}`;\n\n    // Passo 2: Adicionar o CSC\n    const stringToHash = `${baseString}${csc}`;\n\n    // Passo 3: Gerar o hash\n    const codigoHash = generateSHA1Hash(stringToHash);\n\n    // Montar a URL final\n    return `${urlQRCodeNFCe}?p=${baseString}|${codigoHash}`;\n}\n\n// Função para gerar a URL do QR Code para emissão OFFLINE\nexport function generateQRCodeURLOffline(\n    chaveAcesso: string,\n    versaoQRCode: string,\n    tipoAmbiente: number,\n    diaDataEmissao: string,\n    valorTotalNfce: string,\n    digVal: string,\n    identificadorCSC: number,\n    csc: string,\n    utility: Utility\n): string {\n    const urlQRCodeNFCe = utility.getUrlNFCe('URL-QRCode', false, '');\n    chaveAcesso = chaveAcesso.replace('NFe', '');\n\n    // Passo 1: Converter DigestValue para HEXA\n    const digestValueHex = calcularDigestValueHex(digVal)\n\n    // Passo 2: Concatenar parâmetros\n    const baseString = `${chaveAcesso}|${versaoQRCode}|${tipoAmbiente}|${diaDataEmissao}|${valorTotalNfce}|${digestValueHex}|${identificadorCSC}`;\n\n    // Passo 3: Adicionar o CSC\n    const stringToHash = `${baseString}${csc}`;\n\n    // Passo 4: Gerar o hash\n    const hash = sha1(stringToHash).toUpperCase();\n\n    // Montar URL\n    return `${urlQRCodeNFCe}?p=${baseString}|${hash}`;\n}\n","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport BaseNFE from '@Modules/dfe/base/BaseNFe.js';\nimport { ProtNFe } from '@Types';\nimport { AxiosInstance } from 'axios';\nimport { GerarConsultaImpl, NFCERetornoAutorizacaoServiceImpl, SaveFilesImpl } from '@Interfaces';\n\nclass NFCERetornoAutorizacaoService extends BaseNFE implements NFCERetornoAutorizacaoServiceImpl {\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, 'NFERetAutorizacao', axios, saveFiles, gerarConsulta);\n    }\n\n    protected gerarXml(data: string): string {\n        try {\n            const { nfe: { ambiente } } = this.environment.getConfig();\n\n            const xmlObject = {\n                $: {\n                    xmlns: 'http://www.portalfiscal.inf.br/nfe',\n                    versao: \"4.00\",\n                },\n                tpAmb: ambiente,\n                nRec: data\n            }\n            return this.xmlBuilder.gerarXml(xmlObject, 'consReciNFe')\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    /**\n     * Busca o retorno da Autorização pelo número do recibo (nRec)\n     * \n     * @param {string} nRec - Número do recibo retornado pela SEFAZ ao emitir uma NFe em modo assíncrono.\n     * @param {any} xmlNFe - Array contendo as NFe do lote enviado à SEFAZ.\n     * @returns {Promise<string>} XML completo da NFe (já com protocolo de autorização).\n     */\n    async getRetornoRecibo(nRec: string, xmlNFe: string[]): Promise<{\n        success: boolean;\n        message: any;\n        data: string[];\n    }> {\n        try {\n            /**\n             * Gera o XML para consulta de acordo com o número do recibo da emissão (nRec)\n             */\n            const xmlConsulta = this.gerarXml(nRec);\n\n            const { xmlFormated, agent, webServiceUrl, action } = await this.gerarConsulta.gerarConsulta(xmlConsulta, this.metodo);\n\n            // Salva XML de Consulta\n            this.utility.salvaConsulta(xmlConsulta, xmlFormated, this.metodo);\n\n            // Efetua requisição para o webservice NFEStatusServico\n            const xmlRetorno = await this.axios.post(webServiceUrl, xmlFormated, {\n                headers: {\n                    'Content-Type': this.setContentType(),\n                    'SOAPAction': action,\n                },\n                httpsAgent: agent\n            });\n\n            const responseInJson = this.utility.verificaRejeicao(xmlRetorno.data, this.metodo);\n            \n            // Salva XML de Retorno\n            this.utility.salvaRetorno(xmlRetorno.data, responseInJson, this.metodo);\n\n            const { protNFe } = this.utility.getProtNFe(xmlRetorno.data);\n\n            if (!protNFe) {\n                throw new Error(`Não foi possível encontrar a tag 'protNFe'. Talvez a NFe ainda não tenha sido processada.`)\n            }\n            return this.getXmlRetornoAutorizacao(protNFe, xmlNFe);\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    /**\n     * Agrega o protNFe ao restante da NFe gerada na emissão.\n     * \n     * @param {string} protNFe - Tag protNFe do XML em formato JSON.\n     * @param {any} xmlNFe - Array contendo as NFe do lote enviado à SEFAZ.\n     * @returns {} XML completo da NFe (já com protocolo de autorização).\n     */\n    getXmlRetornoAutorizacao(protNFe: ProtNFe[], xmlNFe: string[]): {\n        success: boolean;\n        message: any;\n        data: string[];\n    } {\n        try {\n            /**\n             * Cria o Obj base da NFe já processada (nfeProc)\n             */\n            const XMLs = []\n            for (let i = 0; i < protNFe.length; i++) {\n                const baseXML = {\n                    $: {\n                        versao: \"4.00\",\n                        xmlns: 'http://www.portalfiscal.inf.br/nfe'\n                    },\n                    _: '[XML]'\n                }\n                let xml = this.xmlBuilder.gerarXml(baseXML, 'nfeProc')\n                /**\n                 * Converte a tag protNFe do formato JSON para XML e armazena na string protTag.\n                 * Adiciona a tag protNFe (armazenada na string protTag) ao array contendo os dados das NFe.\n                 */\n                // Expressão regular para capturar o valor do atributo Id\n                const formatedProtNFe: any = protNFe;\n                const xmlCompleto = xmlNFe.find((item) => item.indexOf(formatedProtNFe[i].infProt[0].chNFe[0]) !== -1);\n \n                if (xmlCompleto) {\n                    const protTag = this.xmlBuilder.gerarXml(protNFe[i], 'protNFe')\n                    const xmlFinal = [xmlCompleto]\n                    xmlFinal.push(protTag)\n\n                    /**\n                     * Substitui o \"[XML]\" com as tags NFe e a tag protNFe\n                     */\n                    xml = xml.replace('[XML]', xmlFinal.join(''));\n                    xml = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>${xml}`;\n\n                    XMLs.push(xml)\n                }\n            }\n            return {\n                success: true,\n                message: 'xMotivo',\n                data: XMLs\n            }\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n\n    }\n\n    /**\n     * Retorna o XML completo da Autorização (já com o protocolo de autorização)\n     * \n     * @param {number} tipoEmissao - Informa se o tipo emissão foi síncrona ou assíncrona (0- Não / 1 - Sim).\n     * @param {string | undefined} nRec - Número do recibo retornado pela SEFAZ ao emitir uma NFe em modo assíncrono.\n     * @param {ProtNFe | undefined} protNFe - Tag protNFe do XML em formato JSON.\n     * @param {string[]} xmlNFe - Array contendo as NFe do lote enviado à SEFAZ.\n     * @returns {Promise<string>} XML completo da NFe (já com protocolo de autorização).\n     */\n    async getXmlRetorno({\n        tipoEmissao,\n        nRec,\n        protNFe,\n        xmlNFe\n    }: {\n        tipoEmissao: number,\n        nRec?: string,\n        protNFe?: ProtNFe[],\n        xmlNFe: string[]\n    }): Promise<{\n        success: boolean;\n        message: any;\n        data: string[];\n    }> {\n        try {\n\n            /**\n             * Trata retorno Síncrono\n             */\n            if (tipoEmissao === 1 && protNFe) {\n                return this.getXmlRetornoAutorizacao(protNFe, xmlNFe);\n            }\n\n            /**\n             * Trata retorno Assíncrono\n             */\n            if (tipoEmissao === 0 && nRec) {\n                return this.getRetornoRecibo(nRec, xmlNFe);\n            }\n\n            throw new Error('Não foi possível buscar o retorno da autorização.');\n\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n}\n\nexport default NFCERetornoAutorizacaoService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { NFCERetornoAutorizacaoServiceImpl } from '@Interfaces';\nimport { ProtNFe } from '@Types/NFEAutorizacao';\n\nclass NFCERetornoAutorizacao implements NFCERetornoAutorizacaoServiceImpl {\n    nfceAutorizacaoRetornoService: NFCERetornoAutorizacaoServiceImpl;\n    constructor(nfceAutorizacaoRetornoService: NFCERetornoAutorizacaoServiceImpl) {\n        this.nfceAutorizacaoRetornoService = nfceAutorizacaoRetornoService;\n    }\n\n    async getXmlRetorno(data: {\n        tipoEmissao: number;\n        nRec?: string;\n        protNFe?: ProtNFe[];\n        xmlNFe: string[];\n    }): Promise<{\n        success: boolean;\n        message: any;\n        data: string[];\n    }> {\n        return await this.nfceAutorizacaoRetornoService.getXmlRetorno(data);\n    }\n\n}\n\n\nexport default NFCERetornoAutorizacao;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport { AxiosInstance, AxiosResponse } from 'axios';\nimport XmlParser from '../../../../../core/utils/XmlParser.js';\nimport Environment from '@Modules/environment/Environment.js';\nimport Utility from '@Utils/Utility.js';\nimport XmlBuilder from '@Adapters/XmlBuilder.js';\nimport ValidaCPFCNPJ from '../../../../../core/utils/ValidaCPFCNPJ.js';\nimport { GenericObject, LayoutNFe, NFe, ProtNFe } from '@Types';\nimport BaseNFE from '@Modules/dfe/base/BaseNFe.js';\nimport { format } from 'date-fns';\nimport { generateQRCodeURLOffline, generateQRCodeURLOnline } from './util/NFCEQRCode.js';\nimport xml2js, { Builder } from 'xml2js';\nimport { mountCOFINS, mountICMS, mountPIS } from '@Utils/NFEImposto.js';\nimport { GerarConsultaImpl, NFCEAutorizacaoServiceImpl, SaveFilesImpl } from '@Interfaces';\nimport NFCERetornoAutorizacaoService from '../NFCERetornoAutorizacao/NFCERetornoAutorizacaoService.js';\nimport NFCERetornoAutorizacao from '../../operations/NFCERetornoAutorizacao/NFCERetornoAutorizacao.js';\nimport { logger } from '@Core/exceptions/logger.js';\n\nclass NFCEAutorizacaoService extends BaseNFE implements NFCEAutorizacaoServiceImpl {\n    xmlNFe: string[];\n    constructor(environment: Environment, utility: Utility, xmlBuilder: XmlBuilder, axios: AxiosInstance, saveFiles: SaveFilesImpl, gerarConsulta: GerarConsultaImpl) {\n        super(environment, utility, xmlBuilder, 'NFEAutorizacao', axios, saveFiles, gerarConsulta);\n        this.xmlNFe = [];\n    }\n\n    protected gerarXml(data: NFe): string {\n        return this.gerarXmlNFCEAutorizacao(data);\n    }\n\n    protected salvaArquivos(xmlConsulta: string, responseInJson: GenericObject, xmlRetorno: AxiosResponse<any, any>, options?: Record<string, any>): GenericObject {\n\n        // Recupera configuração do ambiente para verificar se os arquivos gerados serão gravados em disco\n        const config = this.environment.getConfig();\n        let dateAndTimeInFileName = config.dfe.incluirTimestampNoNomeDosArquivos;\n\n        const createFileName = (prefix: string | undefined, includeMethodName?: boolean) => {\n            const dtaTime = dateAndTimeInFileName ? `-${format(new Date(), 'dd-MM-yyyy-HHmm')}` : '';\n\n            const baseFileName = includeMethodName ? `${this.metodo}` : '';\n            const prefixPart = prefix ? includeMethodName ? `-${prefix}` : `${prefix}` : '';\n            const nfePart = responseInJson.chNFe ? `-${responseInJson.chNFe}` : '';\n            const dateTimePart = dtaTime;\n\n            return `${baseFileName}${prefixPart}${nfePart}${dateTimePart}`;\n        }\n\n        const salvarArquivo = (data: any, prefix: string | undefined, path: string | undefined, fileType: 'xml' | 'json', includeMethodName?: boolean) => {\n            const fileName = createFileName(prefix, includeMethodName);\n            const method = fileType === 'xml' ? 'salvaXML' : 'salvaJSON';\n\n            this.utility[method]({\n                data: data,\n                fileName,\n                metodo: this.metodo,\n                path,\n            });\n        };\n\n        let chNFe = ''\n        let xmlAutorizacaoInJson: GenericObject = {} as GenericObject;\n        let xMotivoPorXml: GenericObject[] = [];\n        let xmlsInJson: GenericObject[] = [];\n        if (options) {\n            const { xmlAutorizacao } = options;\n\n            const json = new XmlParser();\n\n            for (let i = 0; i < xmlAutorizacao.length; i++) {\n                xmlAutorizacaoInJson = json.convertXmlToJson(xmlAutorizacao[i], 'NFCEAutorizacaoFinal');\n                xmlsInJson.push(xmlAutorizacaoInJson);\n\n                const chNFe = xmlAutorizacaoInJson.protNFe.infProt.chNFe;\n                const xMotivo = xmlAutorizacaoInJson.protNFe.infProt.xMotivo;\n                const cStat = xmlAutorizacaoInJson.protNFe.infProt.cStat;\n                xMotivoPorXml.push({\n                    chNFe,\n                    xMotivo,\n                    cStat,\n                })\n\n                if (config.dfe.armazenarXMLAutorizacao) {\n                    salvarArquivo(xmlAutorizacao[i], chNFe, config.dfe.pathXMLAutorizacao, 'xml', false);\n                    salvarArquivo(xmlAutorizacaoInJson, chNFe, config.dfe.pathXMLAutorizacao, 'json', false);\n                }\n            }\n\n            return {\n                success: true,\n                xMotivo: xMotivoPorXml,\n                response: xmlsInJson,\n            }\n        }\n        return {\n            success: true,\n            xMotivo: xMotivoPorXml,\n            response: xmlsInJson,\n        }\n    }\n\n    private async trataRetorno(xmlRetorno: string, indSinc: number, responseInJson: GenericObject) {\n        try {\n            /**\n             * Captura o valor nRec e protNFe\n             */\n            const { nRec, protNFe } = this.utility.getProtNFe(xmlRetorno);\n\n            /**\n             * 0 - assíncrona\n             * 1 - síncrona\n             */\n            let tipoEmissao = 0;\n            if (indSinc === 1 && protNFe) {\n                tipoEmissao = 1;\n            }\n            const nfeRetornoAutService = new NFCERetornoAutorizacaoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeRetornoAut = new NFCERetornoAutorizacao(nfeRetornoAutService);\n\n            const retorno = await nfeRetornoAut.getXmlRetorno({\n                tipoEmissao,\n                nRec,\n                protNFe,\n                xmlNFe: this.xmlNFe\n            });\n\n            return retorno;\n        } catch (error: any) {\n            throw new Error(error.message)\n        }\n    }\n\n    /**\n     * Método utilitário para criação do XML a partir de um Objeto\n     */\n\n\n    private anoMesEmissao(dhEmi: string) {\n        // Lógica para obter o ano e mês de emissão (AAMM)\n        const dataAtual = new Date(dhEmi);\n        const ano = dataAtual.getFullYear().toString().slice(-2);\n        const mes = (dataAtual.getMonth() + 1).toString().padStart(2, '0');\n\n        return ano + mes;\n    }\n\n    private diaEmissao(dhEmi: string) {\n        // Converte a string para uma data\n        const dataAtual = new Date(dhEmi);\n\n        // Extrai o dia com dois dígitos\n        const dia = dataAtual.getDate().toString().padStart(2, '0');\n\n        // Retorna o dia\n        return dia;\n    }\n\n    private calcularModulo11(sequencia: string) {\n        const pesos = [4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2, 9, 8, 7, 6, 5, 4, 3, 2];\n\n        let somatoria = 0;\n\n        for (let i = 0; i < sequencia.length; i++) {\n            somatoria += parseInt(sequencia.charAt(i)) * pesos[i];\n        }\n\n        const restoDivisao = somatoria % 11;\n        const digitoVerificador = restoDivisao === 0 || restoDivisao === 1 ? 0 : 11 - restoDivisao;\n\n        return digitoVerificador;\n    }\n\n    private calcularDigitoVerificador(data: LayoutNFe) {\n        const {\n            infNFe: {\n                ide: { cUF, mod, serie, nNF, tpEmis, cNF, dhEmi },\n                emit: { CNPJCPF }\n            }\n        } = data;\n\n        const anoMes = this.anoMesEmissao(dhEmi);\n\n        // Montando a sequência para o cálculo do dígito verificador\n        const sequencia = `${cUF}${anoMes}${CNPJCPF}${mod}${String(serie).padStart(3, '0')}${String(nNF).padStart(9, '0')}${tpEmis}${cNF}`;\n\n        // Calculando o dígito verificador\n        const dv = this.calcularModulo11(sequencia);\n\n        // Montando a chave de acesso\n        const chaveAcesso = `NFe${sequencia}` + dv;\n        this.chaveNfe = `${sequencia}${dv}`;\n\n        return {\n            chaveAcesso,\n            dv\n        };\n    }\n\n    private validaDocumento(doc: string, campo: string) {\n        // Valida se CPF ou CNPJ\n        const nfeAutorizacaoHandler = new ValidaCPFCNPJ();\n        const { documentoValido, tipoDoDocumento } = nfeAutorizacaoHandler.validarCpfCnpj(doc);\n\n        if (!documentoValido || tipoDoDocumento === 'Desconhecido') {\n            const message = tipoDoDocumento === 'Desconhecido'\n                ? `Documento do ${campo} ausente ou inválido`\n                : `${tipoDoDocumento} do ${campo} é inválido`\n            throw new Error(message);\n        }\n\n        return tipoDoDocumento;\n    }\n\n    private extrairDigestValue(xmlAssinado: string): string {\n        const match = xmlAssinado.match(/<DigestValue>([^<]+)<\\/DigestValue>/);\n        if (match && match[1]) {\n            return match[1];\n        }\n        throw new Error('DigestValue não encontrado no XML assinado.');\n    }\n\n    private gerarXmlNFCEAutorizacao(data: NFe) {\n\n        const createXML = (NFe: LayoutNFe) => {\n\n            // Verificando se existe mais de um produto\n            if (NFe?.infNFe?.det instanceof Array) {\n                // Adicionando indice ao item\n                const formatedItens = NFe.infNFe.det.map((det, index) => {\n                    if (det.imposto.ICMS.dadosICMS) {\n                        const icms = mountICMS(det.imposto.ICMS.dadosICMS);\n                        det.imposto.ICMS = icms;\n                    }\n                    if (det.imposto.PIS.dadosPIS) {\n                        const pis = mountPIS(det.imposto.PIS.dadosPIS);\n                        det.imposto.PIS = pis;\n                    }\n                    if (det.imposto.COFINS.dadosCOFINS) {\n                        const cofins = mountCOFINS(det.imposto.COFINS.dadosCOFINS);\n                        det.imposto.COFINS = cofins\n                    }\n                    return {\n                        $: {\n                            nItem: index + 1,\n                        },\n                        ...det,\n                    };\n                });\n                NFe.infNFe.det = formatedItens;\n            }\n\n            // Cria chave da nota e grava digito verificador\n            const { chaveAcesso, dv } = this.calcularDigitoVerificador(NFe)\n            NFe.infNFe.ide.cDV = dv;\n            NFe.infNFe.ide.verProc = NFe.infNFe.ide.verProc || '1.0.0.0';\n\n            // Valida Documento do emitente\n            NFe.infNFe.emit = Object.assign({ [this.validaDocumento(String(NFe.infNFe.emit.CNPJCPF), 'emitente')]: NFe.infNFe.emit.CNPJCPF }, NFe.infNFe.emit)\n            delete NFe.infNFe.emit.CNPJCPF;\n            // Valida Documento do destinatário\n\n            if (NFe.infNFe.dest) {\n                NFe.infNFe.dest = Object.assign({ [this.validaDocumento(String(NFe.infNFe.dest?.CNPJCPF || ''), 'destinatário')]: NFe.infNFe.dest?.CNPJCPF || '' }, NFe.infNFe.dest)\n                delete NFe.infNFe.dest.CNPJCPF;\n            }\n\n            // Valida Documento do transportador\n            if (NFe.infNFe.transp.transporta) {\n                NFe.infNFe.transp.transporta = Object.assign({ [this.validaDocumento(String(NFe.infNFe.transp.transporta?.CNPJCPF), 'transportador')]: NFe.infNFe.transp.transporta?.CNPJCPF }, NFe.infNFe.transp.transporta)\n                delete NFe.infNFe.transp.transporta?.CNPJCPF;\n            }\n\n            // Valida Documento do produtor rural\n            if (NFe.infNFe?.NFref instanceof Array) {\n                const NFrefArray = NFe.infNFe.NFref;\n                if (NFrefArray && NFrefArray.length > 0) {\n                    NFe.infNFe.NFref = NFrefArray.map(NFref => {\n                        if (NFref.refNFP) {\n                            NFref.refNFP = Object.assign(\n                                { [this.validaDocumento(String(NFref.refNFP.CNPJCPF), 'produtor rural')]: NFref.refNFP.CNPJCPF },\n                                NFref.refNFP\n                            );\n                            delete NFref.refNFP.CNPJCPF;\n                        }\n                        return NFref;\n                    });\n                }\n            } else {\n                if (NFe.infNFe.NFref && NFe.infNFe.NFref.refNFP) {\n                    NFe.infNFe.NFref.refNFP = Object.assign(\n                        { [this.validaDocumento(String(NFe.infNFe.NFref.refNFP.CNPJCPF), 'produtor rural')]: NFe.infNFe.NFref.refNFP.CNPJCPF },\n                        NFe.infNFe.NFref.refNFP\n                    )\n                }\n            }\n\n            // Caso Seja hambiente de homologação\n            if (NFe.infNFe.dest) {\n                if (NFe.infNFe.ide.tpAmb === 2) {\n                    NFe.infNFe.dest.xNome = 'NF-E EMITIDA EM AMBIENTE DE HOMOLOGACAO - SEM VALOR FISCAL';\n                }\n            }\n\n            const { nfe: { idCSC, tokenCSC } } = this.environment.getConfig();\n\n            let qrCode = '';\n            if (![4, 9].includes(NFe.infNFe.ide.tpEmis)) {\n                qrCode = generateQRCodeURLOnline(chaveAcesso, '2', NFe.infNFe.ide.tpAmb, Number(idCSC), String(tokenCSC), this.utility);\n            }\n\n            const urlConsultaNFCe = this.utility.getUrlNFCe('URL-ConsultaNFCe', false, '');\n\n            const nfeWithQrCode = {\n                ...NFe,\n                infNFeSupl: {\n                    qrCode: qrCode,\n                    urlChave: urlConsultaNFCe,\n                }\n            }\n            NFe = nfeWithQrCode;\n\n            const xmlObject = {\n                $: {\n                    xmlns: 'http://www.portalfiscal.inf.br/nfe'\n                },\n                infNFe: {\n                    $: {\n                        versao: \"4.00\",\n                        Id: chaveAcesso,\n                    },\n                    ...NFe.infNFe\n                },\n                infNFeSupl: {\n                    ...NFe.infNFeSupl\n                }\n            }\n\n            const eventoXML = this.xmlBuilder.gerarXml(xmlObject, 'NFe')\n            let xmlAssinado = this.xmlBuilder.assinarXML(eventoXML, 'infNFe')\n\n            if ([4, 9].includes(NFe.infNFe.ide.tpEmis)) {\n                // capturar digestValue\n                const digestValue = this.extrairDigestValue(xmlAssinado);\n\n                // substituir tag qrcode\n                const tpAmb = NFe.infNFe.ide.tpAmb;\n                const valNF = NFe.infNFe.total.ICMSTot.vNF;\n\n                const diaEmissao = this.diaEmissao(NFe.infNFe.ide.dhEmi);\n                qrCode = generateQRCodeURLOffline(chaveAcesso, '2', tpAmb, diaEmissao, valNF, digestValue, Number(idCSC), String(tokenCSC), this.utility);\n\n                xml2js.parseString(xmlAssinado, (err, result) => {\n                    if (err) {\n                        throw new Error('Erro ao parsear o XML para atualização do qrCode:');\n                    } else {\n                        if (result.NFe?.infNFeSupl[0]?.qrCode) {\n                            result.NFe.infNFeSupl[0].qrCode[0] = qrCode;\n\n                            const builder = new Builder({\n                                headless: true, renderOpts: {\n                                    pretty: false\n                                },\n                            });\n                            xmlAssinado = builder.buildObject(result)\n                        } else {\n                            throw new Error('Tag qrCode não encontrada no XML.');\n                        }\n                    }\n                });\n\n\n            }\n\n            this.xmlNFe.push(xmlAssinado);\n        }\n\n        if (data.NFe instanceof Array) {\n            for (let i = 0; i < data.NFe.length; i++) {\n                const NFe = data.NFe[i];\n                createXML(NFe);\n            }\n        } else {\n            createXML(data.NFe);\n        }\n\n        // Base do XML\n        const baseXML = {\n            $: {\n                versao: \"4.00\",\n                xmlns: 'http://www.portalfiscal.inf.br/nfe'\n            },\n            idLote: data.idLote,\n            indSinc: data.indSinc,\n            _: '[XML]'\n        }\n\n        // Gera base do XML\n        const xml = this.xmlBuilder.gerarXml(baseXML, 'enviNFe')\n\n        return xml.replace('[XML]', this.xmlNFe.join(''));\n    }\n\n    // protected setContentType() {\n    //     const UF = this.environment.config.dfe.UF;\n\n    //     const ufsAppSoad = ['MG', 'GO', 'MT', 'MS', 'AM'];\n\n    //     if (ufsAppSoad.includes(UF)) {\n    //         return 'application/soap+xml'\n    //     }\n    //     return 'text/xml; charset=utf-8'\n    // }\n\n    async Exec(data: NFe): Promise<{\n        success: boolean;\n        xMotivo: GenericObject;\n        xmls: {\n            NFe: LayoutNFe;\n            protNFe: ProtNFe\n        }[];\n    }> {\n        let xmlConsulta: string = '';\n        let xmlConsultaSoap: string = '';\n        let webServiceUrlTmp: string = '';\n        let responseInJson: GenericObject | undefined = undefined;\n        let xmlRetorno: AxiosResponse<any, any> = {} as AxiosResponse<any, any>;\n        const ContentType = this.setContentType();\n        try {\n            // Gerando XML para consulta de Status do Serviço\n            xmlConsulta = this.gerarXmlNFCEAutorizacao(data);\n\n            const { xmlFormated, agent, webServiceUrl, action } = await this.gerarConsulta.gerarConsulta(xmlConsulta, this.metodo, false, '', 'NFCe');\n\n            xmlConsultaSoap = xmlFormated;\n            webServiceUrlTmp = webServiceUrl;\n\n            // Efetua requisição para o webservice NFEStatusServico\n            const xmlRetorno = await this.axios.post(webServiceUrl, xmlFormated, {\n                headers: {\n                    'Content-Type': ContentType,\n                    'SOAPAction': action,\n                    'CSC': '9cf44de0-502d-4351-bf18-0843e6528e22',\n                },\n                httpsAgent: agent\n            });\n            /**\n             * Verifica se houve rejeição no processamento do lote\n             */\n            const responseInJson = this.utility.verificaRejeicao(xmlRetorno.data, this.metodo);\n\n            const retorno = await this.trataRetorno(xmlRetorno.data, data.indSinc, responseInJson);\n\n            const xmlFinal = this.salvaArquivos(xmlConsulta, responseInJson, xmlRetorno.data,\n                {\n                    xmlAutorizacao: retorno.data,\n                    xMotivo: retorno.message\n                })\n\n            xmlFinal.xMotivo = xmlFinal.xMotivo.map((item: any) => ({\n                ...item,\n                xMotivo: item.xMotivo.replace('NF-e', 'NFC-e')\n            }));\n\n            return {\n                success: true,\n                xMotivo: xmlFinal.xMotivo,\n                xmls: xmlFinal.response,\n            }\n\n        } catch (error: any) {\n            // const logConfig = this.environment.config.lib?.log;\n\n            // if (logConfig) {\n            //     const { armazenarLogs } = logConfig;\n            //     if (armazenarLogs) {\n            //         logger.error({\n            //             message: error.message,\n            //             webServiceUrl: webServiceUrlTmp,\n            //             contentType: ContentType,\n            //             xmlSent: xmlConsultaSoap,\n            //             xmlResponse: error.response?.data || 'Sem resposta',\n            //         });\n            //     }\n            // }\n            throw new Error(error.message)\n        } finally {\n            // Salva XML de Consulta\n            this.utility.salvaConsulta(xmlConsulta, xmlConsultaSoap, this.metodo);\n\n            // Salva XML de Retorno\n            this.utility.salvaRetorno(xmlRetorno.data, responseInJson, this.metodo);\n        }\n    }\n\n}\n\nexport default NFCEAutorizacaoService;","import XmlBuilder from '@Adapters/XmlBuilder';\nimport Utility from '@Core/utils/Utility';\nimport { NFeWizardServiceImpl } from '@Interfaces';\nimport GerarConsulta from '@Modules/dfe/base/GerarConsulta';\nimport SaveFiles from '@Modules/dfe/base/SaveFiles';\nimport Environment from '@Modules/environment/Environment';\nimport { AxiosInstance } from 'axios';\nimport NFEStatusServicoService from '@Modules/dfe/nfe/services/NFEStatusServico/NFEStatusServicoService';\nimport NFEConsultaProtocolo from '../../operations/NFEConsultaProtocolo/NFEconsultaProtocolo';\nimport NFEEpec from '../../operations/NFERecepcaoEvento/NFEEpec';\nimport NFECancelamento from '../../operations/NFERecepcaoEvento/NFECancelamento';\nimport NFECienciaDaOperacao from '../../operations/NFERecepcaoEvento/NFECienciaDaOperacao';\nimport NFEConfirmacaoDaOperacao from '../../operations/NFERecepcaoEvento/NFEConfirmacaoDaOperacao';\nimport NFEOperacaoNaoRealizada from '../../operations/NFERecepcaoEvento/NFEOperacaoNaoRealizada';\nimport MailController from '@Adapters/MailAdapter';\nimport NFCEGerarDanfe from '@Modules/dfe/danfe/NFCEGerarDanfe/NFCEGerarDanfe';\nimport NFEGerarDanfe from '@Modules/dfe/danfe/NFEGerarDanfe/NFEGerarDanfe';\nimport NFCEAutorizacao from '@Modules/dfe/nfce/operations/NFCEAutorizacao/NFCEAutorizacao';\nimport NFEDistribuicaoDFe from '../../operations/NFEDistribuicaoDFe/NFEDistribuicaoDFe';\nimport NFEDistribuicaoDFePorChave from '../../operations/NFEDistribuicaoDFe/NFEDistribuicaoDFePorChave';\nimport NFEDistribuicaoDFePorNSU from '../../operations/NFEDistribuicaoDFe/NFEDistribuicaoDFePorNSU';\nimport NFEDistribuicaoDFePorUltNSU from '../../operations/NFEDistribuicaoDFe/NFEDistribuicaoDFePorUltNSU';\nimport NFEInutilizacao from '../../operations/NFEInutilizacao/NFEInutilizacao';\nimport NFECartaDeCorrecao from '../../operations/NFERecepcaoEvento/NFECartaDeCorrecao';\nimport NFEDesconhecimentoDaOperacao from '../../operations/NFERecepcaoEvento/NFEDesconhecimentoDaOperacao';\nimport NFEAutorizacaoService from '../NFEAutorizacao/NFEAutorizacaoService';\nimport {\n    Cancelamento,\n    CartaDeCorrecao,\n    CienciaDaOperacao,\n    ConfirmacaoDaOperacao,\n    ConsultaNFe,\n    DesconhecimentoDaOperacao,\n    DFePorChaveNFe,\n    DFePorNSU,\n    DFePorUltimoNSU,\n    EmailParams,\n    EPEC,\n    EventoNFe,\n    InutilizacaoData,\n    NFe,\n    NFEGerarDanfeProps,\n    NFeWizardProps,\n    OperacaoNaoRealizada\n} from '@Types';\nimport NFEconsultaProtocoloService from '../NFEConsultaProtocolo/NFEconsultaProtocoloService';\nimport NFEStatusServico from '../../operations/NFEStatusServico/NFEStatusServico';\nimport NFERecepcaoEvento from '../../operations/NFERecepcaoEvento/NFERecepcaoEvento';\nimport NFERecepcaoEventoService from '../NFERecepcaoEvento/NFERecepcaoEventoService';\nimport NFECancelamentoService from '../NFERecepcaoEvento/NFECancelamentoService';\nimport NFECartaDeCorrecaoService from '../NFERecepcaoEvento/NFECartaDeCorrecaoService';\nimport NFECienciaDaOperacaoService from '../NFERecepcaoEvento/NFECienciaDaOperacaoService';\nimport NFEDesconhecimentoDaOperacaoService from '../NFERecepcaoEvento/NFEDesconhecimentoDaOperacaoService';\nimport NFEEpecService from '../NFERecepcaoEvento/NFEEpecService';\nimport NFEOperacaoNaoRealizadaService from '../NFERecepcaoEvento/NFEOperacaoNaoRealizadaService';\nimport NFEAutorizacao from '../../operations/NFEAutorizacao/NFEAutorizacao';\nimport NFEDistribuicaoDFeService from '../NFEDistribuicaoDFe/NFEDistribuicaoDFeService';\nimport NFEDistribuicaoDFePorUltNSUService from '../NFEDistribuicaoDFe/NFEDistribuicaoDFePorUltNSU';\nimport NFEDistribuicaoDFePorNSUService from '../NFEDistribuicaoDFe/NFEDistribuicaoDFePorNSU';\nimport NFEDistribuicaoDFePorChaveService from '../NFEDistribuicaoDFe/NFEDistribuicaoDFePorChave';\nimport NFEInutilizacaoService from '../NFEInutilizacao/NFEInutilizacaoService';\nimport NFCEAutorizacaoService from '@Modules/dfe/nfce/services/NFCEAutorizacao/NFCEAutorizacaoService';\n\nclass NFeWizardService implements NFeWizardServiceImpl {\n    private config: NFeWizardProps = {} as NFeWizardProps;\n    private environment: Environment = {} as Environment;\n    private utility: Utility = {} as Utility;\n    private xmlBuilder: XmlBuilder = {} as XmlBuilder;\n    private axios: AxiosInstance = {} as AxiosInstance;\n    private saveFiles: SaveFiles = {} as SaveFiles;\n    private gerarConsulta: GerarConsulta = {} as GerarConsulta;\n\n    constructor() {\n        if (new.target) {\n            return new Proxy(this, {\n                get(target: NFeWizardService, prop: string | symbol, receiver: any): any {\n                    const origMethod: any = target[prop as keyof typeof target];\n                    if (typeof origMethod === 'function') {\n                        return async function (...args: any[]): Promise<any> {\n                            if (prop === 'NFE_LoadEnvironment') {\n                                return origMethod.apply(target, args);\n                            }\n                            // Lógica de validação antes de cada método\n                            await target.validateEnvironment(prop as string);\n                            // Chama o método original\n                            return origMethod.apply(target, args);\n                        };\n                    }\n                    return Reflect.get(target, prop, receiver);\n                }\n            });\n        }\n    }\n\n    async NFE_LoadEnvironment({ config }: { config: NFeWizardProps }) {\n        try {\n            this.config = config;\n            // Carrega Ambiente\n            this.environment = new Environment(this.config);\n            const { axios } = await this.environment.loadEnvironment();\n            this.axios = axios;\n\n            // Inicia método de Utilitários\n            this.utility = new Utility(this.environment)\n            this.saveFiles = new SaveFiles(this.environment, this.utility);\n\n            // Inicia método de geração de XML\n            this.xmlBuilder = new XmlBuilder(this.environment)\n            this.gerarConsulta = new GerarConsulta(this.environment, this.utility, this.xmlBuilder);\n\n            console.log('===================================');\n            console.log('Biblioteca Inicializada com Sucesso');\n            console.log('===================================');\n\n        } catch (error) {\n            console.log(error)\n            throw new Error(`Erro ao inicializar a lib: ${error}`)\n        }\n    }\n\n    /**\n     * Status Serviço\n     */\n    async NFE_ConsultaStatusServico() {\n        try {\n            const nfeStatusServicoService = new NFEStatusServicoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeStatusServico = new NFEStatusServico(nfeStatusServicoService);\n\n            const response = await nfeStatusServico.Exec();\n\n            console.log('Retorno NFE_ConsultaStatusServico');\n            console.log(`   ${response.xMotivo}`);\n            console.log('===================================');\n\n            return response\n        } catch (error: any) {\n            throw new Error(`NFE_ConsultaStatusServico: ${error.message}`)\n        }\n    }\n\n    /**\n     * Consulta Protocolo\n     */\n    async NFE_ConsultaProtocolo(chave: string) {\n        try {\n            const nfeConsultaProtocoloService = new NFEconsultaProtocoloService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeConsultaProtocolo = new NFEConsultaProtocolo(nfeConsultaProtocoloService);\n\n            const response = await nfeConsultaProtocolo.Exec(chave);\n\n            console.log('Retorno NFE_ConsultaProtocolo');\n            console.log(`   ${response.xMotivo}`);\n            console.log('===================================');\n\n            return response\n        } catch (error: any) {\n            throw new Error(`NFE_ConsultaProtocolo: ${error.message}`)\n        }\n    }\n\n    /**\n     * Recepção de Eventos\n     */\n    async NFE_RecepcaoEvento(evento: EventoNFe) {\n        try {\n            const nfeRecepcaoEventoService = new NFERecepcaoEventoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeRecepcaoEvento = new NFERecepcaoEvento(nfeRecepcaoEventoService);\n            const response = await nfeRecepcaoEvento.Exec(evento);\n\n            console.log('Retorno NFE_RecepcaoEvento');\n            console.table(response.xMotivos);\n            console.log('===================================');\n\n            return response.response\n        } catch (error: any) {\n            throw new Error(`NFE_RecepcaoEvento: ${error.message}`)\n        }\n    }\n    async NFE_EventoPrevioDeEmissaoEmContingencia(evento: EPEC) {\n        try {\n            const nfeEpecService = new NFEEpecService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeEpec = new NFEEpec(nfeEpecService);\n            const response = await nfeEpec.Exec(evento);\n\n            console.log('Retorno NFEEpec');\n            console.table(response.xMotivos);\n            console.log('===================================');\n\n            return response.response\n        } catch (error: any) {\n            throw new Error(`NFEEpec: ${error.message}`)\n        }\n    }\n    async NFE_Cancelamento(evento: Cancelamento) {\n        try {\n            const nfeCancelamentoService = new NFECancelamentoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeCancelamento = new NFECancelamento(nfeCancelamentoService);\n            const response = await nfeCancelamento.Exec(evento);\n\n            console.log('Retorno NFE_Cancelamento');\n            console.table(response.xMotivos);\n            console.log('===================================');\n\n            return response.response\n        } catch (error: any) {\n            throw new Error(`NFE_Cancelamento: ${error.message}`)\n        }\n    }\n    async NFE_CienciaDaOperacao(evento: CienciaDaOperacao) {\n        try {\n            const nfeCienciaDaOperacaoService = new NFECienciaDaOperacaoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeCienciaDaOperacao = new NFECienciaDaOperacao(nfeCienciaDaOperacaoService);\n            const response = await nfeCienciaDaOperacao.Exec(evento);\n\n            console.log('Retorno NFE_CienciaDaOperacao');\n            console.table(response.xMotivos);\n            console.log('===================================');\n\n            return response.response\n        } catch (error: any) {\n            throw new Error(`NFE_CienciaDaOperacao: ${error.message}`)\n        }\n    }\n    async NFE_ConfirmacaoDaOperacao(evento: ConfirmacaoDaOperacao) {\n        try {\n            const nfeConfirmacaoDaOperacaoService = new NFECienciaDaOperacaoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeConfirmacaoDaOperacao = new NFEConfirmacaoDaOperacao(nfeConfirmacaoDaOperacaoService);\n            const response = await nfeConfirmacaoDaOperacao.Exec(evento);\n\n            console.log('Retorno NFE_ConfirmacaoDaOperacao');\n            console.table(response.xMotivos);\n            console.log('===================================');\n\n            return response.response\n        } catch (error: any) {\n            throw new Error(`NFE_ConfirmacaoDaOperacao: ${error.message}`)\n        }\n    }\n    async NFE_OperacaoNaoRealizada(evento: OperacaoNaoRealizada) {\n        try {\n            const nfeOperacaoNaoRealizadaService = new NFEOperacaoNaoRealizadaService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeOperacaoNaoRealizada = new NFEOperacaoNaoRealizada(nfeOperacaoNaoRealizadaService);\n            const response = await nfeOperacaoNaoRealizada.Exec(evento);\n\n            console.log('Retorno NFE_OperacaoNaoRealizada');\n            console.table(response.xMotivos);\n            console.log('===================================');\n\n            return response.response\n        } catch (error: any) {\n            throw new Error(`NFE_OperacaoNaoRealizada: ${error.message}`)\n        }\n    }\n    async NFE_CartaDeCorrecao(evento: CartaDeCorrecao) {\n        try {\n            const nfeCartaDeCorrecaoService = new NFECartaDeCorrecaoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeCartaDeCorrecao = new NFECartaDeCorrecao(nfeCartaDeCorrecaoService);\n            const response = await nfeCartaDeCorrecao.Exec(evento);\n\n            console.log('Retorno NFE_CartaDeCorrecao');\n            console.table(response.xMotivos);\n            console.log('===================================');\n\n            return response.response\n        } catch (error: any) {\n            throw new Error(`NFE_CartaDeCorrecao: ${error.message}`)\n        }\n    }\n    async NFE_DesconhecimentoDaOperacao(evento: DesconhecimentoDaOperacao) {\n        try {\n            const nfeDesconhecimentoDaOperacaoService = new NFEDesconhecimentoDaOperacaoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const nfeDesconhecimentoDaOperacao = new NFEDesconhecimentoDaOperacao(nfeDesconhecimentoDaOperacaoService);\n            const response = await nfeDesconhecimentoDaOperacao.Exec(evento);\n\n            console.log('Retorno NFE_DesconhecimentoDaOperacao');\n            console.table(response.xMotivos);\n            console.log('===================================');\n\n            return response.response\n        } catch (error: any) {\n            throw new Error(`NFE_DesconhecimentoDaOperacao: ${error.message}`)\n        }\n    }\n\n    /**\n     * Distribuição DFe\n     */\n    async NFE_DistribuicaoDFe(data: ConsultaNFe) {\n        try {\n            const distribuicaoDFeService = new NFEDistribuicaoDFeService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const distribuicaoDFe = new NFEDistribuicaoDFe(distribuicaoDFeService);\n            const response = await distribuicaoDFe.Exec(data);\n\n            console.log('Retorno NFE_DistribuicaoDFe');\n            console.log(`   ${response.xMotivo}`);\n            console.log('===================================');\n\n            return response.data\n        } catch (error: any) {\n            throw new Error(`NFE_DistribuicaoDFe: ${error.message}`)\n        }\n    }\n    async NFE_DistribuicaoDFePorUltNSU(data: DFePorUltimoNSU) {\n        try {\n            const distribuicaoDFeService = new NFEDistribuicaoDFePorUltNSUService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const distribuicaoDFe = new NFEDistribuicaoDFePorUltNSU(distribuicaoDFeService);\n            const response = await distribuicaoDFe.Exec(data);\n\n            console.log('Retorno NFE_DistribuicaoDFePorUltNSU');\n            console.log(`   ${response.xMotivo}`);\n            console.log('===================================');\n\n            return response.data\n        } catch (error: any) {\n            throw new Error(`NFE_DistribuicaoDFePorUltNSU: ${error.message}`)\n        }\n    }\n    async NFE_DistribuicaoDFePorNSU(data: DFePorNSU) {\n        try {\n            const distribuicaoDFeService = new NFEDistribuicaoDFePorNSUService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const distribuicaoDFe = new NFEDistribuicaoDFePorNSU(distribuicaoDFeService);\n            const response = await distribuicaoDFe.Exec(data);\n\n            console.log('Retorno NFE_DistribuicaoDFePorNSU');\n            console.log(`   ${response.xMotivo}`);\n            console.log('===================================');\n\n            return response.data\n        } catch (error: any) {\n            throw new Error(`NFE_DistribuicaoDFePorNSU: ${error.message}`)\n        }\n    }\n    async NFE_DistribuicaoDFePorChave(data: DFePorChaveNFe) {\n        try {\n            const distribuicaoDFeService = new NFEDistribuicaoDFePorChaveService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const distribuicaoDFe = new NFEDistribuicaoDFePorChave(distribuicaoDFeService);\n            const response = await distribuicaoDFe.Exec(data);\n\n            console.log('Retorno NFE_DistribuicaoDFePorChave');\n            console.log(`   ${response.xMotivo}`);\n            console.log('===================================');\n\n            return response.data\n        } catch (error: any) {\n            throw new Error(`NFE_DistribuicaoDFePorChave: ${error.message}`)\n        }\n    }\n\n    /**\n     * Autorização\n     */\n    async NFE_Autorizacao(data: NFe) {\n        try {\n            const autorizacaoService = new NFEAutorizacaoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const autorizacao = new NFEAutorizacao(autorizacaoService);\n            const response = await autorizacao.Exec(data);\n\n            console.log('Retorno NFE_Autorizacao');\n            console.table(response.xMotivo);\n            console.log('===================================');\n\n            return response.xmls\n        } catch (error: any) {\n            throw new Error(`NFE_Autorizacao: ${error.message}`)\n        }\n    }\n    async NFCE_Autorizacao(data: NFe) {\n        try {\n            const autorizacaoService = new NFCEAutorizacaoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const autorizacao = new NFCEAutorizacao(autorizacaoService);\n            const response = await autorizacao.Exec(data);\n\n            console.log('Retorno NFCE_Autorizacao');\n            console.table(response.xMotivo);\n            console.log('===================================');\n\n            return response.xmls\n        } catch (error: any) {\n            throw new Error(`NFCE_Autorizacao: ${error.message}`)\n        }\n    }\n\n    /**\n     * Inutilização\n     */\n    async NFE_Inutilizacao(data: InutilizacaoData) {\n        try {\n            const inutilizacaoService = new NFEInutilizacaoService(this.environment, this.utility, this.xmlBuilder, this.axios, this.saveFiles, this.gerarConsulta);\n            const inutilizacao = new NFEInutilizacao(inutilizacaoService);\n            const response = await inutilizacao.Exec(data);\n\n            console.log('Retorno NFE_Inutilizacao');\n            console.log(`   ${response.xMotivo}`);\n            console.log('===================================');\n\n            return response\n        } catch (error: any) {\n            throw new Error(`NFE_Inutilizacao: ${error.message}`)\n        }\n    }\n\n\n    /**\n     * DANFE\n     */\n    async NFE_GerarDanfe(data: NFEGerarDanfeProps) {\n        try {\n            const { dfe: { exibirMarcaDaguaDanfe } } = this.environment.getConfig();\n            const distribuicaoDFe = new NFEGerarDanfe(data);\n            const response = await distribuicaoDFe.generatePDF(exibirMarcaDaguaDanfe);\n\n            console.log('Retorno NFE_GerarDanfe');\n            console.log(response.message);\n            console.log('===================================');\n\n            return response\n        } catch (error: any) {\n            throw new Error(`NFE_GerarDanfe: ${error.message}`)\n        }\n    }\n    async NFCE_GerarDanfe(data: NFEGerarDanfeProps) {\n        try {\n            const { dfe: { exibirMarcaDaguaDanfe } } = this.environment.getConfig();\n            const distribuicaoDFe = new NFCEGerarDanfe(data);\n            const response = await distribuicaoDFe.generatePDF(exibirMarcaDaguaDanfe);\n\n            console.log('Retorno NFCE_GerarDanfe');\n            console.log(response.message);\n            console.log('===================================');\n\n            return response\n        } catch (error: any) {\n            throw new Error(`NFCE_GerarDanfe: ${error.message}`)\n        }\n    }\n\n    /**\n     * Método para envio de e-mail\n     * @param {EmailParams} mailParams - Mensagem de texto (aceita html)\n     */\n    NFE_EnviaEmail(mailParams: EmailParams) {\n        try {\n            const mailController = new MailController(this.environment);\n            const response = mailController.sendEmail(mailParams);\n\n            console.log('Retorno NFE_EnviaEmail');\n            console.log('E-mail enviado com sucesso.');\n            console.log('===================================');\n\n            return response\n        } catch (error: any) {\n            throw new Error(`NFE_EnviaEmail: ${error.message}`)\n        }\n    }\n\n    /**\n     * Validação de ambiente\n     */\n    private async validateEnvironment(prop: string): Promise<void> {\n        if (!this.environment.isLoaded) {\n            throw new Error(`Ambiente não carregado. Por favor, carregue o ambiente utilizando o método \"NFE_LoadEnvironment({ sua_configuracao })\" antes de chamar o método ${prop}.`);\n        }\n    }\n}\n\nexport default NFeWizardService;","/*\n * This file is part of NFeWizard-io.\n * \n * NFeWizard-io is free software: you can redistribute it and/or modify\n * it under the terms of the GNU General Public License as published by\n * the Free Software Foundation, either version 3 of the License, or\n * (at your option) any later version.\n * \n * NFeWizard-io is distributed in the hope that it will be useful,\n * but WITHOUT ANY WARRANTY; without even the implied warranty of\n * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\n * GNU General Public License for more details.\n * \n * You should have received a copy of the GNU General Public License\n * along with NFeWizard-io. If not, see <https://www.gnu.org/licenses/>.\n */\nimport {\n    NFeWizardProps,\n    EventoNFe,\n    ConsultaNFe,\n    NFe,\n    InutilizacaoData,\n    NFEGerarDanfeProps,\n    DFePorChaveNFe,\n    DFePorUltimoNSU,\n    DFePorNSU,\n    Cancelamento,\n    CienciaDaOperacao,\n    ConfirmacaoDaOperacao,\n    OperacaoNaoRealizada,\n    CartaDeCorrecao,\n    DesconhecimentoDaOperacao,\n    EPEC,\n    EmailParams,\n} from 'src/core/types';\nimport { NFeWizardImpl, NFeWizardServiceImpl } from '@Interfaces';\nimport NFeWizardService from '@Modules/dfe/nfe/services/NFeWizard/NFeWizardService';\n\nexport default class NFeWizard implements NFeWizardImpl {\n    private nfeWizardService: NFeWizardServiceImpl;\n\n    constructor() {\n        this.nfeWizardService = new NFeWizardService();\n    }\n\n    async NFE_LoadEnvironment({ config }: { config: NFeWizardProps }) {\n        await this.nfeWizardService.NFE_LoadEnvironment({ config });\n    }\n\n    /**\n     * Status Serviço\n     */\n    async NFE_ConsultaStatusServico() {\n        return await this.nfeWizardService.NFE_ConsultaStatusServico();\n    }\n\n    /**\n     * Consulta Protocolo\n     */\n    async NFE_ConsultaProtocolo(chave: string) {\n        return this.nfeWizardService.NFE_ConsultaProtocolo(chave);\n    }\n\n    /**\n     * Recepção de Eventos\n     */\n    async NFE_RecepcaoEvento(evento: EventoNFe) {\n        return await this.nfeWizardService.NFE_RecepcaoEvento(evento);\n    }\n    async NFE_EventoPrevioDeEmissaoEmContingencia(evento: EPEC) {\n        return await this.nfeWizardService.NFE_EventoPrevioDeEmissaoEmContingencia(evento);\n    }\n    async NFE_Cancelamento(evento: Cancelamento) {\n        return await this.nfeWizardService.NFE_Cancelamento(evento);\n    }\n    async NFE_CienciaDaOperacao(evento: CienciaDaOperacao) {\n        return await this.nfeWizardService.NFE_CienciaDaOperacao(evento);\n    }\n    async NFE_ConfirmacaoDaOperacao(evento: ConfirmacaoDaOperacao) {\n        return await this.nfeWizardService.NFE_ConfirmacaoDaOperacao(evento);\n    }\n    async NFE_OperacaoNaoRealizada(evento: OperacaoNaoRealizada) {\n        return await this.nfeWizardService.NFE_OperacaoNaoRealizada(evento);\n    }\n    async NFE_CartaDeCorrecao(evento: CartaDeCorrecao) {\n        return await this.nfeWizardService.NFE_CartaDeCorrecao(evento);\n    }\n    async NFE_DesconhecimentoDaOperacao(evento: DesconhecimentoDaOperacao) {\n        return await this.nfeWizardService.NFE_DesconhecimentoDaOperacao(evento);\n    }\n\n    /**\n     * Distribuição DFe\n     */\n    async NFE_DistribuicaoDFe(data: ConsultaNFe) {\n        return await this.nfeWizardService.NFE_DistribuicaoDFe(data);\n    }\n    async NFE_DistribuicaoDFePorUltNSU(data: DFePorUltimoNSU) {\n        return await this.nfeWizardService.NFE_DistribuicaoDFePorUltNSU(data);\n    }\n    async NFE_DistribuicaoDFePorNSU(data: DFePorNSU) {\n        return await this.nfeWizardService.NFE_DistribuicaoDFePorNSU(data);\n    }\n    async NFE_DistribuicaoDFePorChave(data: DFePorChaveNFe) {\n        return await this.nfeWizardService.NFE_DistribuicaoDFePorChave(data);\n    }\n\n    /**\n     * Autorização\n     */\n    async NFE_Autorizacao(data: NFe) {\n        return await this.nfeWizardService.NFE_Autorizacao(data);\n    }\n    async NFCE_Autorizacao(data: NFe) {\n        return await this.nfeWizardService.NFCE_Autorizacao(data);\n    }\n\n    /**\n     * Inutilização\n     */\n    async NFE_Inutilizacao(data: InutilizacaoData) {\n        return await this.nfeWizardService.NFE_Inutilizacao(data);\n    }\n\n\n    /**\n     * DANFE\n     */\n    async NFE_GerarDanfe(data: NFEGerarDanfeProps) {\n        return await this.nfeWizardService.NFE_GerarDanfe(data);\n    }\n    async NFCE_GerarDanfe(data: NFEGerarDanfeProps) {\n        return await this.nfeWizardService.NFCE_GerarDanfe(data);\n    }\n\n    /**\n     * Método para envio de e-mail\n     * @param {EmailParams} mailParams - Mensagem de texto (aceita html)\n     */\n    NFE_EnviaEmail(mailParams: EmailParams) {\n        return this.nfeWizardService.NFE_EnviaEmail(mailParams);\n    }\n}"],"names":["defaults","explicitCharkey","trim","normalize","normalizeTags","attrkey","charkey","explicitArray","ignoreAttrs","mergeAttrs","explicitRoot","validator","xmlns","explicitChildren","childkey","charsAsChildren","includeWhiteChars","async","strict","attrNameProcessors","attrValueProcessors","tagNameProcessors","valueProcessors","emptyTag","preserveChildrenOrder","rootName","xmldec","version","encoding","standalone","doctype","renderOpts","pretty","indent","newline","headless","chunkSize","cdata","call","this","assign","getValue","isArray","isEmpty","isFunction","isObject","isPlainObject","slice","hasProp","hasOwnProperty","i","key","len","source","sources","target","arguments","length","Object","apply","val","prototype","toString","ref","Array","ctor","proto","getPrototypeOf","constructor","Function","obj","valueOf","Utility","XMLDOMImplementationModule","exports","XMLDOMImplementation","hasFeature","feature","createDocumentType","qualifiedName","publicId","systemId","Error","createDocument","namespaceURI","createHTMLDocument","title","getFeature","XMLDOMErrorHandlerModule","XMLDOMErrorHandler","handleError","error","XMLDOMStringListModule","XMLDOMStringList","arr","defineProperty","get","item","index","contains","str","indexOf","require$$0","require$$1","XMLDOMConfigurationModule","XMLDOMConfiguration","defaultParams","comments","entities","infoset","namespaces","validate","params","create","keys","getParameter","name","canSetParameter","value","setParameter","NodeTypeModule","Element","Attribute","Text","CData","EntityReference","EntityDeclaration","ProcessingInstruction","Comment","Document","DocType","DocumentFragment","NotationDeclaration","Declaration","Raw","AttributeDeclaration","ElementDeclaration","Dummy","NodeType","XMLAttributeModule","XMLAttribute","parent","options","stringify","debugInfo","attValue","type","isId","schemaTypeInfo","set","clone","writer","attribute","filterOptions","isEqualNode","node","prefix","localName","XMLNamedNodeMapModule","XMLNamedNodeMap","nodes","getNamedItem","setNamedItem","oldNode","nodeName","removeNamedItem","getNamedItemNS","setNamedItemNS","removeNamedItemNS","XMLNode","require$$2","require$$3","require$$4","XMLElementModule","superClass","XMLElement","attributes","child","j","ref1","__super__","attribs","isRoot","documentObject","rootObject","children","extend","attributeMap","att","attName","clonedSelf","forEach","clonedChild","push","keepNullAttributes","removeAttribute","element","a","getAttribute","setAttribute","getAttributeNode","setAttributeNode","newAttr","removeAttributeNode","oldAttr","getElementsByTagName","getAttributeNS","setAttributeNS","removeAttributeNS","getAttributeNodeNS","setAttributeNodeNS","getElementsByTagNameNS","hasAttribute","hasAttributeNS","setIdAttribute","setIdAttributeNS","setIdAttributeNode","idAttr","tagname","getElementsByClassName","classNames","XMLCharacterDataModule","XMLCharacterData","substringData","offset","count","appendData","arg","insertData","deleteData","replaceData","data","XMLCDataModule","XMLCData","text","XMLCommentModule","XMLComment","comment","XMLDeclarationModule","XMLDeclaration","xmlVersion","xmlEncoding","xmlStandalone","declaration","XMLDTDAttListModule","XMLDTDAttList","elementName","attributeName","attributeType","defaultValueType","defaultValue","match","dtdAttType","dtdAttDefault","dtdAttList","XMLDTDEntityModule","XMLDTDEntity","pe","pubID","sysID","internal","dtdPubID","dtdSysID","nData","dtdNData","dtdEntityValue","dtdEntity","XMLDTDElementModule","XMLDTDElement","join","dtdElementValue","dtdElement","XMLDTDNotationModule","XMLDTDNotation","dtdNotation","require$$5","require$$6","require$$7","XMLDocTypeModule","XMLDocType","ref2","attList","entity","pEntity","notation","docType","ele","ent","pent","not","up","root","XMLRawModule","XMLRaw","raw","XMLTextModule","XMLText","next","prev","previousSibling","nextSibling","splitText","replaceWholeText","content","XMLProcessingInstructionModule","XMLProcessingInstruction","insTarget","insValue","processingInstruction","XMLDummyModule","XMLDummy","XMLNodeListModule","XMLNodeList","DocumentPositionModule","Disconnected","Preceding","Following","Contains","ContainedBy","ImplementationSpecific","DocumentPosition","XMLNodeModule","parent1","baseURI","require$$8","require$$9","require$$10","require$$11","require$$12","require$$13","childNodeList","document","nodeType","textContent","setParent","results","childNode","k","lastChild","len1","ref3","ignoreDecorators","convertAttKey","substr","separateArrayItems","dummy","keepNullNodes","convertTextKey","convertCDataKey","convertCommentKey","convertRawKey","convertPIKey","instruction","insertBefore","newChild","refChild","removed","splice","insertAfter","remove","concat","commentBefore","commentAfter","instructionBefore","instructionAfter","doc","unshift","dtd","end","importDocument","clonedRoot","nod","txt","dat","com","ins","dec","e","n","t","d","c","r","u","importXMLBuilder","replaceChild","oldChild","removeChild","appendChild","hasChildNodes","cloneNode","deep","isSupported","hasAttributes","compareDocumentPosition","other","res","Math","random","isAncestor","isDescendant","isPreceding","isSameNode","lookupPrefix","isDefaultNamespace","lookupNamespaceURI","setUserData","handler","getUserData","nodePos","thisPos","treePosition","isFollowing","found","pos","foreachTreeNode","func","bind","fn","me","XMLStringifierModule","XMLStringifier","assertLegalName","assertLegalChar","noValidation","textEscape","replace","attEscape","regex","ampregex","noDoubleEncoding","WriterStateModule","None","OpenTag","InsideTag","CloseTag","WriterState","require$$14","require$$15","XMLWriterBaseModule","XMLWriterBase","filteredOptions","ref4","ref5","ref6","allowEmpty","dontPrettyTextNodes","dontprettytextnodes","spaceBeforeSlash","spacebeforeslash","suppressPrettyCount","user","state","level","indentLevel","endline","openAttribute","closeAttribute","openNode","closeNode","writeChildNode","childNodeCount","firstChildNode","prettySuppressed","every","XMLStringWriterModule","XMLStringWriter","XMLDocumentModule","XMLDocument","documentURI","domConfig","writerOptions","createElement","tagName","createDocumentFragment","createTextNode","createComment","createCDATASection","createProcessingInstruction","createAttribute","createEntityReference","importNode","importedNode","createElementNS","createAttributeNS","getElementById","elementId","adoptNode","normalizeDocument","renameNode","createEvent","eventInterface","createRange","createNodeIterator","whatToShow","filter","createTreeWalker","require$$16","require$$17","require$$18","XMLDocumentCBModule","XMLDocumentCB","onData","onEnd","onDataCallback","onEndCallback","currentNode","currentLevel","openTags","documentStarted","documentCompleted","createChildNode","openCurrent","oldValidationFlag","rootNodeName","chunk","isOpen","isClosed","XMLStreamWriterModule","XMLStreamWriter","stream","isLastRootNode","write","builder","escapeCDATA","requiresCDATA","wrapCDATA","lib","begin","stringWriter","implementation","writerState","entry","builder_1","Builder","opts","buildObject","rootObj","render","rootElement","_this","attr","allowSurrogateChars","sax","parser","opt","SAXParser","SAXStream","createStream","MAX_BUFFER_LENGTH","Stream","buffers","clearBuffers","l","q","bufferCheckPosition","lowercase","lowercasetags","looseCase","tags","closed","closedRoot","sawRoot","tag","noscript","S","BEGIN","strictEntities","ENTITIES","XML_ENTITIES","attribList","ns","rootNS","undefined","unquotedAttributeValues","trackPosition","position","line","column","emit","EVENTS","o","F","charAt","BEGIN_WHITESPACE","beginWhiteSpace","TEXT","starti","textNode","substring","isWhitespace","strictFail","TEXT_ENTITY","OPEN_WAKA","startTagPosition","SCRIPT","SCRIPT_ENDING","script","CLOSE_TAG","SGML_DECL","sgmlDecl","isMatch","nameStart","OPEN_TAG","PROC_INST","procInstName","procInstBody","pad","COMMENT","DOCTYPE_DTD","toUpperCase","CDATA","emitNode","DOCTYPE","isQuote","SGML_DECL_QUOTED","DOCTYPE_QUOTED","DOCTYPE_DTD_QUOTED","COMMENT_ENDING","COMMENT_ENDED","textopts","CDATA_ENDING","CDATA_ENDING_2","PROC_INST_ENDING","PROC_INST_BODY","body","nameBody","newTag","openTag","OPEN_TAG_SLASH","ATTRIB","closeTag","attribName","attribValue","ATTRIB_NAME","ATTRIB_VALUE","attrib","ATTRIB_NAME_SAW_WHITE","ATTRIB_VALUE_QUOTED","ATTRIB_VALUE_UNQUOTED","ATTRIB_VALUE_ENTITY_Q","ATTRIB_VALUE_CLOSED","isAttribEnd","ATTRIB_VALUE_ENTITY_U","CLOSE_TAG_SAW_WHITE","notMatch","returnState","buffer","parsedEntity","parseEntity","unparsedEntities","values","includes","entityBody","entityStart","checkBufferLength","maxAllowed","max","maxActual","closeText","m","resume","close","flush","flushBuffers","require","ex","streamWraps","ev","_parser","writable","readable","onend","onerror","er","_decoder","h","removeAllListeners","on","enumerable","configurable","Buffer","isBuffer","SD","StringDecoder","args","XML_NAMESPACE","XMLNS_NAMESPACE","xml","test","stringFromCharCode","floor","fromCodePoint","s","STATE","COMMENT_STARTING","amp","gt","lt","quot","apos","AElig","Aacute","Acirc","Agrave","Aring","Atilde","Auml","Ccedil","ETH","Eacute","Ecirc","Egrave","Euml","Iacute","Icirc","Igrave","Iuml","Ntilde","Oacute","Ocirc","Ograve","Oslash","Otilde","Ouml","THORN","Uacute","Ucirc","Ugrave","Uuml","Yacute","aacute","acirc","aelig","agrave","aring","atilde","auml","ccedil","eacute","ecirc","egrave","eth","euml","iacute","icirc","igrave","iuml","ntilde","oacute","ocirc","ograve","oslash","otilde","ouml","szlig","thorn","uacute","ucirc","ugrave","uuml","yacute","yuml","copy","reg","nbsp","iexcl","cent","pound","curren","yen","brvbar","sect","uml","ordf","laquo","shy","macr","deg","plusmn","sup1","sup2","sup3","acute","micro","para","middot","cedil","ordm","raquo","frac14","frac12","frac34","iquest","times","divide","OElig","oelig","Scaron","scaron","Yuml","fnof","circ","tilde","Alpha","Beta","Gamma","Delta","Epsilon","Zeta","Eta","Theta","Iota","Kappa","Lambda","Mu","Nu","Xi","Omicron","Pi","Rho","Sigma","Tau","Upsilon","Phi","Chi","Psi","Omega","alpha","beta","gamma","delta","epsilon","zeta","eta","theta","iota","kappa","lambda","mu","nu","xi","omicron","pi","rho","sigmaf","sigma","tau","upsilon","phi","chi","psi","omega","thetasym","upsih","piv","ensp","emsp","thinsp","zwnj","zwj","lrm","rlm","ndash","mdash","lsquo","rsquo","sbquo","ldquo","rdquo","bdquo","dagger","Dagger","bull","hellip","permil","prime","Prime","lsaquo","rsaquo","oline","frasl","euro","image","weierp","real","trade","alefsym","larr","uarr","rarr","darr","harr","crarr","lArr","uArr","rArr","dArr","hArr","forall","part","exist","empty","nabla","isin","notin","ni","prod","sum","minus","lowast","radic","prop","infin","ang","and","or","cap","cup","int","there4","sim","cong","asymp","ne","equiv","le","ge","sub","sup","nsub","sube","supe","oplus","otimes","perp","sdot","lceil","rceil","lfloor","rfloor","lang","rang","loz","spades","clubs","hearts","diams","String","fromCharCode","event","message","qname","qualName","split","local","qn","selfClosing","uri","JSON","p","nv","isSelfClosing","toLowerCase","closeTo","pop","x","num","entityLC","numStr","parseInt","isNaN","result","highSurrogate","lowSurrogate","codeUnits","codePoint","Number","isFinite","RangeError","bom","stripBOM","prefixMatch","RegExp","processors","firstCharLowerCase","stripPrefix","parseNumbers","parseFloat","parseBooleans","events","processItem","setImmediate","thing","process","descriptor","Parser","parseStringPromise","parseString","reset","assignOrPush","processAsync","xmlnskey","err","remaining","saxParser","error1","errThrown","newValue","ontext","stack","ended","resultObject","EXPLICIT_CHARKEY","onopentag","processedKey","onclosetag","emptyStr","objClone","old","xpath","getOwnPropertyNames","charChild","oncdata","cb","Promise","resolve","reject","b","xml2js","ValidationError","f","xs","reduce","seed","acc","map","mapped","wrap","pref","suf","prototypeConcat","varArgs","to","nextSource","nextKey","NodeTypes","XPathParser","init","XPath","expression","setIfUnset","Expression","UnaryOperation","rhs","UnaryMinusOperation","BinaryOperation","lhs","OrOperation","AndOperation","EqualsOperation","NotEqualOperation","LessThanOperation","GreaterThanOperation","LessThanOrEqualOperation","GreaterThanOrEqualOperation","PlusOperation","MinusOperation","MultiplyOperation","DivOperation","ModOperation","BarOperation","PathExpr","filterPreds","locpath","findRoot","parentNode","applyStepWithPredicates","step","xpc","applyPredicates","predicates","applyStep","applyStepToNodes","context","flatten","start","LocationPath","abs","steps","Step","axis","nodetest","preds","NodeTest","VariableReference","v","FunctionCall","superclass","reduceActions","locationPath","DESCENDANTORSELF","nodeTest","Utilities","instance_of","filterPredicates","XString","XNumber","absolute","CHILD","ANCESTOR","ANCESTORORSELF","ATTRIBUTE","DESCENDANT","FOLLOWING","FOLLOWINGSIBLING","NAMESPACE","PARENT","PRECEDING","PRECEDINGSIBLING","SELF","commentTest","textTest","anyPiTest","PITest","nameTestAny","NameTestPrefixAny","NameTestQName","actionTable","actionTableNumber","gotoTable","productions","DOUBLEDOT","DOUBLECOLON","DOUBLESLASH","NOTEQUAL","LESSTHANOREQUAL","GREATERTHANOREQUAL","AND","OR","MOD","DIV","MULTIPLYOPERATOR","FUNCTIONNAME","AXISNAME","LITERAL","NUMBER","ASTERISKNAMETEST","QNAME","NCNAMECOLONASTERISK","NODETYPE","PROCESSINGINSTRUCTIONWITHLITERAL","EQUALS","LESSTHAN","GREATERTHAN","PLUS","MINUS","BAR","SLASH","LEFTPARENTHESIS","RIGHTPARENTHESIS","COMMA","AT","LEFTBRACKET","RIGHTBRACKET","DOT","DOLLAR","tokenize","s1","types","number","isLetter","charCodeAt","isNCNameChar","last","delimiter","literal","XPathException","fromMessage","SHIFT","REDUCE","ACCEPT","parse","tokenPos","tokenType","tokenValue","s_","evaluate","contextNode","expressionContextNode","contextSize","contextPosition","isHtml","XML_NAMESPACE_URI","XMLNS_NAMESPACE_URI","negate","bool","booleanValue","equals","notequal","lessthan","greaterthan","lessthanorequal","greaterthanorequal","plus","multiply","div","mod","nodeset","union","ctx","inNodes","pred","predicateMatches","filtered","getRoot","firstNode","virtualRoot","ownerDoc","ownerDocument","newNodes","getOwnerElement","matches","nnm","firstChild","st","nm","pre","nsn","XPathNamespace","outer","applySteps","applyFilter","XNodeSet","nonNodes","toUnsortedArray","applyLocationPath","startNodes","XPathContext","filterResult","addArray","numberValue","predicateString","predicate","predicatesString","filterStr","ownerElement","selectSingleNode","elts","elt","STEPNAMES","console","warn","NAMETESTANY","NAMETESTPREFIXANY","NAMETESTQNAME","PI","NODE","isNodeType","makeNodeTestType","members","newType","makeNodeTypeTest","nodeTypes","stringVal","hasPrefix","isElementOrAttribute","nameSpaceMatches","nNamespace","allowAnyNamespaceForNoPrefix","namespaceResolver","getNamespace","localNameMatches","nLocalName","caseInsensitive","XPATH_NAMESPACE_NODE","nameParts","variable","parts","resolveQName","variableResolver","getVariable","functionName","FunctionResolver","getFunctionFromContext","functionResolver","thisArg","Operators","XBoolean","AVLTree","isXPathNamespace","nodeValue","vr","nr","fr","VariableResolver","NamespaceResolver","Functions","functions","addStandardFunctions","string","stringValue","compareWithString","numberFormat","NaN","strValue","padSmallNumber","numberStr","base","exponent","padLargeNumber","zerosToAppend","compareWithNumber","Boolean","compareWithBoolean","true_","false_","left","right","depth","balance","ldepth","rdepth","rotateRR","rotateLL","rrdepth","nodeBefore","rightBefore","updateInNewLocation","leftBefore","getDepthFromChildren","add","nodeOrder","n1","n2","cpos","d1","d2","m1","m2","n1Par","n2Par","n1isAttr","isAttribute","n2isAttr","cn","childNodes","ret","tree","size","first","stringForNode","stringForContainerNode","isNamespaceNode","namespace","nt","buildTree","self","toArray","toArrayRec","compareWithNodeSet","oInvert","lop","rop","compareWith","curry","totalargs","partial","newProps","ln","id","startsWith","substringBefore","substringAfter","stringLength","normalizeSpace","translate","boolean_","ceiling","round","addFunction","qName","getFunction","documentElement","aname","ids","eNode","baseName","s2","isSpace","eValue","eFrom","eTo","from","cMap","ch","ceil","splitQName","useDefault","coalesceText","del","code","getMessage","exception","msg","INVALID_EXPRESSION_ERR","TYPE_ERR","XPathExpression","XPathNSResolverWrapper","xpathNSResolver","NodeXPathNSResolver","XPathResult","ANY_TYPE","STRING_TYPE","NUMBER_TYPE","BOOLEAN_TYPE","UNORDERED_NODE_ITERATOR_TYPE","resultType","ANY_UNORDERED_NODE_TYPE","FIRST_ORDERED_NODE_TYPE","singleNodeValue","ORDERED_NODE_ITERATOR_TYPE","invalidIteratorState","iteratorIndex","UNORDERED_NODE_SNAPSHOT_TYPE","ORDERED_NODE_SNAPSHOT_TYPE","snapshotLength","installDOM3XPathSupport","createExpression","createNSResolver","getOwnerDocument","detectHtmlDom","iterateNext","snapshotItem","shouldInstall","defaultNSResolver","defaultFunctionResolver","defaultVariableResolver","makeNSResolverFromFunction","makeNSResolver","resolver","makeNSResolverFromObject","makeNSResolverFromMap","convertValue","makeFunctionResolverFromFunction","makeEvaluator","makeFunctionResolver","makeFunctionResolverFromObject","makeFunctionResolverFromMap","makeVariableResolverFromFunction","copyIfPresent","dest","makeContext","makeVariableResolver","variables","evaluatorPrototype","parsedExpression","evaluateNumber","evaluateString","evaluateBoolean","evaluateNodeSet","select","select1","parsed","single","selectWithResolver","useNamespaces","mappings","isNodeLike","isInteger","isNodeOfType","isArrayOfNodes","isElement","isTextNode","isCDATASection","isProcessingInstruction","isComment","isDocumentNode","isDocumentTypeNode","isDocumentFragment","freeze","object","oc","MIME_TYPE","HTML","isHTML","XML_APPLICATION","XML_TEXT","XML_XHTML_APPLICATION","XML_SVG_IMAGE","SVG","XML","XMLNS","conventions","TypeError","find","list","ac","notEmptyString","input","orderedSetReducer","current","toOrderedSet","splitOnASCIIWhitespace","src","_extends","Class","Super","pt","ELEMENT_NODE","ATTRIBUTE_NODE","TEXT_NODE","CDATA_SECTION_NODE","ENTITY_REFERENCE_NODE","ENTITY_NODE","PROCESSING_INSTRUCTION_NODE","COMMENT_NODE","DOCUMENT_NODE","DOCUMENT_TYPE_NODE","DOCUMENT_FRAGMENT_NODE","NOTATION_NODE","ExceptionCode","ExceptionMessage","INDEX_SIZE_ERR","DOMSTRING_SIZE_ERR","HIERARCHY_REQUEST_ERR","WRONG_DOCUMENT_ERR","INVALID_CHARACTER_ERR","NO_DATA_ALLOWED_ERR","NO_MODIFICATION_ALLOWED_ERR","NOT_FOUND_ERR","NOT_SUPPORTED_ERR","INUSE_ATTRIBUTE_ERR","DOMException","captureStackTrace","NodeList","LiveNodeList","refresh","_node","_refresh","_updateLiveList","inc","_inc","ls","__set__","$$length","NamedNodeMap","_findNodeIndex","_addNamedNode","el","_onRemoveAttribute","_onAddAttribute","_nsMap","_removeNamedNode","lastIndex","DOMImplementation","Node","_xmlEncoder","_visitNode","callback","_onUpdateChild","cs","_removeChild","previous","isDocTypeNode","isElementNode","isElementInsertionPossible","parentChildNodes","docTypeNode","isElementReplacementPossible","hasElementChildThatIsNotChild","assertPreInsertionValidity1to5","hasValidParentNodeType","hasInsertableNodeType","assertPreInsertionValidityInDocument","nodeChildNodes","nodeChildElements","parentElementChild","assertPreReplacementValidityInDocument","hasDoctypeChildThatIsNotChild","_insertBefore","_inDocumentAssertion","cp","newFirst","newLast","Attr","CharacterData","CDATASection","DocumentType","Notation","Entity","XMLSerializer","nodeSerializeToString","nodeFilter","buf","refNode","visibleNamespaces","serializeToString","needNamespaceDefine","addSerializedAttribute","attrs","prefixedNodeName","defaultNS","ai","nsi","pubid","sysid","internalSubset","node2","attrs2","_ownerElement","INVALID_STATE_ERR","SYNTAX_ERR","INVALID_MODIFICATION_ERR","NAMESPACE_ERR","INVALID_ACCESS_ERR","rtv","classNamesSet","nodeClassNames","nodeClassNamesSet","arrayIncludes","specified","pl","_appendSingleChild","newText","newNode","getTextContent","dom","HTML_ENTITIES","Abreve","abreve","acd","acE","Acy","acy","af","Afr","afr","aleph","Amacr","amacr","amalg","AMP","And","andand","andd","andslope","andv","ange","angle","angmsd","angmsdaa","angmsdab","angmsdac","angmsdad","angmsdae","angmsdaf","angmsdag","angmsdah","angrt","angrtvb","angrtvbd","angsph","angst","angzarr","Aogon","aogon","Aopf","aopf","ap","apacir","apE","ape","apid","ApplyFunction","approx","approxeq","Ascr","ascr","Assign","ast","asympeq","awconint","awint","backcong","backepsilon","backprime","backsim","backsimeq","Backslash","Barv","barvee","Barwed","barwed","barwedge","bbrk","bbrktbrk","bcong","Bcy","bcy","becaus","Because","because","bemptyv","bepsi","bernou","Bernoullis","beth","between","Bfr","bfr","bigcap","bigcirc","bigcup","bigodot","bigoplus","bigotimes","bigsqcup","bigstar","bigtriangledown","bigtriangleup","biguplus","bigvee","bigwedge","bkarow","blacklozenge","blacksquare","blacktriangle","blacktriangledown","blacktriangleleft","blacktriangleright","blank","blk12","blk14","blk34","block","bne","bnequiv","bNot","bnot","Bopf","bopf","bot","bottom","bowtie","boxbox","boxDL","boxDl","boxdL","boxdl","boxDR","boxDr","boxdR","boxdr","boxH","boxh","boxHD","boxHd","boxhD","boxhd","boxHU","boxHu","boxhU","boxhu","boxminus","boxplus","boxtimes","boxUL","boxUl","boxuL","boxul","boxUR","boxUr","boxuR","boxur","boxV","boxv","boxVH","boxVh","boxvH","boxvh","boxVL","boxVl","boxvL","boxvl","boxVR","boxVr","boxvR","boxvr","bprime","Breve","breve","Bscr","bscr","bsemi","bsim","bsime","bsol","bsolb","bsolhsub","bullet","bump","bumpE","bumpe","Bumpeq","bumpeq","Cacute","cacute","Cap","capand","capbrcup","capcap","capcup","capdot","CapitalDifferentialD","caps","caret","caron","Cayleys","ccaps","Ccaron","ccaron","Ccirc","ccirc","Cconint","ccups","ccupssm","Cdot","cdot","Cedilla","cemptyv","CenterDot","centerdot","Cfr","cfr","CHcy","chcy","check","checkmark","cir","circeq","circlearrowleft","circlearrowright","circledast","circledcirc","circleddash","CircleDot","circledR","circledS","CircleMinus","CirclePlus","CircleTimes","cirE","cire","cirfnint","cirmid","cirscir","ClockwiseContourIntegral","CloseCurlyDoubleQuote","CloseCurlyQuote","clubsuit","Colon","colon","Colone","colone","coloneq","comma","commat","comp","compfn","complement","complexes","congdot","Congruent","Conint","conint","ContourIntegral","Copf","copf","coprod","Coproduct","COPY","copysr","CounterClockwiseContourIntegral","Cross","cross","Cscr","cscr","csub","csube","csup","csupe","ctdot","cudarrl","cudarrr","cuepr","cuesc","cularr","cularrp","Cup","cupbrcap","CupCap","cupcap","cupcup","cupdot","cupor","cups","curarr","curarrm","curlyeqprec","curlyeqsucc","curlyvee","curlywedge","curvearrowleft","curvearrowright","cuvee","cuwed","cwconint","cwint","cylcty","daleth","Darr","dash","Dashv","dashv","dbkarow","dblac","Dcaron","dcaron","Dcy","dcy","DD","dd","ddagger","ddarr","DDotrahd","ddotseq","Del","demptyv","dfisht","Dfr","dfr","dHar","dharl","dharr","DiacriticalAcute","DiacriticalDot","DiacriticalDoubleAcute","DiacriticalGrave","DiacriticalTilde","diam","Diamond","diamond","diamondsuit","die","DifferentialD","digamma","disin","divideontimes","divonx","DJcy","djcy","dlcorn","dlcrop","dollar","Dopf","dopf","Dot","dot","DotDot","doteq","doteqdot","DotEqual","dotminus","dotplus","dotsquare","doublebarwedge","DoubleContourIntegral","DoubleDot","DoubleDownArrow","DoubleLeftArrow","DoubleLeftRightArrow","DoubleLeftTee","DoubleLongLeftArrow","DoubleLongLeftRightArrow","DoubleLongRightArrow","DoubleRightArrow","DoubleRightTee","DoubleUpArrow","DoubleUpDownArrow","DoubleVerticalBar","DownArrow","Downarrow","downarrow","DownArrowBar","DownArrowUpArrow","DownBreve","downdownarrows","downharpoonleft","downharpoonright","DownLeftRightVector","DownLeftTeeVector","DownLeftVector","DownLeftVectorBar","DownRightTeeVector","DownRightVector","DownRightVectorBar","DownTee","DownTeeArrow","drbkarow","drcorn","drcrop","Dscr","dscr","DScy","dscy","dsol","Dstrok","dstrok","dtdot","dtri","dtrif","duarr","duhar","dwangle","DZcy","dzcy","dzigrarr","easter","Ecaron","ecaron","ecir","ecolon","Ecy","ecy","eDDot","Edot","eDot","edot","ee","efDot","Efr","efr","eg","egs","egsdot","elinters","ell","els","elsdot","Emacr","emacr","emptyset","EmptySmallSquare","emptyv","EmptyVerySmallSquare","emsp13","emsp14","ENG","eng","Eogon","eogon","Eopf","eopf","epar","eparsl","eplus","epsi","epsiv","eqcirc","eqcolon","eqsim","eqslantgtr","eqslantless","Equal","EqualTilde","equest","Equilibrium","equivDD","eqvparsl","erarr","erDot","Escr","escr","esdot","Esim","esim","excl","Exists","expectation","ExponentialE","exponentiale","fallingdotseq","Fcy","fcy","female","ffilig","fflig","ffllig","Ffr","ffr","filig","FilledSmallSquare","FilledVerySmallSquare","fjlig","flat","fllig","fltns","Fopf","fopf","ForAll","fork","forkv","Fouriertrf","fpartint","frac13","frac15","frac16","frac18","frac23","frac25","frac35","frac38","frac45","frac56","frac58","frac78","frown","Fscr","fscr","gacute","Gammad","gammad","gap","Gbreve","gbreve","Gcedil","Gcirc","gcirc","Gcy","gcy","Gdot","gdot","gE","gEl","gel","geq","geqq","geqslant","ges","gescc","gesdot","gesdoto","gesdotol","gesl","gesles","Gfr","gfr","Gg","gg","ggg","gimel","GJcy","gjcy","gl","gla","glE","glj","gnap","gnapprox","gnE","gne","gneq","gneqq","gnsim","Gopf","gopf","grave","GreaterEqual","GreaterEqualLess","GreaterFullEqual","GreaterGreater","GreaterLess","GreaterSlantEqual","GreaterTilde","Gscr","gscr","gsim","gsime","gsiml","Gt","GT","gtcc","gtcir","gtdot","gtlPar","gtquest","gtrapprox","gtrarr","gtrdot","gtreqless","gtreqqless","gtrless","gtrsim","gvertneqq","gvnE","Hacek","hairsp","half","hamilt","HARDcy","hardcy","harrcir","harrw","Hat","hbar","Hcirc","hcirc","heartsuit","hercon","Hfr","hfr","HilbertSpace","hksearow","hkswarow","hoarr","homtht","hookleftarrow","hookrightarrow","Hopf","hopf","horbar","HorizontalLine","Hscr","hscr","hslash","Hstrok","hstrok","HumpDownHump","HumpEqual","hybull","hyphen","ic","Icy","icy","Idot","IEcy","iecy","iff","Ifr","ifr","ii","iiiint","iiint","iinfin","iiota","IJlig","ijlig","Im","Imacr","imacr","ImaginaryI","imagline","imagpart","imath","imof","imped","Implies","in","incare","infintie","inodot","Int","intcal","integers","Integral","intercal","Intersection","intlarhk","intprod","InvisibleComma","InvisibleTimes","IOcy","iocy","Iogon","iogon","Iopf","iopf","iprod","Iscr","iscr","isindot","isinE","isins","isinsv","isinv","it","Itilde","itilde","Iukcy","iukcy","Jcirc","jcirc","Jcy","jcy","Jfr","jfr","jmath","Jopf","jopf","Jscr","jscr","Jsercy","jsercy","Jukcy","jukcy","kappav","Kcedil","kcedil","Kcy","kcy","Kfr","kfr","kgreen","KHcy","khcy","KJcy","kjcy","Kopf","kopf","Kscr","kscr","lAarr","Lacute","lacute","laemptyv","lagran","Lang","langd","langle","lap","Laplacetrf","Larr","larrb","larrbfs","larrfs","larrhk","larrlp","larrpl","larrsim","larrtl","lat","lAtail","latail","late","lates","lBarr","lbarr","lbbrk","lbrace","lbrack","lbrke","lbrksld","lbrkslu","Lcaron","lcaron","Lcedil","lcedil","lcub","Lcy","lcy","ldca","ldquor","ldrdhar","ldrushar","ldsh","lE","LeftAngleBracket","LeftArrow","Leftarrow","leftarrow","LeftArrowBar","LeftArrowRightArrow","leftarrowtail","LeftCeiling","LeftDoubleBracket","LeftDownTeeVector","LeftDownVector","LeftDownVectorBar","LeftFloor","leftharpoondown","leftharpoonup","leftleftarrows","LeftRightArrow","Leftrightarrow","leftrightarrow","leftrightarrows","leftrightharpoons","leftrightsquigarrow","LeftRightVector","LeftTee","LeftTeeArrow","LeftTeeVector","leftthreetimes","LeftTriangle","LeftTriangleBar","LeftTriangleEqual","LeftUpDownVector","LeftUpTeeVector","LeftUpVector","LeftUpVectorBar","LeftVector","LeftVectorBar","lEg","leg","leq","leqq","leqslant","les","lescc","lesdot","lesdoto","lesdotor","lesg","lesges","lessapprox","lessdot","lesseqgtr","lesseqqgtr","LessEqualGreater","LessFullEqual","LessGreater","lessgtr","LessLess","lesssim","LessSlantEqual","LessTilde","lfisht","Lfr","lfr","lg","lgE","lHar","lhard","lharu","lharul","lhblk","LJcy","ljcy","Ll","ll","llarr","llcorner","Lleftarrow","llhard","lltri","Lmidot","lmidot","lmoust","lmoustache","lnap","lnapprox","lnE","lne","lneq","lneqq","lnsim","loang","loarr","lobrk","LongLeftArrow","Longleftarrow","longleftarrow","LongLeftRightArrow","Longleftrightarrow","longleftrightarrow","longmapsto","LongRightArrow","Longrightarrow","longrightarrow","looparrowleft","looparrowright","lopar","Lopf","lopf","loplus","lotimes","lowbar","LowerLeftArrow","LowerRightArrow","lozenge","lozf","lpar","lparlt","lrarr","lrcorner","lrhar","lrhard","lrtri","Lscr","lscr","Lsh","lsh","lsim","lsime","lsimg","lsqb","lsquor","Lstrok","lstrok","Lt","LT","ltcc","ltcir","ltdot","lthree","ltimes","ltlarr","ltquest","ltri","ltrie","ltrif","ltrPar","lurdshar","luruhar","lvertneqq","lvnE","male","malt","maltese","Map","mapsto","mapstodown","mapstoleft","mapstoup","marker","mcomma","Mcy","mcy","mDDot","measuredangle","MediumSpace","Mellintrf","Mfr","mfr","mho","mid","midast","midcir","minusb","minusd","minusdu","MinusPlus","mlcp","mldr","mnplus","models","Mopf","mopf","mp","Mscr","mscr","mstpos","multimap","mumap","Nacute","nacute","nang","nap","napE","napid","napos","napprox","natur","natural","naturals","nbump","nbumpe","ncap","Ncaron","ncaron","Ncedil","ncedil","ncong","ncongdot","ncup","Ncy","ncy","nearhk","neArr","nearr","nearrow","nedot","NegativeMediumSpace","NegativeThickSpace","NegativeThinSpace","NegativeVeryThinSpace","nequiv","nesear","nesim","NestedGreaterGreater","NestedLessLess","NewLine","nexist","nexists","Nfr","nfr","ngE","nge","ngeq","ngeqq","ngeqslant","nges","nGg","ngsim","nGt","ngt","ngtr","nGtv","nhArr","nharr","nhpar","nis","nisd","niv","NJcy","njcy","nlArr","nlarr","nldr","nlE","nle","nLeftarrow","nleftarrow","nLeftrightarrow","nleftrightarrow","nleq","nleqq","nleqslant","nles","nless","nLl","nlsim","nLt","nlt","nltri","nltrie","nLtv","nmid","NoBreak","NonBreakingSpace","Nopf","nopf","Not","NotCongruent","NotCupCap","NotDoubleVerticalBar","NotElement","NotEqual","NotEqualTilde","NotExists","NotGreater","NotGreaterEqual","NotGreaterFullEqual","NotGreaterGreater","NotGreaterLess","NotGreaterSlantEqual","NotGreaterTilde","NotHumpDownHump","NotHumpEqual","notindot","notinE","notinva","notinvb","notinvc","NotLeftTriangle","NotLeftTriangleBar","NotLeftTriangleEqual","NotLess","NotLessEqual","NotLessGreater","NotLessLess","NotLessSlantEqual","NotLessTilde","NotNestedGreaterGreater","NotNestedLessLess","notni","notniva","notnivb","notnivc","NotPrecedes","NotPrecedesEqual","NotPrecedesSlantEqual","NotReverseElement","NotRightTriangle","NotRightTriangleBar","NotRightTriangleEqual","NotSquareSubset","NotSquareSubsetEqual","NotSquareSuperset","NotSquareSupersetEqual","NotSubset","NotSubsetEqual","NotSucceeds","NotSucceedsEqual","NotSucceedsSlantEqual","NotSucceedsTilde","NotSuperset","NotSupersetEqual","NotTilde","NotTildeEqual","NotTildeFullEqual","NotTildeTilde","NotVerticalBar","npar","nparallel","nparsl","npart","npolint","npr","nprcue","npre","nprec","npreceq","nrArr","nrarr","nrarrc","nrarrw","nRightarrow","nrightarrow","nrtri","nrtrie","nsc","nsccue","nsce","Nscr","nscr","nshortmid","nshortparallel","nsim","nsime","nsimeq","nsmid","nspar","nsqsube","nsqsupe","nsubE","nsube","nsubset","nsubseteq","nsubseteqq","nsucc","nsucceq","nsup","nsupE","nsupe","nsupset","nsupseteq","nsupseteqq","ntgl","ntlg","ntriangleleft","ntrianglelefteq","ntriangleright","ntrianglerighteq","numero","numsp","nvap","nVDash","nVdash","nvDash","nvdash","nvge","nvgt","nvHarr","nvinfin","nvlArr","nvle","nvlt","nvltrie","nvrArr","nvrtrie","nvsim","nwarhk","nwArr","nwarr","nwarrow","nwnear","oast","ocir","Ocy","ocy","odash","Odblac","odblac","odiv","odot","odsold","ofcir","Ofr","ofr","ogon","ogt","ohbar","ohm","oint","olarr","olcir","olcross","olt","Omacr","omacr","omid","ominus","Oopf","oopf","opar","OpenCurlyDoubleQuote","OpenCurlyQuote","operp","Or","orarr","ord","order","orderof","origof","oror","orslope","orv","oS","Oscr","oscr","osol","Otimes","otimesas","ovbar","OverBar","OverBrace","OverBracket","OverParenthesis","par","parallel","parsim","parsl","PartialD","Pcy","pcy","percnt","period","pertenk","Pfr","pfr","phiv","phmmat","phone","pitchfork","planck","planckh","plankv","plusacir","plusb","pluscir","plusdo","plusdu","pluse","PlusMinus","plussim","plustwo","pm","Poincareplane","pointint","Popf","popf","Pr","pr","prap","prcue","prE","prec","precapprox","preccurlyeq","Precedes","PrecedesEqual","PrecedesSlantEqual","PrecedesTilde","preceq","precnapprox","precneqq","precnsim","precsim","primes","prnap","prnE","prnsim","Product","profalar","profline","profsurf","Proportion","Proportional","propto","prsim","prurel","Pscr","pscr","puncsp","Qfr","qfr","qint","Qopf","qopf","qprime","Qscr","qscr","quaternions","quatint","quest","questeq","QUOT","rAarr","race","Racute","racute","raemptyv","Rang","rangd","range","rangle","Rarr","rarrap","rarrb","rarrbfs","rarrc","rarrfs","rarrhk","rarrlp","rarrpl","rarrsim","Rarrtl","rarrtl","rarrw","rAtail","ratail","ratio","rationals","RBarr","rBarr","rbarr","rbbrk","rbrace","rbrack","rbrke","rbrksld","rbrkslu","Rcaron","rcaron","Rcedil","rcedil","rcub","Rcy","rcy","rdca","rdldhar","rdquor","rdsh","Re","realine","realpart","reals","rect","REG","ReverseElement","ReverseEquilibrium","ReverseUpEquilibrium","rfisht","Rfr","rfr","rHar","rhard","rharu","rharul","rhov","RightAngleBracket","RightArrow","Rightarrow","rightarrow","RightArrowBar","RightArrowLeftArrow","rightarrowtail","RightCeiling","RightDoubleBracket","RightDownTeeVector","RightDownVector","RightDownVectorBar","RightFloor","rightharpoondown","rightharpoonup","rightleftarrows","rightleftharpoons","rightrightarrows","rightsquigarrow","RightTee","RightTeeArrow","RightTeeVector","rightthreetimes","RightTriangle","RightTriangleBar","RightTriangleEqual","RightUpDownVector","RightUpTeeVector","RightUpVector","RightUpVectorBar","RightVector","RightVectorBar","ring","risingdotseq","rlarr","rlhar","rmoust","rmoustache","rnmid","roang","roarr","robrk","ropar","Ropf","ropf","roplus","rotimes","RoundImplies","rpar","rpargt","rppolint","rrarr","Rrightarrow","Rscr","rscr","Rsh","rsh","rsqb","rsquor","rthree","rtimes","rtri","rtrie","rtrif","rtriltri","RuleDelayed","ruluhar","rx","Sacute","sacute","Sc","sc","scap","sccue","scE","sce","Scedil","scedil","Scirc","scirc","scnap","scnE","scnsim","scpolint","scsim","Scy","scy","sdotb","sdote","searhk","seArr","searr","searrow","semi","seswar","setminus","setmn","sext","Sfr","sfr","sfrown","sharp","SHCHcy","shchcy","SHcy","shcy","ShortDownArrow","ShortLeftArrow","shortmid","shortparallel","ShortRightArrow","ShortUpArrow","sigmav","simdot","sime","simeq","simg","simgE","siml","simlE","simne","simplus","simrarr","slarr","SmallCircle","smallsetminus","smashp","smeparsl","smid","smile","smt","smte","smtes","SOFTcy","softcy","sol","solb","solbar","Sopf","sopf","spadesuit","spar","sqcap","sqcaps","sqcup","sqcups","Sqrt","sqsub","sqsube","sqsubset","sqsubseteq","sqsup","sqsupe","sqsupset","sqsupseteq","squ","Square","square","SquareIntersection","SquareSubset","SquareSubsetEqual","SquareSuperset","SquareSupersetEqual","SquareUnion","squarf","squf","srarr","Sscr","sscr","ssetmn","ssmile","sstarf","Star","star","starf","straightepsilon","straightphi","strns","Sub","subdot","subE","subedot","submult","subnE","subne","subplus","subrarr","Subset","subset","subseteq","subseteqq","SubsetEqual","subsetneq","subsetneqq","subsim","subsub","subsup","succ","succapprox","succcurlyeq","Succeeds","SucceedsEqual","SucceedsSlantEqual","SucceedsTilde","succeq","succnapprox","succneqq","succnsim","succsim","SuchThat","Sum","sung","Sup","supdot","supdsub","supE","supedot","Superset","SupersetEqual","suphsol","suphsub","suplarr","supmult","supnE","supne","supplus","Supset","supset","supseteq","supseteqq","supsetneq","supsetneqq","supsim","supsub","supsup","swarhk","swArr","swarr","swarrow","swnwar","Tab","tbrk","Tcaron","tcaron","Tcedil","tcedil","Tcy","tcy","tdot","telrec","Tfr","tfr","Therefore","therefore","thetav","thickapprox","thicksim","ThickSpace","ThinSpace","thkap","thksim","Tilde","TildeEqual","TildeFullEqual","TildeTilde","timesb","timesbar","timesd","tint","toea","top","topbot","topcir","Topf","topf","topfork","tosa","tprime","TRADE","triangle","triangledown","triangleleft","trianglelefteq","triangleq","triangleright","trianglerighteq","tridot","trie","triminus","TripleDot","triplus","trisb","tritime","trpezium","Tscr","tscr","TScy","tscy","TSHcy","tshcy","Tstrok","tstrok","twixt","twoheadleftarrow","twoheadrightarrow","Uarr","Uarrocir","Ubrcy","ubrcy","Ubreve","ubreve","Ucy","ucy","udarr","Udblac","udblac","udhar","ufisht","Ufr","ufr","uHar","uharl","uharr","uhblk","ulcorn","ulcorner","ulcrop","ultri","Umacr","umacr","UnderBar","UnderBrace","UnderBracket","UnderParenthesis","Union","UnionPlus","Uogon","uogon","Uopf","uopf","UpArrow","Uparrow","uparrow","UpArrowBar","UpArrowDownArrow","UpDownArrow","Updownarrow","updownarrow","UpEquilibrium","upharpoonleft","upharpoonright","uplus","UpperLeftArrow","UpperRightArrow","Upsi","upsi","UpTee","UpTeeArrow","upuparrows","urcorn","urcorner","urcrop","Uring","uring","urtri","Uscr","uscr","utdot","Utilde","utilde","utri","utrif","uuarr","uwangle","vangrt","varepsilon","varkappa","varnothing","varphi","varpi","varpropto","vArr","varr","varrho","varsigma","varsubsetneq","varsubsetneqq","varsupsetneq","varsupsetneqq","vartheta","vartriangleleft","vartriangleright","Vbar","vBar","vBarv","Vcy","vcy","VDash","Vdash","vDash","vdash","Vdashl","Vee","vee","veebar","veeeq","vellip","Verbar","verbar","Vert","vert","VerticalBar","VerticalLine","VerticalSeparator","VerticalTilde","VeryThinSpace","Vfr","vfr","vltri","vnsub","vnsup","Vopf","vopf","vprop","vrtri","Vscr","vscr","vsubnE","vsubne","vsupnE","vsupne","Vvdash","vzigzag","Wcirc","wcirc","wedbar","Wedge","wedge","wedgeq","Wfr","wfr","Wopf","wopf","wp","wr","wreath","Wscr","wscr","xcap","xcirc","xcup","xdtri","Xfr","xfr","xhArr","xharr","xlArr","xlarr","xmap","xnis","xodot","Xopf","xopf","xoplus","xotime","xrArr","xrarr","Xscr","xscr","xsqcup","xuplus","xutri","xvee","xwedge","YAcy","yacy","Ycirc","ycirc","Ycy","ycy","Yfr","yfr","YIcy","yicy","Yopf","yopf","Yscr","yscr","YUcy","yucy","Zacute","zacute","Zcaron","zcaron","Zcy","zcy","Zdot","zdot","zeetrf","ZeroWidthSpace","Zfr","zfr","ZHcy","zhcy","zigrarr","Zopf","zopf","Zscr","zscr","entityMap","nameStartChar","nameChar","tagNamePattern","ParseError","locator","XMLReader","copyLocator","lineNumber","columnNumber","parseElementStartPart","currentNSMap","entityReplacer","errorHandler","addAttribute","startIndex","attributeNames","fatalError","addValue","attrName","warning","setTagName","appendElement","domBuilder","localNSMap","nsp","nsPrefix","_copy","startPrefixMapping","startElement","endElement","endPrefixMapping","parseHtmlSpecialContent","elStartEnd","elEndStart","characters","fixSelfClosed","closeMap","lastIndexOf","parseDCC","startCDATA","endCDATA","matchs","exec","lastMatch","startDTD","endDTD","parseInstruction","ElementAttributes","defaultNSMap","startDocument","defaultNSMapCopy","fixedFromCharCode","surrogate1","surrogate2","appendText","xt","lineEnd","linePattern","lineStart","parseStack","tagStart","currentElement","config","endMatch","locator2","endDocument","getLocalName","getLocator","getQName","getURI","normalizeLineEndings","DOMParser","DOMHandler","_locator","_toString","chars","java","hander","parseFromString","mimeType","setDocumentLocator","buildErrorHandler","errorImpl","isCallback","build","ignorableWhitespace","charNode","skippedEntity","comm","impl","dt","domParser","__DOMHandler","assertIsNodeOfType","typeName","dist","assertIsDocumentFragmentNode","assertIsDocumentNode","assertIsCommentNode","assertIsCDATASectionNode","assertIsTextNode","assertIsElementNode","isDocumentFragmentNode","isProcessingInstructionNode","isCDATASectionNode","isAttributeNode","assertIsNodeLike","assertIsArrayOfNodes","isCommentNode","assertIsAttributeNode","assertIsProcessingInstructionNode","assertIsDocumentTypeNode","validateDigestValue","findAncestorNs","derToPem","pemToDer","normalizePem","EXTRACT_X509_CERTS","PEM_FORMAT_REGEX","encodeSpecialCharactersInText","encodeSpecialCharactersInAttribute","findChilds","findChildren","findAttr","isArrayHasLength","isDomNode","array","attrEqualsExplicitly","attrEqualsImplicitly","xml_special_to_encoded_attribute","xml_special_to_encoded_text","pem","collectAncestorNamespaces","nsArray","search","attributeValue","BASE64_REGEX","der","pemLabel","base64Der","docSubsetXpath","docSubset","isElementSubset","ancestorNs","ancestorNsWithoutDuplicate","notOnTheList","returningNs","subsetNsPrefix","findNSPrefix","subsetAttributes","digest","expectedDigest","expectedBuffer","hashAlgorithms","Sha512","Sha256","Sha1","crypto","getHash","shasum","createHash","update","getAlgorithmName","createOptionalCallbackFunction","syncVersion","possibleCallback","isErrorFirstCallback","signatureAlgorithms","HmacSha1","RsaSha256","RsaSha1","types_1","getSignature","signedInfo","privateKey","signer","createSign","sign","verifySignature","material","signatureValue","verifier","createVerify","verify","RsaSha512","createHmac","signedXml","SignedXml","xmldom","utils","c14n","c14nCanonicalization","C14nCanonicalizationWithComments","C14nCanonicalization","includeComments","attrCompare","nsCompare","attr1","attr2","localeCompare","renderAttrs","attrListToRender","renderComment","sort","renderNs","prefixesInScope","defaultNs","defaultNsForPrefix","ancestorNamespaces","newDefaultNs","nsListToRender","currNs","ancestorNamespace","alreadyListed","nsToRender","rendered","processInner","pfxCopy","isBeforeDocument","isAfterDocument","nextNode","previousNode","beforeDocument","super","execC14n","exclusiveCanonicalization","ExclusiveCanonicalizationWithComments","ExclusiveCanonicalization","isPrefixInScope","pf","inclusiveNamespacesPrefixList","elem","CanonicalizationMethod","inclusiveNamespaces","envelopedSignatures","envelopedSignature","EnvelopedSignature","signatureNode","signature","expectedSignatureValue","expectedSignatureValueData","signatures","nodeSignature","signatureAlgorithm","canonicalizationAlgorithm","implicitTransforms","keyInfoAttributes","getKeyInfoContent","getCertFromKeyInfo","signatureXml","originalXmlWithIds","keyInfo","references","CanonicalizationAlgorithms","HashAlgorithms","SignatureAlgorithms","idMode","idAttribute","publicCert","idAttributes","noop","enableHMAC","x509Certs","publicCertMatches","cert","checkSignature","unverifiedSignedInfoCanon","getCanonSignedInfoXml","unverifiedSignedInfoDoc","reference","loadReference","getReferences","validateReference","findSignatureAlgorithm","c14nOptions","getCanonXml","getCanonReferenceXml","transforms","calculateSignatureValue","signedInfoCanon","algo","findCanonicalizationAlgorithm","findHashAlgorithm","validateElementAgainstReferences","elemOrXpath","firstElem","canonXml","digestAlgorithm","digestValue","num_elements_for_id","tmp_elemXpath","tmp_elem","getValidatedNode","xpathSelector","validationError","selectedValue","findSignatures","loadSignature","signedInfoNodes","canonicalizationAlgorithmForSignedInfo","temporaryCanonSignedInfo","signedInfoDoc","digestAlgoNode","digestAlgo","transformsNode","transformsAll","transform","transformAttr","flatMap","refUri","addReference","isEmptyUri","computeSignature","callbackParam","xmlNsAttr","signatureAttrs","currentPrefix","validActions","location","existingPrefixes","action","createSignedInfo","getKeyInfo","existingPrefixesString","dummySignatureWrapper","signatureDoc","referenceNode","err2","err3","signedInfoNode","createSignature","keyInfoAttrs","keyInfoContent","createReferences","ensureHasId","trans","transformedXml","transformName","some","getSignatureXml","getOriginalXmlWithIds","getSignedXml","ds","__createBinding","k2","desc","getOwnPropertyDescriptor","__esModule","__exportStar","signed_xml_1","XmlBuilder","environment","assinarXML","tagAssinar","signedXmlObj","getCert","getCertKey","serializeXml","rootTag","gerarXml","xmlObject","buildSoapEnvelope","soapMethod","soapVersion","rootTagObj","soapNamespaces","soap12","soap","soapNamespace","soapEnvelopeObj","$","bodyContent","nfeDadosMsg","_","baseDir","path","dirname","fileURLToPath","__filename","href","currentScript","URL","getSchema","metodo","pathSchemas","schema","NFEStatusServico","NFEConsultaProtocolo","RecepcaoEvento","NFeDistribuicaoDFe","NFEAutorizacao","NFEInutilizacao","NFERetAutorizacao","basePath","schemaPath","arrayHelper","optionsHelper","copyOptions","ensureFlagExists","ensureSpacesExists","spaces","ensureAlwaysArrayExists","alwaysArray","ensureKeyExists","compact","checkFnExists","helper","nativeType","nValue","bValue","addField","instructionFn","temp","instructionNameFn","elementsKey","typeKey","nameKey","instructionHasAttributes","attributesKey","instructionKey","addParent","parentKey","manipulateAttributes","attributesFn","nativeTypeAttributes","attributeValueFn","attributeNameFn","onInstruction","attrsRegExp","ignoreDeclaration","declarationKey","ignoreInstruction","onStartElement","elementNameFn","ignoreAttributes","alwaysChildren","onText","ignoreText","captureSpacesBetweenElements","sanitize","onComment","ignoreComment","onEndElement","parentElement","onCdata","ignoreCdata","onDoctype","ignoreDoctype","onError","note","userOptions","validateOptions","oncomment","ondoctype","onprocessinginstruction","xml2json","js","currentElementName","writeIndentation","firstLine","writeAttributes","quote","noQuotesForNativeAttributes","indentAttributes","writeDeclaration","writeInstruction","instructionName","instructionValue","writeComment","commentFn","writeCdata","cdataFn","writeDoctype","doctypeFn","writeText","textFn","writeElements","elements","writeElement","withClosingTag","fullTagEmptyElementFn","fullTagEmptyElement","hasContent","indentText","indentCdata","indentInstruction","commentKey","doctypeKey","cdataKey","textKey","hasContentCompact","anyContent","writeElementCompact","writeElementsCompact","js2xml","json2xml","json","XmlParser","findInObj","chave","removeJsonTextAttribute","pOpKeys","_parent","keyName","arrOfKey","getStatusServicoBody","jsonData","getConsultaProtocoloBody","getRecepcaoEventoBody","getDistribuicaoDFe","getDistribuicaoDFeProcBody","getDistribuicaoDFeResBody","getDistribuicaoDFeEventBody","getAutorizacaoEventBody","getAutorizacaoFinalEventBody","getAutorizacaoRetornoEventBody","getInutilizacaoRetornoEventBody","convertXmlToJson","nsu","jsonAsString","convert.xml2json","jsonBody","loader","merger","assemble","resolveIncludes","normalizeRegexPatterns","mergeProperties","schemaAttributes","extractSchemaAttributes","mergeSchemaAttributes","getSchemaAttributes","load","readFile","applySchemaAttributes","entries","reorderSchemaDirectives","strategy","merge","setMergeStrategy","cjs","xmlParser","createDir","fs","existsSync","mkdirSync","recursive","createFile","fileName","file","extension","writeFileSync","salvaJSON","props","pathJson","salvaXMLFromJson","xmlInJson","pathXml","dfe","pathXMLRetorno","chNFe","salvaXML","getSoapInfo1","uf","methodInfo","method","getSoapInfo","servicos","NFeServicosUrl","chaveMethod","chaveSoap","methodServices","methodUrl","getLatestURLConsulta","soapServices","soapUrl","getLatestURLConsultaFix","temp_urls","referencedUrls","versions","toFixed","setAmbiente","ambienteNacional","versao","getConfig","ambiente","nfe","versaoDF","chaveMae","chaveFilha","UF","getWebServiceUrl","urls","Usar","url","getUrlNFCe","formatErrorMessage","errorCode","errorDescription","validateSchemaJsBased","completeXSD","xsdAssembler","xmlDoc","libxmljs","parseXml","xsdDoc","baseUrl","success","validationErrors","validateSchemaJavaBased","xsdValidator","validateXML","validationResult","valid","messages","verificaRejeicao","responseInJson","xMotivo","infProt","salvaRetorno","getProtNFe","xmlRetorno","protNFe","nRec","nRecTag","protNFeTag","getRequestLogFileName","tipo","salvaConsulta","xmlConsulta","xmlFormated","armazenarXMLConsulta","pathXMLConsulta","armazenarXMLConsultaComTagSoap","xmlConsultaASalvar","armazenarXMLRetorno","armazenarRetornoEmJSON","GerarConsulta","utility","xmlBuilder","gerarConsulta","useForSchemaValidation","agent","getHttpAgent","webServiceUrl","_typeof","Symbol","iterator","toInteger","dirtyNumber","requiredArgs","required","toDate","argument","argStr","Date","getTime","defaultOptions","getDefaultOptions","isValid","dirtyDate","isDate","date","subMilliseconds","dirtyAmount","addMilliseconds","timestamp","amount","startOfUTCISOWeek","day","getUTCDay","diff","setUTCDate","getUTCDate","setUTCHours","getUTCISOWeekYear","year","getUTCFullYear","fourthOfJanuaryOfNextYear","setUTCFullYear","startOfNextYear","fourthOfJanuaryOfThisYear","startOfThisYear","getUTCISOWeek","startOfUTCISOWeekYear","fourthOfJanuary","startOfUTCWeek","_ref","_ref2","_ref3","_options$weekStartsOn","_options$locale","_options$locale$optio","_defaultOptions$local","_defaultOptions$local2","weekStartsOn","locale","getUTCWeekYear","_options$firstWeekCon","firstWeekContainsDate","firstWeekOfNextYear","firstWeekOfThisYear","getUTCWeek","startOfUTCWeekYear","firstWeek","addLeadingZeros","targetLength","output","formatters","y","token","signedYear","M","month","getUTCMonth","dayPeriodEnumValue","getUTCHours","H","getUTCMinutes","getUTCSeconds","numberOfDigits","milliseconds","getUTCMilliseconds","pow","formatters$3","dayPeriodEnum","G","localize","era","width","ordinalNumber","unit","lightFormatters","Y","signedWeekYear","weekYear","R","Q","quarter","L","w","week","I","isoWeek","D","dayOfYear","getUTCDayOfYear","setUTCMonth","difference","E","dayOfWeek","localDayOfWeek","isoDayOfWeek","dayPeriod","hours","B","K","X","_localize","timezoneOffset","_originalDate","getTimezoneOffset","formatTimezoneWithOptionalMinutes","formatTimezone","O","formatTimezoneShort","z","originalDate","T","dirtyDelimiter","absOffset","minutes","formatters$1","dateLongFormatter","pattern","formatLong","timeLongFormatter","time","longFormatters","P","dateTimeLongFormatter","dateTimeFormat","matchResult","datePattern","timePattern","dateTime","longFormatters$1","protectedDayOfYearTokens","protectedWeekYearTokens","throwProtectedError","format","formatDistanceLocale","lessThanXSeconds","one","xSeconds","halfAMinute","lessThanXMinutes","xMinutes","aboutXHours","xHours","xDays","aboutXWeeks","xWeeks","aboutXMonths","xMonths","aboutXYears","xYears","overXYears","almostXYears","formatDistance$1","formatDistance","addSuffix","comparison","buildFormatLongFn","defaultWidth","formats","full","long","medium","short","formatRelativeLocale","lastWeek","yesterday","today","tomorrow","nextWeek","formatRelative$1","formatRelative","_date","_baseDate","_options","buildLocalizeFn","dirtyIndex","valuesArray","formattingValues","defaultFormattingWidth","_defaultWidth","_width","argumentCallback","buildMatchFn","matchPattern","matchPatterns","defaultMatchWidth","matchedString","parsePatterns","defaultParseWidth","findIndex","findKey","valueCallback","rest","defaultLocale","rem100","narrow","abbreviated","wide","am","midnight","noon","morning","afternoon","evening","night","buildMatchPatternFn","parseResult","parsePattern","any","formattingTokensRegExp","longFormattingTokensRegExp","escapedStringRegExp","doubleQuoteRegExp","unescapedLatinCharacterRegExp","dirtyFormatStr","_ref4","_options$locale2","_options$locale2$opti","_ref5","_ref6","_ref7","_options$locale3","_options$locale3$opti","_defaultOptions$local3","_defaultOptions$local4","formatStr","getTimezoneOffsetInMilliseconds","utcDate","UTC","getFullYear","getMonth","getDate","getHours","getMinutes","getSeconds","getMilliseconds","formatterOptions","firstCharacter","longFormatter","cleanEscapedString","matched","formatter","useAdditionalWeekYearTokens","isProtectedWeekYearToken","useAdditionalDayOfYearTokens","isProtectedDayOfYearToken","parseISO","_options$additionalDi","additionalDigits","dateStrings","splitDateString","dateString","timeString","patterns","dateTimeDelimiter","timeZoneDelimiter","timezone","parseYearResult","parseYear","captures","restDateString","century","parseDate","dateRegex","isWeekDate","parseDateUnit","validateWeekDate","_year","dayOfISOWeekYear","isoWeekYear","fourthOfJanuaryDay","validateDate","daysInMonths","isLeapYearIndex","validateDayOfYearDate","parseTime","timeRegex","parseTimeUnit","seconds","validateTime","setFullYear","setHours","parseTimezone","timezoneString","timezoneRegex","validateTimezone","_hours","SaveFiles","salvaArquivos","dateAndTimeInFileName","incluirTimestampNoNomeDosArquivos","salvarArquivo","fileType","dtaTime","createFileName","pathRetornoEmJSON","kindOf","cache","kindOfTest","typeOfTest","isUndefined","isArrayBuffer","isString","isNumber","toStringTag","isFile","isBlob","isFileList","isURLSearchParams","isReadableStream","isRequest","isResponse","isHeaders","allOwnKeys","_key","_global","globalThis","window","global","isContextDefined","isTypedArray","TypedArray","Uint8Array","isHTMLForm","isRegExp","reduceDescriptors","reducer","descriptors","getOwnPropertyDescriptors","reducedDescriptors","defineProperties","isAsyncFn","_setImmediate","setImmediateSupported","postMessageSupported","postMessage","callbacks","addEventListener","shift","setTimeout","asap","queueMicrotask","nextTick","utils$3","isFormData","kind","FormData","append","isArrayBufferView","ArrayBuffer","isView","isBoolean","isStream","pipe","caseless","assignValue","targetKey","inherits","superConstructor","toFlatObject","sourceObj","destObj","propFilter","merged","endsWith","searchString","forEachEntry","done","pair","matchAll","regExp","hasOwnProp","freezeMethods","toObjectSet","arrayOrString","define","toCamelCase","replacer","p1","p2","toFiniteNumber","isSpecCompliantForm","toJSONObject","visit","reducedValue","isThenable","then","catch","AxiosError","request","response","status","toJSON","description","util","DelayedStream","dataSize","maxDataSize","pauseStream","_maxDataSizeExceeded","_released","_bufferedEvents","delayed_stream","delayedStream","option","realEmit","_handleEmit","pause","setEncoding","release","_checkIfMaxDataSizeExceeded","CombinedStream","pauseStreams","_streams","_currentStream","_insideLoop","_pendingNext","combined_stream","combinedStream","isStreamLike","newStream","Infinity","_checkDataSize","_handleErrors","_getNext","_realGetNext","_pipeNext","_emitError","_reset","destroy","_updateDataSize","customProps","axiosError","cause","db","mimeDb","extname","EXTRACT_TYPE_REGEXP","TEXT_TYPE_REGEXP","charset","mime","charsets","lookup","contentType","exts","extensions","populateMaps","preference","forEachMimeType","defer","defer_1","async_1","isAsync","async_callback","nextTick_callback","clean","jobs","abort_1","abort","iterate_1","iterate","runJob","aborter","state_1","sortMethod","isNamedList","initState","keyedList","terminator_1","terminator","parallel_1","ascending","serialOrderedModule","serialOrdered","iteratorHandler","descending","serial_1","serial","asynckit","populate","dst","http","https","parseUrl","_overheadLength","_valueLength","_valuesToMeasure","form_data","LINE_BREAK","DEFAULT_CONTENT_TYPE","field","filename","_error","header","_multiPartHeader","footer","_multiPartFooter","_trackLength","valueLength","knownLength","byteLength","_lengthRetriever","stat","fileSize","headers","contentDisposition","_getContentDisposition","_getContentType","contents","getBoundary","filepath","basename","client","_httpMessage","_lastBoundary","getHeaders","userHeaders","formHeaders","setBoundary","boundary","_boundary","_generateBoundary","getBuffer","dataBuffer","alloc","getLengthSync","hasKnownLength","getLength","submit","port","pathname","host","hostname","protocol","setHeader","onResponse","responce","removeListener","isVisitable","removeBrackets","renderKey","dots","each","toFormData","formData","PlatformFormData","metaTokens","indexes","defined","visitor","defaultVisitor","useBlob","Blob","toISOString","isFlatArray","exposedHelpers","encode","charMap","encodeURIComponent","AxiosURLSearchParams","_pairs","buildURL","_encode","serialize","serializeFn","serializedParams","hashmarkIndex","encoder","InterceptorManager$1","InterceptorManager","handlers","use","fulfilled","rejected","synchronous","runWhen","eject","clear","forEachHandler","transitionalDefaults","silentJSONParsing","forcedJSONParsing","clarifyTimeoutError","URLSearchParams","ALPHA","ALPHABET","DIGIT","ALPHA_DIGIT","platform$1","isNode","classes","generateString","alphabet","randomValues","Uint32Array","randomFillSync","protocols","hasBrowserEnv","_navigator","navigator","hasStandardBrowserEnv","product","hasStandardBrowserWebWorkerEnv","WorkerGlobalScope","importScripts","origin","platform","formDataToJSON","buildPath","isNumericKey","isLast","arrayToObject","parsePropPath","transitional","adapter","transformRequest","getContentType","hasJSONContentType","isObjectPayload","setContentType","toURLEncodedForm","helpers","formSerializer","_FormData","env","stringifySafely","rawValue","transformResponse","JSONRequested","responseType","strictJSONParsing","ERR_BAD_RESPONSE","timeout","xsrfCookieName","xsrfHeaderName","maxContentLength","maxBodyLength","validateStatus","common","Accept","defaults$1","ignoreDuplicateOf","$internals","normalizeHeader","normalizeValue","matchHeaderValue","isHeaderNameFilter","AxiosHeaders","valueOrRewrite","rewrite","_value","_header","_rewrite","lHeader","setHeaders","rawHeaders","parseHeaders","parseTokens","tokens","tokensRE","has","matcher","deleted","deleteHeader","normalized","formatHeader","char","targets","asStrings","computed","accessor","accessors","defineAccessor","buildAccessors","accessorName","methodName","arg1","arg2","arg3","headerValue","AxiosHeaders$1","transformData","fns","isCancel","__CANCEL__","CanceledError","ERR_CANCELED","settle","ERR_BAD_REQUEST","buildFullPath","baseURL","requestedURL","allowAbsoluteUrls","isRelativeUrl","isAbsoluteURL","combineURLs","relativeURL","DEFAULT_PORTS","ftp","gopher","ws","wss","stringEndsWith","getEnv","proxyFromEnv","getProxyForUrl","parsedUrl","shouldProxy","NO_PROXY","proxy","parsedProxy","parsedProxyHostname","parsedProxyPort","plural","ms","msAbs","isPlural","fmtLong","fmtShort","setup","createDebug","prevTime","namespacesCache","enabledCache","enableOverride","debug","enabled","curr","coerce","formatArgs","log","useColors","color","selectColor","newDebug","toNamespace","regexp","default","disable","names","skips","enable","save","humanize","hash","colors","hasFlag","flag","argv","terminatorPosition","tty","inspectOpts","stderr","formatWithOptions","colorCode","module","hideDate","DEBUG","isatty","fd","deprecate","supportsColor","os","forceColor","translateLevel","hasBasic","has256","has16m","haveStream","streamIsTTY","min","TERM","osRelease","CI_NAME","TEAMCITY_VERSION","COLORTERM","TERM_PROGRAM_VERSION","TERM_PROGRAM","FORCE_COLOR","supportsColor_1","getSupportLevel","isTTY","stdout","inspect","browser","__nwjs","srcModule","lastC","storage","setItem","removeItem","getItem","userAgent","style","WebkitAppearance","firebug","table","$1","localstorage","localStorage","warned","Writable","assert","debug_1","useNativeURL","preservedUrlFields","eventHandlers","_redirectable","InvalidUrlError","createErrorType","RedirectionError","TooManyRedirectsError","MaxBodyLengthExceededError","WriteAfterEndError","RedirectableRequest","responseCallback","_sanitizeOptions","_ended","_ending","_redirectCount","_redirects","_requestBodyLength","_requestBodyBuffers","_onNativeResponse","_processResponse","_performRequest","maxRedirects","nativeProtocols","scheme","nativeProtocol","wrappedProtocol","isURL","spreadUrlObject","validateUrl","equal","wrappedRequest","urlObject","spread","removeMatchingHeaders","lastValue","baseClass","CustomError","properties","destroyRequest","_currentRequest","currentRequest","removeHeader","msecs","destroyOnTimeout","socket","addListener","startTimer","_timeout","clearTimeout","clearTimer","once","property","searchPos","agents","_currentUrl","_isRedirect","writeNext","finished","statusCode","trackRedirects","requestHeaders","followRedirects","responseUrl","redirects","beforeRedirect","Host","req","getHeader","currentHostHeader","currentUrlParts","currentHost","currentUrl","redirectUrl","resolveUrl","relative","isSubdomain","subdomain","domain","responseDetails","requestDetails","followRedirectsModule","parseProtocol","DATA_URL_PATTERN","kInternals","AxiosTransformStream","Transform","readableHighWaterMark","maxRate","minChunkSize","timeWindow","ticksRate","samplesCount","internals","bytesSeen","isCaptured","notifiedBytesLoaded","ts","now","bytes","onReadCallback","_read","_transform","bytesThreshold","pushChunk","_chunk","_callback","transformChunk","bytesLeft","chunkRemainder","maxChunkSize","passed","subarray","transformNextChunk","AxiosTransformStream$1","asyncIterator","readBlob$1","blob","arrayBuffer","BOUNDARY_ALPHABET","textEncoder","TextEncoder","CRLF_BYTES","FormDataPart","escapeName","isStringValue","contentLength","readBlob","formDataToStream$1","form","headersHandler","boundaryBytes","footerBytes","computedHeaders","Readable","ZlibHeaderTransformStream","__transform","ZlibHeaderTransformStream$1","callbackify$1","progressEventReducer","listener","isDownloadStream","freq","bytesNotified","_speedometer","speedometer","timestamps","firstSampleTS","head","tail","chunkLength","startedAt","bytesCount","throttle","lastArgs","timer","threshold","invoke","loaded","total","lengthComputable","progressBytes","rate","progress","estimated","progressEventDecorator","throttled","asyncDecorator","zlibOptions","zlib","constants","Z_SYNC_FLUSH","finishFlush","brotliOptions","BROTLI_OPERATION_FLUSH","isBrotliSupported","createBrotliDecompress","httpFollow","httpsFollow","isHttps","supportedProtocols","flushOnFinish","dispatchBeforeRedirect","beforeRedirects","setProxy","configProxy","proxyUrl","username","auth","password","base64","proxyHost","redirectOptions","isHttpAdapterSupported","buildAddressEntry","address","family","resolveFamily","httpAdapter","asyncExecutor","dispatchHttpRequest","onDone","responseEncoding","isDone","_lookup","callbackify","arg0","addresses","addr","all","emitter","EventEmitter","onFinished","cancelToken","unsubscribe","signal","removeEventListener","reason","isRejected","subscribe","aborted","fullPath","convertedData","statusText","fromDataURI","asBlob","_Blob","ERR_INVALID_URL","isBase64","decodeURIComponent","ERR_NOT_SUPPORT","onUploadProgress","onDownloadProgress","maxUploadRate","maxDownloadRate","userBoundary","formDataToStream","hasContentLength","promisify","setContentLength","getContentLength","objectMode","pipeline","delete","paramsSerializer","customErr","exists","httpAgent","httpsAgent","transport","socketPath","isHttpsRequest","insecureHTTPParser","handleResponse","destroyed","streams","responseLength","transformStream","responseStream","lastRequest","decompress","createUnzip","offListeners","statusMessage","responseBuffer","totalResponseBytes","handleStreamData","handlerStreamAborted","handleStreamError","handleStreamEnd","responseData","handleRequestError","handleRequestSocket","setKeepAlive","ERR_BAD_OPTION_VALUE","handleRequestTimeout","timeoutErrorMessage","ETIMEDOUT","ECONNABORTED","errored","_reject","onDoneHandler","isURLSameOrigin","isMSIE","cookies$1","expires","secure","cookie","toGMTString","read","headersToObject","mergeConfig","config1","config2","getMergedValue","mergeDeepProperties","valueFromConfig2","defaultToConfig2","mergeDirectKeys","mergeMap","timeoutMessage","withCredentials","withXSRFToken","computeConfigValue","configValue","resolveConfig","newConfig","btoa","unescape","xsrfValue","cookies","xhrAdapter","XMLHttpRequest","dispatchXhrRequest","_config","requestData","onCanceled","uploadThrottled","downloadThrottled","flushUpload","flushDownload","onloadend","responseHeaders","getAllResponseHeaders","_resolve","responseText","open","onreadystatechange","handleLoad","readyState","responseURL","onabort","handleAbort","ERR_NETWORK","ontimeout","handleTimeout","setRequestHeader","upload","cancel","send","composeSignals$1","signals","controller","AbortController","streamChunk","readStream","reader","getReader","trackStream","onProgress","onFinish","iterable","readBytes","_onFinish","ReadableStream","pull","loadedBytes","enqueue","return","highWaterMark","isFetchSupported","fetch","Request","Response","isReadableStreamSupported","encodeText","supportsRequestStream","duplexAccessed","hasContentType","duplex","supportsResponseStream","resolvers","resolveBodyLength","_request","getBodyLength","fetchAdapter","fetchOptions","composedSignal","composeSignals","toAbortSignal","requestContentLength","contentTypeHeader","isCredentialsSupported","credentials","isStreamResponse","responseContentLength","knownAdapters","xhr","renderReason","isResolvedHandle","adapters","nameOrAdapter","rejectedReasons","reasons","throwIfCancellationRequested","throwIfRequested","dispatchRequest","onAdapterResolution","onAdapterRejection","validators","deprecatedWarnings","formatMessage","ERR_DEPRECATED","spelling","correctSpelling","assertOptions","allowUnknown","ERR_BAD_OPTION","Axios","instanceConfig","interceptors","configOrUrl","boolean","function","withXsrfToken","contextHeaders","requestInterceptorChain","synchronousRequestInterceptors","unshiftRequestInterceptors","interceptor","responseInterceptorChain","promise","pushResponseInterceptors","chain","onFulfilled","onRejected","getUri","forEachMethodNoData","forEachMethodWithData","generateHTTPMethod","isForm","httpMethod","Axios$1","CancelToken","executor","resolvePromise","promiseExecutor","_listeners","onfulfilled","CancelToken$1","HttpStatusCode","Continue","SwitchingProtocols","Processing","EarlyHints","Ok","Created","Accepted","NonAuthoritativeInformation","NoContent","ResetContent","PartialContent","MultiStatus","AlreadyReported","ImUsed","MultipleChoices","MovedPermanently","Found","SeeOther","NotModified","UseProxy","Unused","TemporaryRedirect","PermanentRedirect","BadRequest","Unauthorized","PaymentRequired","Forbidden","NotFound","MethodNotAllowed","NotAcceptable","ProxyAuthenticationRequired","RequestTimeout","Conflict","Gone","LengthRequired","PreconditionFailed","PayloadTooLarge","UriTooLong","UnsupportedMediaType","RangeNotSatisfiable","ExpectationFailed","ImATeapot","MisdirectedRequest","UnprocessableEntity","Locked","FailedDependency","TooEarly","UpgradeRequired","PreconditionRequired","TooManyRequests","RequestHeaderFieldsTooLarge","UnavailableForLegalReasons","InternalServerError","NotImplemented","BadGateway","ServiceUnavailable","GatewayTimeout","HttpVersionNotSupported","VariantAlsoNegotiates","InsufficientStorage","LoopDetected","NotExtended","NetworkAuthenticationRequired","HttpStatusCode$1","axios","createInstance","defaultConfig","instance","VERSION","Cancel","promises","isAxiosError","payload","formToJSON","getAdapter","axios$1","AxiosHttpClient","HttpClientBuilder","httpClient","createHttpClient","axiosConfig","connection","ValidateEnvironment","checkRequiredSettings","requiredConfigFields","missingConfigurations","errors","tableData","categoryKey","category","fields","fieldKey","missingConfig","Categoria","Faltando","forge","usePureJavaScript","api","baseN","_reverseAlphabets","maxline","digits","carry","_encodeWithByteBuffer","at","decode","reverse","utilModule","_checkBitsParam","ByteStringBuffer","putByte","_constructedStringLength","stopPropagation","MutationObserver","observe","oldSetImmediate","isNodejs","globalScope","ByteBuffer","_optimizeConstructedString","putBytes","fillWithByte","putString","encodeUtf8","putInt16","putInt24","putInt32","putInt16Le","putInt24Le","putInt32Le","putInt","putSignedInt","putBuffer","getBytes","getByte","getInt16","rval","getInt24","getInt32","getInt16Le","getInt24Le","getInt32Le","getInt","getSignedInt","setAt","createBuffer","truncate","toHex","decodeUtf8","DataBuffer","readOffset","growSize","DataView","byteOffset","writeOffset","accommodate","setUint8","view","binary","hex","Uint16Array","utf16","setInt16","setInt8","setInt32","getInt8","getUint8","utf8","fillString","xorBytes","s3","hexToBytes","bytesToHex","int32ToBytes","_base64","_base64Idx","_base58","encode64","chr1","chr2","chr3","decode64","enc1","enc2","enc3","enc4","escape","base58","out","deflate","inflate","_setStorageObject","_getStorageObject","_setItem","_getItem","_removeItem","_clearItems","_callStorageFunction","idx","clearItems","re","argi","formatNumber","decimals","dec_point","thousands_sep","formatSize","bytesFromIP","ip","bytesFromIPv4","bytesFromIPv6","blanks","zeros","bytesToIP","bytesToIPv4","bytesToIPv6","zeroGroups","zeroMaxGroup","group","estimateCores","cores","hardwareConcurrency","Worker","blobUrl","createObjectURL","et","sample","samples","numWorkers","avg","revokeObjectURL","workers","worker","terminate","overlaps","r1","overlap","r2","cipher","algorithms","createCipher","algorithm","getAlgorithm","BlockCipher","decrypt","createDecipher","registerAlgorithm","mode","blockSize","_finish","_input","_op","encrypt","_decrypt","initialize","finish","unpad","overflow","afterFinish","modes","cipherModesModule","transformIV","iv","tmp","ints","blocks","inc32","from64To32","ecb","_ints","_inBlock","_outBlock","padding","cbc","_prev","_iv","cfb","_partialBlock","_partialOutput","_partialBytes","inputLength","partialBytes","ofb","ctr","gcm","_R","additionalData","_cipherLength","_tagLength","tagLength","_tag","_hashBlock","_hashSubkey","componentBits","_m","generateHashTable","ivLength","_j0","ghash","_aDataLength","_s","lengths","z_i","v_i","lsb","tableMultiply","x_i","ah","bits","multiplier","perInt","shft","generateSubHashTable","m_i","m_j","aes","Algorithm","startEncrypting","_createCipher","createEncryptionCipher","startDecrypting","createDecryptionCipher","inBlock","outBlock","_updateBlock","_w","_init","encryptOp","_expandKey","sbox","isbox","rcon","mix","imix","Nb","xtime","e2","e4","e8","sx","sx2","ime","ei","iNk","Nk","m0","m3","wnew","wi","a2","b2","c2","Nr","pki","oids","oidsModule","_IN","_I_","asn1","asn1Module","_checkBufferLength","available","requested","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","includeBitStringContents","getBerValueLength","_fromDer","b1","longFormBytes","_getValueLength","decodeBitStrings","savedRead","savedRemaining","unused","used","tc","asn1Options","fromDer","parseAllBytes","byteCount","toDer","useBitStringContents","lenBytes","oidToDer","oid","valueBytes","derToOid","utcTimeToDate","utc","MM","hh","mm","ss","setTime","generalizedTimeToDate","gentime","YYYY","fff","isUTC","dateToUtcTime","dateToGeneralizedTime","integerToDer","integer","derToInteger","capture","optional","captureAsn1","captureBitStringContents","captureBitStringValue","_nonLatinRegex","prettyPrint","indentation","IA5String","subvalues","md","hmacModule","hmac","_md","_ipadding","_opadding","keylen","blockLength","inner","getMac","md5","md5Module","_initialized","_padding","_g","_r","_k","sin","_state","digestLength","messageLength","fullMessageLength","messageLengthSize","messageLength64","int32s","h0","h1","h2","h3","_update","finalBlock","pemModule","foldHeader","insertSpace","candidate","insert","ltrim","procType","contentDomain","dekInfo","parameters","rMessage","rHeader","rCRLF","lines","li","nl","vi","des","_keys","_createKeys","pc2bytes0","pc2bytes1","pc2bytes2","pc2bytes3","pc2bytes4","pc2bytes5","pc2bytes6","pc2bytes7","pc2bytes8","pc2bytes9","pc2bytes10","pc2bytes11","pc2bytes12","pc2bytes13","iterations","shifts","lefttmp","righttmp","spfunction1","spfunction2","spfunction3","spfunction4","spfunction5","spfunction6","spfunction7","spfunction8","looping","endloop","loopinc","right1","right2","pkcs5","pbkdf2","dkLen","pbkdf2Sync","hLen","prf","xor","u_c","u_c1","dk","sha256","sha256Module","h4","h5","h6","h7","t1","t2","s0","maj","g","_crypto","prngModule","prng","plugin","reseeds","generated","keyBytes","pools","_reseedSync","_seed","needed","collect","seedFileSync","_2powK","seedBytes","formatKey","formatSeed","defaultSeedFile","getRandomValues","msCrypto","entropy","QuotaExceededError","hi","lo","pool","generate","generateSync","increment","_reseed","seedFile","randomBytes","collectInt","registerWorker","randomModule","jQuery","prng_aes","_prng_aes_output","_prng_aes_buffer","spawnPrng","getBytesSync","_ctx","_navBytes","mousemove","clientX","clientY","keypress","charCode","piTable","rol","word","ror","rc2","expandKey","effKeyBits","T1","T8","TM","mixRound","mashRound","_output","runPlan","plan","ptr","dbits","BigInteger","fromNumber","fromString","nbi","am3","xl","xh","jsbn","appName","am2","am1","DB","DM","DV","FV","F1","F2","rr","vv","BI_RC","int2char","intAt","nbv","fromInt","nbits","Classic","Montgomery","invDigit","mpl","mph","um","mt2","op_and","op_or","op_xor","op_andnot","lbit","cbit","NullExp","nNop","Barrett","q3","ONE","dlShiftTo","convert","cConvert","compareTo","revert","cRevert","cReduce","divRemTo","mulTo","cMulTo","multiplyTo","sqrTo","cSqrTo","squareTo","montConvert","ZERO","subTo","montRevert","copyTo","montReduce","u0","clamp","drShiftTo","montMulTo","montSqrTo","bnpCopyTo","bnpFromInt","bnpFromString","fromRadix","mi","sh","bnpClamp","bnpDLShiftTo","bnpDRShiftTo","lShiftTo","bnpLShiftTo","bs","cbs","bm","rShiftTo","bnpRShiftTo","bnpSubTo","bnpMultiplyTo","bnpSquareTo","bnpDivRemTo","nsh","ys","y0","yt","qd","bnpInvDigit","isEven","bnpIsEven","exp","bnpExp","bnToString","toRadix","km","bnNegate","bnAbs","bnCompareTo","bitLength","bnBitLength","bnMod","modPowInt","bnModPowInt","nMulTo","nSqrTo","barrettConvert","barrettRevert","barrettReduce","multiplyUpperTo","multiplyLowerTo","dAddOffset","barrettMulTo","barrettSqrTo","lowprimes","lplim","bnpChunkSize","LN2","bnpToRadix","signum","intValue","bnpFromRadix","dMultiply","bnpFromNumber","testBit","bitwiseTo","shiftLeft","isProbablePrime","nextBytes","bnpBitwiseTo","op","changeBit","bnpChangeBit","addTo","bnpAddTo","bnpDMultiply","bnpDAddOffset","bnpMultiplyLowerTo","bnpMultiplyUpperTo","modInt","bnpModInt","millerRabin","bnpMillerRabin","subtract","getLowestSetBit","shiftRight","bnGetPrng","modPow","bnClone","bnIntValue","byteValue","bnByteValue","shortValue","bnShortValue","bnSigNum","toByteArray","bnToByteArray","bnEquals","bnMin","bnMax","bnAnd","bnOr","bnXor","andNot","bnAndNot","bnNot","bnShiftLeft","bnShiftRight","bnGetLowestSetBit","bitCount","bnBitCount","bnTestBit","setBit","bnSetBit","clearBit","bnClearBit","flipBit","bnFlipBit","bnAdd","bnSubtract","bnMultiply","bnDivide","remainder","bnRemainder","divideAndRemainder","bnDivideAndRemainder","bnModPow","k1","g2","is1","modInverse","bnModInverse","bnPow","gcd","bnGCD","bnIsProbablePrime","sha1","sha1Module","pkcs1","pkcs1Module","rsa_mgf1","maskLength","encode_rsa_oaep","label","mgf1Md","mgf1","keyLength","maxLength","lHash","PS","PS_length","seedLength","dbMask","maskedDB","seedMask","decode_rsa_oaep","em","expectedLength","maskedSeed","lHashPrime","in_ps","primeModule","GCD_30_DELTA","THIRTY","generateProbablePrime","rng","primeincFindPrime","primeincFindPrimeWithWorkers","primeincFindPrimeWithoutWorkers","generateRandom","workLoad","workerScript","workerMessage","mrTests","getMillerRabinTests","millerRabinTests","maxBlockTime","_primeinc","deltaIdx","bits1","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","expected","xhex","createKeyPairGenerationState","eInt","qBits","pBits","pqState","stepKeyPairGenerationState","q1","setPrivateKey","publicKey","setPublicKey","generateKeyPair","modulusLength","publicExponent","publicKeyEncoding","privateKeyEncoding","priv","privateKeyFromPem","publicKeyFromPem","generateKey","exportKey","pkcs8","privateKeyFromAsn1","setRsaPublicKey","genOp","oncomplete","exportOp","keypair","generateKeyPairSync","_generateKeyPair","getPrime","schemeOptions","_parseAllDigestBytes","algorithmIdentifier","md2","sha224","sha384","sha512","setRsaPrivateKey","wrapRsaPrivateKey","rsaKey","rsaEncryption","privateKeyModulus","privateKeyPublicExponent","privateKeyPrivateExponent","privateKeyPrime1","privateKeyPrime2","privateKeyExponent1","privateKeyExponent2","privateKeyCoefficient","privateKeyToAsn1","privateKeyToRSAPrivateKey","publicKeyFromAsn1","publicKeyOid","rsaPublicKey","publicKeyModulus","publicKeyExponent","publicKeyToAsn1","publicKeyToSubjectPublicKeyInfo","publicKeyToRSAPublicKey","pbe","encryptedPrivateKeyValidator","PBES2AlgorithmsValidator","pkcs12PbeParamsValidator","prfOidToMessageDigest","prfOid","prfAlgorithm","supported","prfAlgorithmToMessageDigest","factory","encryptPrivateKeyInfo","saltSize","encryptionAlgorithm","encryptedData","salt","countBytes","ivLen","encOid","cipherFn","createPbkdf2Params","saltBytes","generatePkcs12Key","decryptPrivateKeyInfo","encryptionOid","getCipher","encryptionParams","encrypted","encryptedPrivateKeyToPem","epki","encryptedPrivateKeyFromPem","headerType","encryptRsaPrivateKey","legacy","opensslDeriveBytes","decryptRsaPrivateKey","iter","passBuf","Slen","Plen","Inew","getCipherForPBES2","getCipherForPKCS12PBE","supportedOids","kdfOid","kdfSalt","kdfIterationCount","encIv","dIvLen","digests","p7v","pkcs7asn1Module","pkcs7asn1","pkcs7","contentInfoValidator","encryptedContentInfoValidator","envelopedDataValidator","encryptedDataValidator","signerValidator","signedDataValidator","recipientInfoValidator","mgf","mgf1Module","maskLen","pssModule","pss","saltLength","sLen","salt_","pssobj","modBits","emBits","emLen","mHash","m_","ps","mask","checkLen","x509Module","_shortNames","x509CertificateValidator","rsassaPssParameterValidator","certificationRequestInfoValidator","certificationRequestValidator","_getAttribute","shortName","RDNAttributesAsArray","rdn","si","valueTagClass","CRIAttributesAsArray","seq","extensionRequest","certificateExtensionFromAsn1","_readSignatureParameters","fillDefaults","algorithmOid","hashOid","maskGenOid","maskGenHashOid","_createSignatureDigest","signatureOid","_verifySignature","certificate","sha1WithRSAEncryption","sha1WithRSASignature","signatureParameters","_dnToAsn1","_fillMissingFields","valueConstructed","certificateExtensionToAsn1","_fillMissingExtensionFields","b3","digitalSignature","nonRepudiation","keyEncipherment","dataEncipherment","keyAgreement","keyCertSign","cRLSign","encipherOnly","decipherOnly","cA","pathLenConstraint","server","email","objsign","reserved","sslCA","emailCA","objCA","altNames","altName","ski","generateSubjectKeyIdentifier","subjectKeyIdentifier","keyIdentifier","authorityCertIssuer","issuer","serialNumber","subSeq","fullNameGeneralNames","_signatureParametersToAsn1","_CRIAttributesToAsn1","csr","certificateFromPem","computeHash","certificateFromAsn1","certificateToPem","certificateToAsn1","publicKeyToPem","publicKeyToRSAPublicKeyPem","getPublicKeyFingerprint","certificationRequestFromPem","certificationRequestFromAsn1","certificationRequestToPem","certificationRequestToAsn1","createCertificate","siginfo","validity","notBefore","notAfter","getField","sn","subject","setSubject","uniqueId","setIssuer","setExtensions","getExtension","ext","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","gn","createCertificationRequest","csrVersion","csrSignatureOid","csrSignatureParams","csrSignature","certificationRequestInfo","certificationRequestInfoSubject","certificationRequestInfoAttributes","setAttributes","getCertificationRequestInfo","cri","jan_1_1950","jan_1_2050","_dateToAsn1","tbs","certificateExtensionsToAsn1","distinguishedNameToAsn1","dn","createCaStore","certs","caStore","getBySubject","ensureSubjectHasHash","getIssuer","addCertificate","hasCertificate","der1","listAllCertificates","certList","removeCertificate","certificateError","bad_certificate","unsupported_certificate","certificate_revoked","certificate_expired","certificate_unknown","unknown_ca","verifyCertificateChain","validityCheckDate","selfSigned","parents","verified","se","keyUsage","basicConstraints","bcExt","keyUsageExt","vfd","p12","pkcs12Module","pkcs12","pfxValidator","safeBagValidator","attributeValidator","certBagValidator","_getBagsByAttribute","safeContents","attrValue","bagType","safeBags","bag","_decodePkcs7Data","_decryptSafeContents","encAlgorithm","encParameter","encryptedContentAsn1","_decodeSafeContents","safeBag","decoder","bagId","_decodeBagAttributes","bagAttributes","bagAsn1","bagValue","pkcs8ShroudedKeyBag","keyBag","certBag","certId","x509Certificate","certAsn1","decodedAttrs","pkcs12FromAsn1","pfx","getBags","localKeyId","localKeyIdHex","friendlyName","getBagsByFriendlyName","getBagsByLocalKeyId","mac","macKeyBytes","macAlgorithm","macSalt","macIterations","macKey","macDigest","_decodeAuthenticatedSafe","authSafe","contentInfo","toPkcs12Asn1","useMac","generateLocalKeyId","bagAttrs","pairedCert","certSafeBags","certBagAttrs","certSafeBag","certSafeContents","certCI","pkAsn1","keySafeContents","keyCI","macData","safe","macValue","pkiModule","privateKeyToPem","privateKeyInfoToPem","prf_TLS1","secret","slen","md5itr","sha1itr","md5bytes","sha1bytes","record","fragment","readVector","writeVector","tls","TLS_1_0","major","minor","TLS_1_1","TLS_1_2","SupportedVersions","Versions","Version","MaxFragment","ConnectionEnd","PRFAlgorithm","tls_prf_sha256","BulkCipherAlgorithm","none","rc4","des3","CipherType","aead","MACAlgorithm","hmac_md5","hmac_sha1","hmac_sha256","hmac_sha384","hmac_sha512","CompressionMethod","ContentType","change_cipher_spec","alert","handshake","application_data","heartbeat","HandshakeType","hello_request","client_hello","server_hello","server_key_exchange","certificate_request","server_hello_done","certificate_verify","client_key_exchange","Alert","Level","fatal","Description","close_notify","unexpected_message","bad_record_mac","decryption_failed","record_overflow","decompression_failure","handshake_failure","illegal_parameter","access_denied","decode_error","decrypt_error","export_restriction","protocol_version","insufficient_security","internal_error","user_canceled","no_renegotiation","HeartbeatMessageType","heartbeat_request","heartbeat_response","CipherSuites","getCipherSuite","twoBytes","handleUnexpected","handleHelloRequest","handshaking","handshakes","queue","createAlert","parseHelloMessage","session_id","cipher_suite","compression_method","cipher_suites","compression_methods","snl","session","server_name","serverNameList","cipherSuite","compressionMethod","createSecurityParameters","msgRandom","cRandom","sp","client_random","sRandom","createRandom","prf_algorithm","bulk_cipher_algorithm","cipher_type","enc_key_length","block_length","fixed_iv_length","record_iv_length","mac_algorithm","mac_length","mac_key_length","compression_algorithm","pre_master_secret","master_secret","server_random","handleServerHello","fail","sessionId","expect","SCC","resuming","SCE","handleClientHello","sessionCache","getSession","clientHelloVersion","CCC","verifyClient","CCE","CKE","createRecord","createServerHello","createChangeCipherSpec","pending","createConnectionState","createFinished","createServerKeyExchange","createCertificateRequest","createServerHelloDone","handleCertificate","certificate_list","SKE","serverCertificate","clientCertificate","handleServerKeyExchange","SCR","handleClientKeyExchange","enc_pre_master_secret","getPrivateKey","CCV","handleCertificateRequest","certificate_types","certificate_authorities","certificateRequest","SHD","handleCertificateVerify","msgBytes","handleServerHelloDone","createClientKeyExchange","SER","createCertificateVerify","getClientSignature","handleChangeCipherSpec","SFI","CFI","handleFinished","vd","SAD","CAD","peerCertificate","isConnected","connected","handleAlert","handleHandshake","fragmented","hsTable","handleApplicationData","dataReady","handleHeartbeat","createHeartbeat","expectedHeartbeatPayload","heartbeatReceived","__","R0","R1","R2","R3","R4","ctTable","H0","H1","H2","H3","H4","H5","H6","H7","H8","H9","generateKeys","tls10","client_write_MAC_key","server_write_MAC_key","client_write_key","server_write_key","client_write_IV","server_write_IV","createMode","sequenceNumber","macLength","macFunction","cipherState","cipherFunction","compressionState","compressFunction","updateSequenceNumber","initSecurityParameters","initConnectionState","createClientHello","cipherSuites","cSuites","compressionMethods","cMethods","virtualHost","serverName","snList","extLength","hint","getCertificate","certBuffer","certTypes","cAs","byteBuffer","payloadLength","plaintextLength","paddingLength","records","rec","tlsData","tlsDataReady","_certErrorToAlertDesc","verifyOptions","_alertDescToCertError","createSessionCache","capacity","setSession","createConnection","dpth","cts","clearFail","ready","compatibleVersion","_readRecordHeader","_readRecord","aligned","prepare","prepareHeartbeatRequest","tls_1","prf_tls1","seqNum","aesCipherSuitesModule","decrypt_aes_cbc_sha1","encrypt_aes_cbc_sha1","encrypt_aes_cbc_sha1_padding","decrypt_aes_cbc_sha1_padding","macLen","mac2","compareMacs","mac1","sha512Module","_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","asn1Validator","NativeBuffer","ed25519_1","ed25519","messageToNativeBuffer","PUBLIC_KEY_BYTE_LENGTH","PRIVATE_KEY_BYTE_LENGTH","SEED_BYTE_LENGTH","SIGN_BYTE_LENGTH","HASH_BYTE_LENGTH","pk","sk","crypto_sign_keypair","gf","scalarbase","pack","privateKeyOid","ed25519Oid","EdDSA25519","privateKeyBytes","publicKeyBytes","ed25519PublicKey","publicKeyFromPrivateKey","signedMsg","crypto_sign","sm","Float64Array","smlen","modL","sig","crypto_sign_open","unpackneg","chk","den","den2","den4","den6","set25519","gf1","unpack25519","Z","A","pow2523","neq25519","par25519","gf0","scalarmult","crypto_verify_32","D2","msgLen","cswap","sel25519","tx","ty","zi","inv25519","pack25519","car25519","yi","vn","t0","t3","t4","t5","t6","t7","t8","t9","t10","t11","t12","t13","t14","t15","t16","t17","t18","t19","t20","t21","t22","t23","t24","t25","t26","t27","t28","t29","t30","b0","b4","b5","b6","b7","b8","b9","b10","b11","b12","b13","b14","b15","p7","pkcs7Module","_recipientFromAsn1","encryptedContent","parameter","encKey","_recipientsToAsn1","recipients","_signerToAsn1","authenticatedAttributesAsn1","unauthenticatedAttributes","attrsAsn1","_attributeToAsn1","messageDigest","signingTime","_fromAsn1","rawCapture","_decryptContent","ciph","messageFromPem","messageFromAsn1","messageToPem","pemObj","toAsn1","envelopedData","createEnvelopedData","createEncryptedData","signedData","createSignedData","fromAsn1","certificates","crls","signers","digestAlgorithmIdentifiers","signerInfos","addSigner","authenticatedAttributes","detached","detachedContent","addSignerInfos","mds","_signersToAsn1","addDigestAlgorithmIds","addCertificateRevokationList","crl","_recipientsFromAsn1","infos","recipientInfos","ec","findRecipient","sAttr","rAttr","recipient","privKey","desCBC","addRecipient","keyLen","ciphFn","kem","_createKDF","kdf","counterStart","encapsulation","kdf1","kdf2","levels","sLevelInfo","sLoggers","sConsoleLogger","LEVEL_LOCKED","NO_LEVEL_CHECK","INTERPOLATE","logMessage","messageLevelIndex","logger","flags","prepareStandard","standard","prepareFull","prepareStandardFull","standardFull","makeLogger","logFunction","setLevel","lock","addLogger","info","levelHandlers","verbose","query","searchParams","consoleLogger","md_all","require$$19","require$$20","require$$21","require$$22","ssh","sshModule","_addBigIntegerToBuffer","hexVal","_addStringToBuffer","_sha1","sha","privateKeyToPutty","passphrase","ppk","pubbuffer","privbuffer","encLen","aeskey","mackey","macbuffer","publicKeyToOpenSSH","privateKeyToOpenSSH","require$$23","require$$24","require$$25","dir","LoadCertificate","cert_key","loadCertificateWithPEM","pfxPath","pathCertificado","pfxPassword","senhaCertificado","pfxFile","readFileSync","certsDir","caCerts","readdirSync","readPkcs12","p12Password","certForge","Agent","ca","loadCertificateWithNodeForge","p12Asn1","keyBags","certBags","keyPem","certPem","loadCertificate","useOpenSSL","Environment","isLoaded","getIsLoaded","loadEnvironment","getCodIBGE","RO","AC","AM","RR","PA","AP","TO","MA","CE","RN","PB","PE","AL","SE","BA","MG","ES","RJ","SP","PR","SC","RS","MS","MT","GO","DF","AN","BaseNFE","chaveNfe","saveFiles","Exec","xmlConsultaSoap","webServiceUrlTmp","post","NFEStatusServicoService","tpAmb","cUF","xServ","nfeConsultaProtocoloService","NFEEpec","nfeEpecServiceService","NFECancelamento","nfeCancelamentoServiceService","NFECienciaDaOperacao","nfeCienciaDaOperacaoServiceService","NFEConfirmacaoDaOperacao","nfeConfirmacaoDaOperacaoServiceService","NFEOperacaoNaoRealizada","nfeOperacaoNaoRealizadaServiceService","urllib","PassThrough","Cookies","cookieStr","urlparts","getPath","sessionTimeout","isExpired","cookiePart","valueParts","httponly","compare","packageData","net","nmfetch","fetchRes","Authorization","sourceUrl","reqOptions","rejectUnauthorized","isIP","servername","allowErrorResponse","fetchModule","dns","networkInterfaces","isFamilySupported","allowInternal","allowInternalNetworkInterfaces","Resolver","NODATA","NOTFOUND","NOTIMP","SERVFAIL","CONNREFUSED","REFUSED","dnsCache","formatDNSValue","extra","resolveStream","responded","chunks","chunklen","resolveHostname","cached","dnsTtl","parseConnectionUrl","direct","pass","lKey","_logFunc","getLogger","createDefaultLogger","levelMaxLen","levelNames","levelName","repeat","print","tnx","sid","cid","callbackPromise","parseDataURI","commaPos","metaEntries","lastMetaEntry","sep","resolveContent","contentStream","parsedDataUri","createReadStream","subKey","encodeXText","mimeTypes","mimeTypes_1","detectMimeType","detectExtension","rootType","subType","maxInt","regexPunycode","regexNonASCII","regexSeparators","mapDomain","encoded","ucs2decode","counter","digitToBasic","digit","adapt","numPoints","firstTime","bias","basic","oldi","baseMinusT","currentValue","basicLength","handledCPCount","handledCPCountPlusOne","qMinusT","punycode_1","ucs2","codePoints","toASCII","toUnicode","lineLength","wrappedLines","Encoder","_curLine","_remainingBytes","inputBytes","outputBytes","b64","lastLF","_flush","ranges","checkRanges","lineMargin","qp","lineBreak","lastLine","mimeFuncs","isPlainText","isParam","hasLongerLines","encodeWord","mimeWordEncoding","encodedStr","chr","splitMimeEncodedString","lpart","encodeWords","encodeAll","encodedValue","firstMatch","endIndex","buildHeaderValue","structured","paramsArray","param","buildHeaderParam","encodedParam","encodedStrArr","startPos","safeEncodeURIComponent","parseHeaderValue","escaped","actualKey","foldLines","afterSpace","maxlen","curLine","encodeURICharComponent","Tokenizer","operatorCurrent","operatorExpecting","operators","checkChar","addressparser","parsedAddresses","_handleAddress","isGroup","_regexHandler","walkAddressList","addressparser_1","leWindows","LeWindows","lastByte","lastPos","punycode","shared","LastNewline","lastNewline","LeUnix","leUnix","MimeNode","nodeCounter","baseBoundary","boundaryPrefix","disableFileAccess","disableUrlAccess","normalizeHeaderKey","rootNode","keepBcc","textEncoding","_nodeId","_headers","_isPlainText","_hasLongLines","_envelope","_raw","_transforms","_processFuncs","createChild","added","_normalizeHeaderKey","addHeader","setContent","_contentErrorHandler","buflen","returned","getTransferEncoding","transferEncoding","_getTextEncoding","buildHeaders","toUTCString","messageId","prepared","_handleContentType","_encodeWords","_encodeHeaderValue","outputStream","newlineTransform","processFunc","localStream","finalize","childId","processChildNode","multipart","sendContent","_getStream","sourceStream","_resolvedValue","setEnvelope","envelope","_convertAddresses","_parseAddresses","standardFields","getAddresses","getEnvelope","_generateMessageId","setRaw","httpHeaders","_normalizeAddress","elm","uniqueList","_encodeAddressName","groupListAddresses","lastAt","encodedDomain","latinLen","nonLatinLen","mimeNode","relaxedHeaders","fieldNames","skipFields","includedFields","Set","skip","headerFields","relaxedHeaderLine","headersList","signModule","hashAlgo","bodyHash","canonicalizedHeaderData","headerFieldNames","dkimHeader","generateDKIMHeader","domainName","keySelector","dkim","MessageParser","messageParser","lastBytes","headersParsed","headerBytes","headerChunks","bodySize","updateLastBytes","lblen","nblen","checkHeaders","headerPos","curLinePos","pr1","pr2","headersFound","RelaxedBody","relaxedBody","chunkBuffer","chunkBufferLen","_debugBody","updateHash","bodyStr","nextRemainder","needsFixing","DKIMSigner","cacheTreshold","cacheDir","readPos","cachePath","usingCache","hasErrored","cleanup","unlink","createReadCache","sendNextChunk","sendSignedOutput","keyPos","signNextKey","dkimField","createWriteCache","createWriteStream","unpipe","signStream","DKIM","extraOptions","inputStream","writeValue","MailComposer","mailComposer","mail","compile","_alternatives","getAlternatives","_htmlNode","alternative","_attachments","getAttachments","_useRelated","related","_useAlternative","_useMixed","attached","_createMixed","_createAlternative","_createRelated","_createContentNode","findRelated","icalEvent","eventObject","attachments","attachment","isMessageNode","_processDataUrl","isImage","contentTransferEncoding","html","watchHtml","alternatives","httpProxyClient","httpProxyClient_1","destinationPort","destinationHost","connect","tempSocketErr","timeoutErr","reqHeaders","Connection","onSocketData","MailMessage","mailMessage","mailer","_defaults","resolveAll","resolveNext","normalizedHeaders","_getListHeaders","inReplyTo","setMailerHeader","xMailer","setPriorityHeaders","priority","setListHeaders","listHeader","listData","_formatListUrl","Mail","transporter","_defaultPlugins","_convertDataImages","_userPlugins","meta","component","getVersionString","getSocket","setupProxy","sendMail","_processPlugins","dkimDomains","_dkim","homepage","userPlugins","defaultPlugins","pluginCount","processPlugins","curplugins","ipaddress","proxyV2","SocksClient","socksClient","proxyType","connectionOpts","command","userId","userid","authentication","attachDataUrls","cidCounter","dataUri","packageInfo","DataStream","dataStream","inByteCount","outByteCount","smtpConnection","SMTPConnection","stage","secureConnection","alreadySecured","secured","_getHostname","customAuth","mapKey","authenticated","_remainder","_responseQueue","lastServerResponse","_socket","_supportedAuth","allowsAuth","_supportedExtensions","_maxAllowedSize","_responseActions","_recipientQueue","_greetingTimeout","_connectionTimeout","_destroyed","_closing","_onSocketData","_onData","_onSocketError","_onError","_onSocketClose","_onClose","_onSocketEnd","_onEnd","_onSocketTimeout","_onTimeout","connectCallback","isDestroyedMessage","_isDestroyedMessage","_formatError","dnsTimeout","localAddress","setupConnectionHandlers","connectionTimeout","_upgradeConnection","_onConnect","resolved","quit","_sendCommand","closeMethod","_destroy","login","authData","_auth","_authMethod","oauth2","_handleXOauth2Token","_actionAUTH_LOGIN_USER","_actionAUTHComplete","_actionAUTH_CRAM_MD5","lastResponse","handlerResponse","authMethods","maxAllowedSize","sendCommand","cmd","codes","startTime","_setEnvelope","envelopeTime","_createSendStream","messageTime","messageSize","localPort","remoteAddress","remotePort","socketTimeout","_actionGreeting","greetingTimeout","lastline","responseCode","serverResponse","transactionLog","upgrading","socketPlain","logStr","useSmtpUtf8","rcptQueue","rejectedErrors","accepted","dsn","_setDsnEnvelope","_actionMAIL","_usingSmtpUtf8","use8BitMime","_using8BitMime","envid","notify","validNotify","orcpt","_getDsnRcptToArgs","logStream","lmtp","final","_actionLMTPStream","_actionSMTPStream","_actionLHLO","_actionEHLO","requireTLS","_actionHELO","_ehloLines","ignoreTLS","_actionSTARTTLS","opportunisticTLS","_actionAUTH_LOGIN_PASS","challengeMatch","challengeString","base64decoded","hmacMD5","prepended","_actionAUTH_CRAM_MD5_PASS","isRetry","curRecipient","_actionRCPT","_actionDATA","ehlo","getToken","accessToken","buildXOAuth2Token","defaultHostname","xoauth2","XOAuth2","serviceClient","serviceRequestTimeout","provisionCallback","accessUrl","customHeaders","customParams","renew","generateCallback","generateToken","updateToken","urlOptions","loggedUrlOptions","iat","tokenData","iss","scope","aud","jwtSignRS256","grant_type","assertion","refreshToken","client_id","clientId","client_secret","clientSecret","refresh_token","postRequest","logData","errorMessage","error_description","error_uri","access_token","expires_in","toBase64URL","services","normalizeKey","normalizeService","service","aliases","alias","domains","wellKnown","PoolResource","poolResource","authMethod","_connection","_connected","socketOptions","destHost","destPort","unref","forceAuth","maxMessages","_checkRateLimit","smtpPool","SMTPPool","urlData","maxConnections","_rateLimit","waiting","checkpoint","rateDelta","limit","rateLimit","_closed","_queue","_connections","_connectionCounter","idling","requeueAttempts","_processMessages","invokeCallbacks","_createConnection","queueEntry","_removeConnection","_continueProcessing","_shouldRequeuOnConnectionClose","_requeueEntryOnConnectionClose","_failDeliveryOnConnectionClose","maxRequeues","_clearRateLimit","isIdle","sesTransport","SESTransport","ses","SES","connections","sendingRate","sendingRateTTL","rateInterval","rateMessages","_checkSendingRate","_send","_sent","_checkRatedQueue","oldest","delay","statObject","getRawMessage","sesMessage","RawMessage","Data","Source","Destinations","aws","region","sendPromise","SendRawEmailCommand","sendRawEmail","MessageId","Code","Mailer","SMTPTransport","smtpTransport","getAuth","authOpts","hasAuth","sendMessage","SendmailTransport","spawn","sendmailTransport","_spawn","winbreak","sendmail","stdin","kill","StreamTransport","streamTransport","JSONTransport","jsonTransport","skipEncoding","ETHEREAL_API","ETHEREAL_WEB","ETHEREAL_API_KEY","ETHEREAL_CACHE","testAccount","nodemailer","createTransport","urlConfig","createTestAccount","apiUrl","requestBody","requestor","getTestMessageUrl","infoProps","web","MailController","createTransporter","mountMail","mailParams","emailParams","attachmentsWithVerifiedFileName","sendEmail","mailOptions","canPromise","toSJISFunction","CODEWORDS_COUNT","getSymbolSize","getSymbolTotalCodewords","getBCHDigit","setToSJISFunction","isKanjiModeEnabled","toSJIS","kanji","bit","ECLevel","EC_BLOCKS_TABLE","EC_CODEWORDS_TABLE","errorCorrectionCode","getBlocksCount","errorCorrectionLevel","getTotalCodewordsCount","GF","EXP_TABLE","LOG_TABLE","initTables","galoisField","mul","coeff","divident","divisor","generateECPolynomial","degree","poly","versionCheck","byte","KANJI","BYTE_KANJI","BYTE","NUMERIC","ALPHANUMERIC","TEST_KANJI","TEST_NUMERIC","TEST_ALPHANUMERIC","testKanji","testNumeric","testAlphanumeric","VersionCheck","Regex","ccBits","MIXED","getCharCountIndicator","getBestModeForData","dataStr","Utils","ECCode","Mode","G18_BCH","getReservedBitsCount","getTotalBitsFromDataArray","segments","totalBits","reservedBits","getBitsLength","getCapacity","dataTotalCodewordsBits","usableBits","getBestVersionForData","seg","ecl","getBestVersionForMixedData","currentVersion","getBestVersionForDataLength","getEncodedBits","dijkstra","single_source_shortest_paths","graph","predecessors","costs","closest","cost_of_s_to_u","adjacent_nodes","cost_of_s_to_u_plus_cost_of_e","cost_of_s_to_v","PriorityQueue","make","cost","extract_shortest_path_from_predecessor_list","find_path","sorter","default_sorter","NumericData","bitBuffer","put","remainingNum","numericData","AlphanumericData","ALPHA_NUM_CHARS","alphanumericData","ByteData","byteData","KanjiData","kanjiData","getStringByteLength","getSegments","getSegmentsFromString","numSegs","alphaNumSegs","byteSegs","kanjiSegs","getSegmentBitsLength","buildSingleSegment","modesHint","bestMode","fromArray","buildNodes","segs","buildGraph","prevNodeIds","nodeGroup","currentNodeIds","lastCount","prevNodeId","optimizedSegs","mergeSegments","prevSeg","rawSplit","BitBuffer","bufIndex","putBit","getLengthInBits","BitMatrix","reservedBit","row","col","isReserved","bitMatrix","AlignmentPattern","getRowColCoords","posCount","intervals","positions","getPositions","coords","posLength","FinderPattern","finderPattern","MaskPattern","Patterns","PATTERN000","PATTERN001","PATTERN010","PATTERN011","PATTERN100","PATTERN101","PATTERN110","PATTERN111","PenaltyScores","getMaskAt","maskPattern","getPenaltyN1","points","sameCountCol","sameCountRow","lastCol","lastRow","getPenaltyN2","getPenaltyN3","bitsCol","bitsRow","getPenaltyN4","darkCount","modulesCount","applyMask","getBestMask","setupFormatFunc","numPatterns","bestPattern","lowerPenalty","penalty","ReedSolomonEncoder","Polynomial","genPoly","paddedData","buff","reedSolomonEncoder","FormatInfo","G15_BCH","formatInfo","Segments","setupFormatInfo","matrix","createData","remainingByte","createCodewords","totalCodewords","ecTotalCodewords","dataTotalCodewords","ecTotalBlocks","blocksInGroup2","blocksInGroup1","totalCodewordsInGroup1","dataCodewordsInGroup1","dataCodewordsInGroup2","ecCount","rs","dcData","ecData","createSymbol","estimatedVersion","rawSegments","bestVersion","dataBits","moduleCount","modules","setupFinderPattern","setupTimingPattern","setupAlignmentPattern","setupVersionInfo","setupData","bitIndex","byteIndex","dark","qrcode","toSJISFunc","ChunkStream","chunkstreamModule","_buffers","_buffered","_reads","_paused","_encoding","allowLess","_process","_end","destroySoon","_processReadAllowingLess","smallerBuf","_processRead","imagePasses","interlace","getImagePasses","height","images","xLeftOver","yLeftOver","xRepeats","yRepeats","passWidth","passHeight","getInterlaceIterator","outerXLeftOver","outerX","outerYLeftOver","paethPredictor","above","upLeft","paeth","pLeft","pAbove","pUpLeft","interlaceUtils","getByteWidth","bpp","byteWidth","Filter","filterParseModule","bitmapInfo","dependencies","complete","_imageIndex","_images","passes","lineIndex","_xComparison","_reverseFilterLine","_unFilterType1","rawData","unfilteredLine","xComparison","xBiggerThan","rawByte","f1Left","_unFilterType2","_lastLine","f2Up","_unFilterType3","f3Up","f3Left","f3Add","_unFilterType4","f4Up","f4Left","f4UpLeft","f4Add","currentImage","PNG_SIGNATURE","TYPE_IHDR","TYPE_IEND","TYPE_IDAT","TYPE_PLTE","TYPE_tRNS","TYPE_gAMA","COLORTYPE_GRAYSCALE","COLORTYPE_PALETTE","COLORTYPE_COLOR","COLORTYPE_ALPHA","COLORTYPE_PALETTE_COLOR","COLORTYPE_COLOR_ALPHA","COLORTYPE_TO_BPP_MAP","GAMMA_DIVISION","crcTable","currentCrc","CrcCalculator","crcModule","_crc","crc32","crc","parserModule","checkCRC","_hasIHDR","_hasIEND","_emittedHeadersFinished","_palette","_colorType","_chunks","_handleIHDR","_handleIEND","_handleIDAT","_handlePLTE","_handleTRNS","_handleGAMA","metadata","transColor","palette","inflateData","simpleTransparency","headersFinished","_parseSignature","_parseChunkBegin","readUInt32BE","ancillary","_skipChunk","_handleChunkEnd","_parseChunkEnd","fileCrc","readInt32BE","calcCrc","_parseIHDR","colorType","compr","_parsePLTE","_parseTRNS","readUInt16BE","_parseGAMA","_parseIDAT","leftOverLength","_parseIEND","pixelBppMapper","pxData","pxPos","rawPos","pixel","pixelBppCustomMapper","pixelData","maxBit","mapImage8Bit","getPxPos","imageWidth","imageHeight","imagePass","mapImageCustomBit","resetAfterLine","bitmapper","dataToBitMap","bitRetriever","leftOver","byte8","byte7","byte6","byte5","byte4","byte3","byte2","byte1","returner","nonInterlacedPxPos","imageIndex","formatNormaliser","indata","imageData","outdata","dePalette","replaceTransparentColor","makeTrans","scaleDepth","maxInSample","FilterAsync","filterParseAsyncModule","that","_filter","ParserAsync","parserAsyncModule","_handleError","_handleMetaData","_handlePalette","_handleTransColor","_finished","_inflateData","_simpleTransparency","_headersFinished","_inflate","errord","_bitmapInfo","createInflate","_complete","imageSize","Z_MIN_CHUNK","leftToInflate","emitError","filterWrite","metaData","_metaData","filteredData","normalisedBitmapData","bitmapData","CrcStream","bitPacker","bitpacker","dataIn","outHasAlpha","inputColorType","bigEndian","Int16Array","bitDepth","maxValue","inBpp","inputHasAlpha","outBpp","outData","inIndex","outIndex","bgColor","getRGBA","red","green","blue","rgba","writeUInt16BE","grayscale","filters","filterNone","filterSub","filterUp","filterAvg","filterPaeth","upleft","filterSums","filterSumNone","filterSumSub","filterSumUp","filterSumAvg","filterSumPaeth","filterPack","filterTypes","filterType","sel","Packer","packerModule","deflateChunkSize","deflateLevel","deflateStrategy","deflateFactory","createDeflate","getDeflateOptions","filterData","packedData","_packChunk","writeUInt32BE","writeInt32BE","packGAMA","packIHDR","packIDAT","packIEND","ok","kMaxLength","Inflate","_offset","_outOffset","_buffer","_outBuffer","_maxLength","_close","engine","_handle","inflateSync","zlibBufferSync","flushFlag","_finishFlushFlag","Z_FINISH","_processChunk","asyncCb","availInBefore","availOutBefore","_chunkSize","inOff","nread","handleChunk","availInAfter","availOutAfter","_hadError","have","allocUnsafe","writeSync","_writeState","SyncReader","syncReaderModule","hasSyncZlib","deflateSync","FilterSync","filterParseSync","inBuffer","outBuffers","bufferPart","parserSync","inflateDataList","_err_","handleMetaData","_metaData_","handleGamma","_gamma_","handlePalette","handleTransColor","handleInflateData","inflatedData","handleSimpleTransparency","unfilteredData","packerSync","packer","compressedData","pngSync","png","PackerAsync","packerAsyncModule","_packer","_deflate","PNGSync","PNG","fill","_handleClose","_metadata","_gamma","sync","onParsed","parsedData","bitblt","srcX","srcY","deltaX","deltaY","adjustGamma","hex2rgba","hexCode","hexValue","getOptions","margin","scale","light","rendererOpts","getScale","qrSize","getImageWidth","qrToImageData","imgData","qr","symbolSize","scaledMargin","posDst","pxColor","big","terminal","qrData","white","hMargin","vMargin","small","mkCodePixel","sizePlus","mkCode","terminalSmall","inverse","lineSetup","backgroundBlack","backgroundWhite","foregroundWhite","foregroundBlack","createPalette","newLine","getColorAttrib","svgCmd","svgTag","qrcodesize","bg","qrToPath","moveBy","newRow","viewBox","canvas","canvasEl","getContext","getCanvasElement","createImageData","clearCanvas","clearRect","putImageData","renderToDataURL","toDataURL","quality","QRCode","PngRenderer","pngOpts","pngImage","renderToBuffer","renderToFile","called","renderToFileStream","Utf8Renderer","BLOCK_CHAR","WW","WB","BB","BW","INVERTED_BLOCK_CHAR","getBlockChar","writeFile","TerminalRenderer","SvgRenderer","svgTagRenderer","xmlStr","checkParams","getRendererFromType","renderFunc","toCanvas","CanvasRenderer","renderCanvas","argsNum","isLastArgCb","renderer","getStringRendererFromType","toBuffer","toFile","getTypeFromFilename","toFileStream","ValidaCPFCNPJ","validarCpfCnpj","cpfCnpj","isCpf","isCnpj","documentoValido","tipoDoDocumento","cleanCpfCnpj","documentoValidoateCpf","documentoValidoateCnpj","cpf","cnpj","numbers","mascaraCnpjCpf","cpfcnpj","getDesTipoPag","tPag","NFCEGerarDanfe","enviada","outputPath","qrcodePath","documento","det","ide","transp","pag","infAdic","infNFeSupl","exibirMarcaDaguaDanfe","fontSize","larguraPadrao","documentWidth","itemHeight","pageWidth","nfeData","NFe","infNFe","nProt","itensLength","calculateFontSize","pageHeight","calculateHeight","itemsLength","headerHeight","fontPath","fontPathBold","PDFDocument","margins","bufferPages","layout","registerFont","saveQRCode","filePath","getQRCodeBuffer","generateBarcode","barcode","bwipjs","bcid","scaleX","includetext","barcodeDir","barcodeFilePath","centeredPos","texto","page","widthOfString","ajustarPosicao","posicaoOriginal","novaLargura","calculaPosicao","textWidth","drawHeader","isFirstPage","_buildHeader","drawFooter","qrCodeBuffer","_buildFooter","CNPJCPF","CNPJ","CPF","identificationJoined","enderEmit","xLgr","nro","xBairro","centeredPosEmit","xNome","centeredPosEnd","centeredPosText","font","_buildIdentificacaoEmit","_buildProdutos","tableWidth","startX","tableTop","columnWidths","codigo","descricao","qtdeUn","quant","qCom","qTrib","toLocaleString","minimumFractionDigits","maximumFractionDigits","valUnit","vUnCom","vUnTrib","valLiq","vProd","cProd","xProd","uCom","align","_buildTotais","quantidadeTotalDeItens","valTotal","acrescimo","desconto","vFrete","vSeg","vOutro","vDesc","valorTotal","acrescimoTotal","descontoTotal","totalPagar","topTiposPag","detPag","pagto","xPag","topValPags","vPag","valTroco","vTroco","troco","urlChave","topBeforeQrCode","idEstrangeiro","enderDest","xMun","enderecoStr","lineGap","continued","dtaEmi","dhEmi","dtaAut","dhRecbto","nNF","serie","ICMSTot","vTotTrib","generatePDF","qrCode","NFEGerarDanfe","barcodePath","setLineStyle","lineWidth","strokeColor","_buildGuia","_buildSeparator","stroke","characterSpacing","vNF","padStart","moveTo","lineTo","space","undash","bufferedPageRange","topIdentificacao_1","CEP","fone","xFant","tpNF","_buildIdentificacaoDanfe","fillColor","natOp","xProtNfe","_buildIdentificacaoNFe","IE","IEST","_buildIdentificacaoPessoa","_buildDestinatario","docDest","topDestinatario","_buildDestPessoa","_buildDestLogradouro","indIEDest","_buildDestEndereco","_builCalculoImposto","vBC","vICMS","vBCST","vST","fillAndStroke","vIPI","_buildCalcImposto","_builTransporte","getModFrete","modFrete","transporta","veicTransp","RNTC","placa","xEnder","vol","topTrnasport","topTrnasportTitle","topTrnasportValue","createVolume","qVol","esp","marca","nVol","_buildVolumeTransporte","currentPage","CST","getCST","ICMS","chavesICMS","icmsSemCST","tipoICMS","imposto","pIPI","getValoresIPI","IPI","IPITrib","pICMS","getValoresItem","icmsSemvBC","infAdProd","textHeight","heightOfString","NCM","CFOP","uTrib","valDesc","createTable","addPage","infCpl","infAdFisco","topPosition","leftPosition","NFCEAutorizacao","nfceAutorizacaoService","NFERecepcaoEvento","nfeDistribuicaoDFeService","NFEDistribuicaoDFePorChave","nfeDistribuicaoDFePorChaveService","NFEDistribuicaoDFePorNSU","nfeDistribuicaoDFePorNSUService","NFEDistribuicaoDFePorUltNSU","nfeDistribuicaoDFePorUltNSUService","nfeInutilizacaoService","NFECartaDeCorrecao","nfeCartaDeCorrecaoServiceService","NFEDesconhecimentoDaOperacao","nfeDesconhecimentoDaOperacaoServiceService","NFERetornoAutorizacao","nfeStatusServicoService","getXmlRetorno","filterFieldsByType","requiredFields","COFINSMap","PISMap","ICMSMap","mountCOFINS","cofins","cst_cofins","cofinsKey","COFINSAliq","COFINSQtde","COFINSNT","COFINSOutr","cofinsProperties","mountPIS","pis","cst_pis","pisKey","PISAliq","PISQtde","PISNT","PISOutr","pisProperties","mountICMS","icms","CSOSN","cod_sit","icmsKey","ICMS00","ICMS02","ICMS10","ICMS15","ICMS20","ICMS30","ICMS40","ICMS41","ICMS50","ICMS51","ICMS53","ICMS60","ICMS61","ICMS70","ICMS90","ICMSPart","ICMSST","ICMSSN101","ICMSSN102","ICMSSN201","ICMSSN202","ICMSSN500","ICMSSN900","icmsProperties","NFERetornoAutorizacaoService","getRetornoRecibo","xmlNFe","SOAPAction","getXmlRetornoAutorizacao","XMLs","baseXML","formatedProtNFe","xmlCompleto","protTag","xmlFinal","tipoEmissao","NFEAutorizacaoService","gerarXmlNFeAutorizacao","includeMethodName","xmlAutorizacaoInJson","xMotivoPorXml","xmlsInJson","xmlAutorizacao","cStat","armazenarXMLAutorizacao","pathXMLAutorizacao","trataRetorno","indSinc","nfeRetornoAutService","nfeRetornoAut","infRec","tMed","anoMesEmissao","dataAtual","gerarCodigoNumerico","calcularModulo11","sequencia","pesos","somatoria","restoDivisao","calcularDigitoVerificador","tpEmis","cNF","dv","chaveAcesso","validaDocumento","campo","nfeAutorizacaoHandler","createXML","formatedItens","dadosICMS","PIS","dadosPIS","COFINS","dadosCOFINS","nItem","cDV","verProc","NFref","NFrefArray","refNFP","Id","eventoXML","xmlAssinado","idLote","retorno","xmls","NFEconsultaProtocoloService","nfeRecepcaoEventoService","NFERecepcaoEventoService","tpEvento","modelo","xmlEventosNacionais","xmlEventosRegionais","xMotivoPorEvento","getID","evento","nSeqEvento","isAmbienteNacional","getTipoEventoName","separaEventosPorAmbiente","nacional","regional","gerarXmlRecepcaoEvento","eventoProps","cOrgao","detEvento","dhEvento","verEvento","idEvento","orgao","eventoObject","infEvento","envEvento","retornoEventos","tipoEvento","enviaEvento","tipoAmbiente","responseNacionalInJson","responseRegionalInJson","finalResponseInJson","retornoNacional","retornoRegional","xMotivos","NFECancelamentoService","NFECartaDeCorrecaoService","NFECienciaDaOperacaoService","NFEDesconhecimentoDaOperacaoService","NFEEpecService","NFEOperacaoNaoRealizadaService","nfeAutorizacaoService","zero$1","extra_lbits","extra_dbits","extra_blbits","bl_order","static_ltree","static_dtree","D_CODES$1","_dist_code","_length_code","MAX_MATCH$1","base_length","base_dist","StaticTreeDesc","static_tree","extra_bits","extra_base","elems","max_length","has_stree","static_l_desc","static_d_desc","static_bl_desc","TreeDesc","dyn_tree","stat_desc","max_code","d_code","put_short","pending_buf","send_bits","bi_valid","bi_buf","send_code","bi_reverse","gen_codes","bl_count","next_code","MAX_BITS$1","init_block","LITERALS$1","dyn_ltree","dyn_dtree","bl_tree","END_BLOCK","opt_len","static_len","sym_next","bi_windup","smaller","_n2","_m2","pqdownheap","heap","heap_len","compress_block","ltree","dtree","lc","sym_buf","build_tree","stree","heap_max","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","_tr_stored_block$1","stored_len","_tr_init_1","LENGTH_CODES$1","L_CODES$1","tr_static_init","l_desc","d_desc","bl_desc","_tr_flush_block_1","opt_lenb","static_lenb","max_blindex","strm","data_type","block_mask","detect_data_type","BL_CODES$1","build_bl_tree","lcodes","dcodes","blcodes","rank","send_all_trees","_tr_tally_1","sym_end","trees","_tr_init","_tr_stored_block","_tr_flush_block","_tr_tally","_tr_align","STATIC_TREES","bi_flush","adler32_1","adler","makeTable","crc32_1","constants$2","Z_NO_FLUSH","Z_PARTIAL_FLUSH","Z_FULL_FLUSH","Z_BLOCK","Z_TREES","Z_OK","Z_STREAM_END","Z_NEED_DICT","Z_ERRNO","Z_STREAM_ERROR","Z_DATA_ERROR","Z_MEM_ERROR","Z_BUF_ERROR","Z_NO_COMPRESSION","Z_BEST_SPEED","Z_BEST_COMPRESSION","Z_DEFAULT_COMPRESSION","Z_FILTERED","Z_HUFFMAN_ONLY","Z_RLE","Z_FIXED","Z_DEFAULT_STRATEGY","Z_BINARY","Z_TEXT","Z_UNKNOWN","Z_DEFLATED","Z_NO_FLUSH$2","Z_FULL_FLUSH$1","Z_FINISH$3","Z_BLOCK$1","Z_OK$3","Z_STREAM_END$3","Z_STREAM_ERROR$2","Z_DATA_ERROR$2","Z_BUF_ERROR$1","Z_DEFAULT_COMPRESSION$1","Z_DEFAULT_STRATEGY$1","Z_DEFLATED$2","zero","slide_hash","wsize","w_size","hash_size","HASH","hash_shift","hash_mask","flush_pending","avail_out","pending_out","next_out","total_out","flush_block_only","block_start","strstart","put_byte","putShortMSB","read_buf","avail_in","next_in","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","_w_size","more","window_size","ins_h","deflate_stored","min_block","pending_buf_size","high_water","deflate_fast","hash_head","bflush","match_length","max_lazy_match","MIN_MATCH","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","HEAP_SIZE","MAX_BITS","lit_bufsize","deflateStateCheck","deflateResetKeep","deflateReset","deflateInit2","windowBits","memLevel","deflate_1$2","deflateInit","deflateSetHeader","old_flush","level_flags","hcrc","beg","gzhead_extra","bstate","deflate_huff","deflate_rle","deflateEnd","deflateSetDictionary","dictionary","dictLength","tmpDict","avail","deflateInfo","_has","STR_APPLY_UIA_OK","_utf8len","strings","m_pos","str_len","buf_len","TextDecoder","utf16buf","c_len","buf2binstring","zstream","ZStream","toString$1","Z_NO_FLUSH$1","Z_FINISH$2","Z_OK$2","Z_STREAM_END$2","Z_DEFLATED$1","Deflate$1","gzip","dict","_dict_set","deflate$1","deflator","flush_mode","_flush_mode","deflate_1$1","Deflate","deflateRaw","deflateRaw$1","gzip$1","inffast","inflate_fast","_in","_out","dmax","whave","wnext","s_window","hold","lcode","dcode","lmask","dmask","here","from_source","lencode","distcode","lenbits","distbits","dolen","sane","lbase","lext","dbase","dext","inftrees","lens","lens_index","table_index","work","incr","low","sym","drop","huff","MAXBITS","offs","here_bits","here_op","here_val","Z_FINISH$1","Z_OK$1","Z_STREAM_END$1","Z_NEED_DICT$1","Z_STREAM_ERROR$1","Z_DATA_ERROR$1","Z_MEM_ERROR$1","BAD","zswap32","InflateState","havedict","wbits","ncode","nlen","ndist","lendyn","distdyn","back","was","inflateStateCheck","inflateResetKeep","Int32Array","inflateReset","inflateReset2","inflateInit2","lenfix","distfix","virgin","fixedtables","updatewindow","inflate_1$2","inflateInit","last_bits","last_op","last_val","hbuf","inf_leave","xflags","extra_len","inflateEnd","inflateGetHeader","inflateSetDictionary","dictid","inflateInfo","gzheader","GZheader","Inflate$1","inflate$1","inflator","last_avail_out","next_out_utf8","utf8str","inflate_1$1","inflateRaw","inflateRaw$1","ungzip","pako","DistribuicaoHandler","XMLDistribuicaoInJson","XMLDistribuicao","pathXMLDistribuicao","baixarXMLDistribuicao","deCompressDFeXML","loteDistDFeInt","files","docZip","xmlString","decodeDocZip","cleanedXml","removeSignatureTag","parsedResult","getChNFe","getTipo","NSU","xmlDistribuicaoInJson","base64String","binaryString","atob","decompressedData","NFEDistribuicaoDFeService","gerarXmlNFeDistribuicaoDFe","filesList","NFEDistribuicaoDFePorUltNSUService","NFEDistribuicaoDFePorNSUService","NFEDistribuicaoDFePorChaveService","NFEInutilizacaoService","gerarXmlNFeInutilizacao","criarId","codigoUF","ano","numeroInicial","numeroFinal","nNFIni","nNFFin","xJust","anoFormatado","serieFormatada","numNFIniFormatado","numNFFinFormatado","infInut","base64map","crypt","rotl","rotr","endian","bytesToWords","words","wordsToBytes","bytesToBase64","triplet","base64ToBytes","imod4","cryptModule","charenc","stringToBytes","bin","bytesToString","charenc_1","digestbytes","asBytes","asString","_blocksize","_digestsize","generateQRCodeURLOnline","versaoQRCode","identificadorCSC","csc","urlQRCodeNFCe","baseString","generateSHA1Hash","generateQRCodeURLOffline","diaDataEmissao","valorTotalNfce","digVal","digestValueHex","calcularDigestValueHex","NFCERetornoAutorizacaoService","NFCERetornoAutorizacao","nfceAutorizacaoRetornoService","NFCEAutorizacaoService","gerarXmlNFCEAutorizacao","diaEmissao","extrairDigestValue","idCSC","tokenCSC","urlConsultaNFCe","valNF","CSC","NFeWizardService","Proxy","receiver","origMethod","validateEnvironment","Reflect","NFE_LoadEnvironment","NFE_ConsultaStatusServico","nfeStatusServico","NFE_ConsultaProtocolo","nfeConsultaProtocolo","NFE_RecepcaoEvento","nfeRecepcaoEvento","NFE_EventoPrevioDeEmissaoEmContingencia","nfeEpecService","nfeEpec","NFE_Cancelamento","nfeCancelamentoService","nfeCancelamento","NFE_CienciaDaOperacao","nfeCienciaDaOperacaoService","nfeCienciaDaOperacao","NFE_ConfirmacaoDaOperacao","nfeConfirmacaoDaOperacaoService","nfeConfirmacaoDaOperacao","NFE_OperacaoNaoRealizada","nfeOperacaoNaoRealizadaService","nfeOperacaoNaoRealizada","NFE_CartaDeCorrecao","nfeCartaDeCorrecaoService","nfeCartaDeCorrecao","NFE_DesconhecimentoDaOperacao","nfeDesconhecimentoDaOperacaoService","nfeDesconhecimentoDaOperacao","NFE_DistribuicaoDFe","distribuicaoDFeService","distribuicaoDFe","NFEDistribuicaoDFe","NFE_DistribuicaoDFePorUltNSU","NFE_DistribuicaoDFePorNSU","NFE_DistribuicaoDFePorChave","NFE_Autorizacao","autorizacaoService","autorizacao","NFCE_Autorizacao","NFE_Inutilizacao","inutilizacaoService","inutilizacao","NFE_GerarDanfe","NFCE_GerarDanfe","NFE_EnviaEmail","NFeWizard","nfeWizardService"],"mappings":"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AASgC,kBAAkBxE,IAAI,GAAGpG,MAAM,KAAK,GACpE,EACQn5B,KAAKoiC,cAAc,IAAM,SAAU7C,KAC/B,OAAO,IAAIwC,SAASiC,cAAczE,IAAI,GAClD,CACA,EAEIP,YAAYiF,YAAc,CACtB,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,wCAGJjF,YAAYkF,kBAAoB,CAC5B,wCACA,uCACA,uCACA,uCACA,wCACA,wCACA,wCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,wCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,wCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,wCACA,uCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,wCACA,uCACA,wCACA,wCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,wCACA,wCACA,wCACA,wCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,uCACA,4DACA,uCACA,wCACA,uCACA,wCAGJlF,YAAYmF,UAAY,CACpB,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,gCACA,iCAGJnF,YAAYoF,YAAc,CACtB,CAAC,EAAG,EAAG,GACP,CAAC,EAAG,EAAG,GACP,CAAC,EAAG,EAAG,GACP,CAAC,EAAG,EAAG,GAAI,EAAG,GACd,CAAC,EAAG,EAAG,GACP,CAAC,EAAG,EAAG,GAAI,EAAG,GACd,CAAC,EAAG,EAAG,GACP,CAAC,EAAG,EAAG,GAAI,GAAI,GACf,CAAC,EAAG,EAAG,GAAI,EAAG,GACd,CAAC,EAAG,EAAG,GACP,CAAC,E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BA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACK,MAALA,GACK,MAALA,GACK,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACK,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACK,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,OAAUA,GAAK,OACpBA,GAAK,OAAUA,GAAK,OACpBA,GAAK,OAAUA,GAAK,OACpBA,GAAK,OAAUA,GAAK,OACpBA,GAAK,OAAUA,GAAK,OACf,OAALA,GACAA,GAAK,OAAUA,GAAK,KAChC,EAEIktB,UAAUsE,aAAe,SAAUxxB,GAC/B,OAAOA,GAAK,IAAUA,GAAK,IACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,IAALA,GACK,IAALA,GACK,IAALA,GACAktB,UAAUoE,SAAStxB,IACnBA,GAAK,KAAUA,GAAK,KACpBA,GAAK,KAAUA,GAAK,KACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACf,MAALA,GACK,MAALA,GACK,MAALA,GACK,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACf,MAALA,GACAA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,GAAK,MACpBA,GAAK,MAAUA,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"}